/* --------------------------------------------------------
*common
-------------------------------------------------------- */
body {
  color: #333;
  line-height: 1.8;
  background: url("../img/bg_01.jpg") center 0;
  font-size: 86%;
}

a {
  color: #333;
}

a:visited, a:active {
  color: #333;
}

a:hover {
  text-decoration: underline;
}

#wrapper {
  min-width: 1100px;
  overflow: hidden;
}

.wrapper_in {
  width: 1060px;
  margin: 0 auto;
}

.clearfix {
  overflow: hidden;
  *zoom: 1;
}

.leftBox {
  float: left;
}

.rightBox {
  float: right;
}

@media only screen and (min-device-width: 320px) and (max-device-width: 480px) {
  html {
    -webkit-text-size-adjust: 100%;
  }
}

.spOnly {
  display: none;
}

.red {
  color: #BD272D;
}

::selection {
  background: #E6F2F9;
}

.mod-link01 {
  color: #07bfcb !important;
  text-decoration: underline !important;
}

.mod-link01:hover {
  text-decoration: none !important;
}

/* --------------------------------------------------------
*fade
-------------------------------------------------------- */
#g_nav, #main, #content, #footerMopduleWrapper {
  /* opacity: 0; */
}

/* --------------------------------------------------------
*g_nav
-------------------------------------------------------- */
#spHeaer {
  display: none;
}

#g_nav {
  height: 28px;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  background: url("../img/g_nav_bg_01.png") 0 0;
  padding: 14px 0;
  z-index: 999;
  font-family: 'Archivo Narrow', sans-serif;
  font-size: 114%;
  letter-spacing: 0.05em;
}

#g_nav ul {
  overflow: hidden;
  *zoom: 1;
}

#g_nav ul li {
  float: left;
  text-align: center;
  width: 130px;
  border-left: 1px solid #4D4D4D;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

#g_nav ul li a {
  display: block;
  width: 100%;
  height: 100%;
  color: #ddd;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  text-decoration: none;
}

#g_nav ul li a img {
  vertical-align: middle;
}

#g_nav ul li.li07 {
  border-right: 1px solid #4D4D4D;
}

#g_nav ul li:hover a {
  color: #07BFCB;
}

/* --------------------------------------------------------
*main
-------------------------------------------------------- */
body.fixed #content {
  margin-top: 275px;
}

body.sp #content, body.tablet #content {
  margin-top: 0 !important;
}

.m-headMv {
  background: url("") center center no-repeat;
  background-size: cover;
}

.m-headMv-wrap {
  background: #333;
  padding-top: 56px;
}

body.model .m-headMv-wrap {
  display: none;
}

.m-headMv-clear {
  height: 224px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  padding-bottom: 20px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.m-headMv-logo img {
  width: auto;
  height: 70px;
}

#pankuzu {
  display: none;
  background: #222;
  font-size: 86%;
  padding: 4px 0;
}

#pankuzu ul {
  overflow: hidden;
  *zoom: 1;
}

#pankuzu ul li {
  float: left;
  margin-right: 10px;
}

#pankuzu ul li a {
  margin-right: 10px;
}

#pankuzu, #pankuzu a {
  color: #ddd;
}

#pankuzu a {
  -webkit-transition: 0.3s;
  transition: 0.3s;
  text-decoration: none;
}

#pankuzu a:hover {
  color: #07BFCB;
}

#lead {
  padding: 50px 0;
  text-align: center;
}

#lead h1, #lead .m-h01 {
  margin-bottom: 40px;
}

#lead dt {
  margin-bottom: 28px;
}

#lead {
  text-align: center;
  letter-spacing: 0.1em;
}

#lead dl {
  font-family: "Hiragino Mincho Pro", "MS PMincho", serif;
}

#lead dt {
  font-size: 292%;
}

#lead dd {
  font-size: 115%;
}

/* --------------------------------------------------------
*f_nav
-------------------------------------------------------- */
#f_nav {
  background: #222;
  padding: 60px 0;
}

#f_nav, #f_nav a {
  color: #ddd;
}

#f_nav a {
  -webkit-transition: 0.3s;
  transition: 0.3s;
  text-decoration: none;
}

#f_nav a:hover {
  color: #07BFCB;
}

#f_nav .wrapper_in {
  overflow: hidden;
  *zoom: 1;
  width: 1020px;
  margin: 0 auto;
}

#f_nav h2 {
  float: right;
  margin-right: 60px;
}

#f_nav nav {
  float: left;
  width: 720px;
  font-family: 'Archivo Narrow', sans-serif;
  font-size: 134%;
  letter-spacing: 0.05em;
}

#f_nav nav dl {
  border-bottom: 1px solid #4D4D4D;
  margin-bottom: 6px;
  padding-bottom: 6px;
  overflow: hidden;
  *zoom: 1;
}

#f_nav nav dl dt {
  float: left;
  width: 90px;
}

#f_nav nav dl dd {
  float: left;
  margin-right: 8px;
  width: 620px;
}

#f_nav nav dl dd a {
  padding: 0 6px;
}

#f_nav nav dl.oneline dt {
  width: 600px;
}

#f_nav nav dl.twolink dt {
  width: 100px;
}

#f_nav nav dl.twolink dd {
  width: 230px;
}

#f_nav nav dl.twolink dd a {
  display: inline-block;
  margin-left: 20px;
}

/* --------------------------------------------------------
*blogFeed
-------------------------------------------------------- */
#blogFeed {
  background: #333;
  padding: 40px 0 50px;
  position: fixed;
  bottom: -360px;
  width: 100%;
  height: 250px;
  z-index: 999;
  -webkit-transition: 0.6s;
  transition: 0.6s;
}

#blogFeed, #blogFeed a {
  color: #fff;
}

#blogFeed h2 {
  text-align: center;
  margin-bottom: 30px;
}

#blogFeed .entryWrapper {
  overflow: hidden;
  *zoom: 1;
  margin-bottom: 10px;
}

#blogFeed .entryWrapper .entryBox {
  float: left;
  width: 352px;
  border-left: 1px solid #4D4D4D;
}

#blogFeed .entryWrapper .entryBox a {
  padding: 6px 26px;
  display: block;
  text-decoration: none;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

#blogFeed .entryWrapper .entryBox a:hover {
  background: #666;
}

#blogFeed .entryWrapper .entryBox h3 {
  margin-bottom: 8px;
}

#blogFeed .entryWrapper .entryBox article {
  font-size: 82%;
  color: #E2E2E2;
  margin-bottom: 20px;
}

#blogFeed .entryWrapper .entryBox .date {
  overflow: hidden;
  *zoom: 1;
  font-size: 82%;
}

#blogFeed .entryWrapper .entryBox .date dt {
  float: left;
}

#blogFeed .entryWrapper .entryBox .date dd {
  float: right;
}

#blogFeed .entryWrapper .entryBox:last-child {
  border-right: 1px solid #4D4D4D;
}

#blogFeed .pagetop {
  position: relative;
}

#blogFeed .pagetop a {
  display: block;
  width: 100%;
  height: 30px;
  padding: 10px 0 20px;
  z-index: 1;
  text-align: center;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

#blogFeed .pagetop a:hover {
  background: #444;
}

#blogFeed.on {
  bottom: 50px;
}

/* --------------------------------------------------------
*footer
-------------------------------------------------------- */
footer {
  position: fixed;
  bottom: 0;
  left: 0;
  background: #222;
  width: 100%;
  z-index: 999;
}

footer .wrapper_in {
  width: 100%;
  min-width: 1060px;
}

footer #snsBtn {
  float: left;
  overflow: hidden;
  *zoom: 1;
  width: 202px;
}

footer #snsBtn li {
  float: left;
}

footer #blogHoverArea {
  position: absolute;
  height: 50px;
  top: 0px;
  left: 200px;
  width: 73%;
  overflow: hidden;
  *zoom: 1;
}

footer #blogHoverArea, footer #blogHoverArea a {
  color: #ddd;
}

footer #blogHoverArea h2 {
  float: left;
  margin-right: 20px;
  font-family: 'Archivo Narrow', sans-serif;
  font-size: 142%;
  margin-top: 6px;
}

footer #blogHoverArea h2 a {
  -webkit-transition: 0.3s;
  transition: 0.3s;
  text-decoration: none;
}

footer #blogHoverArea h2 a:hover {
  color: #07BFCB;
}

footer #blogHoverArea ul {
  float: left;
  position: relative;
  margin-top: 13px;
}

footer #blogHoverArea li {
  background: url("../img/blog_ico_01.png") 0 8px no-repeat;
}

footer #blogHoverArea li a {
  display: block;
  padding-left: 20px;
}

footer .pagetop, footer .copyright {
  float: right;
}

footer .copyright {
  color: #fff;
  font-size: 75%;
  padding-top: 16px;
  padding-right: 20px;
}

/* --------------------------------------------------------
*worksUl
-------------------------------------------------------- */
.worksUl {
  overflow: hidden;
  *zoom: 1;
  width: 1030px;
  margin: 0 auto;
}

.worksUl .off img {
  opacity: 0.4;
}

.worksUl li {
  float: left;
  margin-right: 15px;
  margin-left: 15px;
  margin-bottom: 15px;
  opacity: 0;
}

.worksUl li img {
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  filter: grayscale(100%);
  filter: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg'><filter id='grayscale'><feColorMatrix type='matrix' values='0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0'/></filter></svg>#grayscale");
  -webkit-filter: gray;
  filter: gray;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  width: 176px;
  height: auto;
}

.worksUl li a:hover img {
  -webkit-filter: grayscale(0%);
  -moz-filter: grayscale(0%);
  -ms-filter: grayscale(0%);
  -o-filter: grayscale(0%);
  filter: grayscale(0%);
  -webkit-filter: url(grayscale.svg);
  filter: url(grayscale.svg);
  /* Firefox 4+ */
  -webkit-filter: none;
  filter: none;
  /* IE 6-9 */
}

.worksUl li a:hover aside {
  display: block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

.worksUl li figure {
  margin-bottom: 5px;
  position: relative;
}

.worksUl li figure aside {
  display: none;
  color: #fff;
  position: absolute;
  bottom: 0;
  left: 0%;
  width: 100%;
  font-size: 82%;
  text-align: center;
}

.worksUl li figure aside span {
  display: block;
  text-align: center;
  background: rgba(0, 0, 0, 0.7);
  padding: 3px 6px;
}

body.sp .worksUl li, body.tablet .worksUl li {
  opacity: 1;
}

/* --------------------------------------------------------
*foldingSec
-------------------------------------------------------- */
.foldingSec {
  -webkit-perspective: 1000px;
  perspective: 1000px;
}

.foldingSec .sec3dParent {
  -webkit-box-shadow: 0 1px 1px 1px rgba(0, 0, 0, 0.1);
  box-shadow: 0 1px 1px 1px rgba(0, 0, 0, 0.1);
  -webkit-transform-origin: 0px 0px;
  -moz-transform-origin: 0px 0px;
  -ms-transform-origin: 0px 0px;
  -o-transform-origin: 0px 0px;
  transform-origin: 0px 0px;
  -webkit-transform: rotateX(-60deg);
  transform: rotateX(-60deg);
  -webkit-transition: 0.6s;
  transition: 0.6s;
  opacity: 0;
}

.foldingSec:nth-child(2n) .sec3dParent {
  -webkit-transform: rotateX(60deg);
  transform: rotateX(60deg);
}

.foldingSec.on .sec3dParent {
  -webkit-transform: rotateX(0deg);
  transform: rotateX(0deg);
  opacity: 1;
}

.foldingSec:nth-child(2n+1) .sec3dParent {
  background: #EDEDED;
}

.foldingSec:nth-child(2n) .sec3dParent {
  background: #fff;
}

body.sp .foldingSec, body.tablet .foldingSec, html#ie9 .foldingSec {
  -webkit-perspective: none;
  perspective: none;
}

body.sp .foldingSec .sec3dParent, body.tablet .foldingSec .sec3dParent, html#ie9 .foldingSec .sec3dParent {
  -webkit-transform-origin: none;
  transform-origin: none;
  -webkit-transform: none;
  transform: none;
  -webkit-transition: none;
  transition: none;
  opacity: 1;
}

body.sp .foldingSec.on .sec3dParent, body.tablet .foldingSec.on .sec3dParent, html#ie9 .foldingSec.on .sec3dParent {
  -webkit-transform: rotateX(none);
  transform: rotateX(none);
}

.nivo-lightbox-theme-default .nivo-lightbox-title {
  background: none !important;
}

.nivo-lightbox-title-wrap {
  background: #000;
}

.nivo-lightbox-theme-default .nivo-lightbox-close {
  width: 36px !important;
  height: 36px !important;
}

#fancybox-left, #fancybox-right {
  position: fixed !important;
  top: 0 !important;
  margin-top: -18px !important;
  z-index: 9000 !important;
  height: 100% !important;
}

#fancybox-left {
  left: 0 !important;
}

#fancybox-right {
  right: 0 !important;
}

#fancybox-left-ico, #fancybox-right-ico {
  top: 50% !important;
}

#fancybox-title {
  bottom: auto;
  margin-top: 10px;
  background: #000;
  padding: 4px;
}

.fancybox-title-float {
  position: static !important;
  height: auto !important;
}

#fancybox-close {
  z-index: 9001 !important;
}

.grecaptcha-badge {
  bottom: 74px !important;
}

.m-btn01 {
  text-align: center;
  display: block;
  width: 200px;
  padding: 14px 0;
  background: #373737;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  font-family: 'Archivo Narrow', sans-serif;
  font-size: 114%;
  letter-spacing: 0.05em;
  text-decoration: none;
  color: #fff !important;
}

.m-btn01 img {
  vertical-align: middle;
}

.m-btn01:hover {
  background: #07BFCB;
  text-shadow: none;
  text-decoration: none;
}

.m-btns1col {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.m-btns1col-item {
  width: 200px;
}

.m-btns1col-item:not(:last-child) {
  margin-bottom: 10px;
}

.u-wysiwyg p:not(:last-child) {
  margin-bottom: 30px;
}

.u-wysiwyg img {
  max-width: 700px;
}

.u-wysiwyg a {
  color: #07bfcb;
  text-decoration: underline;
}

.u-wysiwyg a:hover {
  text-decoration: none;
}

.form-attention {
  border: 1px solid #dedede;
  padding: 30px;
  margin-bottom: 40px;
}

.form-attention.is-blog {
  margin-top: 40px;
}
