@charset "utf-8";
/*
Theme Name: genova_tpl
Theme URI: http://genova.co.jp/
Description: genova template.
Version: 1.0
*/

/* =====================================
■BASE
===================================== */
html {
   font-size: 62.5%;
}

body {
   font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
   font-size: 16px;
   background: #fff;
   color: #333;
   letter-spacing: 0.05em;
   line-height: 2;
   position: relative;
   -webkit-text-size-adjust: 100%;
}

a {
   text-decoration: none;
   color: #333;
   -moz-transition-duration: 0.7s;
   -o-transition-duration: 0.7s;
   -webkit-transition-duration: 0.7s;
   transition-duration: 0.7s;
}

a:focus,
*:focus {
   outline: none;
}

a[href^="tel:"] {
   pointer-events: none;
   cursor: text;
}

@media screen and (max-width: 767px) {
   a[href^="tel:"] {
      pointer-events: auto;
      cursor: pointer;
   }
}


/* =====================================
■MODULE
===================================== */
/*--------------------------------------
汎用
--------------------------------------*/
/* float */
.fr {
   float: right !important;
}

.fl {
   float: left !important;
}

/* clears */
.clearfix {
   *zoom: 1;
}

.clearfix:after {
   content: "";
   display: table;
   clear: both;
}

.cl {
   clear: both !important;
}

/* text indent */
.textHide {
   overflow: hidden;
   text-indent: 100%;
   white-space: nowrap;
}

/* text-align */
.tac {
   text-align: center !important;
}

.tar {
   text-align: right !important;
}

.tal {
   text-align: left !important;
}

/* font-weight */
.fb {
   font-weight: bold !important;
}

.tdU {
   text-decoration: underline!important;
}

/*--------------------------------------
Icon fonts
--------------------------------------*/
@font-face {
   font-family: 'icomoon';
   src: url('img/fonts/icomoon.eot');
   src: url('img/fonts/icomoon.eot#iefix') format('embedded-opentype'),
      url('img/fonts/icomoon.ttf') format('truetype'),
      url('img/fonts/icomoon.woff') format('woff'),
      url('img/fonts/icomoon.svg#icomoon') format('svg');
   font-weight: normal;
   font-style: normal;
}

[class*='icon-']:not([class*='eicon-']):before {
   display: inline-block;
   font-family: 'icomoon';
   speak: none;
   font-style: normal;
   font-weight: normal;
   font-variant: normal;
   text-transform: none;
   line-height: 1;
   vertical-align: baseline;
   -webkit-font-smoothing: antialiased;
   -moz-osx-font-smoothing: grayscale;
}

.icon-blog:before {
   content: "\e900";
}

.icon-category:before {
   content: "\e901";
}

.icon-check:before {
   content: "\e902";
}

.icon-checked:before {
   content: "\e903";
}

.icon-down:before {
   content: "\e904";
}

.icon-facebook:before {
   content: "\e905";
}

.icon-google:before {
   content: "\e906";
}

.icon-line:before {
   content: "\e907";
}

.icon-twitter:before {
   content: "\e908";
}

.icon-arrow02:before {
   content: "\e909";
}

.icon-arrow01:before {
   content: "\e910";
}

.icon-search:before {
   content: "\e911";
}

.icon-tag:before {
   content: "\e912";
}


/*--------------------------------------
Pc sp change
--------------------------------------*/
.sp {
   display: none;
}

.mb {
   display: none;
}

@media screen and (max-width: 767px) {
   .pc {
      display: none !important;
   }

   .sp {
      display: block !important;
   }
}

@media screen and (max-width: 480px) {
   .mb {
      display: block;
   }

   .pcm {
      display: none;
   }
}


/* =====================================
■Layout
===================================== */
/*--------------------------------------
container
--------------------------------------*/
.container {
   width: 100%;
   max-width: 1140px;
   padding: 0 30px;
   margin: 0 auto;
   -webkit-box-sizing: border-box;
   -moz-box-sizing: border-box;
   -ms-box-sizing: border-box;
   -o-box-sizing: border-box;
   box-sizing: border-box;
}

.container:after {
   content: "";
   display: block;
   clear: both;
}

@media (max-width: 767px) {
   .container {
      padding: 0 20px;
   }
   .home .container {
      padding: 0 30px;
   }
}

/*--------------------------------------
header
--------------------------------------*/
#wrapper {
   height: 100%;
   padding-top: 116px;
   box-sizing: border-box;
}
.lp-wrapper {
   padding-top: 0!important;
}

body.home #wrapper {
   padding-top: 0;
}

@media screen and (max-width: 1180px) {
   #wrapper {
      padding-top: 100px;
   }
}

@media screen and (max-width: 1024px) {
   #wrapper {
      padding-top: 85px;
   }
}

@media screen and (max-width: 767px) {
   #wrapper {
      padding-top: 60px;
   }
}

#header {
   position: fixed;
   top: 0;
   left: 0;
   z-index: 1000;
   width: 100%;
   -moz-transition-duration: 0.7s;
   -o-transition-duration: 0.7s;
   -webkit-transition-duration: 0.7s;
   transition-duration: 0.7s;
   background: #fff;
}
body.home #header {
   background: none;
}

@media screen and (max-width: 767px) {
   #header {
      position: absolute;
      top: 0 !important;
   }

   #header .toggleMenu {
      display: block;
   }

   .toggleMenu {
      width: 23px;
      height: 60px;
      position: relative;
      color: #fff;
      cursor: pointer;
      z-index: 2;
   }

   .menu-trigger,
   .menu-trigger span {
      display: inline-block;
      transition: all .4s;
      box-sizing: border-box;
   }

   .menu-trigger {
      width: 100%;
      height: 20px;
      position: absolute;
      top: 50%;
      margin-top: -10px;
   }

   .menu-trigger span {
      position: absolute;
      left: 0;
      width: 100%;
      height: 3px;
      background-color: #7E766B;
      border-radius: 2px;
   }

   .menu-trigger span:nth-of-type(1) {
      top: 0;
   }

   .menu-trigger span:nth-of-type(2) {
      top: 50%;
      margin-top: -1.5px;
   }

   .menu-trigger span:nth-of-type(3) {
      bottom: 0;
   }

   .toggleMenu.active .menu-trigger span:nth-of-type(1) {
      -webkit-transform: translateY(8.5px) rotate(-45deg);
      transform: translateY(8.5px) rotate(-45deg);
   }

   .toggleMenu.active .menu-trigger span:nth-of-type(2) {
      opacity: 0;
   }

   .toggleMenu.active .menu-trigger span:nth-of-type(3) {
      -webkit-transform: translateY(-8.5px) rotate(45deg);
      transform: translateY(-8.5px) rotate(45deg);
   }

   #header .right_box,
   #header .g_nav {
      display: none;
   }

}


/*--------------------------------------
SIDE
--------------------------------------*/
#sidebar {
   display: none;
}

/*--------------------------------------
FOOTER
--------------------------------------*/
#footer .fixed_box {
   position: fixed;
   /*right: 30px;
   bottom: 28px!important;*/
   right: 0;
   bottom: 0!important;
   z-index: 999;
   -moz-transition-duration: 0.7s;
   -o-transition-duration: 0.7s;
   -webkit-transition-duration: 0.7s;
   transition-duration: 0.7s;
}
#footer.lp-footer .fixed_box {
   bottom: 0!important;
   right: 0;
}

#footer .fixed_box ul {
   display: flex;
   -webkit-align-items: center;
           align-items: center;
   -webkit-justify-content: flex-end;
           justify-content: flex-end;
}
#footer .fixed_box li:first-child {
   width: 251px;
}
#footer .fixed_box li:last-child {
   width: 50px;
   margin-left: 14px;
}

#footer .fixed_box li img {
   width: 100%;
   vertical-align: middle;
}

#wpfront-scroll-top-container:hover img {
   opacity: 0.8 !important;
}


@media screen and (max-width: 767px) {
   #wpfront-scroll-top-container {
      display: none !important;
   }
}

/*Pagination CSS*/
ul.page-numbers {
   list-style: none;
   margin: 0;
}

.page-numbers:after {
   content: ".";
   display: block;
   clear: both;
   visibility: hidden;
   line-height: 0;
   height: 0;
}

ul.page-numbers li {
   display: block;
   float: left;
   margin: 0 4px 4px 0;
   text-align: center;
}

.page-numbers a,
.page-numbers span {
   line-height: 1.6em;
   display: block;
   padding: 0 6px;
   height: 18px;
   line-height: 18px;
   font-size: 12px;
   text-decoration: none;
   font-weight: 400;
   cursor: pointer;
   border: 1px solid red;
   color: #888;
}

.page-numbers a span {
   padding: 0
}

.page-numbers a:hover,
.page-numbers.current,
.page-numbers.current:hover {
   color: #000;
   background: #f7f7f7;
   text-decoration: none;
}

.page-numbers:hover {
   text-decoration: none
}