/*--------------------------------------------------------------
	Common
--------------------------------------------------------------*/
@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Josefin+Sans&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: #231815;
  -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: 16px; line-height: 1.7em;}
b, strong, .bold{
}
.btn-block {font-weight: bold;}

.main section {
  opacity: 0;
  -webkit-transition: all .5s ease;
  transition: all .5s ease;
}
.main section.show, #contact {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}
.main section h3 {margin-top: 70px !important;}
section dl, section ul {margin: 0; padding: 0;}

/*--------------------------------------------------------------
	Navbar
--------------------------------------------------------------*/
#head_logo a {font-size: 11px; white-space: nowrap; line-height: 1.3em; color: #231815; 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-top: -4px; 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: 11px;
  -webkit-transition: background, padding 0.4s ease-in-out 0s;
  transition: background, padding 0.4s ease-in-out 0s;
  position: absolute;
}

.navbar a {
  -webkit-transition: color 0.125s ease-in-out 0s;
  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;
  -webkit-box-shadow: none;
          box-shadow: none;
}

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

.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;
}

.navbar-custom .nav li:last-child a {
    display: inline;
    background: #ffe736;
	color: #231815;
    border-radius: 30px;
    padding: 10px 20px;
	margin-left: 25px;
}
.navbar-custom .nav li:last-child a.dropdown-toggle:after {display: none;}

.dropdown-menu {
  min-width: 180px;
  font-size: 11px;
}

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

.h2, h2 {
    font-size: 30px;
}
.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: #231815 !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%;
 -webkit-transform: translateX(-50%);
 transform: translateX(-50%);
 background-color: #999;
 border-radius: 1px;
}
.main section h3.under_line {
    font-size: 18px;
    line-height: 1em;
    padding-bottom: 0.8em;
    border-bottom: solid 2px #ffffff;
    position: relative;
    margin: 30px 0 !important;
}
.under_line:after {
    position: absolute;
    content: " ";
    display: block;
    border-bottom: solid 2px #231815;
    bottom: -2px;
    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:before {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 200vw 52vw 0 0;
  border-color: rgba(255,255,255,1) transparent transparent transparent;
  z-index: 2;
}
.home-section:after {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 180vw 56vw 0 0;
  border-color: rgba(45,124,181,0.85) transparent transparent transparent;
  mix-blend-mode: screen;
  z-index: 1;
}
.contents_inner {
  -webkit-box-sizing: boder-box;
          box-sizing: boder-box;
  margin: 0 auto;
  padding: 30px 0 80px 0;
  color: #fff;
  text-align: center;
}

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


/* 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: 36px;
  font-family: 'Josefin Sans', sans-serif;
  letter-spacing: 1px;
  vertical-align: middle;
  position: relative;
  z-index: 2;
}
#mainImg_txt h2 {
  font-size: 42px;
  font-weight: bold;
  line-height: 1.4em;
}
#mainImg_txt h2 strong {
  color: rgba(45,124,181,1);
}
#mainImg_txt h2 small {
  font-size: 34px;
  font-weight: 600;
  color: inherit;
  line-height: 1.2em;
}
#mainImg_txt .check_list {width: 34%; list-style-type: none; margin: 0 !important; padding: 0 !important;}
#mainImg_txt .check_list li {background: #ffffff; font-weight: bold; text-align: center; line-height: 1.7em; margin: 2% 0 !important; padding: 15px !important; border: 1px solid #fdd000; border-radius: 5px;}
#mainImg_txt .check_list li:before {display: inline-block; color: #fdd000; padding-right: 10px; font-family: "FontAwesome"; content: "\f00c"; font-weight: 900;}
#mainImg_txt .sub_copy {font-size: 20px; margin: 1em 0; line-height: 1.7em;}

#img_mainImg {
  position: absolute;
  bottom: 0;
  right: 0;
}

@-webkit-keyframes display {
  0% {
    -webkit-transform: translateX(200px);
            transform: translateX(200px);
    opacity: 0;
  }
  10% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
  20% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
  30% {
    -webkit-transform: translateX(-200px);
            transform: translateX(-200px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(-200px);
            transform: translateX(-200px);
    opacity: 0;
  }
}

@keyframes display {
  0% {
    -webkit-transform: translateX(200px);
            transform: translateX(200px);
    opacity: 0;
  }
  10% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
  20% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
  30% {
    -webkit-transform: translateX(-200px);
            transform: translateX(-200px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(-200px);
            transform: translateX(-200px);
    opacity: 0;
  }
}

#img_mainImg .slide_inout {
  position: relative;
  width: 100vw;
  height: 600px;
}

#img_mainImg .slide_inout > img {
  position: absolute;
  top: 0;
  left: calc(100% - 400px);
  opacity: 0;
  -webkit-animation: display 20s infinite;
          animation: display 20s infinite;
}

#img_mainImg img:nth-child(2) {
  -webkit-animation-delay: 5s;
          animation-delay: 5s;
}
#img_mainImg img:nth-child(3) {
  -webkit-animation-delay: 10s;
          animation-delay: 10s;
}
#img_mainImg img:nth-child(4) {
  -webkit-animation-delay: 15s;
          animation-delay: 15s;
}

.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: 2em;
  position: absolute;
  right: 0;
  left: 0;
  bottom: -45px;
  z-index: 2;
  padding: 10px 10px 110px;
  overflow: hidden;
  color: rgba(45,124,181,1);
  font-size: 14px;
  font-family: 'Josefin Sans', sans-serif;
  font-weight: 900;
  line-height: 20px;
  letter-spacing: .2em;
  text-transform: uppercase;
  text-decoration: none;
  -webkit-writing-mode: vertical-lr;
      -ms-writing-mode: tb-lr;
          writing-mode: vertical-lr;
}
#btn_scroll a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 1.5em;
  width: 1px;
  height: 100px;
  background: #fff;
}
#btn_scroll a::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 1.5em;
  width: 1px;
  height: 100px;
  background: rgba(45,124,181,0.45);
}
#btn_scroll a::after {
  -webkit-animation: sdl 1.5s cubic-bezier(1, 0, 0, 1) infinite;
          animation: sdl 1.5s cubic-bezier(1, 0, 0, 1) infinite;
}
@-webkit-keyframes sdl {
  0% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  50% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  50.1% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
  100% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
}
@keyframes sdl {
  0% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  50% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  50.1% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
  100% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
}

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

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

section h2 {line-height: 1.3em;}
section h3.title_brd {
  text-align: center;
  font-weight: bold;
  position: relative;
  margin: 3em auto 4em auto;
}
section h3.title_brd small {display: block; margin-top: 1em; line-height: 1.7em;}
section h3.title_brd::before, section h3.title_brd::after {
  display: block;
  content: '';
  width: 1em;
  height: 6px;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1em;
}
section h3.title_brd::before {
  background: #ffe736;
  left: calc(50% - 1em);
}
#form_confirm {background: #fafafa;}
#form_confirm section h3.title_brd::before, #form_confirm section h3.title_brd::after {
  background: #231815;
}
section h3.title_brd::after {
  background: #d9d9d9;
  left: calc(50% - 0em);
}

#about h2 {
  font-weight: 900;
  padding-top: 0.5em;
  margin-bottom: 2em;
  position: relative;
}
#about h2::before {
  display: block;
  content: '';
  width: 0.85em;
  height: 0.15em;
  position: absolute;
  left: 0;
  bottom: -0.5em;
}
#about h2::before {
  background: rgba(45,124,181,0.85);
}
#about #profile_box {background: #ffffff; margin: 30px 0; padding: 0 45px 30px 45px; border: 1px solid #dddddd; position: relative;}
#about #profile_box:after {display: block; content: ''; clear: both;}
#about .img_profile {width: 35%; float: right; padding-top: 10px; left: 5%; position: relative;}
#about .img_profile #name_profile {width: 300px; height: auto; position: absolute; top: 20%; right: 80%; z-index: 3;}
#about .img_profile #thumb_profile {width: 211px; height: 325px; position: relative; z-index: 2;}
#about .img_profile:after {display: block; width: 211px; height: 325px; content: ''; background: rgba(118, 154, 179, 0.35); position: absolute; top: 30px; left: 30px; z-index: 1;}
#about .txt_profile {width: 60%; float: left;}
#about .txt_profile h4 {font-size: 20px; line-height: 1.4em; margin-bottom: 1em;}
#about .txt_profile h4 span {display: block; font-size: 15px;}
#about .txt_profile ul {font-size: 13px; list-style-type: none; margin: 0 0 15px 0; padding: 0;}
#about .txt_profile p {font-size: 13px; margin-bottom: 0.75em;}
#about .txt_profile p:last-child {margin-bottom: 0;}

#about .container {margin-bottom: 30px; padding-top: 50px; border-top: 4px double #dddddd;}
#appeal h3 {font-weight: 900;}
#appeal h3 img {display: block; margin: 1em auto 0 auto;}
#appeal h3:before, #appeal h3:after {display: none;}
h3.title_brd {margin-top: 60px;}
h3.title_brd span {
  font-size: 140%;
}
#appeal ul {
  list-style-type: none;
  margin: 60px 0 0 0 !important;
  padding: 0 !important;
}
#appeal ul:after {
  display: block;
  content: '';
  clear: both;
}
#appeal ul li {text-align: center;}
#appeal ul li span, #appeal ul li strong {
  display: block;
  font-weight: bold;
  margin: 0 auto;
}
#appeal ul li span img {
  display: block;
  width: 240px;
  height: 240px;
  margin: 0 auto 30px auto;
  padding: 30px;
  border-radius: 50%;
}
#appeal ul li strong {
  font-size: 120%;
  margin-bottom: 0.5em;
}

/*==================================================
アコーディオンのための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;
  color: #777777 !important;
  border-color: #777777 !important;
  opacity: 1.0;
}
/*アコーディオンタイトル*/
.title {
	display: inline-block;
    width: 100%;
    height: 3.5em;
    vertical-align: bottom;
    background: #ffffff;
    position: relative;
    cursor: pointer;
    font-size: 18px;
	font-weight: bold;
    line-height: 3.5em;
    text-align: center;
    margin: 0 auto;
    padding: 0;
	border: 1px solid;
	border-bottom: 3px solid;
	border-radius: 35px;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
.title:hover {
	background: rgba(255,255,255,0.45);
}

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

}
/*closeというクラスがついたら形状変化*/
.title.close::before{
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  background-color: rgba(35,24,21,0.85) !important;
}

.title.close::after{
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  background-color: rgba(35,24,21,0.85) !important;
}

/*アコーディオンで現れるエリア*/
.box {
  display: none;
  background: rgba(35,24,21,0.025);
  margin-top: 2em;
  padding: 3% 5%;
}
.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: #231815;
}

.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;
}

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

.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, .bg-merit {
  background: #fafafa;
}

.bg-light-30:before {
  position: absolute;
  background: rgba(255, 255, 255, 0.3);
  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%;
}

figcaption {
  display: block;
  text-align: center;
  margin: 0 auto;
}
figcaption img {
  display: block;
  margin: 0 auto 15px auto;
}
cite {position: relative;}
cite:before {
  display: inline-block;
  font-family: "FontAwesome"; content: "\f08e"; font-weight: 900;
  font-style: normal;
  margin-right: 5px;
}
cite a {
  color: #777777;
}

.txt_red {color: #e73a3a; font-weight: 600;}

#about {
  background-image: url(../images/bg_about.png);
  background-repeat: no-repeat;
  background-position: 90% 70%;
  position: relative;
}
#about dl dt {
  font-size: 130%;
  margin-top: 30px;
  position: relative;
}
#about dl dt small {
  font-size: 12px;
  font-weight: normal;
  vertical-align: top;
}
#about dl dd table {
  background: #ffffff;
  width: 100%;
  margin-top: 15px;
  border-collapse: collapse;
}
#about dl dd table th {
  background: rgba(2,33,92,0.85);
  color: #ffffff;
  font-weight: bold;
}
#about dl dd table th, #about dl dd table td {
  padding: 10px 15px;
  border: 1px solid #cccccc;
}
#about dl dd table th, #about dl dd table td ul {
  font-size: 80%;
}
#about dl dd table td ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
}

.offer_area {
  background: #ffe736 url(../images/bg_offer.png) no-repeat; background-size: auto; background-position: -50px bottom !important;
  position: relative;
}
.offer_area .cv_area {margin-bottom: 0 !important;}
.offer_area img {
  display: block;
  margin: 0 auto;
  width: 320px;
}
section.offer_area h3 {
  font-size: 24px;
  font-weight: 600;
  color: #e43a3a;
  margin-top: 0 !important;
  margin-bottom: 1.5em;
  position: relative;
}
section.offer_area h3:before {
  background: #e43a3a;
  display: block;
  content: '';
  width: 0.85em;
  height: 0.15em;
  position: absolute;
  left: 0;
  bottom: -0.5em;
}
.offer_area .cv_area a {
  width: 60%;
}

#reason {position: relative;}
#reason:after {
  display: block;
  content: '';
  width: 200%;
  height: 20em;
  background: -webkit-gradient(linear, left bottom, right top, color-stop(50%, transparent) , color-stop(50%, #ffe736)) no-repeat top left / 50% 100%, -webkit-gradient(linear,right bottom, left top,color-stop(50%, transparent), color-stop(50%, #ffe736)) no-repeat bottom right/50% 100%;
  background: linear-gradient(to top right, transparent 50% , #ffe736 50%) no-repeat top left / 50% 100%, linear-gradient(to top left,transparent 50%, #ffe736 50%) no-repeat bottom right/50% 100%;
  mix-blend-mode: multiply;
  position: absolute;
  top: 0;
  left: -50%;
}
#reason h2 {
  font-weight: 600;
  text-align: center;
  margin-bottom: 5em;
}
#reason .container {
  position: relative;
  z-index: 1;
}
.reason_box {
  background: #ffffff;
  background-position: left center;
  background-size: auto 100%;
  width: 87%;
  margin: 1em auto 3em auto;
  padding: 3em;
  border-top: 8px solid #ffe736;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
  -webkit-box-shadow: #718cc7 0px 0px 10px -5px, rgba(45,124,181,1) 0px 0px 10px -5px, #ffe736 0px 0px 10px -5px;
          box-shadow: #718cc7 0px 0px 10px -5px, rgba(45,124,181,1) 0px 0px 10px -5px, #ffe736 0px 0px 10px -5px;
  position: relative;
}
#reason .reason_box {background: #ffffff url(../images/bg_reason_box.png) no-repeat; background-size: cover; background-position: left center !important; position: relative;}
.reason_box:last-child {
  margin-bottom: 0;
}
.reason_box::after {
  display: block;
  content: '';
  clear: both;
}
.reason_box span.img_tokuten {
  display: block;
  width: 320px;
  float: left;
}
.reason_box img {
  height: 200px;
  width: 320px;
  -o-object-fit: cover;
     object-fit: cover;
}
.reason_box div {
  width: calc(100% - 350px);
  float: right;
  position: relative;
}
.reason_box strong {
  display: block;
  font-size: 140%;
  font-weight: 600;
  line-height: 1.4em;
  border-left: 10px solid #d9d9d9;
  padding-left: 0.75em;
  position: relative;
}
.reason_box strong::before {
  display: block;
  content: '';
  width: 5px;
  background: #ffe736;
  height: -webkit-fill-available;
  position: absolute;
  left: -10px;
  top: 0;
}
.reason_box strong + div + p + span {overflow: hidden;}
.reason_box div ul, .check_list ul {list-style-type: none; margin: 0 !important; padding: 0 !important;}
.reason_box div li, .check_list ul li {background: #ffffff; font-weight: bold; text-align: center; line-height: 1.7em; padding: 15px !important; border: 3px solid #ffe736; -webkit-box-sizing: border-box; box-sizing: border-box; border-radius: 5px;}
.reason_box div li:before, .check_list ul li:before {display: inline-block; padding-right: 10px; font-family: "FontAwesome"; content: "\f00c"; font-weight: 900;}

.reason_box div > span {
  display: block;
  width: 100%;
  float: none;
  text-align: left;
  margin: 0 0 1em 0;
  overflow: hidden;
}
.reason_box p {float: none; width: 100%;}
.reason_box p:last-child {
  margin-bottom: 0;
}

.check_list {margin-bottom: 5em;}

.half_row {position: relative;}
.half_img {
  height: 540px;
  background-repeat: no-repeat !important;
  background-size: cover !important;
  position: relative;
}
.half_img, .half_txt {display: block !important; width: 100%; position: relative;}
.half_img:before {
  display: block;
  background: rgba(255,231,54,0.8);
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  mix-blend-mode: hard-light;
}
.half_txt {width: 90% !important; text-align: center; margin: -16% auto 0 auto; padding: 5%;}
.half_img img {
  position: absolute;
  width: 320px;
  bottom: 15%;
  left: calc(50% - 160px);
  z-index: 2;
}
.half_txt {-webkit-box-align: center !important;-ms-flex-align: center !important;align-items: center !important; -ms-flex-wrap: wrap; flex-wrap: wrap; position: relative;}
.half_txt div {display: block; width: 100%; background: #ffffff; padding: 5% 5% 3% 5%; border-radius: 10px; position: relative; z-index: 1;}
.half_txt:before, .half_txt:after {
  display: block;
  content: '';
  background: linear-gradient(270deg, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
  width: 15px;
  height: calc(74% - 11px);
  position: absolute;
  -webkit-transform: rotate(-1deg);
          transform: rotate(-1deg);
  top: 14%;
  left: 5%;
}
.half_txt:after {
  background: linear-gradient(-270deg, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
  -webkit-transform: rotate(1deg);
          transform: rotate(1deg);
  right: 5%;
  left: auto;
}
.half_txt h2, h2.fukidashi {color: rgba(45,124,181,1); font-weight: 600; text-align: center; margin: 1em 0;}
.half_txt p {width: 100%;}

#meo, #movie, #marketing, #flow, #conversion {padding-top: 0;}
#meo .half_img {
  background: url(../images/bg_meo.png);
}
#movie .half_img {
  background: url(../images/bg_movie.png);
  background-position: center;
}
#marketing .half_img {
  background: url(../images/bg_marketing.jpg);
  background-position: center;
}
#conversion .half_img {
  background: url(../images/bg_conversion.jpg);
  background-position: top center;
}

#flow .half_img {
  background: url(../images/bg_flow.jpg);
  background-position: center;
}

figure {margin-bottom: 3em;}
figure table {
  width: 100%;
  background: #ffffff;
  border: 1px solid #cccccc;
  border-collapse: collapse;
  position: relative;
  z-index: -1;
}
figure table tr:nth-child(odd) {background: #fafafa;}
figure table tr:first-child th {background: #231815; color: #ffffff;}
figure table tr th, figure table tr td {
  text-align: center;
  padding: 15px;
}

.scrollable_x {overflow-y: hidden !important; z-index: 1;}

.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;
  -webkit-box-sizing: content-box;
          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;
}

#solution {
  padding-bottom: 0;
}
.solution_wrap {position: relative;}
.solution_wrap .col-sm-10 {
  z-index: 2;
}
#solution p {
  font-size: 36px;
  font-weight: 600;
  color: #ffffff;
  text-align: center;
  line-height: 1em;
}
#solution p small {font-size: 65%; line-height: 1em;}
#solution .check_list li {
  display: inline-block;
  background: #ffffff;
  font-size: 14px;
  letter-spacing: 0;
  color: #000a29;
  text-align: center;
  line-height: 1.7em;
  margin: 2% 0 6% 0 !important;
  padding: 20px 30px !important;
  border: 4px solid rgba(35,24,21,0.85);
  border-radius: 7px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
}
#solution .check_list li span {
  display: block;
  font-size: 130%;
  font-weight: 600;
  margin-bottom: 15px;
}
#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), #solution .check_list li:nth-child(5) {
  -webkit-transform: rotate(-3deg);
          transform: rotate(-3deg);
  bottom: 30px;
}
#solution .check_list li:nth-child(2) {
  -webkit-transform: rotate(3deg);
          transform: rotate(3deg);
}
#solution .check_list li:nth-child(3) {
  -webkit-transform: rotate(-2deg);
          transform: rotate(-2deg);
  bottom: 40px;
}
#solution .check_list li:nth-child(4) {
  -webkit-transform: rotate(2deg);
          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, #solution .check_list li:nth-child(5):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: -5%;
  bottom: 0;
  z-index: 1;
}

#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;}

#solution {
  background-image: url(../images/bg_case.jpg);
  background-repeat: no-repeat;
  background-position: center;
  position: relative;
}
#solution:before {
  display: block;
  background: rgba(0,0,0,0.65);
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
#solution h2 {
  color: #ffffff !important;
  font-weight: bold !important;
  text-align: center;
  margin: 1.5em auto;
}
#solution h2 small {display: block; color: #ffffff; font-weight: bold; line-height: 1.3em; margin-bottom: 5px;}
#solution h2 span {font-family: 'Josefin Sans', sans-serif;}
#solution h2:before, #solution h2:after {
  display: none;
}
#case {padding: 80px 0 !important;}
#case h2, #case h2 small {display: block; color: rgba(45,124,181,1); font-weight: 600; text-align: center;}
#case h2 {margin-bottom: 1em;}
#case h2 small {margin-bottom: 15px;}
#case .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;
  -webkit-box-shadow: 0 5px 3px rgb(0 0 0 / 10%);
          box-shadow: 0 5px 3px rgb(0 0 0 / 10%);
  position: relative;
  border: 3px solid rgba(45,124,181,1);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
}
#case .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;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  position: absolute;
  top: -3em;
  left: -3em;
  z-index: 2;
}
#case .bg_case:nth-child(1):before {
  content: 'Case 1';
}
#case .bg_case:nth-child(2):before {
  content: 'Case 2';
}
#case .bg_case:nth-child(3):before {
  content: 'Case 3';
}
#case .bg_case:nth-child(4):before {
  content: 'Case 4';
}
#case .bg_case:nth-child(even) {
  margin-right: 0;
}
#case .bg_case p {
  font-size: 14px;
  margin-bottom: 10px;
}
#case .bg_case p:last-child {
  margin-bottom: 20px;
}
#case .bg_case:after {
  display: block;
  content: '';
  clear: both;
}
#case .case_thumb {
  width: 180px;
  height: auto;
  float: left;
  position: absolute;
  top: 2em;
  left: 15px;
}
#case .case_txt {
  width: calc(100% - 180px);
  float: right;
}
#case .case_txt h4 {
  font-size: 110%;
  font-weight: 600;
  color: rgba(45,124,181,1);
  text-align: center;
  padding: 5px 15px;
  border: 2px solid rgba(45,124,181,0.35);
  border-radius: 5px;
}
#case .case_txt table {
  width: 100%;
  font-size: 12px;
  background: rgba(45,124,181,0.085);
  border-collapse: collapse;
  margin-bottom: 15px;
  border-radius: 5px;
}
#case .case_txt table td {
  color: rgba(45,124,181,1);
  font-weight: 600;
  line-height: 1em;
  padding: 10px 15px;
  text-align: center;
}
#case .case_txt table td span {
  color: rgba(45,124,181,1);
  font-weight: bold;
  line-height: 1em;
}
#case .jirei_list {clear: both; padding-top: 3.5em;}
#case .jirei_list ul li span {display: block; background: rgba(35,24,21,0.05); width: 100%; line-height: 2em; margin: 15px auto 0 auto; border-radius: 35px;}

.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';
}

.ranking {
  background: rgba(35,24,21,0.035);
  width: 60%;
  margin: 2em auto;
  padding: 3em;
  border-radius: 5px;
}
.ranking ol {
  margin: 0 auto;
  text-align: left;
  font-weight: 600;
  list-style-position: inside;
  padding: 0;
}
.ranking ol li {
  padding: 0 0 15px 0;
  border-bottom: 1px dotted #cccccc;
  margin-bottom: 15px;
}
.ranking ol li:nth-child(1) {
  color: #ed736b;
}
.ranking ol li:nth-child(2) {
  color: #ee8c23;
}
.ranking ol li:nth-child(3) {
  color: #dbb337;
}
.ranking ol li:nth-child(4) {
  color: #999999;
}
.ranking ol li:nth-child(5) {
  color: #aaaaaa;
}
.ranking ol li:last-child {
  border: none;
  padding: 0;
  margin: 0;
}

.flex_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-line-pack: justify;
      align-content: space-between;
  list-style-type: none;
  margin: 0;
  padding: 0;
}
.flex_list li {
  font-weight: bold;
  text-align: center;
  margin: 0 2%;
  padding: 0;
}

.flow_list {
  margin-top: 5em;
  position: relative;
}
.flow_list:after {
  display: block;
  content: '';
  background: rgba(45,124,181,0.15);
  width: 80%;
  height: 0.5em;
  left: 10%;
  right: 10%;
  top: 0;
  position: absolute;
  z-index: 0;
}
.flow_list li {
  padding: 5% 0;
  position: relative;
}
.flow_list li:before {
  display: block;
  content: '00';
  background: rgba(45,124,181,1);
  color: #ffffff;
  width: 3em;
  height: 3em;
  line-height: 3em;
  top: -1.25em;
  left: calc(50% - 1.5em);
  border-radius: 50%;
  position: absolute;
  z-index: 1;
}
.flow_list li:nth-child(1):before {
  content: '01';
}
.flow_list li:nth-child(2):before {
  content: '02';
}
.flow_list li:nth-child(3):before {
  content: '03';
}
.flow_list li:nth-child(4):before {
  content: '04';
}
.flow_list li:nth-child(5):before {
  content: '05';
}
.flow_list li span {display: block; margin: 15px auto; position: relative;}
.flow_list li span:before {
  display: block;
  content: '';
  width: 100%;
  height: 100%;
  background: rgba(45,124,181,0.85);
  position: absolute;
  top: 0;
  left: 0;
  mix-blend-mode: hue;
}
.flow_list li span img {
  width: 80px;
  height: auto;
}

.jirei_list .flex_list li {-webkit-box-flex: 1;-ms-flex: 1;flex: 1;}

.calc_02 li {
  width: calc(96%/2);
  margin: 2% 4% 0 0 !important;
}
.calc_02 li:nth-child(even) {margin-right: 0 !important;}
.calc_03 li {
  width: calc(92%/3);
}
.calc_03 li:nth-child(1), .calc_03 li:nth-child(3) {
	margin-left: 0;
	margin-right: 0;
}
.calc_03 li:nth-child(2) {
	margin-left: 4%;
	margin-right: 4%;
}
.microcopy li {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.calc_05 li {
  width: calc(80%/5);
}

.microcopy {
  margin: 3em 0;
}
.microcopy li {
  color: #e73a3a;
  font-size: 14px;
}
.microcopy li span {
  display: block;
  background: #f85032; /* Old browsers */ /* FF3.6-15 */ /* Chrome10-25,Safari5.1-6 */
  background: -webkit-gradient(linear, left top, left bottom, from(#f85032),color-stop(50%, #f16f5c),color-stop(51%, #f6290c),color-stop(71%, #f02f17),to(#e73827));
  background: linear-gradient(to bottom, #f85032 0%,#f16f5c 50%,#f6290c 51%,#f02f17 71%,#e73827 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f85032', endColorstr='#e73827',GradientType=0 ); /* IE6-9 */
  color: #ffffff;
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  line-height: 2.7em;
  padding: 0 15px;
  border: 1px solid #dddddd;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

#price .price_list {
  background: #ffffff;
  width: 100%;
  font-size: 18px;
  border-collapse: collapse;
  margin-top: 3.5em;
}
#price .price_list th, #price .price_list td {
  font-size: 90%;
  line-height: 1.4em;
  border: 1px solid #cccccc;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 15px;
}
#price .price_list tr:nth-child(1) th {
  display: table-cell;
  background: rgba(45,124,181,1);
  color: #ffffff;
  font-size: 100% !important;
  text-align: center;
  position: relative;
  padding: 30px 15px;
}
#price .price_list tr:nth-child(1) th img {
  display: block;
  top: -3.85em;
  left: calc(50% - 3em);
  position: absolute;
}
#price .price_list tr:nth-child(1) th small, #price .price_list td small {
  display: block;
  font-size: 80%;
  margin-top: 0.5em;
  line-height: 1.3em;
}
#price .price_list td table th, #price .price_list tr td table th {
  display: block !important;
  background: none !important;
  font-size: 16px !important;
  color: inherit !important;
  text-align: left !important;
  margin: 1em 0 0.5em 0;
  padding: 0;
  border: none;
}
#price .price_list tr th {
  display: block;
  width: 100%;
  background: rgba(45,124,181,0.05);
}
#price .price_list tr th.no_brd span {
  display: inline-block;
  width: 50%;
  text-align: center;
}
#price .price_list tr th.no_brd span:last-child {
  float: right;
  border-left: 1px dotted;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
#price .price_list tr th.no_brd:after {
  display: block;
  content: '';
  clear: both;
}
#price .price_list td {
  display: block;
  width: 100%;
  text-align: left;
  padding: 10px 15px;
}
#price .price_list td dl {
  background: #fafafa;
  padding: 15px 20px;
  margin: 15px 0;
  border-radius: 5px;
}
#price .price_list td dl table {
   width: 100%;
}
#price .price_list td dl table tr {
  display: block;
  border-bottom: 1px dotted #cccccc;
  margin-bottom: 10px;
  padding-bottom: 10px;
}
#price .price_list td dl table th, #price .price_list td dl table td, #price .price_list td dl table tr:nth-child(1) th {
  font-size: 90% !important;
  border: none;
  padding: 0;
}
#price .price_list td span {
  font-size: 90%;
  font-weight: normal;
}
#price .price_list td small {
  font-weight: normal;
}
#price .price_list td table th, #price .price_list td table td {
}
#price .price_list .no_brd {border-top: none !important; border-bottom: none !important;}
#price .price_list .no_brd small {font-size: 80%; font-weight: 600; margin-left: 10px;}

.js-table-scroll-hint {position: relative;}

#hikaku_list {
  width: 100%;
  background: #ffffff;
  text-align: center;
  position: relative;
  border-collapse: collapse;
  margin: 5% 0 3% 0;
}
#hikaku_list th {
  background: #777777;
  color: #ffffff;
}
#hikaku_list th, #hikaku_list td {padding: 20px 30px; border: 1px solid #cccccc;}
#hikaku_list th {text-align: center;}
#hikaku_list td {background: rgba(0,0,0,0.015); vertical-align: middle;}
#hikaku_list tr:first-child th:nth-child(1), #hikaku_list tr:nth-child(2) td:nth-child(1), #hikaku_list td span {
  font-size: 120%;
  font-weight: 600;
}
#hikaku_list tr:first-child th:nth-child(1) {
  background: rgba(255,231,54,1);
  color: #231815;
}
#hikaku_list tr:nth-child(2) td:nth-child(1) {
  background: rgba(255,231,54,0.035);
  text-align: center;
}
#hikaku_list tr:nth-child(2) td:nth-child(1) img {
  display: block;
  margin: 0 auto 15px auto;
}
#hikaku_list tr:nth-child(2) td:nth-child(1) span {
  display: block;
  width: 100%;
  background: #ffffff;
  text-align: center;
  padding: 7px 10px;
  border-radius: 45px;
  border: 3px solid #ffe736;
}
#hikaku_list tr:nth-child(2) td:nth-child(1) span small {
  display: block;
  font-size: 65%;
}
#hikaku_list td ul {
  font-size: 90%;
  list-style-type: none;
  margin: 10px 0 0 0;
  padding: 0;
}
#hikaku_list tr:nth-child(2) td:nth-child(1) ul {
  margin-bottom: 10px;
}

#faq dl {
  margin: 0 auto;
}
#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:last-child {margin-bottom: 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: #ffe736;
  content: 'Q';
  float: left;
  width: 1.7em;
  height: 1.7em;
  font-weight: normal;
  line-height: 1.7em;
  text-align: center;
}
#faq dl dd:before {
  background: #231815;
  content: 'A';
  color: #ffffff;
}
#faq dl dt div, #faq dl dd div {
  float: right;
  width: calc(100% - 2.5em);
}

#business {position: relative;}
#business .container {position: relative; z-index: 1;}
#business:after {
    display: block;
    content: '';
    background: #ffffff;
    background-image: url(../images/bg_logo.png);
    background-repeat: repeat;
    width: 200%;
    height: 200%;
    position: absolute;
    top: -50%;
    left: -50%;
    -webkit-transform: rotate(-15deg);
            transform: rotate(-15deg);
    opacity: 0.085;
    -webkit-animation: bg_logo infinite linear;
            animation: bg_logo infinite linear;
    -webkit-animation-duration: 5s;
            animation-duration: 5s;
	z-index: 0;
}
@-webkit-keyframes bg_logo {
  0% {  background-position-x: 0;}
  100% {  background-position-x: -288px;}
}
@keyframes bg_logo {
  0% {  background-position-x: 0;}
  100% {  background-position-x: -288px;}
}
#business blockquote {width: 65%; background: rgba(255,231,54,0.25); margin: 0 auto; padding: 5%; border: 7px solid rgba(255,231,54,0.5); -webkit-box-sizing: border-box; box-sizing: border-box; border-radius: 10px;}
#business blockquote p:last-child {margin-bottom: 0;}
#business table th small {color: #777777;}
#business 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: #231815;
}

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

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

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

.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: #231815;
  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: #231815;
}
.btn.btn-border-o:hover,
.btn.btn-border-o:focus {
  background: #23ac38 !important;
  border-bottom: 4px solid #23ac38 !important;
  color: #fff !important;
  -webkit-box-shadow:0px 5px 3px 1px #231815;
          box-shadow:0px 5px 3px 1px #231815;
  -webkit-transition: .9s;
  transition: .9s;
}

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

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

.btn.btn-b {
  background: #231815;
  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 #231815;
  color: #231815;
}

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

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

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

/* 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: #231815;
}

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;
}
section .container h2 strong, section .container h3 strong {
  font-family: 'Josefin Sans', sans-serif;
  color: rgba(45,124,181,1);
}

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 {
  -webkit-transform: rotate(.03deg);
          transform: rotate(.03deg);
}

.box-shadow {-webkit-box-shadow: 0 0 4px rgba(0,0,0,0.3) inset;box-shadow: 0 0 4px rgba(0,0,0,0.3) inset;}
.highlight {
 display: inline !important;
 background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, rgba(255, 239, 107, 1)));
 background: linear-gradient(transparent 60%, rgba(255, 239, 107, 1) 60%);
 font-weight: bold;
 line-height: 1.7em;
}
.wh_highlight {
  display: inline !important;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, rgba(255, 255, 255, 0.5)));
  background: linear-gradient(transparent 60%, rgba(255, 255, 255, 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;
}

#business blockquote p {font-size: 90%; color: #3c3c3c;}
.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, .company_box table td {font-weight: normal; padding: 15px 0;}
.company_box table td ul {list-style-position: inside;}
.company_box table td ul li {font-size: 12px; line-height: 1.7em;}

#contact {background: #ffe736;}
#contact h2 {font-size: 24px; font-weight: 600; margin-top: 2em; margin-bottom: 3em; position: relative;}
#contact h2 small {font-size: 14px; color: #231815;}
#contact h2:before {
  background: #231815;
  display: block;
  content: '';
  width: 0.85em;
  height: 0.15em;
  position: absolute;
  left: 0;
  bottom: -0.5em;
}

/*--------------------------------------------------------------
	Footer
--------------------------------------------------------------*/
.caution_box {
  text-align: center;
  color: #444444;
}
.caution_box dl dt {
  font-size: 80%;
  margin-bottom: 1.3em;
}
.caution_box dl dd ul li {
  font-size: 60%;
  list-style-type: none;
  line-height: 1.6em;
}

.footer {
  padding: 0px 0 150px 0;
}

.footer h3 {margin: 50px auto;}
.policy_box h3 {margin-top: 0;}
.footer .copyright {
  font-size: 10px;
  padding-top: 50px;
  margin: 0;
  text-align: center;
}

.footer .footer_logo {
  display: block;
  clear: both;
  padding-top: 10px;
  margin-bottom: 5em;
}

.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;
}

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: rgba(255,255,255,1);
  width: 100%;
  position: fixed;
  top: 0;
  border-bottom: 1px solid rgba(0,0,0,0.1);
}
.navbar-fixed-top .navbar-brand img {
	margin-bottom: 20px;
}
.navbar-fixed-top #head_logo a {
  height: auto !important;
}
.navbar-fixed-top .navbar-brand img {
  height: 30px;
  width: auto;
}
.navbar-transparent {
  background: none !important;
  border: none !important;
}
.navbar-transparent .navbar-brand img {
  height: 60px;
  width: auto;
}
  .navbar-right .dropdown-menu {
    right: auto;
    left: 0;
  }
  /* Comments */
  .comment .comment {
    margin-left: 75px;
  }
  
  .title h2 {font-size: 57%;}
  .col-sm-3 {width: 33%;}
  .col-sm-4 {width: 25%;}
  
hr {padding: 30px 0; border-bottom: 4px double #dddddd;}
  
#olayBtn {
	display: block !important;
	position: fixed;
	width: 100%;
	background: rgba(255,231,54,0.9);
	padding: 0;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	z-index: 1000;
	-webkit-box-shadow: 0 -1px 3px rgb(0 0 0 / 0.25);
	        box-shadow: 0 -1px 3px rgb(0 0 0 / 0.25);
}
#olayBtn ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	overflow: hidden;
	list-style-type: none;
  justify-content: center;
	margin: 0px !important;
	padding: 0px !important;
	visibility: visible !important;
}
#olayBtn ul li {
	width: 50%;
	margin: 0;
	padding: 15px 0;
}
#olayBtn ul li small {
	display: block;
	text-align: center;
	font-weight: 600;
	margin: 0 0 5px 0;
}
#olayBtn ul li small span, .cv_area small span {
	color: #e43a3a;
}
.cv_area {margin: 30px auto;}
.cv_area small {display: block; color: #23618d; font-size: 100%; font-weight: bold; margin: 0 auto; text-align: center; margin-bottom: 10px;}
#olayBtn ul li:nth-child(1) {margin-right: 15px;}
#olayBtn ul li:nth-child(2) {margin-left: 15px;}
#olayBtn ul li a.ov_btn, .cv_area a {
	display: block;
	background: rgba(45,124,181,1);
	width: 50%;
	vertical-align: middle;
	color: #ffffff;
	text-decoration: none;
	font-size: 140%;
	font-weight: bold;
	line-height: 3.5em;
    text-align: center;
	margin: 0 auto;
	border-bottom: 4px solid #23618d;
    border-radius: 45px;
    -webkit-box-sizing: content-box;
            box-sizing: content-box;
}
#olayBtn ul li a.ov_btn {background: #231815; width: 100%; font-size: 18px; border: none;}
#olayBtn ul li a.line_btn {background: #06c755;}
#olayBtn ul li a.ov_btn:hover, .cv_area a:hover {
	background: #205880;
}
#olayBtn ul li a.ov_btn .fa, #olayBtn ul li a.ov_btn .fab, .cv_area a .fa {
	display: inline-block;
	margin-top: -5px;
	margin-right: 5px;
	vertical-align: middle;
}
.fa-2x {
    font-size: 1.5em;
}

@media (max-width: 1200px) {
  #mainImg_txt .check_list {width: 50%;}
  #case .bg_case {width: 100%;}
  #case .case_thumb {width: 150px; left: 2em;}
}

@media (max-width: 991px) {
.only_tab {display: block !important;}
  #mainImg_txt h2 {font-size: 30px;}
  #mainImg_txt .check_list li {text-align: left; padding: 10px 15px;}
  .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;
}
  .only_pad {display: block !important;}
   .col-md-6-right, .col-md-offset-6-right {width: 100%; float: none; margin-left: 0;}
   #about .col-sm-6 {width: 100% !important;}
   #about {background-position: center 65%;}
   #about .container .row:before {display: block; background: rgba(250,250,250,0.9); content: ''; width: 100%; height: 100%; position: absolute; top: 0; left: 0;}
   #about .container .row .col-sm-7 {position: relative; z-index: 1;}
   #about .img_profile {
    width: 100%;
    float: none;
    padding-top: 0;
    left: 50%;
    right: 50%;
    position: relative;
}
   #about .txt_profile {
    width: 100%;
    float: none;
    margin-top: 5em;
}
   #reason .reason_box:before {display: block; content: ''; width: 100%; height: 100%; background: rgba(255,255,255,0.85); position: absolute; top: 0; left: 0;}
   .reason_box {width: 100%; padding: 3em; position: relative;}
   .reason_box:before {display: block; content: ''; width: 100%; height: 100%; background: rgba(255,255,255,0.85); position: absolute; top: 0; left: 0;}
   .reason_box span {overflow: hidden;}
   .reason_box span, .reason_box div {display: block; position: relative;}
   .reason_box div {width: 100%; float: none; clear: both;}
   .reason_box .img_tokuten {display: block; width: 100% !important; float: none; margin: 0 auto 15px auto;}
   .reason_box img {width: 100%; height: auto;}
   
   .offer_area {background-size: 100%; background-position: center calc(100% + 50px) !important; padding-bottom: 460px;}
   .offer_area .col-sm-5 {display: none;}
   .offer_area .col-sm-7 {width: 100%; float: none; position: relative;}
   
   .microcopy li {-webkit-box-flex: 1;-ms-flex: auto;flex: auto; width: calc(88% / 2); margin: 2%;}
   
   #performance .txt_caution {text-align: left;}
   #case .case_thumb {width: 100px;}
   #case .case_txt {width: calc(100% - 120px); margin-bottom: 30px;}
   #case .bg_case p {font-size: 12px; margin-bottom: 0.7em !important;}
   
   #price .flex_list {display: block;}
   #price .flex_list li {width: 100%; margin: 0 0 6em 0;}
   
   .cv_area a {width: 60%;}
}

@media (max-width: 767px) {
  .navbar-transparent {background: transparent !important; border: none !important;}
  .navbar-collapse.in {background: rgba(255,255,255,0.9); border-top: none; position: relative; overflow: hidden;}
  .navbar-custom .navbar-toggle .icon-bar {width: auto; background: #000000;}
  .navbar-custom .navbar-toggle .menu_txt {display: block; font-family: 'Josefin Sans', sans-serif; margin-top: 3px;}
  .navbar-toggle {color: #000000 !important;}
  .navbar-custom .nav li:last-child {
    margin: 20px 15px;
}
  .navbar-custom .nav li:last-child a {
    display: block;
    width: 100%;
    line-height: 4em;
    text-align: center;
    padding: 0px 30px;
	margin-left: 0;
}
.navbar-fixed-bottom .navbar-collapse, .navbar-fixed-top .navbar-collapse {max-height: 100% !important;}
  .home-section {background-position: center !important; background-size: cover !important;}
  #mainImg {display: block; width: 100%; height: 100vh;}
  #mainImg_txt {display: block; margin-top: 90px; width: 100%; height: calc(100vh - 90px);}
  #mainImg_txt h2 small {font-size: 24px;}
  #mainImg_txt .sub_copy {font-weight: 600; text-shadow: 2px 2px #ffffff, 2px 2px #ffffff, 2px 2px #ffffff;}
  #head_logo {margin: 0;}
  #head_logo a {height: auto !important;}
  #head_logo a span {display: block !important;}
  #head_logo a img {position: relative; height: 30px; width: auto; -webkit-box-shadow: none; box-shadow: none; margin: 10px 15px;}
  .home-section:before {border-width: 180vw 100vw 0 0;}
  .home-section:after {border-width: 180vw 150vw 0 0;}
  #mainImg_txt .check_list {width: 100%;}
  #img_mainImg {width: 100%;}
  #img_mainImg .slide_inout {height: 300px;}
  #img_mainImg .slide_inout > img {height: 300px; left: calc(100% - 350px);}
  #img_mainImg .slide_inout {bottom: -30px;}
  #reason:after {width: 280%; height: 18em; left: -90%;}
  #reason h3 {margin-top: 2em !important;}
  .check_list {width: 100%; margin-bottom: 2em;}
  .main h2 {font-size: 22px; line-height: 1.5em !important;}
  section h3.title_brd {font-size: 18px;}
  section.offer_area h3 {font-size: 24px; margin-top: 0 !important; margin-bottom: 2em; text-align: center;}
  #reason h2 {margin-bottom: 2em !important;}
  #contact h2 {text-align: center;}
  #contact h2 small {display: block; margin-top: 10px;}
  #contact h2:before, section.offer_area h3:before {left: calc(50% - 0.425em);}
  #contact h2:before {bottom: -1em;}
  .sub-page .main {padding-top: 50px;}
  .contents {margin-bottom: -230px;}
  .contents:before {background-size: 50%;}
  .contents img {width: 80%;}
  #business blockquote {width: 90%;}
  #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 {width: 50%;}
  .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;}

  .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;}
  .home-section{height: auto !important; background-position: 20% center;}
  .kv {margin-top: 0; background-position: 60%;}
  #mainImg_txt .col-sm-6 {width: 100%;}
  #mainImg_txt h2 {font-size: 36px; letter-spacing: 1px;}
  .font-alt span, #reason h4 span {display: block;}
  .navbar-custom .navbar-nav {
    letter-spacing: 3px;
    margin-top: 0;
    margin-bottom: 0;
    background: rgba(255, 255, 255, 0.9)
  }
  .navbar-custom .nav li > a {color: #231815;}
  .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: o 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, .footer .footer_logo {float: none; clear: both; text-align: center; margin: 60px auto 5em auto; padding: 0;}
.footer .footer_logo {max-width: 50%;}
.footer p img {max-width: 50% !important;}
#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;}
#about dl dd table th {white-space: nowrap;}
#about #profile_box {margin: 30px 15px;}
#about .img_profile #name_profile {width: 150px; height: auto; right: 90%;}
#about .img_profile {left: 30%; right: 30%;}
.btn_link a {width: 80%; margin: 0 auto;}
#performance table th {font-size: 10px; white-space: nowrap; padding: 10px 0; letter-spacing: 0;}
#performance table td {font-size: 12px;}
#performance .chart_area .ch1 small {display: block;}
section h3.title_brd small {letter-spacing: 0;}
section h3.title_brd small br {display: block;}

#solution p {font-size: 30px;}
#solution p br {display: block !important;}
#solution .check_list li {top: 0; bottom: 0 !important; left: 0 !important; right: 0 !important; margin-left: 0 !important; margin-right: 0 !important; padding: 15px !important;}
#solution .check_list li br {display: none;}
#img_solution {position: relative; bottom: -50px;}
#solution .check_list {margin-top: 3em; margin-bottom: -3em;}
#img_solution img {width: 200px; height: auto; display: block; margin: 0 auto;}
#case .case_thumb {left: 1.5em;}

.main section p, .main section ul, .main section table {font-size: 14px;}
#reason:after {width: 280%; height: 18em; left: -90%;}
#reason h3 {margin-top: 2em !important;}
#reason p img {display: block; margin: 0 auto; max-width: 50%;}
.reason_box div li, .check_list ul li {line-height: 1.4em; padding: 10px !important;}
.reason_box div li:before, .check_list ul li:before {padding-right: 5px;}
.microcopy li {font-size: 12px;}
.microcopy li span {font-size: 14px; padding: 0 10px;}
#meo .container img {display: block; margin: 0 auto 20px auto;}
#meo .sp_half {max-width: 50%; margin-bottom: 0;}
cite {font-size: 12px;}

.offer_area {background-position: center calc(100% + 50px) !important; padding-bottom: 300px;}

.half_img {height: 300px !important; background-position: 100%;}
.half_txt {width: 100% !important; margin-top: -25%;}
.half_txt p, .txt_center p {text-align: left;}
.half_txt p br, .txt_center p br, .main section p br {display: none;}
.half_img img {width: 160px; left: calc(50% - 80px); bottom: 25%;}

.ranking {width: 100%; padding: 2em 1.5em;}

.flow_list {display: block; margin-top: 3em;}
.flow_list:after {
  background: none;
  width: 0.5em;
  height: calc(100% - 7em);
  margin: 3em 0;
  border-left: 0.5em solid rgba(35,24,21,0.15);
  left: 1.25em;
  right: 0;
}
.flow_list li {
  width: 100%;
  text-align: left;
  padding-left: 20%;
}
.flow_list li:before {
  text-align: center;
  top: 3em;
  left: -0.5em;
}
.flow_list li:after {
  display: block;
  content: '';
  clear: both;
}
.flow_list li span, .flow_list li div {
  display: inline-block;
  vertical-align: middle;
}
.flow_list li span {}
.flow_list li div {
  width: calc(100% - 64px);
  line-height: 1.7em;
  padding-left: 1em;
}
.flow_list li span img {
  width: 64px;
}

#case:before {background: rgba(0,0,0,0.65);}
#case h2 {margin-bottom: 1em; line-height: 1.2em;}
#case .bg_case {
    width: 90% !important;
    margin-left: 5%;
    margin-right: 5%;
	padding: 20px;
}
#case .case_txt {margin-bottom: 0;}
#case .case_txt h4 {padding: 8px 10px;}
#case .case_txt table td {padding: 10px; letter-spacing: 0;}
#case .txt_caution {width: 90%; margin: 0 auto;}
#case .jirei_list .flex_list li {-webkit-box-flex: 1;-ms-flex: auto;flex: auto; width: calc(92% / 2); margin-bottom: 2em;}
#case .jirei_list .flex_list li:nth-child(3), #case .jirei_list .flex_list li:nth-child(4) {margin-bottom: 0;}

#hikaku_list, .scrollable_x figure {
  width: 1170px;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 30px 0;
  padding: 0;
  -webkit-overflow-scrolling: touch;
  border-radius: 5px;
  position: relative;
  z-index: -1;
}
.scroll-hint-icon {top: 25%; left: 25%;}
.scrollable_x {overflow-x: scroll !important; overflow-y: hidden !important;}
.is-scrollable {margin-bottom: 3em;}

/*===========
scrollbar
===========*/
/*スクロールバー全体の高さ*/
#flow_list::-webkit-scrollbar {
  height: 4px;
}
/*スクロールバー全体の背景*/
#flow_list::-webkit-scrollbar-track {
  background: #eee;
}
/*スクロールバーの動く部分*/
#flow_list::-webkit-scrollbar-thumb {
  background: #aaa;
  border: none;
}
/*スクロールバーの動く部分のホバー（マウスオーバー）*/
#flow_list::-webkit-scrollbar-thumb:hover {
  background: #999;
}

#appeal ul li {margin-bottom: 4em;}
#case .jirei_list {padding-top: 0;}
.company_box table tr:last-child {border: none;}
#contact h2 {margin-bottom: 2em;}
.cv_area a {width: 90%;}
.cv_area a {line-height: 4em;}
#olayBtn ul li:first-child {position: relative;}
/* #olayBtn ul li:first-child:after {display: block; content: ''; width: auto; height: calc(100% - 30px); position: absolute; top: 15px; right: 0; border-right: 1px dotted;} */
#olayBtn ul li span {display: none !important;}
#olayBtn ul li:first-child small {font-size: 11px; line-height: 1.2em;}
#olayBtn ul li a {display: block; padding: 10px 0;}
#olayBtn ul li a.ov_btn {color: #231815;}
#olayBtn ul li a:hover {background: none !important; color: inherit; opacity: 0.6;}
#olayBtn ul li a.ov_btn {background: none; width: 100%; font-size: 12px; line-height: 1.4em;}
#olayBtn ul li a.ov_btn .fa, #olayBtn ul li a.line_btn .fab {display: block; font-size: 1.7em; line-height: 24px; min-height: 24px; margin: 0 0 5px 0;}
#olayBtn ul li a.line_btn .fab {font-size: 1.8em;}
#olayBtn ul li, #olayBtn ul li:nth-child(1), #olayBtn ul li:nth-child(2) {    margin: 0 auto !important; padding: 0;}
#olayBtn ul li a .fa-2x {margin-bottom: 5px;}
#olayBtn ul li a.ov_btn .fa, #olayBtn ul li a.ov_btn .fab {margin-top: 0;}
.offer_area .cv_area a {width: 80%;}
}

@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;}
#head_logo a img {margin: 6px 15px;}
#mainImg {height: 95vh;}
#img_mainImg .slide_inout {bottom: -50px;}
#img_mainImg .slide_inout > img {width: auto; height: 300px; left: calc(100% - 300px);}
h2,h3 {font-weight: bold;}

#mainImg_txt {height: calc(90vh - 90px);}
#mainImg_txt h2 small {font-size: 22px;}
#mainImg_txt .sub_copy br {display: none;}
.bg_white {background: #fff; padding: 15px 0;}
.footer_link {width: 100%;}
#main {margin: 0 !important; padding: 0 !important; overflow: !important;}
.reason_box div li, .check_list ul li {width: 100% !important; text-align: left; margin: 2% 0 !important; padding: 15px !important;}

.home-section:before {border-width: 220vw 120vw 0 0;}
.home-section:after {border-width: 220vw 150vw 0 0;}
#about h2 {margin-top: 0 !important;}
#about #profile_box {background: none; padding: 0 15px; margin: 30px 0 60px 0; border: none;}
#about .img_profile #name_profile {top: 10%; right: 65%;}
#about .img_profile {left: 13%; right: 13%;}
#about .txt_profile p br {display: none;}
.reason_box {padding: 2em 1.5em;}
#case .case_thumb {width: 120px; height: 120px; -o-object-fit: cover; object-fit: cover; float: none; margin: 0 auto 15px auto; border-radius: 50%; background: rgba(45,124,181,0.085); overflow: hidden; position: relative; left: 0; top: 0;}
#case .case_thumb img {display: block;width: auto; height: 180px; margin: 0 auto;}
#case .case_txt {width: 100%; float: none;}
#case .case_txt table td {letter-spacing: 1px;}
#case .bg_case p:last-child {margin-bottom: 0 !important;}
.half_img {height: 240px !important;}
.half_img img {bottom: 20%;}
.offer_area {padding-bottom: 220px;}
.title {height: 4.5em; font-size: 14px; line-height: 4.25em;}
.title::before, .title::after {right: 8% !important;}
.ranking ol li {font-size: 14px;}
.check_list {margin-bottom: 1em;}

.cv_area a {font-size: 120%;}
.cv_area a, .offer_area .cv_area a {width: 100%; letter-spacing: 0;}
.cv_area small {letter-spacing: 0;}
}

@media only screen and (max-width: 375px) {
.navbar-brand img {height: 24px;}
.txt_big {font-size: 140%;}
#custom-collapse .btn.btn-border-o, .btn.btn-border-o {font-size: 15px;}
#img_mainImg .slide_inout {bottom: 0;}
#img_mainImg .slide_inout > img {width: auto; height: 400px; left: calc(100% - 300px);}
#about .img_profile #name_profile {top: 10%; right: 70%;}
#about .img_profile {left: 20%; right: 20%;}
}

@media only screen and (max-width: 375px) and (max-height: 667px) {
#mainImg_txt h2 {font-size: 36px; line-height: inherit;}
#mainImg_txt h2 br {display: none;}
#mainImg_txt h2 strong {background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, rgba(255, 239, 107, 1)));background: linear-gradient(transparent 60%, rgba(255, 239, 107, 1) 60%); line-height: 1.4em;}
#mainImg_txt h2 small {display: inline-block; background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, rgba(255, 239, 107, 1))); background: linear-gradient(transparent 60%, rgba(255, 239, 107, 1) 60%);}
#mainImg_txt h2 span {display: block; line-height: 1.1em;}
#mainImg_txt .sub_copy {line-height: 1.4em;}
#mainImg_txt .check_list li {line-height: 1em;}
#img_mainImg .slide_inout {bottom: -100px;}
#img_mainImg .slide_inout > img {width: auto; height: 300px; left: calc(100% - 300px);}
#about .img_profile #name_profile {right: 75%;}
}

@media only screen and (max-width: 375px) and (min-height: 668px) {
#img_mainImg .slide_inout {bottom: 0;}
#img_mainImg .slide_inout > img {width: auto; height: 400px; left: calc(100% - 300px);}
}

@media only screen and (max-width: 320px) {
.home-section:before {border-width: 260vw 130vw 0 0;}
.home-section:after {border-width: 260vw 150vw 0 0;}
.navbar-brand img {height: 15px;}
#head_logo a {font-size: 10px;}
#mainImg_txt h2 {background: none; display: block !important; font-size: 30px; line-height: 1.4em !important;}
#mainImg_txt h2 br {display: none;}
#mainImg_txt h2 span {display: inline !important; background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, rgba(255, 239, 107, 1))); background: linear-gradient(transparent 60%, rgba(255, 239, 107, 1) 60%); font-weight: bold;}
#mainImg_txt h2 small {font-size: 18px;}
#mainImg_txt .sub_copy {font-size: 14px;}
.h2, h2 {font-size: 24px;}
.h3, h3 {font-size: 18px;}
.h4, h4 {font-size: 14px;}
.main h2 {font-size: 18px; line-height: 1.4em !important;}
section h3.title_brd, .reason_box strong {font-size: 15px;}
#img_mainImg .slide_inout {bottom: -130px;}
.reason_box div li, .check_list ul li {font-size: 12px; letter-spacing: 0;}
.half_img img {bottom: 15%;}
#img_mainImg .slide_inout > img {height: 200px; left: calc(100% - 225px);}
#about .img_profile {left: 15%; right: 15%;}
#about .img_profile #name_profile {right: 65%;}
#custom-collapse .btn.btn-border-o, .btn.btn-border-o {font-size: 15px;}
#performance table th, #performance table td {padding: 10px 5px;}
#case .case_txt table td {padding: 5px; text-align: center;}
.cv_area small {font-size: 90%;}
#olayBtn ul li a.ov_btn {letter-spacing: 0;}
#olayBtn ul li:first-child small {font-size: 10px;}
}

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

@media (min-width: 1440px) {
}
