@charset "UTF-8";

@font-face {
  font-family: "Yu Gothic M";
  src: local("Yu Gothic Medium");
}
@font-face {
  font-family: "Yu Gothic M";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}
@font-face {
	font-family: "GCPSans";
	src: url(../font/GCPSans.otf);
}
body {
  font-family: "游ゴシック体", YuGothic, "Yu Gothic M", "游ゴシック Medium", "Yu Gothic Medium", "Helvetica Neue", HelveticaNeue, 'Hiragino Kaku Gothic ProN', meiryo, sans-serif;
	font-weight: normal;
	font-size: 62.5%;
	line-height: 1.0;
	-webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
  -webkit-overflow-scrolling: touch;
	color: #000;
	overflow: hidden;
	box-sizing: border-box;
}
.en {
	font-family:"HelveticaNeue", "Arial Narrow", "Roboto Condensed", sans-serif;
}
.en a {
	font-family:"HelveticaNeue", "Arial Narrow", "Roboto Condensed", sans-serif;
}
.gcpsans {
  font-family:"GCPSans", sans-serif;
}
.italic {
  font-style: italic;
}
::selection {
	background: #d7d7d7;
}
::-moz-selection {
	background: #d7d7d7;
}
p {
	max-height: 999999px;
}
li {
	max-height: 999999px;
}
a {
	text-decoration:none;
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
}
a:hover {
	text-decoration: none;
}
img {
	width: 100%;
	height: auto;
}
.ul {
  box-sizing: border-box;
  letter-spacing: -.4em;
}
.ul li {
  box-sizing: border-box;
  letter-spacing: normal;
  display: inline-block;
  vertical-align: top;
}
.inviewfadeIn {
	opacity: 0;
	transform: translate(0, 0);
	-webkit-transform: translate(0, 0);
  -webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
}
.fadeIn {
	opacity: 1.0;
	transform: translate(0, 0);
	-webkit-transform: translate(0, 0);
}
.inviewfadeInUp {
	opacity: 0;
  transform: translate(0, 20px);
	-webkit-transform: translate(0, 20px);
  -webkit-transition: all 0.8s ease;
	-moz-transition: all 0.8s ease;
	-o-transition: all 0.8s ease;
	transition: all 0.8s ease;
}
.fadeInUp {
	opacity: 1.0;
	transform: translateY(0);
	-webkit-transform: translateY(0);
}
.pc {
	display: block;
}
.sp {
	display: none;
}
.none {
	display: none;
}

/* header */
.icon {
  width: 45px;
  height: auto;
  position: fixed;
  top: 20px;
  left: 20px;
  z-index: 100;
}
.logo {
  width: 225px;
  height: auto;
  position: fixed;
  top: 20px;
  left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
  z-index: 100;
}

/* common */
.main {
  width: 90%;
  margin: 0 auto;
}
.main-d {
  width: 90%;
  margin: 0 auto;
}
.main-inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
.txt-title {
  font-size: 1.8em;
  line-height: 1.5;
  text-align: center;
  padding: 130px 0 0 0;
}

/* about */
.about-wrap {
  width: 100%;
  max-width: 1200px;
  height: auto;
  margin: 0 auto;
  padding: 170px 0 0 0;
}
.about-l {
  width: 40%;
  height: auto;
  float: left;
}
.about-r {
  width: 50%;
  height: auto;
  float: right;
}
.member-1 {
  padding: 50px 0 0 0;
}
.member-2 {
  padding: 50px 0 0 0;
}
.member-3 {
  padding: 50px 0 0 0;
}
.icon-wrap {
  width: 80px;
  height: auto;
  float: left;
}
.icon-goo {
  width: 56px;
  height: auto;
  margin: 0 auto;
}
.icon-choki {
  width: 56px;
  height: auto;
  margin: 0 auto;
}
.icon-par {
  width: 66px;
  height: auto;
  margin: 0 auto;
}
.member-txt {
  padding: 6px 0 0 13px;
  float: left;
}
.member-txt-1 {
  font-size: 2.0em;
  font-weight: bold;
}
.member-txt-2 {
  font-size: 1.6em;
  padding: 8px 0 0 0;
}
.member-txt-sub-1 {
  font-size: 1.6em;
  line-height: 22px;
  padding: 60px 0 0 10px;
}
.member-txt-sub-2 {
  font-size: 1.6em;
  line-height: 22px;
  padding: 40px 0 0 10px;
}
.about-mail {
  font-size: 2.8em;
  font-weight: bold;
  padding: 15px 0 0 10px;
}
.about-txt-1 {
  font-size: 2.0em;
  line-height: 28px;
  padding: 0;
}
.about-txt-1 span {
  font-style: italic;
}
.about-txt-2 {
  font-size: 2.4em;
  padding: 60px 0 0 0;
}
.about-txt-3 {
  font-size: 1.6em;
  line-height: 24px;
  padding: 30px 0 0 0;
}
.about-txt-3 span {
  font-weight: bold;
}
.about-pc {
  display: block;
}
.about-sp {
  display: none;
}

/* works */
.white {
  color: #fff;
}
.gold {
  color: #807451;
}
.pa-sp {
  padding: 0 0 0 0;
}
.pa7 {
  padding: 7% 0 0 0;
}
.pa150 {
  padding: 150px 0 0 0;
}
.pa100 {
  padding: 100px 0 0 0;
}
.pa70 {
  padding: 70px 0 0 0;
}
.pa50 {
  padding: 50px 0 0 0;
}
.txt-en {
  font-size: 1.7em;
  text-align: center;
  line-height: 1.5;
}
.txt-en-s {
  font-size: 1.4em;
  text-align: center;
  line-height: 1.5;
}
.txt-ja {
  font-size: 1.5em;
  text-align: center;
  line-height: 1.6;
}
.txt-ja-s {
  font-size: 1.2em;
  text-align: center;
  line-height: 1.6;
}
.txt-link {
  font-size: 1.7em;
  text-align: center;
  line-height: 1.5;
}
.txt-link a {
  color: #c53500;
  text-decoration: underline;
}
.video-wrap {
  width: 96%;
  height: auto;
  margin: 0 auto;
}
.video {
	width:100%;
	height:auto;
}
.video_frame {
	position: relative;
	height: 0;
	padding: 30px 0 56.25%;
	overflow: hidden;
}
.video iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.other-txt {
  font-size: 1.8em;
  line-height: 1;
  padding: 150px 0 0 0;
  text-align: center;
}
.works-ul {
  box-sizing: border-box;
  letter-spacing: -.4em;
  width: 100%;
  margin: 80px auto 0 auto;
}
.works-ul li {
  box-sizing: border-box;
  letter-spacing: normal;
  display: inline-block;
  vertical-align: top;
  width: 25%;
  padding: 0 2% 4% 2%;
}
.works-ul-2 {
  width: 100%;
  margin: 170px auto 0 auto;
}
.works-ul-2 li {
  box-sizing: border-box;
  width: 25%;
  padding: 0 2% 4% 2%;
}
.works-ul-3 {
  width: 99.9%;
  margin: 170px auto 0 auto;
}
.works-ul-3 li {
  box-sizing: border-box;
  width: 29.3%;
  padding: 0 2% 4% 2%;
}
.works-title {
  font-size: 1.7em;
  line-height: 1.5;
  padding: 30px 0 0 0;
}
.works-title-sub {
  font-size: 1.7em;
  font-style: italic;
  line-height: 1.5;
}
.works-year {
  font-size: 1.3em;
  line-height: 1.7;
}
.thumb-box {
  position: relative;
}
.thumb-inner {
  position: absolute;
  padding: 0 0 0 5%;
  -webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
.thumb-logo {
  width: 220px;
  height: auto;
  padding: 210px 0 0 0;
  -webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
.thumb-txt {
  font-size: 1.8em;
  line-height: 1.5;
  padding: 30px 0 0 0;
  -webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
.gallery-ul {
  width: 100%;
  text-align: center;
}
.gallery-ul-l {
  width: 100%;
  text-align: left;
}
.column-1 {
  width: 96%;
  margin: 4% auto 0 auto;
}
.column-1b {
  width: 80%;
  margin: 4% auto 0 auto;
}
.column-2 {
  width: 46%;
  margin: 4% 2% 0 2%;
}
.column-3 {
  width: 29.3%;
  margin: 4% 2% 0 2%;
}
.column-4 {
  width: 21%;
  margin: 4% 2% 0 2%;
}
.column-5 {
  width: 80%;
  text-align: center;
  margin: 6% auto 2% auto;
}
.column-5 li {
  width: 18%;
  margin: 0 1%;
}
.box-border {
  border: 1px solid #929292;
}

/* flower */
.txt-title-flower {
  font-size: 3.6em;
  line-height: 1.5;
  text-align: center;
  color: #FF5460;
  padding: 150px 0 0 0;
}
.txt-flower {
  font-size: 2.4em;
  line-height: 1.8;
  font-weight: bold;
  text-align: center;
  color: #FF5460;
  padding: 70px 0 0 0;
}
.flower-pic {
  width: 270px;
  height: auto;
  margin: 70px auto 0 auto;
}
.flower-ul {
  width: 99.9%;
  max-width: 1200px;
  height: auto;
  margin: 30px auto 0 auto;
}
.flower-ul li {
  width: 27.3%;
  height: auto;
  margin: 6% 3% 0 3%;
}
.li-flower-no {
  font-size: 1.8em;
  line-height: 1.8;
  text-align: center;
  color: #FF5460;
  padding: 0 0 5px 0;
}
.li-flower-file {
  font-size: 1.4em;
  line-height: 1.8;
  text-align: center;
  color: #FF5460;
  padding: 5px 0 10px 0;
}
.li-flower-dl {
  width: 65%;
  height: auto;
  margin: 0 auto;
}
.li-flower-dl img:hover {
	transition: 1.0s;
	opacity: 0.3;
}
.txt-flower-sub {
  font-size: 1.6em;
  line-height: 1.8;
  font-weight: bold;
  text-align: center;
  color: #FF5460;
  padding: 100px 0 0 0;
}
.txt-flower-sub a {
  font-weight: bold;
  color: #FF5460;
  text-decoration: underline;
}
.txt-flower-sub a:hover {
	opacity: 50%;
}

/* footer */
.footer {
  width: 100%;
  padding: 150px 0 100px 0;
}
.footer-menu {
  margin: 0 auto;
  text-align: center;
  padding: 0 0 100px 0;
}
.footer-menu li {
  font-size: 1.7em;
  padding: 0 20px;
  display: inline-block;
}
.footer-menu li a {
  color: #000;
}
.footer-menu-w {
  margin: 0 auto;
  text-align: center;
  padding: 0 0 100px 0;
}
.footer-menu-w li {
  font-size: 1.7em;
  padding: 0 20px;
  display: inline-block;
}
.footer-menu-w li a {
  color: #fff;
}
.footer-icon {
  width: 30px;
  height: auto;
  margin: 0 auto;
}
.copy {
  font-size: 1.3em;
  text-align: center;
  padding: 100px 0 0 0;
}

.pink {
  color: #ff5a63 !important;
}
.pink a {
  color: #ff5a63 !important;
}

@media screen and (max-width:1400px) {
  /* main */
  .works-ul li {
    width: 33.3%;
    padding: 0 2% 4% 2%;
  }
  .works-ul-2 li {
    width: 33.3%;
    padding: 0 2% 4% 2%;
  }
  .thumb-logo {
    padding: 200px 0 0 0;
  }
}

@media screen and (max-width:1200px) {
  /* main */
  .thumb-logo {
    padding: 180px 0 0 0;
  }
}

@media screen and (max-width:1000px) {
  /* main */
  .works-ul {
    width: 100%;
    margin: 70px auto 0 auto;
  }
  .works-ul li {
    width: 50%;
  }
  .works-ul-2 {
    width: 100%;
    margin: 70px auto 0 auto;
  }
  .works-ul-2 li {
    width: 50%;
  }
  .thumb-logo {
    padding: 80px 0 0 0;
  }
  /* about */
  .about-l {
    width: 47%;
    float: left;
  }
  .about-r {
    width: 47%;
    float: right;
  }
}

@media screen and (max-width:800px) {
  /* main */
  .thumb-logo {
    padding: 30px 0 0 0;
  }
  /* about */
  .about-l {
    width: 100%;
    float: none;
  }
  .about-r {
    width: 100%;
    float: none;
  }
  .icon-wrap {
    width: 66px;
  }
  .member-txt {
    padding: 6px 0 0 20px;
  }
  .member-txt-sub-1 {
    padding: 60px 0 0 0;
  }
  .member-txt-sub-2 {
    padding: 40px 0 0 0;
  }
  .about-mail {
    padding: 15px 0 0 0;
  }
  .about-txt-1 {
    font-size: 2.0em;
    line-height: 28px;
    padding: 60px 0 0 0;
  }
  .about-pc {
    display: none;
  }
  .about-sp {
    display: block;
  }
}

@media screen and (max-width:640px) {
  .ul li {
    display: block;
  }
	.pc {
		display: none;
	}
	.sp {
		display: block;
	}
  /* header */
  .icon {
    width: 28px;
  }
  .logo {
    width: 140px;
  }
  /* common */
  .main-d {
    width: 94%;
  }
  .main-inner {
    width: 96%;
  }
  .txt-title {
    font-size: 1.6em;
    padding: 170px 0 0 0;
  }
  /* about */
  .member-1 {
    padding: 60px 0 0 0;
  }
  .member-txt-1 {
    font-size: 1.8em;
  }
  .member-txt-2 {
    font-size: 1.4em;
    padding: 8px 0 0 0;
  }
  .member-txt-sub-1 {
    font-size: 1.4em;
    line-height: 20px;
  }
  .member-txt-sub-2 {
    font-size: 1.4em;
    line-height: 20px;
  }
  .about-mail {
    font-size: 2.4em;
    font-weight: bold;
  }
  .about-txt-1 {
    font-size: 1.7em;
    line-height: 26px;
    padding: 30px 0 0 0;
  }
  .about-txt-2 {
    font-size: 2.0em;
    padding: 60px 0 0 0;
  }
  .about-txt-3 {
    font-size: 1.4em;
    line-height: 20px;
    padding: 30px 0 0 0;
  }
  /* works */
  .pa-sp {
    padding: 50px 0 0 0;
  }
  .pa150 {
    padding: 90px 0 0 0;
  }
  .txt-en {
    font-size: 1.3em;
  }
  .txt-en-s {
    font-size: 1.1em;
  }
  .txt-ja {
    font-size: 1.1em;
  }
  .txt-ja-s {
    font-size: 1.0em;
  }
  .txt-link {
    font-size: 1.3em;
  }
  .other-txt {
    font-size: 1.3em;
    padding: 90px 0 0 0;
  }
  .works-title {
    font-size: 1.2em;
    padding: 8px 0 0 0;
  }
  .works-title-sub {
    font-size: 1.1em;
  }
  .works-year {
    font-size: 1.0em;
  }
  .works-ul {
    width: 100%;
    margin: 30px auto 0 auto;
  }
  .works-ul li {
    box-sizing: border-box;
    width: 50%;
    padding: 0 2% 20px 2%;
  }
  .works-ul-2 {
    width: 100%;
    margin: 150px auto 0 auto;
  }
  .works-ul-2 li {
    width: 100%;
    padding: 0 0 50px 0;
  }
  .works-ul-3 {
    width: 100%;
    margin: 150px auto 0 auto;
  }
  .works-ul-3 li {
    width: 100%;
    padding: 0 0 50px 0;
  }
  .thumb-logo {
    width: 170px;
    padding: 50px 0 0 0;
  }
  .thumb-txt {
    font-size: 1.3em;
    line-height: 1.5;
    padding: 30px 0 50px 0;
  }
  .gallery-ul-l {
    text-align: center;
  }
  .column-1 {
    width: 100%;
    margin: 50px 0 0 0;
  }
  .column-1b {
    width: 100%;
    margin: 50px 0 0 0;
  }
  .column-2 {
    width: 100%;
    margin: 50px 0 0 0;
  }
  .column-3 {
    width: 100%;
    margin: 50px 0 0 0;
  }
  .column-4 {
    width: 100%;
    margin: 50px 0 0 0;
  }
  .column-5 {
    width: 100%;
    margin: 0;
  }
  .column-5 li {
    width: 100%;
    margin: 50px 0 0 0;
  }
  .video-wrap {
    width: 100%;
  }
  /* flower */
  .txt-title-flower {
    font-size: 3.6em;
    padding: 120px 0 0 0;
  }
  .txt-flower {
    font-size: 1.6em;
	font-weight: bold;
    padding: 30px 0 0 0;
  }
  .flower-pic {
    width: 60%;
    margin: 50px auto 0 auto;
  }
  .flower-ul {
    width: 100%;
    margin: 30px auto 0 auto;
  }
  .flower-ul li {
    width: 100%;
    height: auto;
    margin: 60px 0 0 0;
  }
  .li-flower-no {
    font-size: 1.6em;
  }
  .li-flower-file {
    font-size: 1.3em;
  }
  .txt-flower-sub {
    font-size: 1.1em;
	font-weight: bold;
    padding: 70px 0 0 0;
  }
  /* footer */
  .footer {
    width: 100%;
    padding: 100px 0 80px 0;
  }
  .footer-menu {
    margin: 0 auto;
    padding: 0 0 20px 0;
  }
  .footer-menu li {
    font-size: 1.3em;
    padding: 0 0 30px 0;
    display: block;
  }
  .footer-menu-w {
    margin: 0 auto;
    padding: 0 0 20px 0;
  }
  .footer-menu-w li {
    font-size: 1.3em;
    padding: 0 0 30px 0;
    display: block;
  }
  .copy {
    padding: 50px 0 0 0;
  }
  .footer-icon {
    width: 20px;
  }
  .copy {
    font-size: 1.0em;
    padding: 50px 0 0 0;
  }
}
