/*--------------------------------------------------------------
	Common
--------------------------------------------------------------*/
@charset "utf-8";
@font-face {
  font-family: "Yu Mincho";
  src: local("Yu Mincho Regular");
  font-weight: 500;
}

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

body {
  background: #fff;
  font-family: 'Noto Serif JP', sans-serif !important;
  color: #0d1c1f;
  -webkit-font-smoothing: antialiased;
  word-wrap: break-word;
}
img {object-fit: cover;}
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {overflow: hidden !important;}
p, ol, ul, dl, blockquote, .content-box, .alt-features-item, .form-group {font-size: 16px; line-height: 1.7em;}
b, strong, .bold{
}
.btn-block {font-weight: bold;}
.content-box {position: relative;}

#home {position: relative;}
#home:before {position: absolute; width: 725px; height: 354px; top: 0; left: 0; display: block; content: ""; background: no-repeat url("../images/bg_corner-top.png");}
#home:after {position: absolute; width: 570px; height: 281px; bottom: 0; right: 0; display: block; content: ""; background: no-repeat url("../images/bg_corner-bottom.png");}

/*--------------------------------------------------------------
	Navbar
--------------------------------------------------------------*/
#head_logo {margin: 0; padding: 0;}
#head_logo a {font-size: 11px; white-space: nowrap; line-height: 1.3em; color: #0d1c1f;}
#head_logo a span {display: inline-block; margin-top: -4px;}
#mainImg_txt {color: #333333;}
#mainImg_txt h2 strong, .start_pack h3 strong {font-size: 120%;}
@media (max-width: 1200px) {#head_logo a span, #head_logo span {display: none !important;} #mainImg_txt p {letter-spacing: 0 !important;} #mainImg_txt{top: 50%;}}
.navbar-brand img {height: 30px; margin-top: -4px; float: left; padding-right: 13px;}

.navbar-custom {
  background-color: rgba(255, 255, 255, 1.0);
  border: 0;
  border-radius: 0;
  z-index: 1000;
  letter-spacing: 3px;
  font-size: 11px;
  border-bottom: 1px solid #ddd;
  transition: background, padding 0.4s ease-in-out 0s;
}

.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 {
  position: relative;
  font-size: 11px;
  padding-left: 20px;
  font-weight: 900;
  color: rgba(0, 0, 0, 0.8);
}

.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: #0d1c1f;
}

.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: "\f107";
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.navbar-toggle {padding: 0; margin-top: 0; top: 10px;}

.navbar-custom .navbar-toggle .icon-bar {
  background: #000;
}

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

.sns-header {}
.sns_ul_pc {float: left;}
.sns_ul_pc li {list-style-type: none; float: left; padding-right: 5px; padding-top: 5px;}
.sns_ul_pc li iframe {vertical-align: bottom;}
.sns_ul_pc li a {padding: 7px 0 0 0 !important;}

#mainImg_txt .main_txt .flex_box li {
    font-size: 80%;
    color: #555555;
    border: none;
    padding: 15px 5px;
    background: rgba(12,84,255,0.1);
}

.cl_logo {color: #112c86 !important;}

#about, #negative, #flow, #testimonial, #testimonial, #contact {
  padding-top: 50px !important;
}
#flow {margin-bottom: -20px;}
section {padding-bottom: 50px; margin-top: -50px !important;}
#contact {margin-bottom: 0 !important; padding-bottom: 0 !important;}
#contact-form {padding: 0 15px;}

.txt_bk {color: #0d1c1f;}

.bg_bl {
  background: #fffd62 !important;
  margin-top: 0 !important;
}
.bg_bl h2 {
  text-align: center;
  font-weight: bold;
  padding: 15px 0;
  margin-top: 0;
}
.bg_bl:before {
  border-top-color: #fffd62 !important;
}
.mgt-40 {margin-top: -40px !important;}
.mgt-50 {margin-top: -50px !important;}
.pdt50 {padding-top: 50px;}
.pdb70 {padding-bottom: 70px;}

#member p {font-size: 14px;}

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

.frame {
 position: relative;
 line-height: 1.4;
 padding:0.25em 1em;
 display: inline-block;
 top:0;
}

.frame:before,.frame:after{ 
  position: absolute;
  top: 0;
  content:'';
 width: 8px;
 height: 100%;
 display: inline-block;
}
.frame:before{
 border-left: solid 1px #fff;
 border-top: solid 1px #fff;
 border-bottom: solid 1px #fff;
  left: 0;
}
.frame:after{
  content: '';
  border-top: solid 1px #fff;
  border-right: solid 1px #fff;
  border-bottom: solid 1px #fff;
  right: 0;
}

.flex_box {display: flex;}
.flex_box li {flex-wrap: wrap; width: 100%; font-size: 90%; font-weight: bold; padding: 5px; margin: 1em; text-align: center !important; border: 4px double #0d1c1f;}

.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: 2px;
}
.bg_bl_c {
 background: rgba(48, 187, 219, 1.0);
 color: #ffffff;
 font-weight: bold;
 padding: 10px 15px;
 border-radius: 25px;
 margin-left: 30px;
 margin-right: 30px;
}

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

.img_eyecatch {
  margin: 3em 5%;
  text-align: center;
}

.fukidashi_down {
    position: relative;
    background: #fff;
    padding: 3em 0.5em;
    margin: 3em 0;
    border: 1px solid #112c86;
    border-top: 5px solid #112c86;
}
.fukidashi_down:after {
    position: absolute;
    content: '';
    top: 100%;
    left: 48%;
    border: 15px solid transparent;
    border-top: 15px solid #fffd62;
    width: 0;
    height: 0;
}
.contents .fukidashi_down:after, .container .fukidashi_down:after {border-top: 15px solid #112c86 !important;}
.down_no:after {display: none;}
.fukidashi_down h2 {
    margin: 0; 
    padding: 0;
}

.fukidashi {
  position: relative;
  display: inline-block;
  margin: 1.5em auto;
  padding: 7px 10px;
  width: 100%;
  color: #555;
  font-size: 16px;
  background: #FFF;
}

.fukidashi:before{
  content: "";
  position: absolute;
  bottom: -24px;
  left: 50%;
  margin-left: -15px;
  border: 12px solid transparent;
  border-top: 12px solid #FFF;
  z-index: 2;
}

.fukidashi:after{
  content: "";
  position: absolute;
  bottom: -30px;
  left: 50%;
  margin-left: -17px;
  border: 14px solid transparent;
  z-index: 1;
}

.fukidashi h2 img {vertical-align: top;}
.fukidashi h2 {margin-bottom: 0;}

.fukidashi h3 {
 font-size: 24px;
 color: #112c86;
 font-weight: bold;
 margin: 0;
 padding: 10px;
 text-align: center;
}

iframe {
  display: block;
  border: 0;
  margin: 0 auto 3em auto;
  text-align: center;
}

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

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

.position-relative {
  position: relative;
}

.leftauto {
  right: 0 !important;
  left: auto !important;
}

/*--------------------------------------------------------------
	Header
--------------------------------------------------------------*/
.home-section {
  position: relative;
  background-color: #fff;
  background-repeat: no-repeat;
  background-position: center center;
  width: 100%;
  z-index: 1;
  background-size: cover;
}

.titan-title-size-1 {
  letter-spacing: 4px;
  font-size: 15px;
}

.titan-title-size-2 {
  line-height: 1.3;
  letter-spacing: 3px;
  font-size: 18px;
  opacity: .8;
}

.titan-title-size-3 {
  letter-spacing: 16px;
  font-size: 46px;
}

.titan-title-size-4 {
  font-weight: 900;
  font-size: 20%;
  padding: 10px 0;
  line-height: 1.6em;
  border: 5px solid #0d1c1f;
  background: rgba(255, 255, 255, .5);
}

.titan-title-size-5 {
  font-weight: 900;
  color: #fff;
  font-size: 248px;
  line-height: 1em;
  text-align: center;
  text-shadow:0 2px 0 rgba(0, 0, 0, .1);
}

.titan-title-size-5 span.txt_s {
  display: block;
  font-size: 20%;
  line-height: 1em;
}

.titan-title-size-5 small {
  display: inherit;
  font-size: 24px;
  line-height: 1.6em;
}

.bg_gr {background: #fafafa;}

#about {
  position: relative;
  overflow: hidden;
  margin: 0;
}
#about .features-item {position: relative;}
#about .features-item:after {
  display: block;
  position: absolute;
  left: 100%;
  top: 25%;
  content: "\f0da";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-size: 400%;
}

.no-dis .features-item:after {
  display: none !important;
}

.contents_inner {
  box-sizing: boder-box;
  margin: 0 auto;
  padding: 30px 0 80px 0;
  text-align: center;
}

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


/* mainImg */
.kvc {position:relative; padding-top: 0 !important;}
#mainImg_v_white{position:absolute; width:100%; height:100%; background:rgba(0,0,0,0); z-index:10;}
#mainImg_txt {
width: 90%;
text-align: center;
margin: 0 5%;
position:absolute;
z-index:20;
}
.txt_or {color: #e12f44;}
#mainImg_txt h2 {font-size: 40px; font-weight: 900; margin-bottom: 30px; letter-spacing: 5px;}
#mainImg_txt .main_txt {}
#mainImg_txt p {font-size: 18px; font-weight: bold; letter-spacing: 5px;}
#mainImg_txt p.txt_24 {font-size: 24px;}
#mainImg, .kv {height: 100% !important;}
.kv {
padding-top: 0 !important;
position: relative;
top: 20%;
}
video { display: block; }
#mainImg_v video { position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; min-width: 100%; min-height: 100%; width: auto; height: auto; z-index: -100; }
#mainImg_sp { display: none; }
#mainImg_txt .btn_other {margin-top: 3%;}
#mainImg_txt .btn_top span, #mainImg_txt .btn_other span {font-size: 130%;}
#mainImg_txt .btn_other span small {font-size: 60%;}
#mainImg_txt .btn.btn-border-o {font-size: 180%; margin-left: 0;}
.btn_other a {display: block; margin: 0 auto !important;}

/*--------------------------------------------------------------
	Slider & Carousel
--------------------------------------------------------------*/
.flex-direction-nav a,
.flex-control-nav > li > a {
  transition: all 0.3s ease-in-out 0s;
}

.flex-direction-nav a {
  position: absolute;
  display: block;
  height: 100%;
  width: 50%;
  top: 0;
  z-index: 10;
  overflow: hidden;
  opacity: 0;
  margin: 0;
}

.flex-direction-nav .flex-prev {
  opacity: 0;
  left: 0;
  cursor: url(../images/prev-light.png), e-resize;
}

.flex-direction-nav .flex-next {
  opacity: 0;
  right: 0;
  cursor: url(../images/next-light.png), e-resize;
}

.flex-control-nav {
  position: absolute;
  width: auto;
  left: 50%;
  bottom: 20px;
  z-index: 11;
  text-align: center;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
}

.flex-control-nav > li {
  display: inline-block;
  margin: 5px 3px;
}

.flex-control-nav > li > a {
  background: #fff;
  border: 1px solid #cccccc;
  display: block;
  height: 10px;
  width: 10px;
  border-radius: 10px;
}

.flex-control-nav > li > a:hover,
.flex-control-nav > li > a.flex-active {
  background: #cccccc;
}

.flex-control-nav {
  bottom: 0;
}

.post-thumbnail,
.post-images-slider,
.post-video {
  margin: 0 0 20px;
}

.post-quote {
  background: #f5f5f5;
  text-align: center;
  padding: 20px;
}

.client-logo,
.gallery-caption,
.gallery-image:after,
.gallery-image img,
.price-table,
.team-detail,
.team-image:after,
.work-caption,
.work-image > img,
.work-image:after,
.post-thumbnail,
.post-video,
.post-images-slider {
  transition: all 0.3s ease-in-out 0s;
}

/* Reset box-shadow */
.btn,
.well,
.panel,
.progress,
.form-control,
.form-control:hover,
.form-control:focus,
.navbar-custom .dropdown-menu {
  box-shadow: none;
}

/* Reset border-radius */
.well,
.label,
.alert,
.progress,
.form-control,
.modal-content,
.panel-heading,
.panel-group .panel,
.nav-tabs > li > a,
.nav-pills > li > a {
  border-radius: 2px;
}
.form-control {font-size: 15px;}
input[type=button].btn-block {padding: 15px 0; border-color: #ffffff;}

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

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

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

.module,
.module-small {
  position: relative;
  padding: 70px 0;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
}

/* Module header */
.module-small {
  padding: 70px 0;
}

.module-extra-small {
  padding: 25px 0px;
}

.module-medium {
  padding: 75px 0px;
}

/* Sections dividers */
.divider-w {
  border-top: 1px solid #eaeaea;
  margin: 0;
}

.divider-d {
  border-top: 1px solid #202020;
  margin: 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%;}

#negative h3.module-title small {font-family: 'Great Vibes', cursive; margin-top: 15px;}
#negative p {line-height: 1.6em;}
.negative_list {padding-left: 0 !important;}
.negative_list li {list-style-type: none; list-style-position: inside; font-size: 120%; margin-bottom: 0.7em;}
.negative_list li:before {
  display: inline-block;
  margin-right: 8px;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f071";
}

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

.bg-dark, #flow {
  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;
}

.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-light {
  background: #ffffff;
}

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

.bg-gray, .bg-merit {
  background: #fafafa;
}

.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: #112c86;
}

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

.amcharts-chart-div a, desc, .amcharts-legend-div g g g:last-child {display: none !important;}

@media only screen and (max-height: 716px) {
#home:before {background-size: 60%;}
#home:after {background-size: 60%; background-position: right bottom;}
.titan-title-size-4 {font-size: 24px !important; font-weight: 900;}
.titan-title-size-4 br {display: block;}
.titan-title-size-5 {font-size: 180px;}
}

/*--------------------------------------------------------------
	About
--------------------------------------------------------------*/

.check_list {list-style-type: none; margin-top: 1.3em;}
.check_list, ol.check_list {padding: 0;}
.check_list li {text-align: left; line-height: 1.7em; margin-bottom: 0.7em;}
.check_list li:before {
  display: inline-block;
  padding-right: 1.3%;
  font-family: "Font Awesome 5 Free";
  content: "\f00c";
  font-weight: 900;
}
ol.check_list li:before {display: none;}
ol.check_list {list-style-type: decimal; width: 70%; margin-left: auto; margin-right: auto;}
.col-md-6 .check_list {width: 70%; margin-left: auto; margin-right: auto;}
.txt_bl {color: #112c86; font-weight: bold; text-align: center;}
.txt_wh {color: #ffffff; font-weight: bold; text-align: center;}
#about .progress_box h3 {color: #0d1c1f; text-align: left; font-size: 80%; font-weight: bold; margin: 1em 0;}

/* Progress bars */
.progress_box {max-width: 60%; margin: 0 auto;}
.progress {
  overflow: visible;
  height: 15px;
  background-color: #dddddd;
}

.progress-bar {
  position: relative;
  background-color: #337ab7;
}

.progress-bar.pb-dark {
  background: #111;
}

.progress-bar span {
  position: absolute;
  display: block;
  right: -0px;
  top: -24px;
  opacity: 0;
  line-height: 12px;
  font-size: 12px;
  color: #337ab7;
  font-weight: bold;
  padding: 4px 0px;
}

.progress-bar span:after {
  display: inline-block;
  content: "%";
}

  .side-image img {
    display: block;
    position: relative;
    margin: 0 auto 0 auto;
    padding: 0;
    top: 40%;
  }

#flow .alt-services-image p {
  color: #1d3c76;
  margin-top: 15px;
  font-size: 90%;
}
#flow p {text-align: center;}
.flow_box {
  display: flex;
  padding: 0;
}
.flow_box li {width: 100%; position: relative; text-align: center; list-style-type: none; margin: 1em;}
.flow_box li:first-child {margin-left: 0;}
.flow_box li:last-child {margin-right: 0;}
.flow_box li:last-child:after {display: none;}
.flow_box li span {display: block; text-align: center; margin: 0 auto 10px auto; background: yellow; width: 30px; height: 30px; border-radius: 30px;}
.flow_box li:after {
  display: block;
  position: absolute;
  right: -15%;
  top: 42%;
  content: "\f0da";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-size: 180%;
 }
 
.hikaku {width: 100%; border: 1px solid #cccccc; background: #ffffff; border-collapse: collapse; margin: 5em 0 3em 0;}
.hikaku th, .hikaku td {text-align: center; border: 1px solid #cccccc; padding: 15px 12px;}
.hikaku th {background: #efefef;}
.hikaku td span {display: block; font-size: 80%;}
.hikaku td:first-child {white-space: nowrap;}
.hikaku th:first-child, .hikaku td:first-child {background: transparent; border-right: 3px solid rgba(48, 187, 219, 1.0);}
.hikaku th:nth-child(2), .hikaku td:nth-child(2) {background: rgba(48, 187, 219, 0.1); border: 3px solid rgba(48, 187, 219, 1.0) !important; font-size: 120%;}

.txt_big {font-size: 180% !important; font-weight: bold; margin-bottom: 1.7em;}

.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: #112c86;
  font-weight: bold;
  margin: 0 auto;
  text-align: center;
}
.features-icon img {width: 60%; text-align: center; margin: 0 auto;}

.features-title {font-size: 18px; font-weight: bold;}
h3.features-title span {display: block; font-size: 80%; margin-top: 5px;}

.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: #112c86;
  font-weight: 900;
  text-align: center;
  line-height: 2em;
  font-size: 300%;
}

/*--------------------------------------------------------------
	Proof
--------------------------------------------------------------*/
#chartdiv {
  margin: 3em auto 2em auto;
  position: relative;
  height: 560px !important;
}
.yajirushi {
  z-index: 999999;
  position: absolute;
  top: 18%;
  left: 25%;
}

#proof .fukidashi {border-color: #ffffff; background: none;}
#proof .fukidashi:after {border-top-color: #ffffff;}
#proof .features-item {background: none !important;}
#proof .features-item p, #proof .features-title small, #proof .features-icon {color: #ffffff !important;}
.waku {border: 1px solid #112c86; margin-top: 2em;}
.logo_list {width: 100%; list-style-type: none; margin: 1em 0; padding: 1% 0; text-align: center;}
.logo_list li {display: inline-block; margin: 1em 0; width: calc(100%/9);}
.logo_list li img {max-width: 100px;}

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


/* Video */
.video-controls-box {
  position: absolute !important;
  bottom: 40px;
  left: 0;
  width: 100%;
  z-index: 1;
}

.video-controls-box a {
  display: inline-block;
  color: #fff;
  margin: 0 5px 0 0;
}

/*--------------------------------------------------------------
	Testimonial
--------------------------------------------------------------*/
#testimonial {margin-bottom: -50px;}
#testimonial h2 small {color: #ffffff !important;}
#testimonial .check_list {width: 100% !important;}
#testimonial .check_list li {font-size: 80%; color: #555555; border: none; background: rgba(12,84,255,0.1);}

.testimonials-slider {
  position: relative;
  font-weight: bold;
}

.testimonial-text {
  text-align: center;
  font-style: normal;
  font-size: 30px;
}

.testimonial-caption {
  text-align: center;
  padding: 10px 0 0;
}

.testimonial-title {
  font-size: 18px;
}

.testimonial-descr {
  font-size: 15px;
}

.balloon5 {
  width: 100%;
  margin: 1.5em 0;
  overflow: hidden;
}

.balloon5 .faceicon {
  float: left;
  margin-right: -90px;
  width: 80px;
}

.balloon5 .faceicon img{
  width: auto;
  height: auto;
  max-height: 150px;
}

.balloon5 .chatting {
  width: 100%;
}

.says {
  display: inline-block;
  position: relative; 
  margin: 5px 0 0 105px;
  padding: 17px 13px;
  border-radius: 12px;
  background: #efefef;
}

.says:after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 18px; 
  left: -24px;
  border: 12px solid transparent;
  border-right: 12px solid #efefef;
}

.youtube {
  padding: 4em 5% 0 5%;
}

/* Landing Page */

.landing-image-text {
  padding-top: 30px;
  padding-bottom: 0px;
}

.landing-image-text h2 {
	color: #0d1c1f;
	font-weight: bold;
	font-size: 180% !important;
}

#testimonial .landing-image-text h2, #proof .landing-image-text h2, #mission .landing-image-text h2 {
	font-size: 180% !important;
}
.img_intro {margin: 3em auto; text-align: center;}

.mission_txt img {padding-top: 70px;}
.mission_txt p {line-height: 1.7em;}

#testimonial, #mission, #proof {background-position: top center;}
.module-title {font-weight: bold;}
.module-title small {display: block; font-weight: bold; line-height: 1.7em; margin: 40px auto 0 auto; color: #555555;}
.bg-dark .module-title small, .bg-dark .module-title small a {color: #ffffff;}
.bg-dark .module-title small a {text-decoration: underline;}
.bg-dark .module-title small a:hover {text-decoration: none;}
.module-title span {display: block;}
#proof .module-title span {display: inline-block !important;}

.title {
	text-align: center;
	color: #FFF;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	letter-spacing: 15px;
}

.title h2 {
	background-image: url("https://media.giphy.com/media/24FQKrld82giZfXVcu/giphy.gif");
	background-size: cover;
	background-position: center;
	color: transparent;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	-moz-background-clip: text;
	-webkit-background-clip: text;
	-o-background-clip: text;
	-ms-background-clip: text;
	text-transform: uppercase;
	font-size: 160px;
	font-weight: 900 !important;
	line-height: 1.1em;
	padding: 0 10px;
	margin: 10px 0;
}

.title h2 span {font-size: 60%;}
/* styling my button */

.white-mode {
	text-decoration: none;
	padding: 7px 10px;
	background-color: #122;
	border-radius: 3px;
	color: #FFF;
	transition: .35s ease-in-out;
	position: absolute;
	left: 15px;
	bottom: 15px;
}

.white-mode:hover {
	background-color: #FFF;
	color: #122;
}

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

.btn_other strong {color: #e8340c;}

/*--------------------------------------------------------------
	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: 30px;
}

.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: #e12f44;
  border-bottom: 4px solid #98202e;
  color: #fff;
  font-size: 24px;
}

.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: #98202e !important;
  color: #fff !important;
  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-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;
}

.rotate {
  text-shadow: none !important;
}

.module-title {
  position: relative;
  letter-spacing: 4px;
  text-align: center;
  font-size: 33px;
  color: #0d1c1f;
  margin: 0 0 45px;
}

.module-subtitle {
  text-align: center;
  font-size: 30px;
  color: #0d1c1f;
  margin-bottom: 30px;
}

.module-icon {
  text-align: center;
  font-size: 32px;
  margin-bottom: 20px;
}

.module-title + .module-subtitle {
  margin-top: -35px;
}

.color_logo {color: #0d1c1f !important;}

.alt-module-subtitle {
  display: table;
}

.alt-module-subtitle h5 {
  display: table-cell;
  white-space: pre;
  padding: 0 8px;
  color: #0d1c1f;
}

.landing-reason .module-title + .module-subtitle {
  margin-top: -60px;
  margin-bottom: 40px;
}

.module-title, .module-subtitle, .titan-title-size-4, .gradient, .content-box-title, .font-alt, .btn.btn-border-w, h1, h2, h3, h4, h5, h6, .navbar-custom .nav li > a, .btn.btn-circle, .btn.btn-d, .alt-features-title, .fl_left, .fl_right {
  transform: rotate(.03deg);
}

.content-box-title {text-align: center; font-weight: bold; color: #112c86;}
#jirei .content-box-title, #mission .content-box-title {font-size: 110%; line-height: 1.6em; margin-bottom: 20px;}
#jirei .content-box-title span, #mission .content-box-title span {
  display: block;
  font-size: 120%;
  padding: 0.5em 0;
  border-top: solid 1px #999;
  border-bottom: solid 1px #999;
  margin-bottom: 1.6em;
}

.module-subtitle span {background:rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #ffff7f 0%) repeat scroll 0 0; padding: 0;}

.bg-blue {
  background-color: rgba(44, 91, 177, 0.9);
  color: #FFFFFF;
}

.bg-blue .color-golden {
  color: #ffff7f;
}

/* Caption */
.titan-caption {
  position: relative;
  display: table;
  height: 100%;
  width: 70%;
  margin: 0 auto;
}

.titan-caption {
  position: relative;
  display: table;
  height: 100%;
  width: 100%;
  margin: 0 auto;
}

.caption-content {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
}

/*--------------------------------------------------------------
	Preloader
--------------------------------------------------------------*/
.page-loader {
  position: fixed;
  background: #000;
  bottom: 0;
  right: 0;
  left: 0;
  top: 0;
  z-index: 9998;
}

.loader {
  position: absolute;
  border-left: 2px solid #ffffff;
  border-top: 2px solid rgba(255, 255, 255, 0.2);
  border-right: 2px solid rgba(255, 255, 255, 0.2);
  border-bottom: 2px solid rgba(255, 255, 255, 0.2);
  height: 46px;
  width: 46px;
  left: 50%;
  top: 50%;
  margin: -23px 0 0 -23px;
  text-indent: -9999em;
  font-size: 10px;
  z-index: 9999;
  -webkit-animation: load 0.8s infinite linear;
  -moz-animation: load 0.8s infinite linear;
  ms-animation: load 0.8s infinite linear;
  o-animation: load 0.8s infinite linear;
  animation: load 0.8s infinite linear;
}

.loader,
.loader:after {
  border-radius: 50%;
  width: 46px;
  height: 46px;
}

@-webkit-keyframes load {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

@keyframes load {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}


/*--------------------------------------------------------------
	Case
--------------------------------------------------------------*/
.cp_box *, .cp_box *:before, .cp_box *:after {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.cp_box {
	position: relative;
}
.cp_box label {
	position: absolute;
	z-index: 1;
	bottom: 0;
	width: 100%;
	height: 140px; /* グラデーションの高さ */
	cursor: pointer;
	text-align: center;
	/* 以下グラデーションは背景を自身のサイトに合わせて設定してください */
	background: linear-gradient(to bottom, rgba(92, 195, 216, 0) 0%, rgba(92, 195, 216, 0.95) 90%);
	margin-bottom: 0;
}
.cp_box label.cp02 {background: linear-gradient(to bottom, rgba(252, 252, 252, 0) 0%, rgba(252, 252, 252, 0.95) 90%);}
.cp_box input:checked + label {
	display: none;
	background: inherit; /* 開いた時にグラデーションを消す */
}
.cp_box label:after {
	line-height: 2.5rem;
	position: absolute;
	z-index: 2;
	bottom: 20px;
	left: 50%;
	width: 64rem;
	font-family: FontAwesome;
	content: '\f13a'' もっとみる';
	transform: translate(-50%, 0);
	letter-spacing: 0.05em;
	color: #4ca2b3;
	padding: 15px;
	border: 2px solid #4ca2b3;
	border-radius: 30px;
	background-color: #ffffff;
}
.cp_box input {
	display: none;
}
.cp_box .cp_container {
	overflow: hidden;
	height: 630px; /* 開く前に見えている部分の高さ */
	transition: all 0.5s;
}
.cp_box .cp_container02 {
        overflow: hidden;
	height: 1080px;
	transition: all 0.5s;
}
.cp_box input:checked + label {
	/* display: none; 閉じるボタンを消す場合解放 */
}
.cp_box input:checked + label:after {
	font-family: FontAwesome;
	content: '\f139'' 閉じる';
}
.cp_box input:checked ~ .cp_container, .cp_box input:checked ~ .cp_container02 {
	height: auto;
	padding-bottom: 80px; /* 閉じるボタンのbottomからの位置 */
	transition: all 0.5s;
}

#testimonial caption {caption-side: bottom; text-align: right;}
#testimonial table {width: 80%; border: 1px solid #112c86; border-collapse: collapse; margin: 0 10%;}
#testimonial table tr {background: rgba(0,91,172,0.1);}
#testimonial table tr:nth-child(odd) {background: rgba(0,91,172,0.2);}
#testimonial table th {text-align: center; background: #112c86; color: #ffffff; padding: 15px; border: 1px solid #dddddd;}
#testimonial table td {border: 1px solid #112c86; padding: 15px; text-align: center;}
#testimonial .module-icon {
  font-size: 300%;
  color: #112c86;
}
#testimonial .features-item {
  padding: 2em 1em;
  margin-top: 3em;
  border: 1px solid #112c86;
  border-top: 5px solid #112c86;
}

.brd_colorful {
  border-top: 4px solid #f6ee41;
  border-right: 4px solid #e8340c;
  border-bottom: 4px solid #5ac2d8;
  border-left: 4px solid #14a83b;
}

.box-shadow {box-shadow: 0 0 4px rgba(0,0,0,0.3) inset;}

/*--------------------------------------------------------------
	Mission
--------------------------------------------------------------*/
#mission h3 {font-size: 20px; font-weight: bold; padding-left: 12px; line-height: 1em; margin-bottom: 15px;}
#mission h3.txt_bl {border-left: 7px solid #112c86;}
#mission h3.txt_gr {border-left: 7px solid #112c86;;}
.highlight {
 display: inline !important;
 background: linear-gradient(transparent 60%, rgba(255, 239, 107, 0.6) 60%);
 font-weight: bold;
 line-height: 1.7em;
}


#testimonial .module-title span, #proof .module-title span {display: inline-block;}

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

/*--------------------------------------------------------------
	Footer
--------------------------------------------------------------*/
.footer {
  padding: 30px 0;
  border-top: 1px solid #cccccc;
}

.footer .copyright {
  font-size: 10px;
  padding-top: 15px;
  margin: 0;
  text-align: center;
}

.footer .footer_logo {
  clear: both;
  padding-top: 10px;
}

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

/*--------------------------------------------------------------
	Flow
--------------------------------------------------------------*/
.team-item {
  position: relative;
  text-align: center;
  margin-bottom: 30px;
}

.team-image {
  position: relative;
  overflow: hidden;
}

.team-image img {
  width: 100%;
}

.team-image:after {
  position: absolute;
  background: transparent;
  content: " ";
  display: block;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 1;
}

.team-detail {
  position: absolute;
  width: 100%;
  opacity: 0;
  bottom: 100%;
  left: 0;
  z-index: 2;
  text-align: center;
  font-size: 12px;
  color: #aaa;
  padding: 20px;
}

.team-detail h5 {
  font-size: 16px;
}

.team-detail p {
  font-size: 14px;
}

.team-social a {
  display: inline-block;
  color: #aaa;
  padding: 5px 6px;
}

.team-social a:hover {
  color: #FFF;
}

.team-descr {
  margin: 20px 0 0;
}

.team-name {
  font-size: 18px;
  color: #fff;
  font-weight: bold;
  text-align: center;
}

.team-role {
  font-size: 18px;
  color: #ccc;
  font-weight: bold;
  text-align: center;
}

/*--------------------------------------------------------------
	INFORMATION
--------------------------------------------------------------*/
.contact_extra table {
  width: 100%;
  margin-top: 30px;
}

.contact_extra table th,.contact_extra table td {
  font-size: 13px;
  padding: 10px;
}

.contact_extra table tr {
}

.contact_extra table td ul {
  margin: 0;
  padding: 0;
}

.contact_extra table td ul li {
  list-style-type: none;
  font-size: 12px;
}

.contact_extra table th {white-space: nowrap;}


#contactForm small {font-weight: normal;}
#contact h3 {font-weight: bold;}
.under_line {
  font-size: 18px;
  line-height: 1em;
  padding-bottom: 0.8em;
  border-bottom: solid 2px #ededed;
  position: relative;
  margin: 30px 0;
}
.under_line:after {
  position: absolute;
  content: " ";
  display: block;
  border-bottom: solid 2px #112c86;
  bottom: -3px;
  width: 80px;
}
.under_line span {
  text-align: right;
  display: inline-block;
  position: absolute;
  right: 0;
  font-weight: normal;
}

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

input.hissu {background: rgba(232, 52, 12, 0.1) !important;}

#confirm {font-size: 15px; width: 100%; margin-bottom: 3%; color: #fff;}
#confirm tr th {width: 30%; padding-bottom: 15px;}

#after_sent {
  background: #112c86;
  color: #ffffff;
  font-weight: bold;
  text-align: center;
  margin: 15px auto 30px auto;
  line-height: 3em;
}

/* オーバーレイボタン */
#olayBtn {
	position: fixed;
	width: 100%;
	background: rgba(255, 255, 255, 0.6);
	box-sizing: border-box;
	z-index: 1000;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden;
}
#olayBtn div {
	margin: 0 !important;
	padding: 5px 15px 10px 15px !important;
	visibility: visible !important;
}
#olayBtn .btn-border-o {display: block; font-size: 200%; margin: 0 auto; padding: 10px;}
#olayBtn .btn_other span {margin-bottom: 0;}

/*--------------------------------------------------------------
	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-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%;}
  .content-box-image {margin: 0 auto; text-align: center;}
}

@media (max-width: 1200px) {
  #home:before {background-size: 80%;}
  #home:after {background-size: 80%; background-position: right bottom;}
  .alt-features-item {
    margin: 0;
  }
  #head_logo a span, #head_logo span {display: none !important;}
}

@media (max-width: 1080px) {
  #home:before {background-size: 70%;}
  #home:after {background-size: 70%; background-position: right bottom;}
  .home-section {padding-top: 15px;}
  .btn_other {font-size: 140%;}
  
  /* Navbar */
  .navbar-custom {
    letter-spacing: 1px;
  }
   .title h2 {font-size: 54%;}
   #mainImg_txt .col-sm-6 {width: 80%;}
   #mainImg_txt {top: 75%; margin-left: 30px;}
}

@media (max-width: 991px) {
.only_tab {display: block !important;}
  .titan-title-size-5 {font-size: 180px;}
  #mainImg_txt h2 {font-size: 30px;}
  #mainImg_txt p br {display: none;}
  .btn_other, .btn-border-o {font-size: 120%;}
  #flow .alt-services-image img {max-width: 60%; margin: 0 auto;}
  .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;
  }
  .title h2 {font-size: 54%; letter-spacing: 3px;}
  /* Headers */
  .titan-title-size-3 {
    font-size: 36px;
  }
  .titan-title-size-4 {
    font-size: 24px;
    padding: 10px 0;
    line-height: 1.6em;
  }
  .only_pad {display: block !important;}
   #mainImg_txt {top: 65%; margin-left: 30px;}
   .col-md-6-right, .col-md-offset-6-right {width: 100%; float: none; margin-left: 0;}
}

@media (max-width: 767px) {
  #home:before {background-size: 60%;}
  #home:after {background-size: 60%; background-position: right bottom;}
  #head_logo a span {display: block !important;}
  .navbar-nav>li>a {padding-top: 20px !important; padding-bottom: 20px !important;}
  .bg_bl h2 {padding: 10px 15px; font-size: 160%;}
  iframe {width: 90%;}
  .contents {margin-bottom: 0;}
  .contents:before {background-size: 50%;}
  .fukidashi_down {padding: 15px;}
  #mainImg_txt h2 {margin-bottom: 30px;}
  #mainImg_txt {top: 50% !important;}
  #mainImg_txt .main_txt p {font-size: 1.2em;}
  #mainImg_txt .main_txt .flex_box {margin-top: 1em;}
  #mainImg_txt .main_txt .flex_box li {padding: 10px 5px;}
  .flex_box {display: block;}
  .flex_box li {padding: 10px;}
  #mainImg_txt .main_txt p br {display: none;}
  #mainImg_txt .btn_other span {font-size: 230%; text-align: center; margin-left: 0;}
  #mainImg_txt .btn.btn-border-o {font-size: 240%;}
  .btn_other span {margin-left: 0 !important;}
  #about .progress_box h3 {margin-bottom: 1.7em;}
  #about .features-item:after {position: static; text-align: center; content: "\f0dd"; margin-top: 1em;}
  .fukidashi_down:after {left: 46%;}
  .landing-image-text {padding-top: 0;}
  .logo_list, .logo_list li {margin: 1em 0; padding: 0;}
  .logo_list li {width: calc(100%/5);}
  .logo_list li img {max-width: 100px;}
  .side-image img {
  display: block;
  position: relative;
  top: 40%;
  }
  .negative_list {margin: 3em 1em 0 1em;}
  .testimonial-text {text-align: center;}
  .balloon5 .faceicon {width: 60px; margin-right: -70px;}
  .says {margin-left: 85px;}
  .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;}
.check_list {width: 100%;}
#proof .module-title span {margin-bottom: 0.5em;}
.testimonial-caption {text-align: left; margin: 0 15px;}
.testimonial-title, .testimonial-descr {display: inline-block; text-align: left;}
.cp_box .cp_container {
	height: auto;
}
.cp_box label {
	display: none;
}
.cp_box .cp_container02 {height: 660px;}
.cp_box label.cp02 {display: block;}
.cp_box label.cp02:after {width: 100%;}

  /* Navbar */
  .only_pc {display: none !important;}
  .only_sp {display: block !important; line-height: 0;}
  .home-section{background-position: 55% center;}
  .kv {margin-top: 0; background-position: 60%;}
  #mainImg_txt .col-sm-6 {width: 100%;}
  #mainImg_txt h2 {font-size: 30px; letter-spacing: 0;}
  #mainImg_txt h2 span {font-size: 16px;}
  #mainImg_txt p {font-size: 14px; letter-spacing: 0px; line-height: 1.4em; margin-bottom: 1em;}
  #mainImg_txt .btn_other {margin: 10px auto !important;}
  .module-title, .landing-image-text h2 {font-size: 20px; margin-top: 15px;}
  .module-title small, #jirei .content-box-title, .testimonial-title, #mission .content-box-title {font-size: 15px !important;}
  .negative_list li {font-size: 1em;}
  #jirei .content-box-title {text-align: left;}
  #jirei .content-box-title span {text-align: center;}
  #mission .content-box-title, #mission .features-item p, #contact .module-title small {text-align: left !important;}
  #mission .features-item p {margin: 0 12px;}
  .features-item p, .testimonial-descr {font-size: 14px;}
  .testimonial-text, .fukidashi h3 {font-size: 18px;}
  .frame {font-size: 22px;margin-top: 15px;}
  .landing-image-text h2, #reason h4 {text-align: center; margin-top: 15px;}
  #reason h4 {font-size: 20px;}
  .font-alt span, #reason h4 span {display: block;}
  .module-subtitle {font-size: 18px;}
  .txt_wh, .sp_15 {font-size: 18px;}
  .panel-body dl dd {margin-bottom: 4%;}
  .btn-warning {font-size: 120%;}
  .ls_s {display: inline !important;}
  .navbar-custom .navbar-nav {
    letter-spacing: 3px;
    margin-top: 1px;
    margin-bottom: 0;
    background: rgba(255, 255, 255, 0.1)
  }
  .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: "\f107";
  }
  .navbar-custom .nav > .open > .dropdown-toggle:after,
  .navbar-custom .dropdown-menu .dropdown.open .dropdown-toggle:after {
    right: 7px;
    content: "\f106";
  }
  .navbar-custom .navbar-nav > li:last-child.navbar-cart > a {
    padding-left: 15px;
  }
  .navbar-custom .cart-item-number {
    display: none;
  }
  .navbar-custom .navbar-cart > a:after {
    content: "\f107";
  }
  .navbar-custom .navbar-cart-item a {
    border: 0 !important;
  }
  .navbar-toggle .icon-bar {text-align: center; margin: 0 auto;}
  .dropdown-menu.cart-list {
    text-align: left;
    border-bottom: 1px solid rgba(73, 71, 71, 0.15) !important;
  }
  .navbar-cart-item {
    border: none;
    border-bottom: 1px solid rgba(73, 71, 71, 0.15) !important;
    padding-bottom: 10px;
  }
  .navbar-cart-img {
    display: none;
  }
  .navbar-cart-title {
    white-space: normal;
    padding: 0;
    margin-left: 0;
  }
  /* Headers */
  .titan-title-size-1 {
    letter-spacing: 2px;
    font-size: 14px;
  }
  .titan-title-size-2 {
    line-height: 1.3;
    letter-spacing: 2px;
    font-size: 16px;
    opacity: .8;
  }
  .titan-title-size-3 {
    letter-spacing: 4px;
    font-size: 26px;
  }
  .titan-title-size-4 {
    letter-spacing: 0px;
    font-size: 13px !important;
    line-height: 1.6em;
    margin-bottom: 0px;
    padding: 5px 0;
  }
  .titan-title-size-5 {
    font-size: 64px;
    letter-spacing: 0px;
    line-height: 1.2em;
    padding: 10px 0;
  }
  
  .titan-title-size-5 small {
    letter-spacing: 0px;
    font-size: 18px !important;
    line-height: 1.6em;
    margin-bottom: 0px;
    padding: 5px 0;
  }
  
  .titan-title-size-4 br {display: block;}
  
  .btn.btn-border-w {
    font-size: 140%;
  }
  /* Features */
  .features-item {
    margin: 0 0 30px;
  }
  .alt-features-item {
    padding-left: 0;
    margin: 0 0 30px;
  }
  .alt-features-title, .sp_center {display: block; text-align: center;}
  .alt-features-icon {
    position: static;
    width: auto;
    margin: 0 auto 8px;
    text-align: center;
    font-weight: bold;
  }

  .parallax-bg {background-size: auto; background-attachment: fixed;}
  /* Callout */
  .callout-text {
    margin: 0 0 30px;
  }
  .callout-text,
  .callout-btn-box {
    text-align: center;
  }
  .post.mb-0 {
    margin-bottom: 40px !important;
  }
  .footer {
    text-align: center;
  }
  .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;}
.title h2 {font-size: 68%; line-height: 1em; margin: 0;}
.title h2 span {display: inline;}

.titan-title-size-4 {font-size: 16px !important;}

.check_list {width: 90%; margin: 0 auto;}
.features-title {margin-bottom: 1.7em;}
#testimonial .module-title, #proof .module-title {margin-bottom: 30px;}
#testimonial table {margin: 2% 5%; width: 90%;}
#testimonial table th, #testimonial table td {font-size: 100%;}
.check_list li {margin-left: 0;}
.fukidashi_down h3 {font-size: 20px !important; line-height: 2em;}

.content-box-title {font-size: 120%; margin-bottom: 30px;}
.content-box-image img {display: block; max-width: 90%; margin: 0 auto; text-align: center;}
.features-item {margin-left: auto; margin-right: auto;}
.footer .footer_link, .footer .footer_logo {float: none; clear: both; text-align: center; margin: 60px auto 0 auto; padding: 0;}
.footer .footer_logo {max-width: 50%;}
.btn_top, .btn_other {font-size: 50%; margin: 10px 15px !important;}
.fukidashi_down .btn_other {margin: 10px 0 !important;}
.btn.btn-border-o {width: 100%; font-size: 240%; padding: 16px 0; letter-spacing: 1px;}
.bg_sptop {margin-top: 15px;}
.bg_sptop h3 {color: #0d1c1f; font-size: 20px; font-weight: bold;}
.bg_sptop p {text-align: center; line-height: 1.5em; font-size: 13px;}
.sns-footer {width: 100%;}
.sns-footer ul li {float: none; display: inline-block;}
.sns_ul_sp li {list-style-type: none; float: left; padding-right: 5px; padding-top: 5px;}
.sns_ul_sp li iframe {vertical-align: bottom;}
.sns_ul_sp li a {padding: 7px 0 0 0 !important;}
.footer p img {max-width: 60% !important; margin-top: 20px;}
#custom-collapse .btn.btn-border-o {width: 90%; margin: 15px; color: #ffffff; font-weight: bold; font-size: 110%; border-bottom: 4px solid #35717d !important;}
#custom-collapse .btn.btn-border-o:hover {border-bottom: 4px solid #35717d !important;}

.col-sm-3, .col-sm-4 {width: 100%;}
.mission_txt {margin: 0 15px;}
.mission_txt .landing-image-text {padding-top: 0;}

/* オーバーレイボタン */
#olayBtn div {
	display: none;
}

#olayBtn {
	position: fixed;
	width: 100%;
	background: transparent;
	padding: 0;
	box-sizing: border-box;
	z-index: 1000;
}
#olayBtn ul {
	overflow: hidden;
	margin: 0px !important;
	padding: 0px !important;
	visibility: visible !important;
}
#olayBtn ul li {
	display: table;
	width: calc(100% / 2);
	margin: 0;
	float: left;
}
#olayBtn ul li:last-of-type {
	margin: 0;
}
#olayBtn ul li:nth-child(1) {
	background : #000;
}

#olayBtn ul li:nth-child(2) {
	background : #000;
        box-shadow: 1px 0 0 0 #dddddd inset;	 
}

#olayBtn ul li a {
	display: table-cell;
	color: #fff;
	vertical-align: middle;
	text-align: center;
	height: 60px;
	text-decoration: none;
	font-size: 12px;
	border: none;
}
#olayBtn ul li a:hover, #olayBtn ul li a:active {
	background: #777777;
}
#olayBtn ul li a i.fa,#olayBtn ul li a i.fab,#olayBtn ul li a i.fas {
	display: block;
	color: #fff;
	width: 36px;
	height: 36px;
	margin: 0 auto;
	background-repeat: no-repeat;
	background-size: 100% auto;
}

.fa-2x {
    font-size: 2em;
}

}

@media only screen and (max-width: 640px) {
.hikaku td:nth-child(2) {font-size: 100%;}
.scroll{overflow: auto !important; white-space: nowrap;}
.scroll::-webkit-scrollbar{height: 5px !important;}
.scroll::-webkit-scrollbar-track{background: #F1F1F1 !important;}
.scroll::-webkit-scrollbar-thumb {background: #BCBCBC !important;}

.home-section {padding-top: 75px;}
#mainImg {height: 100% !important;}
#mainImg .kv {top: 10% !important;}
#mainImg_txt {margin-left: 15px; top: 20% !important;}
#mainImg_txt .mb-60 {margin-bottom: 15px !important;}
#mainImg_txt p {letter-spacing: 1px;}
#mainImg_txt h2 {font-size: 24px; letter-spacing: 1px;}
.negative_list {margin: 1em 15px;}
.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;}
#head_logo a {position: relative; top: 1px;}
.parallax-bg {background-size: auto; background-attachment: scroll;}

#head_logo a {font-size: 13px;}
.module {padding: 45px 0 !important;}
h2,h3 {font-weight: bold;}
.title {letter-spacing: 0;}
.title h2 {font-size: 82%; letter-spacing: 2px;}
.title h2 span {font-size: 45%;}
.fukidashi h2 img, .under_l img {max-width: 60%;}

.contents_inner {padding: 0 0 30px 0 !important;}
.mt-60 {margin-top: 30px;}
.bg_white {background: #fff; padding: 15px 0;}
.check_list {width: 60%;}

.yajirushi {
    top: 48% !important;
    left: 20% !important;
    max-width: 65%;
}
.bg_sptop h3 {font-size: 23px;}
.btn_top span {font-size: 240%;}
.btn.btn-border-o {font-size: 260%;}
.bg_sptop p {font-size: 16px; font-weight: bold;}

.slide-wrap {
  display: flex;
}

.slide-wrap {
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
  }
  .slide-wrap div.col-md-6, .slide-wrap div.col-md-4 {
    flex: 0 0 80%;
  }
  
  .slide-wrap div.col-md-6:after, .slide-wrap div.col-md-4:after {
    display: block;
    content: "▶︎";
    font-size: 180%;
    position: absolute;
    bottom: 50%;
    right: -4%;
  }
  
  .slide-wrap div.col-md-6:last-child:after, .slide-wrap div.col-md-4:last-child:after {
  display: none;
  }

.content-box {font-size: 18px; line-height: 1.5em;}
.module, .module-small {padding: 70px 0;}
.module-title {margin: 0 0 45px;}
.features-item {padding: 25px 15px 5px 15px;}
.btn_other span {font-size: 230%;}

.footer_link {width: 100%;}
#testimonial table tr th, #testimonial table tr td {font-size: 12px; line-height: 1.5em; white-space: nowrap;}
#main {margin: 0 !important; padding: 0 !important; overflow: !important;}
.check_list {width: 100% !important;}
.progress_box {max-width: 70%;}
}

@media only screen and (max-width: 480px) {
#mainImg .kv {top: 8% !important;}
#mainImg_txt img {max-width: 40%;}
#mainImg_txt h2 {font-size: 20px; margin-bottom: 15px;}
#home:before {background-size: 50%;}
#home:after {background-size: 50%; background-position: right bottom;}
.fukidashi h2 img, .under_l img {max-width: 50%; display: block; text-align: center; margin: 0 auto; padding-bottom: 5px;}
#contact h3 {font-size: 16px;}
.form_label, table#confirm th {width: 100% !important;}
}

@media only screen and (max-width: 375px) {
.navbar-brand img {height: 24px;}
#head_logo a {font-size: 10px;}
#home .titan-title-size-4 {font-size: 120% !important;}
.bg_bl h2 {font-size: 24px;}
.bg_sptop h3 {font-size: 20px;}
.title h2 {font-size: 70%;}
h2.module-title, .txt_big {font-size: 170%;}
#custom-collapse .btn.btn-border-o, .btn.btn-border-o {font-size: 15px;}
.content-box-title {font-size: 20px !important;}
#head_logo a {top: 1px;}
.check_list {width: 90%;}
}


@media only screen and (max-width: 320px) {
.navbar-brand img {height: 15px;}
#head_logo a {font-size: 10px;}
#home .titan-title-size-4 {font-size: 120% !important;}
.bg_sptop h3 {font-size: 18px;}
.title h2 {font-size: 60%; letter-spacing: 5px;}
h2.module-title {font-size: 180%;}
.btn_top, .btn_other {font-size: 50%;}
#mainImg_txt .btn_other span {font-size: 180%;}
#custom-collapse .btn.btn-border-o, .btn.btn-border-o {font-size: 15px;}
.content-box-title {font-size: 18px !important;}
}

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

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