/*--------------------------------------------------------------
	Common
--------------------------------------------------------------*/
@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@500;800&display=swap');
body {
  font-family: -apple-system, blinkMacSystemFont, /* Macの欧文はSan Francisco (OS X 10.11以降) */
               'Helvetica Neue',            /* Macの欧文 (OS X 10.10以前) */
               'Segoe UI',                  /* Windowsの欧文 */
               'Hiragino Kaku Gothic ProN', /* Macのヒラギノ */
               Meiryo,                      /* Windowsのメイリオ */
               sans-serif;
}

html {
  overflow-y: scroll;
  overflow-x: hidden;
  -ms-overflow-style: scrollbar;
}

body {
  background: #fff;
  font: 400 11px/1.8;
  color: #2c2c2c;
  -webkit-font-smoothing: antialiased;
  word-wrap: break-word;
}
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {overflow: hidden !important;}
p, ol, ul, dl, blockquote, .form-group {font-size: 15px; line-height: 1.7em;}
b, strong, .bold{
}
ul {list-style-type: none; margin: 0; padding: 0;}
.btn-block {font-weight: bold;}

/*--------------------------------------------------------------
	Navbar
--------------------------------------------------------------*/
#head_logo {margin: 0; line-height: 70px;}
#head_logo a {font-size: 11px; white-space: nowrap; line-height: 1.3em; color: #0d1c1f; display: block; height: 85px !important; margin: 0; padding: 0;}
.navbar-brand {float: none; margin: 0; padding: 0;}
#head_logo a span {display: inline-block; margin: 8px 0 0 13px; letter-spacing: 0.3px;}
.navbar-brand img {float: left;}

.navbar-custom {
  background: transparent;
  border: 0;
  border-radius: 0;
  z-index: 1000;
  letter-spacing: 3px;
  font-size: 12px;
  transition: background, padding 0.4s ease-in-out 0s;
  position: absolute;
}

.navbar a {
  transition: color 0.125s ease-in-out 0s;
}

.navbar-custom .dropdown-menu {
  background: rgba(26, 26, 26, 0.9);
  border-radius: 0;
  border: 0;
  padding: 0;
  box-shadow: none;
}

.navbar-custom .navbar-brand {
  font-size: 24px;
}
.navbar-custom .nav li > a {
  font-size: 13px;
  font-weight: 900;
  line-height: 70px;
  letter-spacing: 1px;
  padding-top: 0;
  padding-bottom: 0;
}
.navbar-transparent .nav li > a {
  position: relative;
  font-size: 13px !important;
  font-weight: 900;
  color: #2c2c2c;
  letter-spacing: 1px;
  padding-left: 20px;
}
.sub-page .navbar-custom .nav li > a {
  color: #2c2c2c;
}

.navbar-custom .dropdown-menu > li > a {
  border-bottom: 1px solid rgba(73, 71, 71, 0.15) !important;
  padding: 11px 20px !important;
  letter-spacing: 2px;
  color: #999;
}

.navbar-custom .dropdown-menu .dropdown-menu {
  border-left: 1px solid rgba(73, 71, 71, 0.15);
  left: 100%;
  right: auto;
  top: 0;
  margin-top: 0;
}

.navbar-custom .dropdown-menu.left-side .dropdown-menu {
  border: 0;
  border-right: 1px solid rgba(73, 71, 71, 0.15);
  right: 100%;
  left: auto;
}

.navbar-custom .nav > li > a:focus,
.navbar-custom .nav > li > a:hover,
.navbar-custom .nav .open > a,
.navbar-custom .nav .open > a:focus,
.navbar-custom .nav .open > a:hover,
.navbar-custom .dropdown-menu > li > a:focus,
.navbar-custom .dropdown-menu > li > a:hover {
  background: none;
  color: #dddddd;
}

.navbar-custom .dropdown-menu > li > a:hover {
  background: rgba(255, 255, 255, 0.1) !important;
}

.navbar-custom .dropdown-toggle:after {
  position: absolute;
  display: block;
  right: 0;
  top: 50%;
  margin-top: -6px;
  font: normal normal normal 14px/1 FontAwesome;
  font-size: 9px;
  content: "\f105";
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.navbar-toggle {color: #fff; padding: 0; margin-top: 0; top: 10px;}
.sub-page .navbar-toggle {color: #000000;}

.navbar-custom .navbar-toggle .icon-bar {
  background: #fff;
}
.nav>li>a {padding: 10px 20px;}
.sub-page .navbar-custom .navbar-toggle .icon-bar {
  background: #000000;
}
.dropdown-menu {
  min-width: 180px;
  font-size: 11px;
}

section {padding-top: 50px; padding-bottom: 50px;}

.h2, h2, .h3, h3, .h4, h4, .txt_title {
    font-size: 36px;
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-weight: 600;
}
.sub_catch, .strong_box li div strong {
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-weight: 600;
}
.mgt-40 {margin-top: -40px !important;}
.mgt-50 {margin-top: -50px !important;}
.pdb70 {padding-bottom: 70px;}

.only_sp {display: none !important;}
.only_pad {display: none !important;}
.ls_s {letter-spacing: -10px; background: none !important;}
.txt_center {margin: 0 auto; text-align: center !important;}
.txt_o {color: #0d1c1f !important;}

.navbar-right {
 font-weight: 900;
}
.under_l {
 width: 100%;
 position: relative;
 display: inline-block;
 margin-bottom: 2em;
}
.under_l:before {
 content: '';
 position: absolute;
 bottom: -15px;
 display: inline-block;
 width: 60px;
 height: 1px;
 left: 50%;
 -moz-transform: translateX(-50%);
 -webkit-transform: translateX(-50%);
 -ms-transform: translateX(-50%);
 transform: translateX(-50%);
 background-color: #999;
 border-radius: 1px;
}
.under_line {
    font-size: 18px;
    line-height: 1em;
    padding-bottom: 0.8em;
    border-bottom: solid 1px #ededed;
    position: relative;
    margin: 30px 0;
}
.under_line:after {
    position: absolute;
    content: " ";
    display: block;
    border-bottom: solid 1px #000a29;
    bottom: -1px;
    width: 90px;
}

img {
  max-width: 100%;
  height: auto;
}

.align-center {
  text-align: center;
}

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

.position-relative {
  position: relative;
}

a img:hover {
  opacity: 0.9;
}

/*--------------------------------------------------------------
	Header
--------------------------------------------------------------*/
.home-section {
  position: relative;
  background-color: #fff;
  background-repeat: no-repeat;
  background-position: center center;
  width: 100%;
  z-index: 1;
  background-size: cover;
  padding: 0;
}
.home-section::after {
  display: block;
  content: '';
  width: 100%;
  height: 100vh;
  border: 12px solid #000000;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  mix-blend-mode: multiply;
}
.bg_dot {
  display: block;
  background: url("../images/overlay_dot.png") center center;
  background-position: center center;
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: '';
}
.contents_inner {
  box-sizing: boder-box;
  margin: 0 auto;
  padding: 30px 0 80px 0;
  color: #fff;
  text-align: center;
}

/* Transition elsements */
a,
.btn {
  transition: all 0.125s ease-in-out 0s;
}

#header_news {
  background: rgba(0,0,0,0.85);
  position: absolute;
  width: 100%;
  bottom: 0;
  left: 0;
  padding: 15px 20px;
}
#header_news_title {
  width: 1em;
  font-size: 12px;
  line-height: 1.3em;
  text-align: center;
  position: absolute;
  left: 2em;
  top: 2em;
}
#header_news ul {
  width: calc(100% - 2em);
  margin: 0 0 0 1em;
  padding: 0 0 0 1em;
  border-left: 1px solid #999999;
}
#header_news ul li {
  font-size: 12px;
}
#header_news ul li p {
  width: calc(100% - 89px);
  font-size: 12px;
  margin-bottom: 0;
  padding-bottom: 0;
}
#header_news .news_date {
  width: 70px;
  line-height: 1em;
  border-right: 1px solid #999999;
  margin-right: 15px;
}
#header_news .news_date, #header_news p {
  display: inline-block;
  vertical-align: middle;
}

/* mainImg */
.kvc {
  position: relative;
  height: 100%;
  padding-top: 0 !important;
}
#mainImg_v_white{position:absolute; width:100%; height:100%; background:rgba(0,0,0,0); z-index:10;}
#mainImg {
  display: table;
  height: 100vh;
  text-align: left;
  position: relative;
  z-index: 3;
}
#mainImg_txt {
  display: table-cell;
  font-size: 40px;
  font-family: 'Josefin Sans', sans-serif;
  letter-spacing: 5px;
  vertical-align: middle;
  position: relative;
  z-index: 2;
}
#mainImg_txt h2 {
  font-size: 48px;
  font-weight: 600;
  margin: 0;
}
#mainImg_txt h2 strong {
  color: #ffffff;
  background: #d91618;
  padding: 5px 7px;
}
.sub_catch {
  display: block;
  color: #ffffff;
  font-size: 20px;
  font-weight: 600;
  margin-top: 1em;
  line-height: 1.7em;
}

.bgextend{
  display: inline-block;
  animation-name:bgextendAnimeBase;
  animation-duration:1s;
  animation-fill-mode:forwards;
  position: relative;
  overflow: hidden;/*　はみ出た色要素を隠す　*/
  opacity:0;
}

@keyframes bgextendAnimeBase{
  from {
    opacity:0;
  }

  to {
    opacity:1;  
}
}

/*中の要素*/
.bgappear{
  animation-name:bgextendAnimeSecond;
  animation-duration:1s;
  animation-delay: 0.6s;
  animation-fill-mode:forwards;
  opacity: 0;
}
.sub_catch .txt_small {
  animation-delay: 1.0s;
}

@keyframes bgextendAnimeSecond{
  0% {
  opacity: 0;
  }
  100% {
  opacity: 1;
}
}

/*左から右*/
.bgLRextend::before{
  animation-name:bgLRextendAnime;
  animation-duration:1s;
  animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #d91618;/*伸びる背景色の設定*/
}
@keyframes bgLRextendAnime{
  0% {
    transform-origin:left;
    transform:scaleX(0);
  }
  50% {
    transform-origin:left;
    transform:scaleX(1);
  }
  50.001% {
    transform-origin:right;
  }
  100% {
    transform-origin:right;
    transform:scaleX(0);
  }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.bgappearTrigger,
.bgLRextendTrigger{
    opacity: 0;
}

.form-control {font-size: 15px;}
input[type=button].btn-block {display: inline; padding: 15px 0; margin-bottom: 60px; border: none; border-color: #ffffff;}

.navbar-custom {margin-bottom: 0;}

#btn_scroll a {
  display: inline-block;
  width: 3em;
  position: absolute;
  right: 0;
  left: calc(50% - 2em);
  bottom: -45px;
  z-index: 2;
  padding: 10px 10px 110px;
  overflow: hidden;
  color: #ffffff;
  font-size: 12px;
  font-family: 'Josefin Sans', sans-serif;
  font-weight: 900;
  line-height: 2em;
  letter-spacing: .2em;
  text-transform: uppercase;
  text-decoration: none;
  writing-mode: vertical-lr;
}
#btn_scroll a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 1.75em;
  width: 1px;
  height: 100px;
  background: #fff;
}
#btn_scroll a::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 1.75em;
  width: 1px;
  height: 100px;
  background: rgba(255,255,255,0.45);
}
#btn_scroll a::after {
  animation: sdl 1.5s cubic-bezier(1, 0, 0, 1) infinite;
}
@keyframes sdl {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}

/* Sections */
.navbar-custom + .main {
}

.main {
  position: relative;
  background-color: #fff;
  letter-spacing: 1px;
  z-index: 0;
}

.main section h2, section h3, #form-area h2 {letter-spacing: 3px; font-weight: 600;}
.main section h2, #form-area h2 {margin-bottom: 1.7em; text-align: center;}
.main section h2 span {display: inline-block; border-top: 1px solid; text-align: center; padding-top: 0.75em; line-height: 1.4em;}
.main section h2 small {display: block; color: #d91618 !important; font-size: 18px; line-height: 1.7em; margin-top: 30px;}
section h3 {margin-bottom: 1em;}
section h3.title_brd {
  text-align: center;
  position: relative;
  margin: 1em auto 3em auto;
}
section h3.title_brd::before, section h3.title_brd::after, #contact h3.title_brd::before, #contact h3.title_brd::after {
  display: block;
  content: '';
  width: 1em;
  height: 3px;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1em;
}
section h3.title_brd::before {
  background: rgba(0,10,41,0.65) !important;
  left: calc(50% - 1em);
}
section h3.title_brd::after {
  background: rgba(0,10,41,0.45) !important;
  left: calc(50% - 0em);
}
#access h3.title_brd::before {
  background: rgba(255,255,255,0.85) !important;
}
#access h3.title_brd::after {
  background: rgba(255,255,255,0.45) !important;
}
#contact h3.title_brd::before {
  background: rgba(255,255,255,0.85);
  left: calc(50% - 1em);
}
#contact h3.title_brd::after {
  background: rgba(255,255,255,0.45);
  left: calc(50% - 0em);
}
h2 strong {font-weight: 600;}

#news h2, #service h2, #form-area h2 {
  font-weight: 600;
  line-height: 1em;
  padding-top: 0.5em;
  position: relative;
}

#form-area h2::before {
  background: #000a29;
}
#news ul li img {
  width: 349px;
  height: 230px;
  object-fit: cover;
}
#news ul li span {
  display: block;
}
#news ul li span.news_thumb {
  margin-bottom: 1em;
}
#news ul li span.news_date {
  font-size: 13px;
  margin-bottom: 0.5em;
}
#news ul li p {
  font-size: 14px !important;
  line-height: 1.4em !important;
}
#news ul li p strong {
  display: block;
  font-size: 15px !important;
  font-weight: 600;
  line-height: 1.4em !important;
  margin-bottom: 0.5em;
}

#appeal .container {margin-bottom: 30px; padding-top: 50px; border-top: 4px double #dddddd;}
#appeal h3 {font-weight: 900;}
h3.title_brd {margin-top: 60px;}
h3.title_brd span {
  font-size: 140%;
}
#appeal ul {
  list-style-type: none;
  margin: 30px 0 0 0!important;
  padding: 0 !important;
}
#appeal ul li {text-align: center;}
#appeal ul li span {
  display: block;
  font-weight: bold;
  margin: 0 auto;
}
#appeal ul li span img {
  display: block;
  background: rgba(45,124,181,0.085);
  width: 150px;
  height: 150px;
  margin: 0 auto 30px auto;
  padding: 30px;
  border-radius: 50%;
}

.cv_btn {
  background: url("../images/bg_mainImg.jpg") center center;
  background-position: center center;
  position: relative;
  padding: 0;
  margin: 4em 0;
}
.cv_btn .bg_dot {
  padding: 50px 15px;
}
.cv_btn dl, .cv_btn dl dt, .cv_btn dl dd {
  margin: 0;
  padding: 0;
}
.cv_btn dl {
  margin: 0 auto;
  text-align: center;
}
.cv_btn dl dd a {
  display: inline-block;
  margin-top: 10px;
  margin-bottom: 0;
}

/*==================================================
アコーディオンのためのcss
===================================*/

/*アコーディオン全体*/
.accordion-area{
    list-style: none;
    width: 100%;
    margin: 30px auto 0 auto;
}

.accordion-area li{
    margin: 10px 0;
}

.accordion-area section {
  padding: 0;
}
.close {float: none; opacity: 1.0;}
/*アコーディオンタイトル*/
.title {
	display: inline-block;
    width: 70%;
    height: 3.5em;
    vertical-align: bottom;
    background: #ffffff;
    position: relative;
    cursor: pointer;
    color: rgba(45,124,181,1);
    font-size: 15px;
	font-weight: bold;
    line-height: 3.5em;
    text-align: center;
    margin: 0 auto;
    padding: 0 2em;
	border: 1px solid rgba(45,124,181,1);
	border-bottom: 3px solid rgba(45,124,181,0.85);
	border-radius: 30px;
	box-sizing: content-box;
}
.title:hover {
	background: rgba(255,255,255,0.45);
}

/*アイコンの＋と×*/
.title::before,
.title::after{
    position: absolute;
    content:'';
    width: 15px;
    height: 2px;
    background-color: rgba(45,124,181,1);
    
}
.title::before{
    top:48%;
    right: 10%;
    transform: rotate(0deg);
    
}
.title::after{    
    top:48%;
    right: 10%;
    transform: rotate(90deg);

}
/*closeというクラスがついたら形状変化*/
.title.close::before{
  transform: rotate(45deg);
}

.title.close::after{
  transform: rotate(-45deg);
}

/*アコーディオンで現れるエリア*/
.box {
  display: none /*はじめは非表示*/;
  margin-top: 2em;
}
.box p {
  font-size: 13px;
  text-align: left;
}

.box_wh {
  background: rgba(255,255,255,0.8);
  padding: 30px;
  margin: 30px 0;
  border-radius: 5px;
  border: 2px solid #ffffff;
  clear: both;
}
.box_wh:after {display: block; clear: both; content: "";}
.box_wh h3 {font-size: 24px; line-height: 1.2em; letter-spacing: 5px; margin-bottom: 20px; border-left: 5px solid rgba(144,207,195,0.8) !important; padding-left: 10px;}
.box_wh p {font-size: 18px;}
.box_wh h3 span {font-size: 60%; color: #6e7372; padding-left: 5px;}
.box_wh .fl_left {
  width: 30%;
}
.box_wh .fl_right {
  width: 66%;
}
.box_wh p:last-child {margin-bottom: 0;}

/* Half-image */
.side-image {
  position: absolute;
  height: 100%;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
  border-top: 1px solid #e5e5e5;
  border-collapse: collapse;
}

.side-image-text {
  background: #fff;
  border-top: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
  padding: 140px 60px 140px;
}

.col-md-offset-6-right {float: right; width: 50%; margin-right: 50%;}
.col-md-6-right {width: 50%; margin-left: 50%;}

/* Dark background */
.bg-dark,
.bg-dark-15,
.bg-dark-30,
.bg-dark-45,
.bg-dark-60,
.bg-dark-90 {
  color: #fff;
}

.bg-dark, #management {
  background: #0d1c1f;
}

.bg-dark-15:before {
  position: absolute;
  background: rgba(2, 2, 2, 0.2);
  content: " ";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
}

.bg-dark-30:before {
  position: absolute;
  background: rgba(2, 2, 2, 0.4);
  content: " ";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
  mix-blend-mode: multiply;
}

.bg-dark-45:before {
  position: absolute;
  background: rgba(2, 2, 2, 0.45);
  content: " ";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
  mix-blend-mode: multiply;
}

.bg-dark-60:before {
  position: absolute;
  background: rgba(0, 0, 0, 0.8);
  content: " ";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
}

.bg-dark-90:before {
  position: absolute;
  background: rgba(34, 34, 34, 0.9);
  content: " ";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
}

.bg-blur {position: relative;}
.bg-blur:before {
  content: '';
  background: inherit;
  -webkit-filter: blur(3px);
  -moz-filter: blur(3px);
  -o-filter: blur(3px);
  -ms-filter: blur(3px);
  filter: blur(3px);
  position: absolute;
  top: -3px;
  left: -3px;
  right: -3px;
  bottom: -3px;
  z-index: -1;
}

.bg-light {
  background: #ffffff;
}

.bg-gray {
  background: #efefef;
}

.bg_square {
  background-color: #efefef;
  background-image: url("../images/axiom-pattern.png");
}

.bg-light-30:before {
  position: absolute;
  background: rgba(255, 255, 255, 0.3);
  content: " ";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
}

.bg-light-45:before {
  position: absolute;
  background: rgba(255, 255, 255, 0.45);
  content: " ";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
}

.bg-light-60:before {
  position: absolute;
  background: rgba(255, 255, 255, 0.6);
  content: " ";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
}

.bg-light-70:before {
  position: absolute;
  background: rgba(255, 255, 255, 0.7);
  content: " ";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
}

.bg-light-80:before {
  position: absolute;
  background: rgba(255, 255, 255, 0.8);
  content: " ";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
}

.bg-sky {
  background: #d83d00;
}

.bg-sky h3 {color: #ffffff !important;}
.bg-sky .under_l:before {background: #ffffff !important;}

.parallax-bg {
  background-attachment: fixed;
  background-size: cover;
}

/* Vertical margin, padding */
.p-0 {
  padding: 0 !important;
}

.pt-0 {
  padding-top: 0 !important;
}

.pt-10 {
  padding-top: 10px !important;
}

.pt-20 {
  padding-top: 20px !important;
}

.pt-30 {
  padding-top: 30px !important;
}

.pt-40 {
  padding-top: 40px !important;
}

.pt-50 {
  padding-top: 50px !important;
}

.pt-140 {
  padding-top: 140px !important;
}

.pb-0 {
  padding-bottom: 0 !important;
}

.pb-10 {
  padding-bottom: 10px !important;
}

.pb-20 {
  padding-bottom: 20px !important;
}

.pb-30 {
  padding-bottom: 30px !important;
}

.pb-40 {
  padding-bottom: 40px !important;
}

.pb-50 {
  padding-bottom: 50px !important;
}

.pb-140 {
  padding-bottom: 140px !important;
}

.m-0 {
  margin: 0 !important;
}

.mt-0 {
  margin-top: 0 !important;
}

.mt-10 {
  margin-top: 10px !important;
}

.mt-20 {
  margin-top: 20px !important;
}

.mt-30 {
  margin-top: 30px !important;
}

.mt-40 {
  margin-top: 40px !important;
}

.mt-50 {
  margin-top: 50px !important;
}

.mt-60 {
  margin-top: 60px !important;
}

.mt-70 {
  margin-top: 70px !important;
}

.mt-80 {
  margin-top: 80px !important;
}

.mb-0 {
  margin-bottom: 0 !important;
}

.mb-10 {
  margin-bottom: 10px !important;
}

.mb-15 {
  margin-bottom: 15px !important;
}

.mb-20 {
  margin-bottom: 20px !important;
}

.mb-30 {
  margin-bottom: 30px !important;
}

.mb-40 {
  margin-bottom: 40px !important;
}

.mb-50 {
  margin-bottom: 50px !important;
}

.mb-60 {
  margin-bottom: 60px !important;
}

.mb-70 {
  margin-bottom: 70px !important;
}

.mb-80 {
  margin-bottom: 80px !important;
}

.features-item {
  color: #2c2c2c;
  margin: 20px 0;
  padding: 30px 20px 10px 20px;
  text-align: center;
}
.features-item p {
  text-align: left;
  font-size: 14px;
  line-height: 1.6em;
}

.features-item p strong {
  color: #b92222;
}

.features-item p small {
  display: block;
}

.features-icon {
  line-height: 1.2;
  font-size: 48px;
  color: #d83d00;
  font-weight: bold;
}

.features-title {font-size: 18px; color: #d83d00; font-weight: bold;}

.alt-features-title {
  letter-spacing: -1px;
  font-size: 16px;
  font-weight: 900;
  color: #1d3c76;
  margin: 0 0 15px 0;
  text-align: center;
}
.alt-features-title small {
  display: block;
  margin-top: 10px;
  font-size: 80%;
}

.alt-features-item {
  position: relative;
  padding-left: 40px;
  margin: 0 0 35px 0;
  font-size: 14px;
  line-height: 1.4em;
  text-align: center;
}

.alt-features-icon {
  color: #d83d00;
  font-weight: 900;
  text-align: center;
  line-height: 2em;
  font-size: 300%;
}

#news {
  background-color: #000a29;
background-image: url("../images/axiom-pattern.png");
/* This is mostly intended for prototyping; please download the pattern and re-host for production environments. Thank you! */
  position: relative;
}
#news dl dt {
  font-size: 130%;
  margin-top: 30px;
  position: relative;
}
#news dl dt small {
  font-size: 12px;
  font-weight: normal;
  vertical-align: top;
}
#news dl dd table {
  background: #ffffff;
  width: 100%;
  margin-top: 15px;
  border-collapse: collapse;
}
#news dl dd table th {
  background: rgba(2,33,92,0.85);
  color: #ffffff;
  font-weight: bold;
}
#news dl dd table th, #news dl dd table td {
  padding: 10px 15px;
  border: 1px solid #cccccc;
}
#news dl dd table th, #news dl dd table td ul {
  font-size: 80%;
}
#news dl dd table td ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
}
.btn_link a {
  display: block;
  background: #ffffff;
  width: 320px;
  color: #02215c;
  font-weight: bold;
  line-height: 3.5em;
  text-align: center;
  border-radius: 30px;
  border: 1px solid #02215c;
  border-bottom: 3px solid #02215c;
  box-sizing: content-box;
}
.btn_link a:before {
  display: inline-block;
  content: '\f080';
  font-family: 'Font Awesome 5 Free';
  font-size: 1.2em;
  font-weight: 900;
  vertical-align: middle;
  margin-right: 5px;
}

#performance table {
  width: 100%;
  table-layout: fixed;
  margin-top: 30px;
  border-collapse: collapse;
}
#performance table th, #performance table td {
  text-align: center;
  padding: 10px 15px;
  border: 1px solid #cccccc;
}
#performance table th {
  background: rgba(45,124,181,0.065);
  color: rgba(45,124,181,1);
}
#performance .chart_area .ch1 {
  color: rgba(45,124,181,1);
  font-weight: bold;
  text-align: center;
  text-decoration: underline;
  margin: 30px auto 15px auto;
}
#performance .txt_caution {text-align: center;}
canvas {display: block !important; width: 100% !important; height: auto !important;}

#bg_mind {
  background-image: url(../images/bg_mind.jpg);
  background-repeat: no-repeat;
  background-position: center;
  position: relative;
}
#mind {
  background-image: url(../images/img_mind.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: -20% top;
  position: relative;
}
#mind h2 {
  color: #ffffff !important;
  text-align: center;
  margin: 1.5em auto;
}
#mind h2 small {display: block; color: #ffffff; font-weight: bold; margin-bottom: 5px;}
#mind h2 span {font-family: 'Josefin Sans', sans-serif;}
#mind h2:before, #mind h2:after {
  display: none;
}
#mind .bg_case {
  width: calc(50% - 1em);
  background: rgba(255,255,255,1);
  padding: 20px 30px 0 30px;
  margin: 0 2em 2em 0;
  border-radius: 5px;
  box-shadow: 0 5px 3px rgb(0 0 0 / 10%);
  position: relative;
  overflow: hidden;
}
#mind .bg_case:before {
  display: block;
  content: '';
  background: rgba(45,124,181,0.85);
  width: 6em;
  height: 6em;
  font-family: 'Josefin Sans', sans-serif;
  color: #ffffff;
  text-align: center;
  line-height: 10.8em;
  letter-spacing: 0;
  transform: rotate(-45deg);
  position: absolute;
  top: -3em;
  left: -3em;
}
#mind .bg_case:nth-child(1):before {
  content: 'Case 1';
}
#mind .bg_case:nth-child(2):before {
  content: 'Case 2';
}
#mind .bg_case:nth-child(3):before {
  content: 'Case 3';
}
#mind .bg_case:nth-child(4):before {
  content: 'Case 4';
}
#mind .bg_case:nth-child(even) {
  margin-right: 0;
}
#mind .bg_case p {
  font-size: 14px;
}
#mind .bg_case p:last-child {
  margin-bottom: 0;
}
#mind .bg_case:after {
  display: block;
  content: '';
  clear: both;
}
#mind .case_thumb {
  width: 200px;
  height: auto;
  float: left;
}
#mind .case_txt {
  width: calc(100% - 220px);
  float: right;
}
#mind .case_txt h4 {
  font-weight: bold;
  color: rgba(45,124,181,1);
  text-align: center;
  padding: 5px 15px;
  border: 2px solid rgba(45,124,181,0.35);
  border-radius: 5px;
}
#mind .case_txt table {
  width: 100%;
  font-size: 12px;
  background: rgba(45,124,181,0.085);
  border-collapse: collapse;
  margin-bottom: 15px;
  border-radius: 5px;
}
#mind .case_txt table td {
  line-height: 1em;
  padding: 7px 15px;
}
#mind .case_txt table td span {
  color: rgba(45,124,181,1);
  font-weight: bold;
  line-height: 1em;
}
.txt_caution p {font-size: 12px;}
.txt_wh {color: #ffffff !important;}
.case_experience::before, .case_amount::before {
  display: inline-block;
  content: '';
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  margin-right: 3px;
}
.case_experience::before {
  content: '\f559';
}
.case_amount::before {
  content: '\f4d3';
}

#faq dl {
  margin: 60px auto;
}
#faq dl dt {
  color: rgba(45,124,181,1);
}
#faq dl dt:after, #faq dl dd:after {
  display: block;
  content: '';
  clear: both;
}
#faq dl dt {
  margin-right: 2em;
}
#faq dl dd {
  margin: 1em 1em 3em 0;
}
#faq dl dd div p {
  font-size: 14px;
}
#faq dl dd div p:last-child {
  margin-bottom: 0;
}
#faq dl dt:before, #faq dl dd:before {
  display: block;
  background: rgba(45,124,181,0.85);
  content: 'Q';
  float: left;
  width: 1.7em;
  height: 1.7em;
  font-weight: normal;
  line-height: 1.7em;
  color: #ffffff;
  text-align: center;
}
#faq dl dd:before {
  background: #ffffff;
  content: 'A';
  color: rgba(45,124,181,0.85);
  border: 1px solid rgba(45,124,181,0.85);
}
#faq dl dt div, #faq dl dd div {
  float: right;
  width: calc(100% - 2.5em);
}

#service {
  position: relative;
}
.service_list {
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-content: space-between;
  list-style-type: none;
}
.service_list li {
  background: #ffffff;
  width: calc(94%/3);
  font-weight: 600;
  margin: 2% 1% 0 1% !important;
  padding: 20px;
  border: 3px solid;
  border-radius: 5px;
  box-sizing: border-box;
  position: relative;
}
.service_list li img.service_thumb {
  width: auto;
  height: 60px;
  position: absolute;
  right: 10px;
  bottom: 0;
}

#gallery h3 {
  display: block;
  font-size: 120% !important;
  font-weight: bold;
  line-height: 1.2em;
  margin-bottom: 1.7em !important;
  border-left: 10px solid #acacac !important;
  padding-left: 0 !important;
  position: relative;
}
#gallery h3::before {
  display: block;
  content: '';
  width: 5px;
  background: #333333;
  font-size: 100% !important;
  height: 1.2em;
  line-height: 1.2em;
  position: absolute;
  left: -10px;
  top: 0;
}
#gallery p {text-align: center;}
#gallery .item_list dl dd p {text-align: left;}

#gallery dl {
  background: #ffffff;
  margin-bottom: 3em;
  padding: 3em;
  border-top: 5px solid #2c2c2c;
}
#gallery dl dt ul, #gallery dl dd ul {margin-bottom: 0; padding-bottom: 0;}

.bg_madori_box {background: #ffffff; margin-bottom: 10em;}
.madori {
  width: 49%;
  display: inline-block;
  position: relative;
  background: #ffffff;
}
.madori ul {
  position: absolute;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  top: 0;
  left: 0;
  z-index: 2;
}
.madori ul li {
  position: absolute;
  animation-name:updown1;   /* アニメーション名の指定 */
    animation-delay:0s;   /* アニメーションの開始時間指定 */
    animation-duration: 3s;   /* アニメーション動作時間の指定 */
    animation-timing-function: ease-in-out;  /* アニメーションの動き指定（徐々に早く）*/
    animation-iteration-count: infinite;
}
@keyframes updown1 {
    0% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
  65% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(0);
  }
}
.madori ul li a {
  display: block;
  width: 65px;
  margin: 0 auto;
  text-align: center;
}
.madori ul li a::before {
  display: block;
  background: #ffffff;
  border: 1px solid #d91618;
  border-radius: 25px;
  color: #d91618;
  line-height: 1em;
  padding: 5px 10px;
  content: '\f00e  拡大';
  font-family: "FontAwesome";
  font-weight: 600;
  font-size: 80%;
  text-align: center;
  position: absolute;
  bottom: -2.4em;
  left: 0;
  right: 0;
  z-index: 2;
}
.madori ul li a::after {
  display: none;
  background: rgba(0,0,0,0.3);
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%; 
}
.madori ul li img {
  width: 60px;
  height: 60px;
  object-fit: cover;
  border-radius: 50%;
  border: 1px solid #cccccc;
}
#madori_area {
  margin-top: 4em;
  padding-top: 6em;
  background-image: url(../images/strong/bg_madori.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  position: relative;
  background-attachment: fixed;
  padding-bottom: 10em;
  position: relative;
}
#madori_area::before {
  display: block;
  content: '';
  background: rgba(2, 2, 2, 0.45);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
#madori_area h2, #madori_area h2 small {color: #ffffff !important;}
.floor_01 ul li:nth-child(1) {
  top: 20%;
  left: 10%;
  animation-delay: 1.0s;
}
.floor_01 ul li:nth-child(2) {
  top: 3%;
  left: 40%;
  animation-delay: 1.2s;
}
.floor_01 ul li:nth-child(3) {
  top: 45%;
  right: 10%;
  animation-delay: 1.4s;
}
.floor_01 ul li:nth-child(4) {
  top: 20%;
  right: 12%;
  animation-delay: 1.6s;
}
.floor_01 ul li:nth-child(5) {
  top: 1%;
  right: 32%;
  animation-delay: 1.8s;
}

.floor_02 ul li:nth-child(1) {
  top: 40%;
  left: 2%;
  animation-delay: 1.0s;
}
.floor_02 ul li:nth-child(2) {
  top: 44%;
  right: 1%;
  animation-delay: 1.2s;
}
.floor_02 ul li:nth-child(3) {
  top: 10%;
  left: 22%;
  animation-delay: 1.4s;
}
.floor_02 ul li:nth-child(4) {
  top: 32%;
  left: 42%;
  animation-delay: 1.6s;
}

.lum-previous-button, .lum-next-button {display: none;}
.lum-lightbox.lum-open {
  background: rgba(255,255,255,0.85);
}
.lum-lightbox-image-wrapper {
  padding-top: 70px;
}
.lum-lightbox-inner img {
  display: block;
  max-width: 80%;
  max-height: 80%;
  margin: 0 auto;
}
.lum-lightbox-caption {
  display: inline-block;
  font-weight: 600;
  margin-top: 10px !important;
  color: #333333 !important;
}

#price_list {
  width: 100%;
  background: #ffffff;
  border-collapse: collapse;
}
#price_list th, #price_list td {
  font-size: 16px;
  text-align: center;
  padding: 15px;
  border: 1px solid #cccccc;
  box-sizing: border-box;
}
#price_list th {
  background: #000000;
  color: #ffffff;
}
#price_list th small {
  display: block;
  font-size: 14px;
  font-weight: normal;
  margin-top: 10px;
}
#price_list td {
  line-height: 1.4em;
  vertical-align: baseline;
}
#price_list td div {
  display: table;
  width: 100%;
}
#price_list td img {
  display: table-cell;
  width: 90px;
  height: auto;
  margin: 0 auto;
  text-align: center;
  vertical-align: bottom;
}
#price_list td span {
  display: inline-block;
  background: #ffffff;
  line-height: 1.4em;
  margin-right: 10px;
  padding: 0 15px;
  border-radius: 30px;
  border: 1px solid #999999;
  vertical-align: middle;
}

#flow p {
  text-align: center;
}
#flow .flow_box::after, #flow .flow_box dl::after {
  display: block;
  content: '';
  clear: both;
}
#flow .flow_box {
  clear: both;
  margin-bottom: 2em;
  padding-bottom: 2em;
  border-bottom: 1px solid #cccccc;
}
.flow_box:first-child {
  padding-top: 3em;
}
#flow .flow_box .flow_period {
  background: #ffffff;
  width: 3em;
  text-align: center;
  margin: 0 auto;
  padding: 15px 0;
  position: relative;
}
#flow .flow_box .flow_period::after {
  display: block;
  content: '';
  border-top: 20px solid #ffffff;
  border-right: 20px solid transparent;
  border-bottom: 20px solid transparent;
  border-left: 20px solid transparent;
  position: absolute;
  bottom: -40px;
}
#flow .flow_box:last-child .flow_period, #flow .flow_box:last-child .flow_period::after {
  display: none;
}
#flow .flow_box:last-child {
  border: none;
  margin-bottom: 0;
}
#flow .flow_box .flow_period span {
  display: block;
  width: 1em;
  margin: 0 auto;
  text-align: center;
}
#flow .flow_box dl {
  float: left;
  margin-right: 30px;
}
#flow .flow_box dl:last-child {
  margin-right: 0;
}
#flow .flow_box dl dd {
  margin-top: 10px;
  font-size: 80%;
  line-height: 1.7em;
}

.strong_box {margin: 0; padding: 0;}
.strong_box li {
  position: relative;
  margin-bottom: 10em;
}
.strong_box li:last-child {
  margin-bottom: 0;
}
.strong_box li dl:last-child {
  margin-bottom: 0;
}
.strong_box li dl dd {
 font-size: 90%;
 line-height: 1.7em;
}
.strong_box li::after {
  display: block;
  content: '';
  clear: both;
}
.strong_box li span {
  display: block;
}
.strong_box li:nth-child(even) span {
  float: right;
}
.strong_box li:nth-child(odd) div {
  width: calc(50% + 6em);
  background: #ffffff;
  padding: 3em;
  position: relative;
  top: 4em;
  right: 0;
  position: absolute;
}
.strong_box li:nth-child(even) div {
  width: calc(50% + 6em);
  background: #ffffff;
  padding: 3em;
  position: relative;
  top: 4em;
  left: 0;
  position: absolute;
}
.strong_box li div strong {
  display: block;
  font-size: 120%;
  font-weight: 700;
  margin-bottom: 1.5em;
}
.strong_box li div p:last-child {
  margin-bottom: 0;
}
.strong_box li span ul {
  margin-top: 20px;
}
.strong_box li span ul li {
  display: inline-block;
  margin-right: 15px;
}
.strong_box li span ul li:last-child {
  margin-right: 0;
}
.strong_box li span ul li img {
  height: 120px;
  width: auto;
}
.strong_box li .yajirushi {
  position: absolute;
  z-index: 2;
}
.strong_box li:nth-child(odd) .yajirushi {
  top: 80%;
  right: 40%;
}

.mention_box {
  position: relative;
  margin-bottom: 3em;
}
.mention_box .bg_negative {
  position: relative;
  margin: 0 auto;
  text-align: center;
}
.mention_box p:last-child {
  margin-bottom: 0;
}
.mention_box .bg_negative img {
  width: auto;
  height: 80px;
}

.mention_box .check_list {margin: 2em auto 0 auto; text-align: center;}
.mention_box .check_list li {
  animation-name: updown-fukidashi;   /* アニメーション名の指定 */
  animation-delay:0s;   /* アニメーションの開始時間指定 */
  animation-duration: 3s;   /* アニメーション動作時間の指定 */
  animation-timing-function: ease-in-out;  /* アニメーションの動き指定（徐々に早く）*/
  animation-iteration-count: infinite;
  display: inline-block;
  position: relative;
}
@keyframes updown-fukidashi {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
  100% {
    transform: translateY(0);
  }
}
.mention_box .check_list li div {
  display: inline-block;
  background: #7e6e60;
  font-size: 16px;
  font-weight: 600;
  color: #ffffff;
  letter-spacing: 0;
  text-align: center;
  line-height: 1.4em;
  margin: 2% 0 6% 0 !important;
  padding: 20px 30px !important;
  border-radius: 7px;
  box-sizing: border-box;
}
.mention_box .check_list li span:before {
  display: inline-block;
  padding-right: 10px;
  font-family: "FontAwesome";
  content: "\f00c";
  font-weight: 600;
}
.mention_box .check_list li div:before {
  content: "";
  position: absolute;
  bottom: -23px;
  left: 50%;
  margin-left: -15px;
  border: 12px solid transparent;
  border-top: 12px solid #7e6e60;
  z-index: 2;
}
.mention_box .check_list li:nth-child(1) {
  animation-delay: 1.0s;
}
.mention_box .check_list li:nth-child(2) {
  animation-delay: 1.3s;
}
.mention_box .check_list li:nth-child(3) {
  animation-delay: 1.6s;
}
.mention_box .check_list li:nth-child(1) div {
  transform: rotate(-3deg) !important;
  bottom: 30px;
}
.mention_box .check_list li:nth-child(2) div {
  transform: rotate(3deg);
}
.mention_box .check_list li:nth-child(3) div {
  transform: rotate(-2deg);
  bottom: 40px;
}
.mention_box .check_list li:nth-child(even) {
  margin-left: 4% !important;
}
.mention_box .check_list li:nth-child(1):before {
  left: 50%;
}
.mention_box .check_list li:nth-child(2):before {
  left: 45%;
}
.mention_box .check_list li:nth-child(3):before {
  left: 63%;
}
.solution_txt {
  text-align: center;
  font-weight: 600;
  margin: 4em auto;
}
.solution_txt h3, .solution_txt h3 small {
  font-weight: 600 !important;
}
.solution_txt h3 small {
  color: inherit;
}

.solution_wrap {position: relative;}
.solution_wrap .col-sm-10 {
  z-index: 2;
}
#solution p {font-size: 24px; text-align: center;}
#solution .check_list li {
  display: inline-block;
  background: #ffffff;
  font-size: 16px;
  letter-spacing: 0;
  color: #000a29;
  text-align: center;
  line-height: 1.4em;
  margin: 2% 0 6% 0 !important;
  padding: 20px 30px !important;
  border: 3px solid rgba(0,10,41,0.65);
  border-radius: 7px;
  box-sizing: border-box;
  position: relative;
}
#solution .check_list {margin: 6em auto 0 auto; text-align: center;}
#solution .check_list li span:before {
  display: inline-block;
  color: #000a29;
  padding-right: 10px;
  font-family: "FontAwesome";
  content: "\f00c";
  font-weight: 900;
}
#solution .check_list li:before {
  content: "";
  position: absolute;
  bottom: -23px;
  left: 50%;
  margin-left: -15px;
  border: 12px solid transparent;
  border-top: 12px solid #ffffff;
  z-index: 2;
}
#solution .check_list li:nth-child(1) {
  transform: rotate(-3deg);
  bottom: 30px;
}
#solution .check_list li:nth-child(2) {
  transform: rotate(3deg);
}
#solution .check_list li:nth-child(3) {
  transform: rotate(-2deg);
  bottom: 40px;
}
#solution .check_list li:nth-child(4) {
  transform: rotate(2deg);
  left: 30px;
  bottom: 20px;
}
#solution .check_list li:nth-child(even) {
  margin-left: 4% !important;
}
#solution .check_list li:nth-child(1):before {
  left: 50%;
}
#solution .check_list li:nth-child(2):before {
  left: 45%;
}
#solution .check_list li:nth-child(3):before {
  left: 63%;
}
#solution .check_list li:nth-child(4):before {
  left: 37%;
}
#img_solution {
  position: absolute;
  right: 0;
  bottom: -50px;
  z-index: 1;
}

#access {
  position: relative;
}
#access table th small {color: #777777;}
#access table td small {display: inline-block; color: #757575; margin-top: 5px; letter-spacing: 0;}

/* Scroll to top */
.scroll-up {
  position: fixed;
  display: none;
  bottom: 7px;
  right: 7px;
  z-index: 999;
}

.scroll-up a {
  background: #fff;
  display: block;
  height: 28px;
  width: 28px;
  text-align: center;
  line-height: 28px;
  font-size: 14px;
  color: #000;
  opacity: 0.6;
  border-radius: 2px;
}

.scroll-up a:hover,
.scroll-up a:active {
  opacity: 1;
  color: #000;
}

.txt_wh, .txt_wh a, .txt_white {color: #fff !important;}
.txt_wh small {color: #fff !important; font-size: 14px;}

.txt_gray {color: #999999;}

.btn_top, .btn_other {margin: 0 auto; text-align: center;}
.btn_top, .btn_top a, .btn_other, .btn_other a {font-weight: bold;}
.btn_top span, .btn_other span {
	display: inline-block;
	font-size: 18px;
	margin-bottom: 5px;
	line-height: 1.9em;
}

/*--------------------------------------------------------------
	Buttons
--------------------------------------------------------------*/
.btn {
  border-radius: 0;
  letter-spacing: 2px;
  font-size: 16px;
  padding: 16px 37px;
}

.btn.active.focus,
.btn.active:focus,
.btn.focus,
.btn:active.focus,
.btn:active:focus,
.btn:focus {
  outline: 0;
}

.btn.btn-round {
  border-radius: 2px;
}

.btn.btn-circle {
  border-radius: 45px;
}

.btn.btn-w {
  background: rgba(255, 255, 255, 0.8);
  color: #0d1c1f;
}

.btn.btn-w:hover,
.btn.btn-w:focus {
  background: white;
  color: #0d1c1f;
}

.btn.btn-g {
  background: #e5e5e5;
  color: #0d1c1f;
}

.btn.btn-g:hover,
.btn.btn-g:focus {
  background: #d8d8d8;
  color: #0d1c1f;
}

.btn-warning {
  font-size: 150%;
  background: #eea236;
  border-color: #eea236;
}

.btn.btn-border-w {
  background: #efefef;
  border: 1px solid rgba(255, 255, 255, 0.75);
  color: #0d1c1f;
  font-size: 150%;
}
.btn.btn-border-o {
  width: 70%;
  background: #fff600;
  border-bottom: 4px solid #a9a300;
  color: #d83d00;
  font-size: 24px;
  line-height: 0;
  padding-bottom: 0 !important;
}

.btn.btn-border-w:hover,
.btn.btn-border-w:focus {
  background: #fff;
  border-color: transparent;
  color: #0d1c1f;
}
.btn.btn-border-o:hover,
.btn.btn-border-o:focus {
  background: #23ac38 !important;
  border-bottom: 4px solid #23ac38 !important;
  color: #fff !important;
  box-shadow:0px 5px 3px 1px #0d1c1f;
  transition: .9s;
}

.btn.btn-d {
  background: rgba(17, 17, 17, 0.8);
  color: #fff;
}

.btn.btn-d:hover,
.btn.btn-d:focus {
  background: #0d1c1f;
}

.btn.btn-b {
  background: #0d1c1f;
  color: #fff;
}

.btn.btn-b:hover,
.btn.btn-b:focus {
  background: rgba(17, 17, 17, 0.8);
}

.btn-border-d {
  background: transparent;
  border: 1px solid #0d1c1f;
  color: #0d1c1f;
}

.btn.btn-border-d:hover,
.btn.btn-border-d:focus {
  background: #0d1c1f;
  color: #fff;
}

.btn.btn-font-w {
  background: rgba(255, 255, 255, 0.8);
  color: #fff;
}

.btn.btn-font-w:hover {
  background: #fff;
  color: #0d1c1f;
}

/* Buttons size */
.btn.btn-lg {
  padding: 12px 45px;
  font-size: 13px;
}

.btn.btn-sm {
  padding: 6px 25px;
  font-size: 10px;
  letter-spacing: 1px;
}

.btn.btn-xs {
  padding: 4px 19px;
  font-size: 10px;
  letter-spacing: 0;
}

.btn-list .btn {
  margin: 5px 0;
}

.image-button {
  margin: 0px 5px;
}

/*--------------------------------------------------------------
	Typography
--------------------------------------------------------------*/
a {
  color: #0d1c1f;
}

a:hover, a:focus {
  text-decoration: none;
  color: #aaa;
  outline: 0;
}

.bg-price {
  background: #fff600;
}

.bg-dark a {
  color: #aaa;
}

.bg-dark a:hover, .bg-dark a:focus {
  color: #fff;
}

h1, h2, h3, h4, h5, h6 {
  line-height: 1.4;
  font-weight: 400;
}

p, ol, ul, blockquote {
  margin: 0 0 20px;
}

blockquote {
  border: 0;
  font-style: italic;
  font-size: 15px;
  padding: 0;
}

.font-alt {
  letter-spacing: 2px;
}

.font-serif {
  font-style: italic;
}

.large-text {
  font-size: 24px !important;
}

h1, h2, h3, h4, h5, h6, .navbar-custom .nav li > a, .fl_left, .fl_right {
  transform: rotate(.03deg);
}

.box-shadow {box-shadow: 0 0 4px rgba(0,0,0,0.3) inset;}
.highlight, .service_list li strong {
 display: inline !important;
 background: linear-gradient(transparent 60%, rgba(213, 220, 81, 0.5) 60%);
 font-weight: bold;
 line-height: 1.7em;
}

.txt_highlight {
 color: #f6ee41;
 font-size: 140%;
 font-weight: bold;
}

.txt_highlight {
  position: relative;
  line-height: 1em;
  padding: 0.15em 0.45em;
  margin: 0 0.5em;
}

.txt_highlight:before, .txt_highlight:after{ 
  content:'';
  width: 10px;
  height: 15px;
  position: absolute;
}

.txt_highlight:before{
  border-left: solid 1px #f6ee41;
  border-top: solid 1px #f6ee41;
  top:0;
  left: 0;
}

.txt_highlight:after{
  border-right: solid 1px #f6ee41;
  border-bottom: solid 1px #f6ee41;
  bottom:0;
  right: 0;
}

.company_box {margin: 3em 0 5em 0;}
.company_box h3 {margin-bottom: 2em;}
.company_box table {width: 100%; margin: 0;}
.company_box table tr {border-bottom: 1px dotted #dddddd; margin-bottom: 10px;}
.company_box table th {width: 20%;}
.company_box table th, .company_box table td {font-weight: normal; padding: 15px 0;}

.gmap iframe,
.gmap object,
.gmap embed {
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  filter: grayscale(100%);
  -webkit-transition: all 0.7s ease;
  -moz-transition: all 0.7s ease;
  -o-transition: all 0.7s ease;
  transition: all  0.7s ease;
}
.gmap iframe:hover,
.gmap object:hover,
.gmap embed:hover {
  -webkit-filter: grayscale(0%);
  -moz-filter: grayscale(0%);
  -ms-filter: grayscale(0%);
  -o-filter: grayscale(0%);
  filter: grayscale(0%);
}
.gmap a {
  display: block;
  font-size: 12px;
  color: #d91618;
  margin-top: 10px;
  text-decoration: underline;
}

#access {
  margin-top: 4em;
  padding-top: 6em;
  background-image: url(../images/bg_company.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  padding-bottom: 10em;
  position: relative;
}
#access h2 {
  color: #ffffff;
  border-color: #ffffff;
}
#access::before {
  display: block;
  content: '';
  background: rgba(2, 2, 2, 0.45);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
#access .bg_bk {
  background: #000000;
  color: #ffffff;
  font-weight: 600;
  padding: 3em 4em 3em 3em;
  position: relative;
}
#access .bg_wh {
  background: #ffffff;
  padding: 2em 3em;
  top: 3em;
  right: 3em;
  position: relative;
}
#access .bg_wh table {
  position: relative;
}
#access .bg_wh table a {
  color: #d91618;
  text-decoration: underline;
}
#access .bg_bk p:last-child {
  margin-bottom: 0;
}
.bg_wh table tr:last-child {
  border: none;
}
#access .bg_wh table tr:last-child th, #access .bg_wh table tr:last-child td {
  margin-bottom: 0;
  padding-bottom: 0;
}
#access .bg_wh table tr td ul {font-size: 14px;}
#access .bg_wh table tr:last-child td ul, #access .bg_wh table tr:last-child td ul li:last-child {margin: 0;}
#access .bg_bk::after {
  display: block;
  content: '';
  width: 100%;
  height: 100%;
  background: url(../images/img_company.png) no-repeat;
  background-size: 50%;
  background-position: center;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0.25;
}
#access .bg_wh::after {
  display: block;
  content: '';
  width: 100%;
  height: 100%;
  background: #cccccc;
  mix-blend-mode: multiply;
  position: absolute;
  top: 3em;
  left: 3em;
  z-index: -1;
}

#form-area {position: relative;}

/*--------------------------------------------------------------
	Footer
--------------------------------------------------------------*/
#contact h4 {font-weight: 600;}
.caution_box {
  text-align: center;
  color: #444444;
}
#contact .txt_send p {
  margin-bottom: 1em;
}
#contact p {
 text-align: center;
 font-weight: 600;
}
#thanks #contact p {
  font-weight: normal;
}
.caution_box dl dt {
  font-size: 80%;
  margin-bottom: 1.3em;
}
.hissu {
  display: inline-block;
  background: #333333;
  color: #ffffff !important;
  font-weight: 600;
  line-height: 1em;
  padding: 5px 10px 3px 10px !important;
  margin-left: 1em;
}
.caution_box dl dd ul li {
  font-size: 60%;
  list-style-type: none;
  line-height: 1.6em;
}

.footer {
  padding: 0;
  position: relative;
}

.footer h3 {margin: 50px auto;}
.policy_box h3 {margin-top: 0;}
.footer .copyright {
  background: #000000;
  font-size: 11px;
  padding-top: 50px;
  margin: 0;
  text-align: center;
}
.footer .copyright div {
  color: #ffffff;
  text-align: left;
}
.footer .copyright div span {
  display: block;
}
.footer .copyright div span.txt_footer a {
  display: block;
  color: #ffffff;
  margin-top: 5px;
}
.footer .copyright address {
  clear: both;
  text-align: center;
  margin-top: 50px;
  padding-top: 10px;
  border-top: 1px dotted #999999;
}
.footer .copyright::after {
  display: block;
  content: '';
  clear: both;
}
.footer .footer_logo {
  display: block;
  clear: both;
  margin: 0;
}
.footer .footer_logo img {
  width: auto;
  height: 30px;
}
.footer .footer_link ul {
  float: left;
  padding: 7px 10px;
  font-size: 12px;
  line-height: 1.8em;
  list-style-type: none;
  border-left: 1px dotted #cccccc;
}

.footer .footer-social-links {
  text-align: right;
}

.footer .footer-social-links a {
  display: inline-block;
  padding: 0 6px;
}

#form .footer {
  display: table;
  width: 100%;
  min-height: 100vh;
  position: relative;
}
#form #contact {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  display: table-cell;
  vertical-align: middle;
  padding-bottom: 146px;
}
#form .footer .copyright {
  position: absolute;
  width: 100%;
  bottom: 0;
  left: 0;
  margin: 0;
}

hr {display: block; float: none; clear: both; border: none;}

.fl_left {float: left; width: 48%;}
.fl_right {float: right; width: 48%;}
.txt_140,p#txt_kakunin {font-size: 140%; font-weight: 900; line-height: 1.8em;}

/*--------------------------------------------------------------
	Responsive Styles - Media Queries
--------------------------------------------------------------*/
.navbar-custom .dropdown-menu {
    position: absolute;
    display: block;
    visibility: hidden;
    opacity: 0;
}
.navbar-custom .open > .dropdown-menu {
    visibility: visible;
    opacity: 1;
}
.navbar-custom .dropdown-menu .dropdown-toggle:after {
    position: absolute;
    display: block;
    right: 9px;
    top: 50%;
    margin-top: -6px;
    font: normal normal normal 14px/1 FontAwesome;
    font-size: 9px;
    content: "\f105";
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.navbar-fixed-top {
  background: #ffffff;
  width: 100%;
  position: fixed;
  top: 0;
  box-shadow: 0 2px 2px 1px rgb(0 0 0 / 20%);
}
.navbar-collapse.collapse {position: relative;}
.navbar-fixed-top .navbar-collapse.collapse::before {
  display: block;
  background: #2c2c2c;
  content: '';
  width: 100%;
  height: 4px;
  position: absolute;
  bottom: 0;
  left: 0;
}
.navbar-fixed-top #head_logo a {
  display: inline-block;
  height: auto !important;
  vertical-align: middle;
}
.navbar-fixed-top .navbar-brand img {
  height: 30px;
  width: auto;
}
.navbar-transparent {
  border: none !important;
}
.navbar-transparent .navbar-collapse.collapse::before {
  display: none;
}
  .navbar-right .dropdown-menu {
    right: auto;
    left: 0;
  }
  /* Comments */
  .comment .comment {
    margin-left: 75px;
  }
  
  .col-sm-3 {width: 33%;}
  #news .col-sm-3 {width: calc(92% / 3); padding: 0;}
  #news .col-sm-3:nth-child(2) {margin: 0 4%;}
  .col-sm-4 {width: 25%;}
  
hr {padding: 30px 0; border-bottom: 4px double #dddddd;}

.cv_area {margin: 60px auto 30px auto;}
.cv_area small {display: block; color: #23618d; font-weight: bold; margin: 0 auto; text-align: center; margin-bottom: 10px;}
.cv_area a {
	display: block;
	background: rgba(45,124,181,1);
	width: 35%;
	vertical-align: middle;
	color: #ffffff;
	text-decoration: none;
	font-weight: bold;
	line-height: 3.5em;
    text-align: center;
	margin: 0 auto;
	border-bottom: 3px solid #23618d;
    border-radius: 30px;
    box-sizing: content-box;
}
@media (max-width: 1200px) {
.madori ul li a::before {
  font-size: 80%;
}
.service_list li {padding-right: 70px;}
.service_list li br {display: none;}
#ifa ul li div {min-height: 390px;}
}
@media (max-width: 991px) {
.only_tab {display: block !important;}
  .mt-sm-0 {
    margin-top: 0 !important;
  }
  .mt-sm-10 {
    margin-top: 10px !important;
  }
  .mt-sm-20 {
    margin-top: 20px !important;
  }
  .mt-sm-30 {
    margin-top: 30px !important;
  }
  .mt-sm-40 {
    margin-top: 40px !important;
  }
  .mt-sm-50 {
    margin-top: 50px !important;
  }
  .mt-sm-60 {
    margin-top: 60px !important;
  }
  .mt-sm-70 {
    margin-top: 70px !important;
  }
  .mt-sm-80 {
    margin-top: 80px !important;
  }
  .mb-sm-0 {
    margin-bottom: 0 !important;
  }
  .mb-sm-10 {
    margin-bottom: 10px !important;
  }
  .mb-sm-20 {
    margin-bottom: 20px !important;
  }
  .mb-sm-30 {
    margin-bottom: 30px !important;
  }
  .mb-sm-40 {
    margin-bottom: 40px !important;
  }
  .mb-sm-50 {
    margin-bottom: 50px !important;
  }
  .mb-sm-60 {
    margin-bottom: 60px !important;
  }
  .mb-sm-70 {
    margin-bottom: 70px !important;
  }
  .mb-sm-80 {
    margin-bottom: 80px !important;
  }
    /* Half-image */
  .side-image {
    position: relative;
    height: 300px;
  }
  /* Navbar */
  .navbar-custom {
    letter-spacing: 0;
}
  .navbar-transparent .nav li > a {padding-left: 7px;}
  .only_pad {display: block !important;}
   .col-md-6-right, .col-md-offset-6-right {width: 100%; float: none; margin-left: 0;}
   #news .col-sm-6 {width: 100% !important;}
   #strong .strong_box li {margin-bottom: 14em;}
   .service_list li {font-size: 15px; min-height: 120px; padding: 15px;}
   .service_list li {width: calc(96%/2); padding-right: 15px;}
   .service_list li span {display: block;}
   .service_list li:nth-child(even) {margin-right: 0 !important;}
}

/* オーバーレイボタン */
@media (min-width:768px) {
#olayBtn {
	display: none;
}
}

@media (max-width: 767px) {
  .navbar-fixed-top .navbar-collapse {max-height: inherit !important;}
  .navbar-transparent {border: none !important;}
  .nav li > a {font-weight: 600 !important; font-size: 13px !important;}
  .navbar-transparent .nav li > a {padding-left: 20px;}
  .navbar-collapse.in {background: rgba(255,255,255,0.9); border-top: 1px solid #cccccc; position: relative; overflow: hidden;}
  .navbar-custom .navbar-toggle .icon-bar {width: auto; background: #2c2c2c;}
  .navbar-custom .navbar-toggle .menu_txt {display: block; font-family: 'Josefin Sans', sans-serif; margin-top: 3px;}
  .navbar-toggle {color: #2c2c2c !important; z-index: 999999;}
  .navbar-fixed-top .container::before {
  display: block;
    background: #2c2c2c;
    content: '';
    width: calc(100% - 30px);
    height: 4px;
    position: absolute;
    bottom: 0;
    left: 15px;
}
  .navbar-transparent .container::before {display: none;}
  .home-section::after {border: 4px solid #000000; border-top: 54px; solid #000000;}
  #mainImg {width: 100%; height: 95vh;}
  #mainImg_txt {width: 90%; margin: 0 auto; display: table;}
#mainImg_txt h2 {padding-top: 100px;}
  #head_logo {line-height: 42px; padding-bottom: 10px;}
  #head_logo a {height: auto !important;}
  #head_logo a span {display: block !important; font-size: 10px; line-height: 1.4em; margin: 0; padding-top: 3px;}
  #head_logo a img {position: relative; height: 30px; width: auto; box-shadow: none; padding: 0 15px;}
  .check_list {width: 100%;}
  .h2, h2 {font-size: 30px;}
  .sub-page .main {padding-top: 50px;}
  .contents {margin-bottom: -230px;}
  .contents:before {background-size: 50%;}
  .contents img {width: 80%;}
  #faq dl dt, #faq dl dd {margin-right: 0;}
  .company_box {margin: 0;}
  .company_box:fist-child {margin-top: 3em;}
  .company_box table {width: 100%; margin: 0 auto;}
  .company_box table th, .company_box table td {letter-spacing: 0;}
  #mainImg_txt .main_txt {text-align: left; margin-bottom: 1.7em;}
  #mainImg_txt .main_txt p br {display: none;}
  #mainImg_txt .btn.btn-border-o {font-size: 240%;}
  .mainImg_tel_txt span  {font-size: 130% !important;}
  .mainImg_tel_txt .btn {font-size: 280% !important;}
  #header_news {width: 90%; left: 5%; right: 5%; padding: 15px;}
  #header_news .container {padding: 0; margin: 0;}
  #header_news .news_date {margin-right: 7px; padding-right: 7px; width: auto;}
  #header_news .news_date span {display: none;}
  #header_news_title {display: none; top: 1.5em; font-weight: 600;}
  #header_news ul {width: 100%; margin: 0; padding: 0; border: none;}
  #header_news ul li {margin-bottom: 10px;}
  #header_news ul li:last-child {margin-bottom: 0;}
  #header_news ul li p {width: calc(100% - 48px); font-size: 11px;}
  #header_news ul li p strong {display: block; font-size: 12px;}
  #header_news .news_date, #header_news p {vertical-align: top; line-height: 1.7em;}
  #news ul li span.news_thumb {width: 30%; float: left;}
  #news ul li div {width: 65%; float: right;}
  .main section h2 small {font-size: 14px;}
  #news ul li img {width: 100%; height: auto;}
  #news ul li p {font-size: 13px !important;}
  #news ul li p strong {font-size: 14px !important;}
  #news .col-sm-3 {padding: 0; clear: both; margin: 0 auto !important;}
  #news .col-sm-3:after {display: block; content: ''; clear: both; margin-bottom: 15px;}
  #solution p {font-size: 20px;}
  #solution .check_list li {top: 0; bottom: 0 !important; left: 0 !important; right: 0 !important; margin-left: 0 !important; margin-right: 0 !important;}
  #img_solution {position: relative;}
  #solution .check_list {margin-top: 3em; margin-bottom: -3em;}
  #img_solution img {width: 200px; height: auto; display: block; margin: 0 auto;}
  #mind {background-size: contain; background-position: left -50%;}
  #negative {background-size: contain; background-position: left top;}
  .main section br {display: none;}
  #gallery dl {padding-bottom: 1.5em;}
  .mention_box .bg_negative img {display: block; text-align: center; margin: 0 auto;}
  
  .mention_box .check_list li div {font-size: 14px; padding: 20px;}
  
  .solution_txt h3 {font-size: 24px;}
  .solution_txt h3 br {display: block !important;}
  .bg_madori_box {margin-bottom: 5em;}
  .madori {display: block; width: 100%; padding-bottom: 3.7em;}
  .madori ul {position: static; margin: 0 auto; text-align: center;}
  .madori ul li {position: static; display: inline-block; width: calc(90% / 5); text-align: center;}
  .madori ul li a {display: block; position: relative;}
  .madori ul li a::before {background: none; width: 80%; font-weight: 600; margin: 0 auto; text-align: center; border: none; padding: 0; bottom: -1.7em;}
  .madori ul li img {width: 60px; height: 60px;}
  
  .cv_btn {margin: 2em 0;}
  
  .service_list li {width: 100% !important; margin-right: 0 !important; min-height: auto;}
  .service_list li span {display: block;}
  #strong .strong_box {margin-bottom: -5em;}
  #strong .strong_box li {margin-bottom: 0;}
  .strong_box li span {float: none !important;}
  .strong_box li div {width: 90% !important; top: -5em !important; left: 5% !important; right: 5% !important; padding: 2em !important; position: relative !important;}

  .menu_txt {text-align: center; font-size: 85%;}
  .mt-xs-0 {
    margin-top: 0 !important;
  }
  .mt-xs-10 {
    margin-top: 10px !important;
  }
  .mt-xs-20 {
    margin-top: 20px !important;
  }
  .mt-xs-30 {
    margin-top: 30px !important;
  }
  .mt-xs-40 {
    margin-top: 40px !important;
  }
  .mt-xs-50 {
    margin-top: 50px !important;
  }
  .mt-xs-60 {
    margin-top: 60px !important;
  }
  .mt-xs-70 {
    margin-top: 70px !important;
  }
  .mt-xs-80 {
    margin-top: 80px !important;
  }
  .mb-xs-0 {
    margin-bottom: 0 !important;
  }
  .mb-xs-10 {
    margin-bottom: 10px !important;
  }
  .mb-xs-20 {
    margin-bottom: 20px !important;
  }
  .mb-xs-30 {
    margin-bottom: 30px !important;
  }
  .mb-xs-40 {
    margin-bottom: 40px !important;
  }
  .mb-xs-50 {
    margin-bottom: 50px !important;
  }
  .mb-xs-60 {
    margin-bottom: 60px !important;
  }
  .mb-xs-70 {
    margin-bottom: 70px !important;
  }
  .mb-xs-80 {
    margin-bottom: 80px !important;
  }
  .col-md-offset-6-right, .col-md-6-right {float: right; width: 100%; margin-right: 0; margin: 0;}
  .side-image-text {padding: 30px 15px;}

  /* Navbar */
  .only_pc {display: none !important;}
  .only_sp {display: block !important; line-height: 0;}
  .kv {margin-top: 0; background-position: 60%;}
  #mainImg_txt .col-sm-6 {width: 100%;}
  #mainImg_txt h2 {font-size: 36px;}
  .sub_catch .txt_small {letter-spacing: 1px;}
  .sub_catch .txt_small br {display: none;}
  .font-alt span, #reason h4 span {display: block;}
  .navbar-custom .navbar-nav {
    letter-spacing: 0;
    margin-top: 0;
    margin-bottom: 0;
    background: rgba(255, 255, 255, 0.9);
  }
  .navbar-custom .nav li > a {color: #0d1c1f;}
  .navbar-custom li > a:hover {
    background: rgba(255, 255, 255, 0.1) !important;
  }
  .navbar-custom .navbar-nav .open .dropdown-menu .dropdown-header,
  .navbar-custom .navbar-nav .open .dropdown-menu > li > a {
    padding: 10px 25px;
  }
  .navbar-custom .navbar-nav .open .dropdown-menu .dropdown-menu .dropdown-header,
  .navbar-custom .navbar-nav .open .dropdown-menu .dropdown-menu > li > a {
    padding: 10px 35px;
  }
  .navbar-custom li a,
  .navbar-custom .dropdown-search {
    border-bottom: 1px solid rgba(73, 71, 71, 0.15) !important;
  }
  .navbar-custom .dropdown-toggle:after,
  .navbar-custom .dropdown-menu .dropdown-toggle:after {
    right: 7%;
    content: "\f105";
  }
  .navbar-custom .nav > .open > .dropdown-toggle:after,
  .navbar-custom .dropdown-menu .dropdown.open .dropdown-toggle:after {
    right: 7px;
    content: "\f106";
  }
  .navbar-toggle .icon-bar {text-align: center; margin: 0 auto;}
  .parallax-bg {background-attachment: inherit !important;}
  .post.mb-0 {
    margin-bottom: 40px !important;
  }
  .copyright {width: 100%; margin: 0 auto;}
  .footer-social-links {
    text-align: center;
    margin: 10px 0;
  }
  .align-center-sm {
    text-align: center;
  }
  .align-left-sm {
    text-align: left;
  }
  
.bg-light-60:before {
  position: absolute;
  background: rgba(255, 255, 255, 0.8);
}
#head_logo a {font-size: 12px; display: block; height: auto; margin: 0; padding: 0;}
.footer .footer_link {float: none; clear: both; text-align: center; margin: 60px auto 0 auto; padding: 0;}
.footer .footer_logo {margin-top: 2em;}
#custom-collapse .btn.btn-border-o {width: 90%; margin: 15px auto; color: #d83d00; font-weight: bold; font-size: 120% !important; border-bottom: 4px solid #a9a300 !important; padding: 15px 0 !important;}
#custom-collapse .btn.btn-border-o:hover {border-bottom: 4px solid #35717d !important;}
.col-sm-3, .col-sm-4 {width: 100% !important;}
#news dl dd table th {white-space: nowrap;}
.btn_link a {width: 80%; margin: 0 auto;}
#access .bg_bk::after {background-size: 100%;}
#access .bg_wh {right: 0; margin-bottom: 1em;}
#access .bg_wh table tr td ul li {line-height: 1.3em; margin-bottom: 1em;}
#appeal ul li {margin-bottom: 4em;}
.company_box table tr:last-child {border: none;}
.cv_area a {line-height: 4em;}
.footer .copyright {padding: 30px 0 60px 0;}
.footer .copyright address {font-size: 10px; margin-top: 30px;}
.footer .copyright .col-sm-2 {width: 128px; float: left; padding: 0;}
.footer .copyright .col-sm-10 {width: calc(100% - 145px); float: right; padding: 0;}
.footer .copyright .col-sm-10::after {display: block; content: ''; clear: both; margin-bottom: 15px;}
.footer .copyright div span.txt_footer {margin-top: 15px;}

#olayBtn {
	display: block !important;
	position: fixed;
	width: 100%;
	background: transparent;
	padding: 0;
	box-sizing: border-box;
	z-index: 999999;
}
#olayBtn ul {
	overflow: hidden;
	margin: 0px !important;
	padding: 0px !important;
	visibility: visible !important;
}
#olayBtn ul li {
	display: table;
	width: calc(100% / 2);
	margin: 0;
	padding: 0;
	float: left;
}
#olayBtn ul li:last-of-type {
	margin: 0;
}
#olayBtn ul li:nth-child(1) {
	background : #06c755;
}
#olayBtn ul li a {
	display: table-cell;
	color: #fff;
	vertical-align: middle;
	text-align: center;
	height: auto;
    padding: 10px 0;
	text-decoration: none;
	font-size: 1.2rem;
	font-weight: bold;
	border: none;
}
#olayBtn ul li:nth-child(2) {
	background: #d91618;
	box-shadow: 1px 0 0 0 #dddddd inset;
	color: #000000 !important;
}
#olayBtn ul li a:hover, #olayBtn ul li a:active {
	opacity: 0.8;
}
#olayBtn ul li a i.fa,#olayBtn ul li a i.fab,#olayBtn ul li a i.fas {
	display: inline-block;
	color: #fff;
	margin: 0;
	background-repeat: no-repeat;
	background-size: 100% auto;
}
#olayBtn ul li:nth-child(2) a, #olayBtn ul li:nth-child(2) a i.fa, #olayBtn ul li:nth-child(2) a i.fab, #olayBtn ul li:nth-child(2) a i.fas {
	color: #ffffff !important;
}
.main .container p {text-align: left !important;}
#price_list th, #price_list td {font-size: 14px;}
#price_list th small {font-size: 10px;}
#price_list td span {display: block; width: 100%; margin: 15px auto 5px auto; padding: 0;}
}

@media only screen and (max-width: 480px) {
.fl_left, .fl_right {float: none; width: 100%;}
.navbar-brand {padding-right: 0;}
.navbar-toggle {padding: 0 10px;}
.navbar-custom .nav li > a {font-size: 14px;}
.nav>li>a {font-size: 14px;}
.navbar-custom .navbar-brand {font-size: 18px;}
.navbar-brand img {height: 20px; position: relative; top: 4px;}
#head_logo a {position: relative; top: 1px;}
#head_logo a {font-size: 13px;}
.bg_white {background: #fff; padding: 15px 0;}
.footer_link {width: 100%;}
#main {margin: 0 !important; padding: 0 !important; overflow: !important;}
section h2 {font-size: 30px;}
section h3 {font-size: 24px;}
.check_list {letter-spacing: 3px;}
#mainImg {height: 95vh;}
#mainImg_txt {width: 90%; margin: 0 auto; display: table;}
#mainImg_txt h2 {font-size: 36px; line-height: 1.5em;}
#mainImg_txt .sub_catch {font-size: 14px; line-height: 1.7em;}
#mainImg_txt .sub_catch .sp_block {display: block; margin-bottom: 1em;}
#header_news {bottom: 10vh;}
.strong_box li div {top: -4.5em !important;}
#strong .strong_box li {margin-bottom: 0 !important;}
.strong_box li dl:last-child {margin-bottom: 2em;}
#access .bg_wh {padding: 2em;}
#gallery h3::before {height: 1.15em; line-height: 1.15em;}
.company_box table {font-size: 12px;}
.company_box table th {width: 1em;}
.company_box table td {padding-left: 30px;}
.company_box table td iframe {height: 200px;}
#olayBtn ul li a {width: 90%; letter-spacing: 0;}
.cv_area a {width: 100%; letter-spacing: 0;}
#contact h2 {font-size: 24px;}
.lum-lightbox-image-wrapper {padding-top: 0;}
.lum-lightbox-inner img {max-width: 80vw !important; max-height: 65vh !important;}
.lum-lightbox-inner .lum-lightbox-caption {position: relative;}
.cv_btn dl dd a {width: 100% !important;}
#madori_area, #access {background-size: contain; background-position: top center; background-attachment: inherit;}
.cv_btn dl dt {font-size: 12px;}
}

@media only screen and (max-width: 375px) {
.navbar-brand img {height: 24px;}
#head_logo a {font-size: 10px;}
#mainImg_txt h2 {font-size: 32px;}
#mainImg_txt .sub_catch p {font-size: 14px;}
.txt_big {font-size: 140%;}
#custom-collapse .btn.btn-border-o, .btn.btn-border-o {font-size: 15px;}
#head_logo a {top: 1px;}
}

@media only screen and (max-width: 375px) and (min-height: 667px) {
#mainImg_txt h2 {font-size: 32px;}
#mainImg_txt .sub_catch p {font-size: 14px;}
}
@media only screen and (max-width: 375px) and (max-height: 666px) {
#btn_scroll {display: none;}
}

@media only screen and (max-width: 320px) {
.navbar-brand img {height: 15px;}
#head_logo a {font-size: 10px;}
#mainImg_txt h2 {font-size: 25px; padding-top: 75px;}
#mainImg_txt .sub_catch p {font-size: 14px; margin-bottom: 15px;}
#header_news ul li p span {display: none;}

.h2, h2 {font-size: 24px;}
.h3, h3 {font-size: 18px;}
.h4, h4 {font-size: 14px;}

#custom-collapse .btn.btn-border-o, .btn.btn-border-o {font-size: 15px;}
.service_list li {margin-bottom: 2%;}
.service_list li:last-child {margin-bottom: 0;}
.cv_btn dl dd a {padding-left: 0; padding-right: 0; letter-spacing: 1px;}
.footer .copyright .col-sm-2 {width: 64px;}
.footer .footer_logo img {height: auto;}
.footer .copyright .col-sm-10 {width: calc(100% - 80px);}
}

@media(min-width: 768px){
  a[href^="tel:"]{
    pointer-events: none;
  }
  .navbar-toggle {
    display: none !important;
}
}