/*
Theme Name: Client
Author: CordialPleasure Co.,Ltd.
Author URI: http://c-pleasure.jp/
Description: 専用テーマ
*/
/* original css */
body {
   font-feature-settings: "palt";
   line-height: 1;
   font-weight: 300;
   overflow-x: hidden;
}

main article section.bg-common {
   overflow: hidden;
}

.bg-common.fixed::before {
   position: fixed;
}

/* common */
.jumbotron {
   background: none;
   padding: 0;
   margin: 0;
   border-radius: 0;
}

.jumbotron-common {
   background-size: cover;
   background-repeat: no-repeat;
   background-position: center;
   overflow: visible;
}

.jumbotron-common::before {}

.jumbotron-common .ttl-main {
   text-align: left;
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   align-items: baseline;
   justify-content: center;
   flex-wrap: wrap;
   margin: 0;
}

.jumbotron-common .ttl-main-eng {
   position: absolute;
   right: 0;
   bottom: -30px;
}

.jumbotron-common .ttl-main .title, .jumbotron-common .ttl-main-eng .title {
   margin: 0;
}

.jumbotron-common .ttl-cont {
   text-align: center;
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   align-items: center;
   justify-content: center;
   height: 360px;
}

@media (max-width: 991px) {
   .jumbotron-common {
      padding-bottom: 0;
      margin-bottom: 0;
      overflow: hidden;
   }

   .jumbotron-common .ttl-cont {
      height: 180px;
   }
}

/* common */
.container-fluid.inner {
   max-width: 1280px;
}

@media (min-width: 1201px) {
   .container-fluid.inner.wide {
      width: 100%;
      max-width: 1560px;
      padding-right: 30px;
      padding-left: 30px;
   }
}

.container-fluid.slick {
   padding-right: 8px;
   padding-left: 8px;
}

@media (max-width: 575px) {
   .row {
      margin-right: -8px;
      margin-left: -8px;
   }

   .row [class^="col-"] {
      padding-right: 8px;
      padding-left: 8px;
   }
}

.row [class^="col-"] [class^="block_"], .row [class^="col-"] .cont, .row [class^="col-"] .metabox .item .title {}

.row.center {
   justify-content: center;
}

.row-stretch [class^="col-"], .row-stretch [class^="col-"] .cont, .row-stretch [class^="col-"] .cont-box {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
}

.row-stretch [class^="col-"] .cont, .row-stretch [class^="col-"] .cont .cont-box, .row-stretch [class^="col-"] .cont .box {
   width: 100%;
}

.row .item-text {
   z-index: 1;
}

.row .item-image {
   z-index: 0;
}

.row-fix {
   margin-right: 0;
   margin-left: 0;
}

.row-fix .cont {}

.row-fix [class^="col-"] {
   padding-right: 0;
   padding-left: 0;
}

.row-fix .item [class^="block_"], .row-fix .item .cont, .row-fix .item .metabox .item .title {}

.row-narrow {
   margin: -5px;
}

.row-narrow [class^="col-"] {
   padding: 5px;
}

.row-narrow-fix {
   margin: 0;
}

.row-narrow-fix [class^="col-"] {
   padding: 0;
}

@media (max-width: 575px) {
   .row-styleB .item {
      padding: 8px;
   }
}

@media (min-width: 576px) {
   .row-styleB .item {
      padding: 15px;
   }
}

.row-wide {
   margin-right: -15px;
   margin-left: -15px;
}

.row-wide [class^="col-"] {
   padding-right: 15px;
   padding-left: 15px;
}

@media (min-width: 576px) {
   .row-wide {
      margin-right: -30px;
      margin-left: -30px;
   }

   .row-wide [class^="col-"] {
      padding-right: 30px;
      padding-left: 30px;
   }
}

.row-reverse {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   flex-wrap: wrap;
   flex-direction: row-reverse;
}

.row-end {
   justify-content: flex-end;
}

.v-middle {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   align-items: center;
   flex-wrap: wrap;
}

.v-middle.center {
   justify-content: center;
}

.v-bottom {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   align-items: flex-end;
}

.works-list.row {
   display: block;
}

.row .slick-list [class^="col-"], .works-list.row [class^="col-"] {
   margin-right: 0;
   margin-left: 0;
}

@media (min-width: 992px) {
   .row-layar .item.item-image .cont figure {
      margin-bottom: 60px;
   }

   .cont-main .cont-item:nth-child(odd) .row-layar .item.item-text .cont .cont-box {
      margin-right: -60px;
   }

   .cont-main .cont-item:nth-child(even) .row-layar .item.item-text .cont .cont-box {
      margin-left: -60px;
   }

   .row-layar.row-reverse .item.item-text .cont .cont-box {
      margin-right: -60px;
      margin-left: 0;
   }
}

@media (min-width: 768px) and (max-width: 991px) {
   .row-layar .item.item-image .cont figure {
      margin-bottom: 0;
   }

   .row-layar .item.item-text .cont .cont-box {
      margin-left: 0;
   }

   .row-layar.row-reverse .item.item-text .cont .cont-box {
      margin-right: 0;
      margin-left: 0;
   }
}

@media (min-width: 1201px) {
   .ttl-area .ttl {
      font-size: 1.1em;
   }
}

:focus {
   outline: none !important;
}

a.block-area {
   display: block;
   width: 100%;
}

a.block-area.no-bg {
   background: none;
}

a.block-area:hover, a.block-area:active, a.block-area:focus {
   opacity: 1;
}

a.block-area figure {
   position: relative;
   transition: .5s ease all;
   opacity: 1;
}

a.block-area:hover figure, a.block-area:active figure, a.block-area:focus figure {
   transition: .5s ease all;
   opacity: .5;
}

a.block-area.no-transparent figure {
   opacity: 1;
}

a.block-area.no-transparent:hover, a.block-area.no-transparent:active, a.block-area.no-transparent:focus, a.block-area.no-transparent:hover figure, a.block-area.no-transparent:active figure, a.block-area.no-transparent:focus figure {
   opacity: 1;
}

a.block-area.scale figure div {
   overflow: hidden;
}

a.block-area.scale figure div img {
   transform: scale(1);
   transition: 1s ease all;
   opacity: 1;
}

a.block-area.scale:hover figure div img, a.block-area.scale:focus figure div img, a.block-area.scale:active figure div img {
   transform: scale(1.1);
   transition: 1s ease all;
   opacity: .5;
}

body {
   position: relative;
}

@media (max-width: 767px) {
   main h1 {
      font-size: 1.5rem;
   }

   main h2 {
      font-size: 1.25rem;
   }

   main h3 {
      font-size: 1.2rem;
   }

   main h4 {
      font-size: 1.1rem;
   }

   main h5 {
      font-size: 1.1rem;
   }

   main h6 {
      font-size: 1rem;
   }
}

hr {
   margin-top: 15px;
   margin-bottom: 15px;
   border-color: #d6d6d6;
}

.alignleft, .aligncenter, .alignright {
   display: block;
}

.alignleft {
   margin-right: auto;
   margin-left: 0;
}

.aligncenter {
   margin-right: auto;
   margin-left: auto;
}

.alignright {
   margin-right: 0;
   margin-left: auto;
}

.button-left, .button-center, .button-right {
   text-align: center;
   position: relative;
   z-index: 1;
}

@media (min-width: 576px) {
   .button-left {
      text-align: left;
   }

   .button-center {
      text-align: center;
   }

   .button-right {
      text-align: right;
   }
}

.bg-common {
   background-size: auto;
}

.cont-main>[class^="block"]:first-child {
   padding-top: 0;
}

.cont-main>[class^="block"]:last-child {
   padding-bottom: 0;
}

.cont {
   text-align: left;
}

.cont figure {
   overflow: hidden;
   margin-bottom: 1em;
}

.cont figure.b0 {
   margin-bottom: 0;
}

.cont figure.visible {
   overflow: visible;
}

.cont .round {
   border-radius: 30px;
}

.cont.border {
   border: 1px solid #d6d6d6;
}

.cont.right {
   text-align: right;
}

.cont figure.border {
   border: none;
   border-bottom: 2px solid #1a51a3;
}

.cont figure.center {
   text-align: center;
}

.cont .cont-box {
   padding: 60px;
}

.cont .cont-box.half {
   padding: 30px;
}

.cont .cont-box.mini {
   padding: 15px;
}

.cont .title {
   margin-bottom: 0;
}

.cont .metabox {
   line-height: 1.5;
   margin-bottom: 1em;
}

.cont .metabox.b0 {
   margin-bottom: 0;
}

.cont .metabox.main p {
   line-height: 2;
}

@media (min-width: 992px) {
   .cont .metabox.main p {
      font-size: 1.1em;
   }
}

@media (min-width: 992px) and (max-width: 1200px) {
   .cont .cont-box {
      padding: 45px;
   }
}

@media (min-width: 768px) {
   .cont .metabox.center p {
      text-align: center;
   }
}

@media (max-width: 767px) {
   .cont .metabox p {
      font-size: 14px;
   }
}

.b0 {
   padding-bottom: 0 !important;
   margin-bottom: 0 !important;
}

.box-shadow {
   box-shadow: 0 0 15px rgba(0, 0, 0, .2);
}

.box-shadow-border {
   box-shadow: none;
}

.box-shadow-border::after {
   content: '';
   background-image: -webkit-gradient(linear, 0 0, 100% 100%, color-stop(.25, #f5d4d2), color-stop(.25, transparent), color-stop(.5, transparent), color-stop(.5, #f5d4d2), color-stop(.75, #f5d4d2), color-stop(.75, transparent), to(transparent));
   -webkit-background-size: 7px 7px;
   position: absolute;
   top: 10px;
   left: 10px;
   right: -10px;
   bottom: -10px;
   z-index: -1;
}

.box-shadow-flat {
   box-shadow: 5px 5px #f6f6f6;
}

.no-box-shadow {
   box-shadow: none !important;
}

@media (max-width: 991px) {
   .bg-common {
      background-size: cover;
   }

   .cont .cont-box {
      padding: 45px;
   }

   .cont .cont-box.half {
      padding: 20px;
   }

   .cont .cont-box.mini {
      padding: 15px;
   }

   .cont .cont-box.half p {
      font-size: .8rem;
   }
}

@media (max-width: 767px) {
   .cont.right {
      text-align: left;
   }

   .cont .cont-box {
      padding: 15px;
   }

   .cont .cont-box.half {
      padding: 15px;
   }

   .cont .cont-box.mini {
      padding: 15px;
   }
}

.block_1 {
   padding: 30px 0;
}

.block_2 {
   padding: 25px 0;
}

.block_3 {
   padding: 20px 0;
}

.block_4 {
   padding: 15px 0;
}

.block_5 {
   padding: 8px 0;
}

.block_6 {
   padding: 0 0 30px;
}

.block_7 {
   padding: 0 0 25px;
}

.block_8 {
   padding: 0 0 20px;
}

.block_9 {
   padding: 0 0 15px;
}

.block_10 {
   padding: 0 0 8px;
}

@media (min-width: 768px) {
   .block_1 {
      padding: 50px 0;
   }

   .block_2 {
      padding: 40px 0;
   }

   .block_3 {
      padding: 30px 0;
   }

   .block_4 {
      padding: 20px 0;
   }

   .block_5 {
      padding: 10px 0;
   }

   .block_6 {
      padding: 0 0 50px;
   }

   .block_7 {
      padding: 0 0 40px;
   }

   .block_8 {
      padding: 0 0 30px;
   }

   .block_9 {
      padding: 0 0 20px;
   }

   .block_10 {
      padding: 0 0 10px;
   }
}

@media (min-width: 992px) {
   .block_1 {
      padding: 60px 0;
   }

   .block_2 {
      padding: 45px 0;
   }

   .block_3 {
      padding: 30px 0;
   }

   .block_4 {
      padding: 20px 0;
   }

   .block_5 {
      padding: 15px 0;
   }

   .block_6 {
      padding: 0 0 60px;
   }

   .block_7 {
      padding: 0 0 45px;
   }

   .block_8 {
      padding: 0 0 30px;
   }

   .block_9 {
      padding: 0 0 20px;
   }

   .block_10 {
      padding: 0 0 15px;
   }
}

@media (min-width: 1200px) {
   .block_1 {
      padding: 60px 0;
   }

   .block_2 {
      padding: 45px 0;
   }

   .block_3 {
      padding: 30px 0;
   }

   .block_4 {
      padding: 20px 0;
   }

   .block_5 {
      padding: 15px 0;
   }

   .block_6 {
      padding: 0 0 60px;
   }

   .block_7 {
      padding: 0 0 45px;
   }

   .block_8 {
      padding: 0 0 30px;
   }

   .block_9 {
      padding: 0 0 20px;
   }

   .block_10 {
      padding: 0 0 15px;
   }
}

.no-padding {
   padding: 0 !important;
}

@media (max-width: 575px) {
   .no-padding-xs {
      padding: 0 !important;
   }
}

@media (max-width: 767px) {
   .no-padding-sm {
      padding: 0 !important;
   }
}

@media (max-width: 991px) {
   .no-padding-md {
      padding: 0 !important;
   }
}

@media (max-width: 1200px) {
   .no-padding-lg {
      padding: 0 !important;
   }
}

.table-dl dl {
   display: table;
   max-width: 100%;
}

.table-dl dl dt {
   display: table-cell;
   vertical-align: middle;
}

.table-dl dl dd {
   display: table-cell;
   vertical-align: middle;
}

.table-base dl {
   text-align: left;
   display: table;
   width: 100%;
   margin-bottom: 0;
}

.table-base dl dt {
   font-weight: normal;
   width: 25%;
   min-width: 210px;
   padding: 1.5em;
   position: relative;
}

.table-base dl dd {
   padding: 1.5em;
   margin-bottom: 0;
   position: relative;
}

.table-base dl dd .button {
   margin-top: 1em;
}

.table-base dl dd dl {
   margin: 0;
}

.table-base dl dd dl dt {
   display: block;
   background: none;
   width: 100%;
   padding: 0;
   border: none;
}

.table-base dl dd dl dd {
   display: block;
   width: 100%;
   padding: 0;
   border: none;
}

.table-base dl dd dl dd:before {
   display: none;
}

.table-base dl:last-child dd dl dt, .table-base dl:last-child dd dl dd {
   border: none;
}

.table-base dl dd dl:last-child dt, .table-base dl dd dl:last-child dd {
   border: none;
}

@media (max-width:767px) {
   .table-base dl dd:before {
      display: none;
   }
}

.table-block dl {}

.table-block dl:first-child {
   margin-top: 0;
}

.table-block dl:last-child {
   margin-bottom: 0;
}

.table-block dl dt, .table-block dl dd {
   display: block;
   width: 100%;
   padding: 1rem;
   border: none;
}

.table-block dl dt {}

.table-block dl dd {}

.table-block dl dd:before {
   display: none;
}

.table-block dl:last-child dt {}

.table-base dl dd .table-block>dl {
   margin: 20px 0;
}

.table-base dl dd .table-block>dl:first-child {
   margin-top: 0;
}

.table-base dl dd .table-block>dl:last-child {
   margin-bottom: 0;
}

.table-base dl dd .table-block>dl>dt, .table-base dl dd .table-block>dl>dd {
   padding: 1em;
   border: 1px solid #d6d6d6;
}

.table-base dl dd .table-block>dl>dt {
   background: #efefef;
}

.table-base dl dd .table-block>dl>dd {
   background: #fff;
   border-top: none;
}

.table-reverse dl dt {
   background: none;
   width: 100%;
   border-top: 1px solid #d6d6d6;
   border-right: 1px solid #d6d6d6;
}

.table-reverse dl dd {
   text-align: right;
   min-width: 120px;
}

.table-mini dl dt, .table-mini dl dd {
   padding: 1em;
}

@media (max-width: 575px) {
   .table-dl dl {
      width: 100%;
   }

   .table-dl dl dt {
      display: block;
      width: 100%;
      padding: 1em;
   }

   .table-dl dl dd {
      display: block;
      padding: 1em;
      border-top: none;
   }

   .table-base dl dd dl dt {
      display: block;
      width: 100%;
   }

   .table-base dl dd dl dd {
      display: block;
      border-bottom: none;
   }

   .table-base dl dd dl:last-child dd {
      border-top: none;
   }

   .table-reverse dl dt {
      border-right: none;
      border-bottom: none;
   }

   .table-reverse dl dd {
      min-width: 90px;
      border-top: 1px solid #d6d6d6;
   }

   .table-reverse dl dt, .table-reverse dl dd {
      display: table-cell;
   }
}

.cont-main {
   position: relative;
   z-index: 1;
}

.cont-main .cont-item:nth-child(odd) .row-cross {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   flex-direction: row-reverse;
   flex-wrap: wrap;
}

.cont-main .cont-item:nth-child(even) .row-cross {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   flex-direction: row;
   flex-wrap: wrap;
}

.caption-area {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   align-items: center;
   background: #f9f9f9;
   padding: 15px;
   border-radius: 5px;
}

.caption-area figure {
   margin-right: 15px;
}

@media (min-width: 768px) {
   .table-no-frame dl dt, .table-no-frame dl dd {
      border-top: none;
   }

   .table-no-frame dl:first-child dt {
      border-top: none;
   }

   .table-no-frame dl:last-child dt, .table-no-frame dl:last-child dd {
      border-bottom: none;
   }
}

.table-block dl dt, .table-block dl dd {
   padding: 1.5em;
}

@media (max-width: 767px) {
   .table-history.table-no-frame .item:first-child dl:last-child dd {
      border-bottom: none;
   }
}

.table-fixed {
   table-layout: fixed;
}

/* header */
.navbar-nav .nav-link {
   border-radius: 0;
}

.navbar-toggler {
   padding: .75rem;
   border: none;
}

.sr-only {
   position: absolute;
   width: 1px;
   height: 1px;
   padding: 0;
   margin: -1px;
   overflow: hidden;
   clip: rect(0, 0, 0, 0);
   border: 0;
}

.navbar-toggler .icon-bar {
   display: block;
   width: 22px;
   height: 2px;
   border-radius: 1px;
   position: relative;
   transition: .2s ease all;
}

.navbar-toggler .icon-bar+.icon-bar {
   margin-top: 4px;
}

.navbar-toggler .icon-bar:nth-child(2) {
   transform: rotate(45deg);
   top: 6px;
}

.navbar-toggler .icon-bar:nth-child(3) {
   opacity: 0;
}

.navbar-toggler .icon-bar:nth-child(4) {
   transform: rotate(-45deg);
   top: -6px;
}

.navbar-toggler.collapsed .icon-bar {
   transform: rotate(0deg);
   top: 0;
   opacity: 1;
   transition: .2s ease all;
}

.dropdown-toggle {
   position: relative;
   overflow: hidden;
}

.dropdown .dropdown-menu {
   display: none;
   opacity: 0;
   transition: .5s ease all;
   pointer-events: none;
   width: auto;
   min-width: 100%;
}

.dropdown.show>.dropdown-menu, .dropdown:hover>.dropdown-menu {
   display: block;
   border-radius: 0;
   transition: .5s ease all;
   pointer-events: all;
   opacity: 1;
}

.dropdown-menu {
   padding: 0;
   margin-top: 0;
   border: none;
   top: 90%;
   left: 0;
   z-index: 10000;
   transition: .5s ease all;
}

.dropdown-item {
   padding: 1rem;
}

.dropdown-toggle:before, .dropdown-toggle:after {
   position: absolute;
   top: 0;
   right: 0;
   bottom: 0;
   margin: 0;
}

@media (max-width: 991px) {
   .dropdown-toggle:before, .dropdown-toggle:after {
      width: 48px;
   }
}

.dropdown-toggle::before {
   content: '';
   left: inherit;
}

.dropdown-toggle::after {
   font-family: ionicons;
   content: '\f3d0';
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   align-items: center;
   justify-content: center;
   border: none;
   transform: rotate(0deg);
   transition: .5s ease all;
}

.dropdown.show>.dropdown-toggle::after {
   transform: rotate(180deg);
   transition: .5s ease all;
}

.dropdown-menu>li>.dropdown-menu {
   display: block;
   background: none;
   opacity: 1;
   pointer-events: all;
}

.navbar-nav>li>.dropdown-menu>li>.dropdown-menu {
   display: block;
   background: none;
   top: 100%;
   left: 0;
   margin: 0;
}

@media (min-width: 992px) {
   .dropdown>.dropdown-menu {
      display: block;
      transition: .5s ease all;
      opacity: 0;
      pointer-events: none;
   }

   .dropdown-menu>li>.dropdown-menu {
      display: none;
      background: none;
      transition: .5s ease all;
      opacity: 0;
      pointer-events: none;
   }
}

/* slider */
.slider-base {
   opacity: 1;
   transition: opacity .3s linear;
}

.slider-base.slick-initialized {
   opacity: 1;
}

.main-slider .item {
   background-size: cover;
   max-height: 720px;
}

.main-slider .item figure {
   margin: 0 auto;
}

.row-slider .item {
   padding: 36px 0;
}

.row-slider .item.item-left figure {
   margin-right: -60px;
}

.row-slider .item.item-right figure {
   margin-left: -60px;
}

.main-slider .slick-prev, .main-slider .slick-next {
   font-size: 3em;
   color: #1a51a3;
   background: none;
}

.main-slider .slick-dots {
   bottom: -30px;
}

.main-slider .slick-dots li {
   margin: 0 10px !important;
}

.main-slider .slick-dots li button {
   border-radius: 100%;
}

@media (max-width: 991px) {
   .main-slider .slick-dots li {
      margin: 0 5px !important;
   }
}

.slider-area {
   position: relative;
}

.slider-area .main-catch {}

.slider-area .main-catch figure {}

.slider-area .slick-slider .item .main-catch {
   font-size: 1.5rem;
   color: #1a51a3;
   line-height: 1;
   font-weight: bold;
   font-style: italic;
   position: absolute;
   top: 15px;
   left: 110px;
   z-index: 2;
}

.slider-area .slick-slider .item .main-catch span {
   position: relative;
}

.slider-area .slick-slider .item .main-catch span::before {
   content: '';
   border-bottom: 10px solid #d6d6d6;
   position: absolute;
   right: 0;
   bottom: 2px;
   left: 0;
   z-index: -1;
}

.slider-area .slick-slider .item img {
   width: 100%;
   height: auto;
}

.slider-area .slick-slider .item .cont {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   align-items: center;
}

.slider-area .slick-slider .item .cont .cont-box {
   padding: 0;
   margin-top: 80px;
}

.slider-area .slick-slider .item .cont .cont-box .main-caption {
   font-size: 9rem;
   color: #1a51a3;
   line-height: 1;
}

/* slick */
.slick-slide {
   height: inherit;
}

.slick-arrows {
   position: absolute;
   top: 50%;
   margin: 0 auto;
   left: 0;
   right: 0;
}

.slick-prev, .slick-next {
   font-size: 2em;
   color: #fff;
   line-height: 48px;
   text-indent: -9999px;
   text-align: center;
   background: rgba(68, 174, 52, .8);
   width: 48px;
   height: 48px;
   padding: 0;
   border: none;
   border-radius: 0;
   position: absolute;
   top: 50%;
   z-index: 10;
   transform: translateY(-50%);
}

.slick-prev {
   left: 1em;
}

.slick-next {
   right: 1em;
}

.slick-prev:hover, .slick-prev:active, .slick-prev:focus, .slick-next:hover, .slick-next:active, .slick-next:focus {
   outline: 0;
}

.slick-prev:before, .slick-next:before {
   font-family: ionicons;
   text-indent: 0;
   position: absolute;
   top: 0;
   right: 0;
   bottom: 0;
   left: 0;
   transition: .5s ease all;
}

.slick-prev:before {
   content: '\f3d2';
}

.slick-next:before {
   content: '\f3d3';
}

.slick-prev:hover:before, .slick-next:hover:before {
   transition: .5s ease all;
}

.slick-prev:hover:before {
   left: -15px;
}

.slick-next:hover:before {
   left: 15px;
}

.slick-dots {
   position: absolute;
   bottom: -21px;
   z-index: 5;
   width: 100%;
   padding: 0;
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   list-style: none;
   justify-content: center;
}

.slick-dots li {
   font-size: 0;
   margin: 0 5px !important;
}

.slick-dots>li:first-child:last-child {
   display: none;
}

.slick-dots li button {
   font-size: 0;
   text-indent: 100%;
   white-space: nowrap;
   background: #1a51a3;
   width: 12px;
   height: 12px;
   padding: 0;
   border: none;
   border-radius: 100%;
   outline: 0;
   overflow: hidden;
   opacity: .5;
}

.slick-dots li.slick-active button, .slick-dots li button:hover, .slick-dots li button:active, .slick-dots li button:focus {
   background: #1a51a3;
   opacity: 1;
}

@media (max-width: 767px) {
   .card-item {
      margin-bottom: 1rem;
   }
}

/* breadcrumbs */
.breadcrumb-area {
   position: relative;
}

.breadcrumb {
   background: none;
   padding: 1em;
   margin-bottom: 0;
   border-radius: 0;
}

.breadcrumb>.active {
   color: #333;
}

.breadcrumb li {
   font-size: 14px;
   display: inline;
}

.breadcrumb>li+li:before {
   content: '\f3d3';
   font-family: ionicons;
   padding: 0 5px;
}

.breadcrumb li a {
   position: relative;
}

@media (max-width: 767px) {
   .breadcrumb-area {
      overflow-x: scroll;
   }

   .breadcrumb-area ol {
      list-style: none;
      display: table;
      padding-right: 15px !important;
   }

   .breadcrumb-area ol li {
      display: table-cell;
      white-space: nowrap;
   }

   .breadcrumb-area .container-fluid {
      padding-right: 0;
      padding-left: 0;
   }
}

.breadcrumb-area {
   background: none;
}

.breadcrumb-cont {
   background: none;
   -webkit-overflow-scrolling: touch;
}

.breadcrumb li {
   font-size: 14px;
   display: inline;
   z-index: 5;
   position: relative;
}

/* page-home */
.border-common {
   border: 2px solid;
}

.page-home .jumbotron-common {}

.page-home .jumbotron-common .bg-img {
   background-position: center;
   width: auto;
   position: absolute;
   top: inherit;
   right: 0;
   bottom: 0;
   left: 0;
   z-index: 2;
   height: 150px;
   pointer-events: none;
}

.page-home .jumbotron-common::before {
   display: none;
   background: none;
}

/* faq */
.table-faq dl dt, .table-faq dl dd {
   padding-left: 60px;
}

.table-faq dl dt::before, .table-faq dl dd::before {
   font-size: 2em;
   line-height: 1;
   display: block;
   position: absolute;
   top: 50%;
   left: 20px;
   transform: translateY(-50%);
   -webkit-backface-visibility: hidden;
   backface-visibility: hidden;
}

.table-faq dl dt::before {
   content: 'Q';
}

.table-faq dl dd::before {
   content: 'A';
   color: #1a51a3;
}

@media (max-width: 767px) {
   .table-faq dl dt, .table-faq dl dd {
      font-size: .8em;
      padding-right: 0;
      padding-left: 40px;
   }

   .table-faq dl dt::before, .table-faq dl dd::before {
      font-size: 1.5em;
      left: 10px;
   }
}

/* blog */
.post .cont figure, .post .cont figure a {
   display: inline-block;
}

.row-blog .cont .cont-box.border {
   border: 1px solid #343434;
}

.row-blog .blog-info {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   -ms-align-items: center;
   align-items: center;
   margin: -5px;
}

.row-blog .blog-info>div {
   padding: 5px;
}

.row-blog .cont.post h1, .row-blog .cont.post h2, .row-blog .cont.post h3, .row-blog .cont.post h4, .row-blog .cont.post h5, .row-blog .cont.post h6 {}

.row-blog .cont.post .metabox p {
   margin-bottom: 2em;
}

.row-blog .cont.post .metabox p:last-child {
   margin-bottom: 0;
}

.row-blog table {
   width: 100% !important;
}

.row-blog table tr th, .row-blog table tr td {
   padding: 15px;
   border: 1px solid #343434;
}

.row-blog table tr th {
   background: #d6d6d6;
}

.blog-ttl-area {
   display: block;
   margin-bottom: 30px;
}

.blog-ttl-area .date-area {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   justify-content: center;
   -ms-align-items: center;
   align-items: center;
   text-align: center;
   float: left;
   width: 90px;
   height: 90px;
   padding: 10px;
   margin-right: 15px;
   border: 1px solid #1a51a3;
   position: absolute;
}

.blog-ttl-area .date-area .date-cont {
   margin: 0;
}

.blog-ttl-area .date-area .date-cont span {
   font-size: 1.5rem;
   color: #1a51a3;
   display: block;
}

.blog-ttl-area .title {
   padding-bottom: 0 !important;
   margin-bottom: 0 !important;
   margin-left: 120px;
   border: none !important;
}

.cont figure.eye-catch {
   margin-bottom: 30px;
}

.widget-area {
   margin: 0;
}

.widget-area [id^="custom_html"] {
   margin-bottom: 30px;
}

.widget-area [id^="custom_html"]:last-child {
   margin-bottom: 0;
}

.widget {
   padding: 0;
}

.widget>ul {
   margin: 0;
}

.widget>ul>li {
   padding: 0;
   border-top: 1px solid #343434;
}

.widget>ul>li:last-child {
   border-bottom: 1px solid #343434;
}

.widget>ul>li a {
   display: block;
   padding: 15px 0;
}

.widget>ul>li .date {
   font-size: 14px;
   display: block;
   margin-bottom: 5px;
}

.widget>ul>li .metabox p {
   line-height: 1;
}

/* contact */
.contact-area ul li {
   display: block;
}

.contact-check {
   font-size: 18px;
}

.contact-check input[type=checkbox] {
   width: 20px;
   height: 20px;
}

.contact dl dt label {
   display: block;
   position: relative;
   margin-bottom: 0;
}

.contact dl dt label::after {
   font-size: 12px;
   font-weight: bold;
   margin-right: 5px;
   margin-left: 5px;
   padding: 2px 4px;
   border-radius: 2px;
   position: absolute;
   right: 0;
   top: 50%;
   margin-top: -11px;
}

/* IE11だけに適用 */
@media all and (-ms-high-contrast:none) {
   .contact dl dt label::after {
      padding-top: 6px;
      margin-top: -14px;
   }
}

.contact dl dt {
   min-width: 240px;
}

.contact .btn-area input {
   margin: 0 10px;
}

div.wpcf7-mail-sent-ok {
   background: #1a51a3;
}

.input-lg {
   border-radius: 2px;
}

.wpcf7-form-control-wrap {
   display: inline-block;
}

.help-block {
   margin: 5px 0 0;
}

span.wpcf7-list-item {
   display: inline-block;
   margin: 0 1em 0 0 !important;
}

span.wpcf7-not-valid-tip {
   font-size: .8em !important;
   color: #fff !important;
   background: #1a51a3;
   padding: .25em;
   border-radius: 2px;
   position: absolute;
   top: -29px;
   left: 0;
}

span.wpcf7-not-valid-tip br {
   display: none;
}

span.wpcf7-not-valid-tip:after {
   content: "";
   position: absolute;
   bottom: -5px;
   left: 25%;
   margin-left: -5px;
   display: block;
   width: 0px;
   height: 0px;
   border-style: solid;
   border-width: 5px 5px 0 5px;
   border-color: #1a51a3 transparent transparent transparent;
}

div.wpcf7-validation-errors {
   color: #fff;
   text-align: center;
   background: #1a51a3;
   padding: 15px;
   margin: 0 0 30px !important;
   border: 1px solid #1a51a3;
}

div.wpcf7-mail-sent-ok {
   color: #fff;
   text-align: center;
   background: #1a51a3;
   padding: 15px;
   margin-bottom: 30px;
   border: none;
}

div.wpcf7-response-output {
   padding: 15px !important;
   border: 2px solid #1a51a3 !important;
}

.wpcf7 [class^="w-length"] {
   width: 100%;
}

@media (min-width: 768px) {
   .w-length-120 {
      width: 120px;
   }

   .w-length-150 {
      width: 150px;
   }

   .w-length-180 {
      width: 180px;
   }

   .w-length-210 {
      width: 210px;
   }

   .w-length-240 {
      width: 240px;
   }

   .w-length-270 {
      width: 270px;
   }

   .w-length-300 {
      width: 300px;
   }

   .w-length-330 {
      width: 330px;
   }

   .w-length-360 {
      width: 360px;
   }

   .w-length-390 {
      width: 390px;
   }

   .w-length-420 {
      width: 420px;
   }

   .w-length-450 {
      width: 450px;
   }

   .w-length-480 {
      width: 480px;
   }

   .w-length-100per {
      width: 100%;
   }
}

/* IE11だけに適用 */
@media all and (-ms-high-contrast:none) {
   .contact dl.req dt label::after {
      padding-top: 7px;
   }

   .contact dl.any dt label::after {
      padding-top: 7px;
   }
}

/* footer */
footer .footer-top-area {
   background: none;
}

@media (min-width: 992px) {
   footer .navbar-nav {
      display: block;
   }

   footer .navbar-nav .nav-item, footer .navbar-nav .nav-link {
      display: inline-block;
   }

   footer .footer-top-area .footer-top h1 {
      margin-bottom: 0;
   }

   footer .navbar-collapse {
      margin-left: auto;
   }
}

footer .navbar-nav>li>a .link-menu {
   padding: 5px 10px;
}

footer .ttl-eng {
   margin: 0;
   display: none;
}

@media (max-width: 991px) {
   footer .footer-top-area .footer-top {
      text-align: center;
   }

   footer .footer-top-area .footer-top .logo-image {
      display: inline-block;
   }

   footer .footer-top-area .footer-top .recruit-name {
      display: block;
   }

   footer .footer-top-area .footer-top .company-info {
      text-align: center;
   }

   footer .footer-top-area .footer-top .company-info a {
      display: inline-block;
   }

   footer .footer-top-area .footer-top .company-info a h1 {
      margin: 0;
   }

   footer .navbar-collapse {
      padding: 8px 0;
      margin-bottom: 0;
   }

   footer .company-data {
      margin-bottom: 15px;
   }

   footer .company-data .cont .metabox p {
      text-align: center;
   }
}

footer .footer-top .navbar-nav li .dropdown-menu {
   background: none;
   opacity: 1;
   position: relative;
   top: 0;
   display: block;
   left: 0;
   pointer-events: all;
   margin-top: 10px;
}

footer .footer-top .navbar-nav li .dropdown-menu a {
   color: #000;
   line-height: 1.5rem;
   font-weight: normal;
   display: inline-block;
   padding-left: 12px;
   position: relative;
}

footer .footer-top .navbar-nav li .dropdown-menu a::before {
   content: '';
   position: absolute;
   left: 0;
   width: 6px;
   height: 1px;
   background: #000;
   top: 50%;
}

footer .footer-top .navbar-nav li .dropdown-menu>li>a .link-menu:after {
   display: none;
}

footer .footer-top .navbar-nav li .dropdown-menu>li>.dropdown-menu {
   padding-left: 1rem;
   margin-top: 0;
}

footer .footer-middle {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   justify-content: flex-start;
   flex-wrap: wrap;
   align-items: center;
   padding: 10px 0;
}

footer .footer-middle .footer-company a {
   font-size: 1rem;
   font-weight: bold;
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   align-items: center;
   margin: 0;
}

footer .footer-middle .footer-company a span {
   display: block;
}

footer .footer-middle .footer-company a span:first-child {
   margin-right: 15px;
}

footer .footer-middle .footer-subnav .navbar-nav>li>a {
   font-size: 12px;
   display: inline-block;
   padding: 0 8px;
}

footer .footer-bottom {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
   justify-content: center;
   flex-wrap: wrap;
   align-items: center;
   text-align: center;
}

footer .footer-bottom .footer-address {
   display: -webkit-flex;
   display: -moz-flex;
   display: -ms-flex;
   display: -o-flex;
   display: flex;
}

footer .footer-bottom-area {
   border: none;
}

footer .footer-copy a, footer .footer-by a, footer .footer-copy, footer .footer-by {
   color: #000;
   line-height: 1;
}

footer .invert .footer-copy a, footer .invert .footer-by a, footer .invert .footer-copy, footer .invert .footer-by {
   color: #fff;
}

@media (min-width: 992px) and (max-width: 1200px) {
   footer .footer-middle .footer-company {
      margin-right: 15px;
   }

   footer .footer-middle .footer-subnav {
      margin-left: auto;
   }
}

@media (min-width: 992px) {
   footer .footer-middle .footer-subnav {
      margin-left: auto;
   }
}

@media (max-width: 991px) {
   footer .footer-company {
      text-align: center;
   }

   footer .navbar-nav {
      width: 100%;
   }

   footer .footer-company .footer-company-info .cont .metabox {
      text-align: center;
   }

   .navbar-collapse {
      border: none;
      box-shadow: none;
   }

   .recruit footer .footer-bottom {
      display: block;
   }

   .recruit footer .footer-bottom .footer-address {
      justify-content: center;
   }
}

@media (max-width: 767px) {
   footer .footer-top #menu-footer.navbar-nav>li {}

   footer .footer-top #menu-footer.navbar-nav>li:last-child {
      border-bottom: none;
   }

   footer .footer-middle .footer-company a {
      justify-content: center;
   }

   footer .footer-middle .footer-company, footer .footer-middle .footer-subnav {
      width: 100%;
   }

   footer .nav>li>a.dropdown-toggle {
      display: inline-block;
   }

   footer .footer-top .navbar-nav li .dropdown-menu a {
      display: inline-block;
   }

   footer .footer-middle .footer-subnav .navbar-nav>li>a {
      display: inline-block;
   }

   footer .footer-copy {
      margin-bottom: 10px;
   }

   footer .footer-by {
      margin: 0;
   }

   footer .footer-bottom .footer-address {
      display: block;
   }
}

@media print {
   header {
      position: relative;
   }
}
