@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Shippori+Mincho:wght@500;600&display=swap');
@import '../css/bootstrap.min.css';
@import '../css/font-awesome.min.css';

nav .logo {
  float: left;
  margin-left: 30px;
}
nav .logo a {
  font-size: 28px;
  line-height: 80px;
  text-transform: uppercase;
  color: #CACACA;
  text-decoration: none;
  letter-spacing: 0.5px;
}
nav .logo em {
  font-style: normal;
  font-weight: 200;
}
nav {
    background-color: rgba(250,250,250,0.2);
    height: 80px;
    position: fixed;
    width: 100%;
    left: 0;
    top: 0;
    z-index: 300;
    box-shadow: 0px 2px 10px 0px rgba(0,0,0,0.5);
}
.b {
    background-image: url(../img/topber.png);
}
.menu-icon {
    background: transparent;
    border: 2px solid #CACACA;
    width: 50px;
    height: 50px;
    margin: 15px 39px 0 auto;
    position: relative;
    cursor: pointer;
    transition: background 0.5s;
    border-radius: 5px;
}
.menu-icon span,
.menu-icon span:before,
.menu-icon span:after {
    cursor: pointer;
    border-radius: 1px;
    height: 2px;
    width: 35px;
    background-color: #CACACA;
    position: absolute;
    left: 12%;
    top: 50%;
    display: block;
    content: '';
    transition: all 0.5s ease-in-out;
}
.menu-icon span:before {
  left: 0;
  top: -10px;
}

.menu-icon span:after {
  left: 0;
  top: 10px;
}

.menu-icon.active {
  background: #163590;
}

.menu-icon.active span {
  background-color: transparent;
}

.menu-icon.active span:before,
.menu-icon.active span:after {
  top: 0;
}

.menu-icon.active span:before {
  transform: rotate(135deg);
}

.menu-icon.active span:after {
  transform: rotate(-135deg);
}
.overlay-menu {
    background-color: rgba(219,219,219,0.95);
    color: #2F0AF6;
    position: fixed;
    z-index: 100;
    left: 0;
    top: 0;
    height: 100%;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    width: 100%;
    padding: 50px 0;
    opacity: 0;
    text-align: center!important;
    transform: translateY(-100%);
    transition: all 0.5s;
}
.overlay-menu.open {
  opacity: 1;
  transform: translateY(0%);
}
.overlay-menu .main-menu {
  transform: translateY(50%);
  opacity: 0;
  transition: all 0.3s;
  transition-delay: 0s;
}
.overlay-menu.open .main-menu {
  transition: all 0.7s;
  transition-delay: 0.7s;
  opacity: 1;
  transform: translateY(0%);
}

.overlay-menu .main-menu:nth-child(2) {
  transition-delay: 0s;
}
.container .row .main-menu {
	margin-left: auto;
	margin-right: auto;
}
.overlay-menu.open .main-menu:nth-child(2) {
  transition-delay: 1.25s;
}
.overlay-menu {
  overflow: scroll;
}
.overlay-menu::-webkit-scrollbar {
  display: none;
}
.overlay-menu ul {
  list-style: none;
  margin-top: 80px;
  padding: 0px;
}
.overlay-menu ul li {
  padding: 15px 0px;
}
.overlay-menu ul li a {
    font-size: 18px;
    font-weight: 400;
    color: #163590;
    text-decoration: none;
    transition: all 0.5s;
}
.overlay-menu ul li a:hover {
    color: rgba(251,126,1,0.78);
}
.overlay-menu p {
    margin-top: 60px;
    font-size: 13px;
    text-transform: uppercase;
    color: #062C91;
    font-weight: 200;
    letter-spacing: 0.5px;
    text-align: center;
}
@media only screen and (min-width: 300px) and (max-width: 479px) {
	.navbar-brand img{
		width: 75%!important;
		padding-top: 5px!important;
	}}
/*----------- nav -----------*/




* {
    margin: 0;
    padding: 0;
    font-size: medium;
}
p{
	text-align:justify;
	word-break:break-all; 
  text-justify:inter-ideograph;
  text-justify:inter-character;
  word-wrap:break-word;
  overflow-wrap:break-word;
}
.panel.single-accordion p a{
	font-size: 13px;
}
.contact-heading-text.text-center.mb-100 p img{
    padding-bottom: 4px;
}
.single-service-area.text-center.mb-100 p img{
	padding-bottom: 4px!important;
}
.blog-content p img{
	padding-bottom: 4px!important;
}

.blog-content table{
	margin-top: -20px;
    margin-left: auto;
    margin-right: auto;
	margin-bottom: 20px;
    width: 75%;
    text-align:left;
    color: #303030;
    font-weight: 400;
    line-height: 35px;
    font-size: 12pt;
}
.blog-content table tr td{
	padding-left: 10%;
}

.top {
	margin-top: 75px;
}
.single-cool-fact.d-flex.align-items-center .gimg .counter-area .no2{
	
	background-image:url("../img/yp-t.png");
}
.single-cool-fact.d-flex.align-items-center .counter-area h5 {
    background-image: url(../img/y-m.png);
}
.single-cool-fact.d-flex.align-items-center .gimg .counter-area h5 {
    background-image: url("../img/yp.png");
}

.single-blog-area.text-center.mb-100.wow.fadeInUpBig .blog-content .c {
	margin-top: -30px;
    text-align: center;
    line-height: 20px;
}
.single-blog-area.text-center.mb-100.wow.fadeInUpBig .blog-content .c {
    font-weight: bold;
    color: #484848;
}
.single-blog-area.text-center.mb-100.wow.fadeInUpBig .blog-content .c3 {
	font-weight: 500;
	margin-top: 30px;
	margin-left: 5%;
	margin-right: 5%;
	text-align: center;
}
.single-blog-area.text-center.mb-100.wow.fadeInUpBig .blog-content .pr{
	margin-left: 0px!important;
	margin-right: -10px!important;
	margin-bottom: 20px!important;
}
.single-blog-area.text-center.mb-100.wow.fadeInUpBig .blog-content p{
	margin-left: 20px!important;
}
.blog-content p b{
	margin-left: -20px!important;
}
.social-sidebar-area.bg-white .message-box {
    background-color: #1724DD;
}
.row.justify-content-center .col-10.col-md-5 .em{
	padding-bottom: 100px;
}
body {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
    overflow-x: hidden;
    padding-left: 0px;

}
.b .navbar-brand img{
	padding-bottom: 12px;
}
.row.justify-content-center .col-10 .right{
	text-align: right!important;
	
}
h1,
h2,
h3,
h4,
h5,
h6 {
    color: #1d1d1d;
    line-height: 1.2;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
}

h4 {
  position: relative;
  line-height: 1.4;
  letter-spacing: 2px;
  text-indent: 2px;
  padding:0.25em 1em;
  margin-bottom: 40px;
  display: inline-block;
  top:0;
}

h4:before, h4:after { 
  position: absolute;
  top: 0;
  content:'';
  width: 8px;
  height: 100%;
  display: inline-block;
}
h4:before {
  border-left: solid 1px black;
  border-top: solid 1px black;
  border-bottom: solid 1px black;
  left: 0;
}
h4:after {
  content: '';
  border-top: solid 1px black;
  border-right: solid 1px black;
  border-bottom: solid 1px black;
  right: 0;
}
.col-10 .contact-heading-text.text-center.mb-50 h2{
	text-align: left;
}
.row.justify-content-center .col-10 h3 {
	padding-top: 0.8em;
	font-size: 1.3rem;
}
.col-12.col-md-4 .single-service-area.text-center.mb-100 h6 {
    color: #163590;
    padding-top: 5px;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    border-bottom-color: #BBBBBB;
    border-bottom-style: solid;
    text-align: center;
    padding-bottom: 10px;
}
.col-10 .contact-heading-text.text-center.mb-100 h6 {
	font-size: 18pt;
	font-weight: 400;
	letter-spacing: 0.06em;
    text-align: center;
    padding-top: 30px;
}
.col-10 .contact-heading-text.text-center.mb-100 h6 {
}
.single-cool-fact.d-flex.align-items-center .counter-area h5 {
    font-size: medium;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 300;
    color: #d70051;
    text-align: center;
}
.single-cool-fact.d-flex.align-items-center .counter-area h5 {
    padding-bottom: 5px;
}

.single-blog-area.text-center.mb-100.wow.fadeInUpBig .blog-content .l {
    text-align: left;
    color: #303030;
    font-weight: 400;
    line-height: 35px;
    font-size: 12pt;
    padding-left: 10%;
}

.row.justify-content-center .col-10 h3{
	font-size:2rem!important;
	font-weight: 600;
}

.row.justify-content-center .col-10.col-md-5 h6 {
	font-size:1.5rem!important;
	font-weight: 600;
}

.col-10 .blog-content h3 {
    text-align: center;
    font-weight: 400!important;
    color: #040404;
    font-size: 22px;
    letter-spacing: 0.05em;
	}

.col-10 .blog-content h3 {
    position: relative;
    margin-top: 70px!important;
    margin-left: 20%;
    margin-right: 20%;
    margin-bottom: 20px;
    padding-top: 17px;
    padding-bottom: 18px;
    font-family: "Noto Sans JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
}
.col-10 .blog-content h3:before,.col-10 .blog-content h3:after {
    position: absolute;
    left: 0;
    content: '';
    width: 100%;
    height: 6px;
    box-sizing: border-box;
}
.col-10 .blog-content h3:before {
    top: 0;
    border-top: 1px solid #ddd;
    border-bottom: 2px solid #ddd;
}
.col-10 .blog-content h3:after {
    bottom: 0;
    border-top: 2px solid #ddd;
    border-bottom: 1px solid #ddd;
}
.single-blog-area.text-center.mb-100.wow.fadeInUpBig .blog-content h3{
	margin-bottom: 35px;
}
.head-border {
    display: flex;
    align-items: center;
    color: #163590;
    font-size: 30px;
	letter-spacing: 3px;
	text-indent: 3px;
    padding-left: 10px;
    padding-top: 5px;
    padding-bottom: 5px;
    margin-bottom: 25px;
    font-family: "Shippori Mincho", serif;
	font-weight: 600;
	font-style: normal;
}
.head-border:before,
.head-border:after {
    content: "";
    height: 1px;
    flex-grow: 1;
    background-color: #666;
}

.head-border:before {
    margin-right: 1rem;
	background: linear-gradient(-90deg, #666, transparent);
}

.head-border:after {
    margin-left: 1rem;
	background: linear-gradient(90deg, #666, transparent);
}  

p {
    color: #202020;
    font-size: 15px;
    line-height: 1.8em!important;
    font-weight: 300;
    text-align: justify;
    padding-top: 15px;
	font-family: "Noto Sans JP", sans-serif;
	font-optical-sizing: auto;
}
.col-12.col-sm-6.col-md-3 .single-pie-bar p {
	font-size: 13px;
    line-height: 1.5em!important;
	padding-top: 0.3em!important;
}

.row.justify-content-center .col-10.col-md-5 .c {
    color: #3146D9;
    font-weight: bold;
    text-align: left;
    padding-left: 25%;
	margin-top: -20px;
}

.single-cool-fact.d-flex.align-items-center .counter-area p {
	font-size: 14px;
	text-align: justify;
	line-height: 1.6em;	
}
.single-cool-fact.d-flex.align-items-center .counter-area p {
}

.col-10.col-md-5 .panel.single-accordion p {
    padding-left: 20px;
    text-align: justify;
}

a:focus {
    outline: 0 solid;
}

a,
a:hover,
a:focus {
    -webkit-transition: all 500ms ease 0s;
    transition: all 500ms ease 0s;
    text-decoration: none;
    outline: none;
    font-size: 14px;
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
}

#preloader {
    position: fixed;
    z-index: 9999;
    width: 100%;
    height: 100%;
    background-color: #f2f4f8;
    top: 0;
    left: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.questions-area ul li {
    display: none;
    font-size: 14px;
    font-weight: 500;
    color: #1d1d1d;
    -webkit-transition-duration: 500ms;
    transition-duration: 500ms;
}

.questions-area ul li.question-show {
    display: block;
}

.questions-area {
    padding: 0 15px;
    position: absolute;
    bottom: 100px;
    z-index: 15;
    width: 100%;
    height: auto;
    left: 0;
}

.questions-area p {
    margin-bottom: 0;
}

.showbox {
    position: relative;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 0;
}

.loader {
    position: relative;
    margin: 0 auto;
    width: 60px;
}

.loader:before {
    content: '';
    display: block;
    padding-top: 100%;
}

.circular {
    -webkit-animation: rotate 2s linear infinite;
    animation: rotate 2s linear infinite;
    height: 100%;
    -webkit-transform-origin: center center;
    transform-origin: center center;
    width: 100%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
}

.path {
    stroke-dasharray: 1, 200;
    stroke-dashoffset: 0;
    -webkit-animation: dash 1.5s ease-in-out infinite, color 6s ease-in-out infinite;
    animation: dash 1.5s ease-in-out infinite, color 6s ease-in-out infinite;
    stroke-linecap: round;
}
.single-service-area.text-center.mb-100 p img{
	margin-bottom: 0px!important;
}
.row.justify-content-center .col-10 .contact-heading-text.text-center.mb-50 p{
	text-align: justify;
}

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

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

@-webkit-keyframes dash {
    0% {
        stroke-dasharray: 1, 200;
        stroke-dashoffset: 0;
    }
    50% {
        stroke-dasharray: 89, 200;
        stroke-dashoffset: -35px;
    }
    100% {
        stroke-dasharray: 89, 200;
        stroke-dashoffset: -124px;
    }
}

@keyframes dash {
    0% {
        stroke-dasharray: 1, 200;
        stroke-dashoffset: 0;
    }
    50% {
        stroke-dasharray: 89, 200;
        stroke-dashoffset: -35px;
    }
    100% {
        stroke-dasharray: 89, 200;
        stroke-dashoffset: -124px;
    }
}

@-webkit-keyframes color {
    100%,
    0% {
        stroke: #d62d20;
    }
    40% {
        stroke: #0057e7;
    }
    66% {
        stroke: #008744;
    }
    80%,
    90% {
        stroke: #ffa700;
    }
}

@keyframes color {
    100%,
    0% {
        stroke: #d62d20;
    }
    40% {
        stroke: #0057e7;
    }
    66% {
        stroke: #008744;
    }
    80%,
    90% {
        stroke: #ffa700;
    }
}

ul,
ol {
    margin: 0;
}

ol li,
ul li {
    list-style: outside none none;
}

img {
    height: auto;
    max-width: 100%;
    padding-top: 5px;
}

.row p .m {
	padding-top: 0!important;
	padding-bottom: 3px;
	padding-right: 4px;
}
.studio-cool-facts-area.mb-100 .row p img {
	padding-left: 20px;
}
.studio-cool-facts-area.mb-100 .row .r {
	color: #d70051;
}
.row.justify-content-center .col-10 .elements-title{
	margin-top: -60px!important; 
	padding-top: -40px!important; 
}
.col-10.col-md-5 .c img {
    padding-right: 7px;
	padding-bottom: 6px;
}

.single-cool-fact.d-flex.align-items-center .counter-area img {
    text-align: center;
}
.counter-area .y img {
    width: 100%;
}

.studio-table {
    display: table;
    z-index: 9;
    position: absolute;
    width: 100%;
    height: 100%;
    margin: 0;
}

.studio-table-cell {
    display: table-cell;
    vertical-align: middle;
}

.mt-15 {
    margin-top: 15px;
}

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

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

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

.mt-100 {
    margin-top: 100px;
}

.mb-15 {
    margin-bottom: -15px;
}
.mb-20 {
    margin-bottom: 20px;
}
.mb-30 {
    margin-bottom: 30px;
}

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

.ml-15 {
    margin-left: 15px;
}

.ml-30 {
    margin-left: 30px;
}

.mr-15 {
    margin-right: 15px;
}

.mr-30 {
    margin-right: 30px;
}

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

.mb-100 {
    margin-bottom: 100px;
}
.row.justify-content-center .col-10.col-md-5 .services-progress-bar.mb-100.in {
}
.row.justify-content-center .col-10.col-md-5 .accordions.mb-100.in {
}
.row.justify-content-center .col-10.col-md-5 .accordions.mb-100.in {
}
.row.justify-content-center .col-10 .single-blog-area.text-center.mb-100.wow.fadeInUpBig {
	margin-bottom: 30px;
}

.bg-img {
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
}

.bg-gray {
    background-color: #f6f6f6;
}

.bg-transparent {
    background-color: transparent;
}

.bg-transparent-dark {
    background-color: rgba(0, 0, 0, 0.5) !important;
}

.bg-transparent-light {
    background-color: rgba(255, 255, 255, 0.5) !important;
}

.font-bold {
    font-weight: 700;
}

.font-light {
    font-weight: 300;
}

.height-500 {
    height: 500px !important;
}

.height-600 {
    height: 600px !important;
}

.height-700 {
    height: 700px !important;
}

.height-800 {
    height: 800px !important;
}

#scrollUp {
    background-color: #222;
    border-radius: 0;
    bottom: 100px;
    box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.3);
    color: #fff;
    font-size: 24px;
    height: 40px;
    line-height: 40px;
    right: 0;
    text-align: center;
    width: 35px;
}

.section_padding_100 {
    padding: 100px 0;
}

.section_padding_50 {
    padding: 50px 0;
}

.section_padding_100_70 {
    padding: 100px 0 70px;
}

.section_padding_100_50 {
    padding: 100px 0 50px;
}

.section_padding_100_0 {
    padding: 100px 0 0;
}

.section_padding_0_100 {
    padding: 0 0 100px;
}

.section_heading {
    margin-bottom: 50px;
    position: relative;
    z-index: 1;
}

.section_heading h2 {
    font-size: 30px!important;
    margin-bottom: 0;
    text-transform: uppercase;
}

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

.studio-btn {
    display: inline-block;
    color: #fff;
    background-color: #1d1d1d;
    height: 52px;
    padding: 0 15px;
    border-radius: 0;
    line-height: 52px;
    font-size: 16px;
    min-width: 140px;
}

.studio-btn > img {
    padding-right: 5px;
}

.studio-btn:hover,
.studio-btn:focus {
    color: #fff;
    font-size: 16px;
}

/* :: 4.0 Header Area CSS */

.header-area {
    width: 100%;
    height: 110px;
    position: fixed;
    z-index: 1000;
    top: 0;
    left: 0;
    padding: 0 34px;
}

#searchbtn {
    cursor: pointer;
    margin-left: 15px;
}

.header-search-form,
.search-form-on .navbar-nav {
    display: none;
}

.search-form-on .header-search-form {
    display: block;
}

.header-area .main-menu .nav-link {
    font-size: 14px;
    text-transform: uppercase;
    color: #ffffff;
    padding: 0 25px;
}

.header-area .main-menu .nav-link:hover,
.header-area .main-menu .nav-link:focus {
    color: #fff;
}

.dropdown-menu.show {
    border: none;
    padding: 15px 0;
    box-shadow: 0 5px 40px rgba(0, 0, 0, 0.15);
    margin-top: 15px;
}

.dropdown-item {
    text-transform: uppercase;
    font-size: 13px;
}

.dropdown-item:hover {
    color: #000;
    font-size: 13px;
}

.header-search-form form input {
    width: 600px;
    height: 35px;
    padding: 5px 15px;
    font-size: 12px;
    color: #fff;
    border: none;
    background-color: transparent;
    border: 2px solid rgba(255, 255, 255, 0.6);
    border-radius: 30px;
    -webkit-transition-duration: 500ms;
    transition-duration: 500ms;
}

.header-search-form form input:focus {
    box-shadow: none;
    border-color: rgba(255, 255, 255, 1);
    background-color: transparent;
}

.gradient-background-overlay {
    position: fixed;
    z-index: 3;
    top: 0;
    left: 0;
    width: 100%;
    height: 150px;
}

.gradient-background-overlay:before {
    content: "";
    position: absolute;
    height: 150px;
    width: 100%;
    z-index: -1;
    top: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.3);
    background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.01) 90%, rgba(0, 0, 0, 0) 100%);
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.01) 90%, rgba(0, 0, 0, 0) 100%);
}

/* :: 5.0 Sidebar Area CSS */

.social-sidebar-area {
    width: 150px;
    height: 100%;
    background-color: transparent;
    position: fixed;
    bottom: 100px;
    left: 0;
    z-index: 100;
    overflow: hidden;
}

.social-info-area {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg);
    position: absolute;
    bottom: 370px;
    left: -50px;
    z-index: 10;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.social-info-area a {
    text-transform: none;
    font-size: 12px!important;
	color: #3B3B3B;
    font-weight: 200;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 5px;
	margin-left: 10px;
    line-height: 1;
}

.social-info-area a i {
    font-size: 16px;
    color: #0C17CD;
    margin-right: 5px;
	margin-bottom: 5px;
}

.message-box > a {
    width: 120px;
    height: 100px;
    position: absolute;
    left: 0;
    bottom: 0;
    background-color: #101010;
    text-align: center;
    color: #fff;
    font-size: 30px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.message-box > a > img {
    max-width: 40px;
}

/* :: 6.0 Welcome Area CSS */

.welcome-area {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100vh !important;
}

.carousel-indicators {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: auto;
    margin: 0;
    z-index: 9999;
}

.carousel-indicators li {
    width: 100%;
    height: 100px;
    margin-right: 0;
    margin-left: 0;
    text-indent: -9999999px;
    background-color: #fff;
    cursor: pointer;
    -webkit-transition-duration: 500ms;
    transition-duration: 500ms;
}

.carousel-indicators li:after,
.carousel-indicators li:before {
    display: none;
}

.carousel-indicators li.active:after {
    content: '';
    display: block;
    width: 16px;
    height: 16px;
    top: -26px;
    z-index: 1100;
    position: absolute;
    background-image: url(../img/active.png);
}

.carousel-item:after {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.17);
    content: '';
    z-index: -1;
}

.carousel-content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.slide-text {
    padding: 25px 30px 15px;
    border-left: 3px solid #fff;
    margin-left: 200px;
    background-color: rgba(255, 255, 255, 0.2);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
    -ms-flex-align: baseline;
    align-items: baseline;
    margin-top: -100px;
}

.slide-text h2 {
    margin-bottom: 0;
    font-size: 30px;
    color: #fff;
    line-height: 1;
}

.slide-text span {
    font-size: 100px;
    color: #fff;
    line-height: 1;
    font-weight: 100;
}

/* :: 7.0 About Me Area CSS */

.about-content span {
    width: 30px;
    height: 2px;
    background-color: #bebebe;
    margin: 0 auto 30px;
    display: block;
}
.about-content h2 {
    margin-bottom: 40px;
    font-size: 36px;
}
.single-service-area img {
    margin-bottom: 20px;
}
.single-service-area h5 {
    margin-bottom: 20px;
}

.single-pie-bar h6 {
    margin-top: 15px;
    margin-bottom: 0;
}


/* :: 9.0 Footer Area CSS */
.footer-area .container-fluid.h-100 p{
	font-family: "Noto Sans JP", sans-serif!important;
	text-align: center;
  color: #fff;
  font-weight: lighter!important;
  font-size: 14px;
}

.footer-area {
    
    z-index: 100;
    background-color: rgba(22,53,144,1.00);
    height: 80px;
    width: 100%;
    padding: 0 35px;
    bottom: 0;
    left: 0;
}

.single-footer-content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.single-footer-content > a {
    font-size: 14px;
    font-weight: 600;
    color: #fff;
    margin-left: 5px;
    line-height: 1;
}

/* :: 10.0 Portfolio Area CSS */

.gallery_area {
    height: calc(100% - 380px);
    width: calc(100% - 245px);
    overflow-y: scroll;
    position: fixed;
    z-index: 1;
    top: 200px;
    left: 185px;
    right: 60px;
    padding-right: 45px;
}

.portfolio-menu button {
    background-color: transparent;
    font-size: 15px;
    color: #838383;
    padding: 0 20px;
    -webkit-transition-duration: 500ms;
    transition-duration: 500ms;
}

.portfolio-menu button.active,
.portfolio-menu button:hover {
    color: #1d1d1d;
}

.portfolio-menu button:focus {
    box-shadow: none;
}

.gallery_menu {
    margin-bottom: 100px;
}

.column_single_gallery_item {
    margin-bottom: 30px;
}

.column_single_gallery_item img {
    width: 100%;
}

.hover_overlay {
    position: absolute;
    width: calc(100% - 30px);
    height: 100%;
    background-color: rgba(0, 0, 0, 0.3);
    top: 0;
    left: 15px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    -webkit-transition-duration: 500ms;
    transition-duration: 500ms;
}

.hover_overlay a {
    font-size: 30px;
    color: #fff;
}

.column_single_gallery_item:hover .hover_overlay {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}

/* :: 11.0 Blog & Contact Area CSS */

.blog-content span,
.contact-heading-text span {
    display: block;
    width: 100%;
    height: 2px;
    background-color: #FFFFFF;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 70px;
}

.blog-content h2,
.contact-heading-text h2 {
    font-size: 30px;
	font-family: "Shippori Mincho", serif;
	font-weight: 600;
	font-style: normal;
}

.col-10 .blog-content .e {
	 color: #d70051;
}
.contact-heading-text h2,
.blog-content p {
    margin-bottom: 50px;
}
.col-10 .blog-content .c2 {
    color: #d70051;
    padding-left: 5%;
    padding-right: 5%;
    text-align: justify;
    font-size: medium;
    font-weight: 500;
}
.post-date,
.post-date:hover,
.post-date:focus {
    display: block;
    font-size: 14px;
    margin-bottom: 5px;
    font-weight: 500;
}

.post-author,
.post-author:hover,
.post-author:focus {
    font-size: 12px;
    text-transform: uppercase;
    color: #838383;
    display: block;
    margin-bottom: 50px;
}

.pagination-area .page-link {
    color: #1d1d1d;
    border: none;
    font-size: 16px;
    font-weight: 500;
    position: relative;
    z-index: 1;
}

.page-item.active .page-link {
    z-index: 1;
    color: #1d1d1d;
    background-color: transparent;
    border-color: transparent;
    padding-right: 80px;
}

.page-item.active .page-link:after {
    content: '';
    width: 70px;
    height: 2px;
    background-color: #1d1d1d;
    position: absolute;
    bottom: 13px;
    left: 45px;
}

.contact-form-area form .form-control {
    margin-bottom: 30px;
    font-size: 14px;
    font-style: italic;
    height: 60px;
    border-bottom: 2px solid #c0c0c0;
    border-top: 0;
    border-left: 0;
    border-radius: 0;
    border-right: none;
    background-color: transparent;
    -webkit-transition-duration: 500ms;
    transition-duration: 500ms;
}

.contact-form-area form .form-control:focus {
    box-shadow: none;
    border-color: #1d1d1d;
    -webkit-transition-duration: 500ms;
    transition-duration: 500ms;
}

.contact-form-area form textarea.form-control {
    height: 200px;
}

.map-area {
    position: relative;
    z-index: 1;
    padding-bottom: 100px;
}

#googleMap {
    width: 100%;
    height: 485px;
    position: relative;
    z-index: 1;
}

.contact-core-info {
    position: absolute;
    top: 30px;
    width: 280px;
    background-color: #1d1d1d;
    z-index: 1000;
    left: -90px;
    padding: 15px 40px;
    text-align: center;
    height: calc(100% - 60px);
}

.contact-core-info img {
    margin-bottom: 50px;
}

.contact-core-info .single-footer-content {
    display: block;
    margin-bottom: 10px;
    text-align: center;
}

.contact-core-info .single-footer-content img {
    display: block;
    margin: 0 auto 10px;
}

.contact-popup-form .modal-content {
    padding: 50px;
}

.contact-popup-form .modal-content {
    padding: 50px;
    border: none;
    box-shadow: 0 5px 50px rgba(0, 0, 0, 0.15);
    background-color: rgba(255, 255, 255, 0.9);
}

/* :: 12.0 Elements Area CSS */

/* Accordians */

.elements-title h2 {
	color: #163590;
    font-size: 36px;
    margin-bottom: 55px;
}

.panel {
    box-shadow: 0 0 0 transparent;
    margin-bottom: 15px;
}
.single-accordion:last-of-type {
    margin-bottom: 0px;
}

.col-10 .elements-title h2 {
	font-size: 22px;
	font-family: "Shippori Mincho", serif;
	font-weight: 600;
	font-style: normal;
	letter-spacing: 3px;
	position: relative;
	border-left: 1px solid #666666;
}
.blog-content .elements-title h2 {
    text-align: left;
	letter-spacing: 1px!important;
}
.contact-heading-text.text-center .elements-title h2 {
    text-align: left;
}
.col-10 .elements-title h2:after {
  content: "";
  display: block;
  height: 2px;
  background: -webkit-linear-gradient(to right, rgb(230, 90, 90), transparent);
  background: linear-gradient(to right, rgb(102, 102, 96), transparent);
 margin-top: 5px;
}
.elements-title2 h2 {
	color: #163590;
    font-size: 36px;
}

.row.justify-content-center.mb-50 .col-10 .elements-title2{
	margin-top: -60px;
}
.col-10 .elements-title2 h2 {
	font-size: 22px;
	font-family: "Shippori Mincho", serif;
	font-weight: 600;
	font-style: normal;
	letter-spacing: 1px;
	position: relative;
	border-left: 1px solid #666666;
	margin-top: 40px;
	margin-bottom: 35px;
}
.blog-content .elements-title2 h2 {
    text-align: left;
	letter-spacing: 1px!important;
}
.contact-heading-text.text-center .elements-title2 h2 {
    text-align: left;
}
.col-10 .elements-title2 h2:after {
  content: "";
  display: block;
  height: 2px;
  background: -webkit-linear-gradient(to right, rgb(230, 90, 90), transparent);
  background: linear-gradient(to right, rgb(102, 102, 96), transparent);
 margin-top: 5px;
}
.col-10 .elements-title2　st h2 {
	font-size: 22px;
	font-family: "Shippori Mincho", serif;
	font-weight: 600;
	font-style: normal;
	letter-spacing: 1px;
	position: relative;
	border-left: 1px solid #666666;
	margin-top: 40px;
	margin-bottom: 35px;
}
.col-10 .elements-title2　st h2:after {
  content: "";
  display: block;
  height: 2px;
  background: -webkit-linear-gradient(to right, rgb(230, 90, 90), transparent);
  background: linear-gradient(to right, rgb(102, 102, 96), transparent);
 margin-top: 5px;
}
.single-accordion h6 a {
    background-color: #1d1d1d;
    border-radius: 0;
    color: #fff;
    display: block;
    margin: 0;
    padding: 20px 60px 20px 20px;
    position: relative;
    font-size: 16px;
    text-transform: capitalize;
    font-weight: 500;
}

.single-accordion h6 a.collapsed {
    background-color: #aeaeae;
    color: #fff;
}

.single-accordion h6 a span {
    font-size: 10px;
    position: absolute;
    right: 20px;
    text-align: center;
    top: 25px;
}

.single-accordion h6 a.collapsed span.accor-close {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
}

span.accor-open {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
}

.single-accordion h6 a.collapsed span.accor-open {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    filter: alpha(opacity=100);
}

.single-accordion h6 {
    margin-bottom: 0;
    text-transform: uppercase;
}

.single-accordion .accordion-content {
    border-top: 0 solid transparent;
    box-shadow: none;
}

.single-accordion .accordion-content p {
    padding: 20px 15px 5px;
    margin-bottom: 0;
}

/* barfiller */

.single_progress_bar {
    margin-bottom: 20px;
}

.single_progress_bar:last-of-type {
    margin-bottom: 0;
}

.barfiller {
    background: #e0e0e0;
    border: none;
    border-radius: 0;
    box-shadow: none;
    height: 2px;
    margin-bottom: 5px;
    position: relative;
    width: 100%;
}

.barfiller .fill {
    display: block;
    position: relative;
    width: 0px;
    height: 100%;
    background: #333;
    z-index: 1;
}

.barfiller .tipWrap {
    display: none;
}

.barfiller .tip {
    margin-top: 15px;
    font-size: 15px;
    color: #838383;
    left: 0px;
    position: absolute;
    z-index: 2;
    background: transparent;
}

.barfiller .tip:after {
    display: none;
}
.single_progress_bar p {
    margin-bottom: 0;
    margin-top: 10px;
}
/* Cool Facts */


.counter-area h6 {
    margin-bottom: 0;
    color: #838383;
}

.studio-btn.studio-btn-2 {
    background-color: transparent;
    border: 2px solid #1d1d1d;
    color: #1d1d1d;
}

.studio-btn.studio-btn-4 {
    background-color: transparent;
    border: 2px solid #aeaeae;
    color: #aeaeae;
}

/* Sonar CSS */
.carousel-indicators li.active:before {
    content: '';
    display: inline-block;
    position: absolute;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    top: -25px;
    left: 1px;
    -webkit-animation: sonar-effect 1s ease-in-out .1s infinite;
    animation: sonar-effect 1s ease-in-out .1s infinite;
    z-index: 1;
    background-color: #fff;
}
@-webkit-keyframes sonar-effect {
    0% {
        opacity: 0;
        -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    }
    50% {
        opacity: 0.5;
        -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
        box-shadow: 0 0 0 3px #fff, 0 0 5px 5px #fff, 0 0 0 5px #fff;
    }
    100% {
        box-shadow: 0 0 0 3px #fff, 0 0 5px 5px #fff, 0 0 0 5px #fff;
        -webkit-transform: scale(1.5);
        transform: scale(1.5);
        opacity: 0;
        -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    }
}
@keyframes sonar-effect {
    0% {
        opacity: 0;
        -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    }
    50% {
        opacity: 0.5;
        -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
        box-shadow: 0 0 0 3px #fff, 0 0 5px 5px #fff, 0 0 0 5px #fff;
    }
    100% {
        box-shadow: 0 0 0 3px #fff, 0 0 5px 5px #fff, 0 0 0 5px #fff;
        -webkit-transform: scale(1.5);
        transform: scale(1.5);
        opacity: 0;
        -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    }
}
.col-10 .contact-form .head-border {
	margin-top: 35px!important;
	margin-bottom: 20px;
	font-size: 26px;
    font-family: "Shippori Mincho", serif!important;
	font-weight: 400;
}