/* GENERAL */

@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);

body {
    /* font-family: Georgia,游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN",HGS明朝E,メイリオ,Meiryo,serif; */
    /* font-family: "Noto Sans Japanese", sans-serif; */
    font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif;
    background-color: #ece7da;
}

a {
    text-decoration: none;
    -webkit-transition: all .3s;
    transition: all .3s;
}

a:hover,
a:visited,
a:focus {
    border: none;
    outline: none;
    text-decoration: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {}

p {
    margin: 0;
}

img {
    max-width: 100%;
}

li {
    list-style: none;
}

.slidewrapper {
    position: relative;
    z-index: 1000 !important;
}

.rows {
    width: 100%;
    float: left;
}

section,
header,
footer {
    width: 100%;
    float: left;
}

.bg-f2f2f2 {
    background: #f2f2f2;
}

.wrap-content {
    padding: 40px 0;
}

/* END GENERAL */

/* ------------------------------------------------------------------------------------------------------------------------------*/

/* HEADER */

.navbar-brand {
    max-width: 300px;
}

.navbar-collapse {
    max-height: inherit !important;
}

/* MENU TOP*/

nav ul li {
    text-align: center;
    display: inline-block;
    position: relative;
    font-family: 'Amiri', serif;
}

nav ul li a {
    display: block;
    color: #656464;
    text-transform: uppercase;
}

nav ul li a i {
    transition: all .5s ease;
    -webkit-transition: all .5s ease;
}

nav ul li a:hover i {
    transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
}

nav ul li a:hover i.fa-facebook {
    color: #3b5998 !important;
}

nav ul li a:hover i.fa-twitter {
    color: #55acee !important;
}

nav ul li a:hover i.fa-google-plus {
    color: #dd4b39 !important;
}

.tooltips {
    opacity: 0;
    position: absolute;
    top: 40px;
    left: 0;
    z-index: 9999;
    width: 100px;
    padding: 5px 0;
    color: #fff;
    background: #000;
    text-align: center;
    transition: all .5s ease;
    -webkit-transition: all .5s ease;
}

.tooltips:after {
    content: "";
    display: block;
    position: absolute;
    left: 25%;
    top: -4px;
    border-top: 4px solid transparent;
    border-left: 4px solid #000;
}

nav ul li:hover .tooltips {
    display: block;
    opacity: 1;
}

/* END MENU */

/* END HEADER */

/* CSS T  */

.section_overlay h1 {
    margin-top: 0;
}

.top-txt p {
    color: #004ba5;
    font-size: 18px;
    text-align: center;
    line-height: 160%;
}

.top-ct-img a img,
.top-ct-img img {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.layout-column-txt span.top-title {
    font-size: 20px;
    font-weight: bold;
    color: #d61518;
    line-height: 180%;
}

.row-table .table-title td {
    background: #F781BE;
    ;
    color: #fff;
}

.table-left tr td:last-child {
    text-align: center;
}

.table-left tr td:first-child {
    background: #fff;
    ;
    color: #333;
    font-weight: bold;
    text-align: center;
}

.link-phone {
    color: #004ba5;
}

.link-phone:hover {
    opacity: 0.7 !important;
}

.form-cont #btn_submit {
    background: #ffd028 !important;
    color: #000;
    font-size: 18px;
}

.footer_logo img {
    max-width: 300px;
}

.navbar-brand>img {
    height: 4.167vw;
    object-fit: scale-down;
}

.navbar {
    min-height: inherit;
    margin-bottom: 0;
}

.navbar-brand {
    padding: 0;
    font-size: 0;
    height: inherit;
    line-height: inherit;
}

.navbar .container {
    height: 90px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-around;
    align-items: center;
    align-content: stretch;
    margin-top: ;
}

.navbar-header,
#bs-example-navbar-collapse-1 {
    float: inherit;
}

.clear {
    clear: both;
}

.layout-column-table tr.table-title1 th {
    background: #F781BE;
    ;
    color: #fff;
}

.navbar-default {
    background-color: rgba(243, 243, 243, 0.76);
}

.top-map iframe {
    width: 100%;
    height: 317px;
}

.form-cont textarea {
    outline: none;
    resize: none;

}

.top-map {
    width: 100%;
}

.top-fb,
.top-ins {
    overflow: hidden !important;
}

/* row new */

.description p:nth-child(odd) {
    background-color: #fff;
    padding: 10px;
    margin-bottom: 0px;
}

.description p:nth-child(even) {
    background-color: #fff;
    padding: 10px;
    margin-bottom: 0px;
}

.top-txt img {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.top-txt p {
    color: #d61518;
}

.top-ins iframe {
    width: 100% !important;
}

.layout-column-txt p span.top-cl-b {
    color: #F781BE;
    font-size: 18px;
    font-weight: bold;
    line-height: 180%;
}

.top-img-fr img {
    float: right;
}

.bg-top {
    background: #fff;
}

.flex-rows {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
}

.ow {
    width: 100%;
    overflow: hidden;
}

.top-img .layout-column-img:last-child {
    margin-bottom: 0;

}

.top-img-2 {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.top-news-sp,
.top-blog-sp {
    display: none;
}

/* if both
/* End row new */
.slide-top {
    position: relative;
}

.slide-top .slide-text {
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    margin: 0 auto;
    z-index: 9;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
}

.slide-top .slide-text img {
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
}

.slide-top .slide-text p {
    font-size: 34px;
    font-weight: bold;
    text-align: center;
    margin-top: 20px;
    color: #28397E;
    text-shadow: rgb(255, 255, 255) 1px 0px 0px, rgb(255, 255, 255) 0.540302px 0.841471px 0px, rgb(255, 255, 255) -0.416147px 0.909297px 0px, rgb(255, 255, 255) -0.989992px 0.14112px 0px, rgb(255, 255, 255) -0.653644px -0.756802px 0px, rgb(255, 255, 255) 0.283662px -0.958924px 0px, rgb(255, 255, 255) 0.96017px -0.279415px 0px;
}

.txt-ul ul {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.txt-ul li {
    list-style: none;
    float: left;
    padding: 20px;
    width: 49%;
    margin-right: 2%;
    background: #eb3178;
    color: #fff;
    margin-bottom: 20px;
}

.txt-ul li:last-child,
.txt-ul li:nth-child(2) {
    margin-right: 0;
}

.txt-ul li i {
    padding-right: 5px;
    font-size: 18px;
}

.layout-column-txt p i {
    padding-top: 10px;
    transform: rotate(-270deg);
    font-size: 28px;
}

.txt-top p {
    font-size: 18px;
}

.title-top {
    padding-left: 0;
    padding-right: 0;
}

.flex-ct {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.layout-column-txt p {
    font-size: 16px;
    line-height: 180%;
}

.txt-top-b {
    font-size: 18px !important;
    line-height: 180%;
}

.all-time p {
    font-size: 16px;
    line-height: 180%;
}

.layout-column-txt a.phone {
    font-size: 32px;
    line-height: 180%;
}

/* RECRUIT */
.title-recuit h3 {
    margin-bottom: 40px;
    letter-spacing: 2px;
    font-weight: bold;
    color: #eb3178;
    font-size: 28px;
}

.rec-txt span {
    display: block;
    color: #eb3178;
    font-size: 24px;
    text-align: center;
    padding: 50px 0;
    line-height: 180%;
}

.rec-box ul {
    padding-left: 0;
    padding-right: 0;
}

.rec-box ul li {
    list-style: none;
    float: left;
    width: 32%;
    margin-right: 2%;
}

.rec-box ul li img {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.rec-box ul li:last-child {
    margin-right: 0;
}

.rec-box ul li span {
    margin-top: 25px;
    display: block;
    text-align: center;
    line-height: 160%;
}

.rec-title {
    margin-bottom: 30px;
}

.rec-title h4 {
    font-size: 26px;
    font-weight: bold;
    color: #eb3178;
    font-family: "メイリオ", "ヒラギノ丸 Pro W3", "Hiragino Maru Gothic Pro", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.row-table .toptb-bd tr td {
    padding: 30px;
}

.row-table .toptb-bd tr td:first-child {
    background: none;
    color: #333;
    font-weight: bold;
}

.row-table .toptb-bd tr td {
    border: none;
    border-bottom: 2px #F781BE solid;
}

.row-table .toptb-bd tr td {
    background: none;
}

/* END RECRUIT */
.slide-top .owl-carousel {
    height: 100%;
}

.bg-top {
    /* background-color: #ececec; */
    background-image: url(./assets/images/bg1.jpg);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover;
}

.row-news p span {
    background: #6CB801;
    color: #fff;
    padding: 0px 5px;
    border-radius: 5px;
}

.row-news p:nth-child(2n-1) span {
    background: #6CB801;
    color: #fff;
    padding: 0px 5px;
    border-radius: 5px;
}

.box-more li {
    list-style: none;
    width: 24%;
    float: left;
    margin-right: 1%;
    background: #f0f1f3;
    text-align: center;
}

.box-more li:last-child {
    margin-right: 0;
}

.box-more p img {
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding: 10px 0;
}

.box-more p.more-txt {
    background: #fff;
    padding: 30px;
}

.img-left {
    width: 48%;
    float: left;
    margin-right: 4%;
}

.img-left:last-child {
    margin-right: 0;
}

.top-box-ser .t-box {
    width: 100%;
    float: left;
    background: #fff;
}

.top-box-ser {
    max-width: 850px;
    width: 100%;
    margin: 0 auto;
}

.top-box-ser .t-box:last-child {
    margin-right: 0;
}

.top-box-ser .box-span {
    padding: 10px;
    float: left;
    font-size: 16px;
    line-height: 160%;
}

.flex-center {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.table-left span {
    display: block;
    margin-bottom: 10px;
}

.table-left td:first-child {
    width: 20%;
}

.masongram-image-caption-container {
    width: 100%;
    height: 100%;
    position: relative;
    z-index: 9;
}

.masongram-image-caption-container a {
    display: block;
    width: 100%;
    height: 100%;
}

.title_insta {
    width: 100%;
    float: left;
    text-align: center;
    font-size: 40px;
    font-weight: bold;
    margin-top: 30px;
    margin-bottom: 20px;
}

#instagram-feed1 {
    width: 100%;
    max-width: 1200px;
    margin: auto;
    margin-top: 20px;
}

.ins-box {
    max-height: 1300px;
    overflow: hidden;
}

.rows-news p a {
    color: #333 !important;
}

.box-post-img {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.top-tb-custom .top-tb2 tr td:first-child {
    width: 35%;
    text-align: left;
}

.t-box {
    padding: 20px;
}

.top-ytb iframe {
    margin: 0 auto;
    display: block;
}

.top-box-tt h3,
.top-box-tt .ser-tt-txt {
    text-align: center;
    color: #78502f;
}

.top-scroll-id ul,
.top-scroll-id-more ul {
    width: 100%;
    overflow: hidden;
    margin: 0;
    padding: 0;
}

.top-scroll-id li {
    list-style: none;
    width: 24%;
    margin-right: 1.3%;
    margin-bottom: 15px;
    float: left;
    border-bottom: 1px solid #eee;
    background: #fff;
}

.top-scroll-id li:nth-child(4n) {
    margin-right: 0;
}

.top-scroll-id li a {
    padding: 14px;
    color: #000;
    display: block;
    border-left: 2px solid #4DAF56;
}

.bg-top-2 {
    background: url('assets/images/bg2.jpg');
}

.top-scroll-id-more li {
    width: 24%;
    margin-right: 1.3%;
    float: left;
    background: #ffffff;
    margin-bottom: 20px;
}

.top-scroll-id-more li .top-more-title a {
    text-align: center;
    font-weight: bold;
    padding-top: 10px;
    color: #4ab752;
}

.top-scroll-id-more li:nth-child(4n) {
    margin-right: 0;
}

.top-more-title,
.top-more-txt {
    padding: 0 10px;
}

.top-more-title {
    text-align: center;
    font-weight: bold;
    padding-top: 10px;
    color: #4ab752;
}

.top-more-txt {
    text-align: left;
    font-weight: normal;
    padding: 10px 10px;
    line-height: 180%;
}

li.step01 p {
    line-height: 180%;
}

.top-ser-box li h4 {
    line-height: 160%;
}

.dl_flex {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
}

.top-post ul {
    padding: 0;
}

.top-post li {
    width: 24%;
    margin-right: 1.3%;
    float: left;
    background: #ffffff;
    padding: 10px;
    background: #6CB801;
    color: #fff;
    text-align: center;
    margin-bottom: 20px;
}

.top-post li:nth-child(4n) {
    margin-right: 0;
}

.top-post li:last-child {
    margin-right: 0;
}

.top-post a .tt-post {
    color: #fff;
    text-align: center;
    margin-top: 10px;
    font-size: 16px;
    line-height: 160%;
    min-height: 75px;
}

.top-post a .sub-post {
    padding: 20px 0;
    color: #fff;
    font-size: 16px;
    line-height: 160%;
}

.top-post a .btn-post {
    background: #fff;
    color: #333;
    font-size: 16px;
    line-height: 160%;
    padding: 10px;
}

.bg-top-3 {
    background: url('assets/images/bg3.jpg');
}

.bg-top-4 {
    background: url('assets/images/bg4.jpg');
}

.top-tb2 td.td-col3 {
    width: 100% !important;
    text-align: left !important;
    font-weight: normal !important;
}

.top-tb2 tr td.td-col3 {
    border-bottom: 1px solid #eee;
}

.title-tb {
    font-size: 18px;
    font-weight: bold;
    color: #77BF00;
    text-align: center;
}

.title-tb i {
    padding-right: 10px;
}

.top-tb2 td i {
    padding-right: 5px;
    color: #77BF00;
}

.img-tb {
    padding-left: 0;
    padding-right: 0;
}

.top-ser-box ul {
    margin: 0;
    padding: 0;
}

.top-ser-box li {
    margin-top: 20px;
    padding: 10px 0 0 105px;
}

.top-ser-box li:first-child {
    margin-top: 0;
}

.top-ser-box li h4 {
    color: #78502f;
    font-size: 14px;
    font-weight: bold;
    padding-left: 20px;
}

.top-ser-box li p {
    margin-top: 7px;
    border-top: 1px dotted #999;
    padding-top: 10px;
}

.title-img {
    font-size: 18px;
    font-weight: bold;
    line-height: 160%;
    display: block;
    text-align: center;
    margin-top: 20px;
}

.txt-img {
    font-size: 16px;
    line-height: 160%;
    display: block;
    text-align: center;
    margin-top: 5px;
}

.img-tt2 {
    font-size: 18px;
    font-weight: bold;
    display: block;
}

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

.tt-cl {
    color: #78502f;
}

.table-top tr td:first-child {
    background: none;
}

.table-top table tr td {
    background: none !important;
}

.table-top td.tb-col2 {
    font-weight: normal !important;
}

span.img-tt2 {
    display: block;
    margin-bottom: 10px;
}

.img-sub-txt {
    margin-top: 10px;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.img-sub-txt2,
.top-map {
    margin-bottom: 10px;
}

.bg-fff {
    background: #fff;
    padding: 15px 0;
}

.infor-box {
    width: 49%;
    float: left;
    margin-right: 2%;
}

.infor-box:last-child {
    margin-right: 0;
}

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

.infor-btn a {
    display: block;
    max-width: 200px;
    font-size: 18px;
    width: 100%;
    background: #ffd028;
    line-height: 160%;
    padding: 20px;
    border-radius: 5px;
    color: #000;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

.infor-btn a i {
    padding-right: 10px;
}

.top-calendar iframe {
    height: 400px;
    width: 100%;
}

p.tal-l {
    line-height: 180%;
}

.imgft-left {
    width: 33%;
    float: left;
    margin-right: 2%;
}

.imgft-right {
    width: 65%;
    float: left;
}

.imgft-right span {
    display: block;
    text-align: left;
    color: #fff;
}

.imgft-right span.ft-tt {
    color: #78502f;
    font-size: 17px;
    line-height: 180%;
    margin-top: 10px;
}

.imgft-right span.ft-t2 {
    color: #fff;
    font-size: 16px;
    line-height: 180%;
    margin-top: 15px;
}

.imgft-right span.ft-t3-tel {
    color: #fff;
    font-size: 24px;
    line-height: 180%;
    margin-top: 10px;
}

.imgft-right span.ft-t3-tel a {
    font-size: 24px;
    color: #fff !important;
}

.imgft-right span.ft-t3-tel {
    color: #fff;
    font-size: 16px;
    line-height: 180%;
    margin-top: 10px;
}

.ft-box-if h3 {
    margin-top: 20px;
    font-size: 16px !important;
    color: #fff;
    text-align: center;
}

.ft-box-if h3 a {
    color: #fff !important;
    font-weight: normal !important;
}


.top-post li {
    display: block;
    display: none;
}

.postMore a {
    display: block;
    max-width: 200px;
    font-size: 18px;
    width: 100%;
    background: #ffd028;
    line-height: 160%;
    padding: 20px;
    border-radius: 5px;
    color: #000;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

.top-bg-1 span {
    font-size: 26px;
    line-height: 160%;
    color: #613712;
    font-weight: bold;
}

.top-bg-1 p a {
    color: #613712;
}

.owl-theme .owl-nav {
    display: none;
}

.cont1000 {
    max-width: 1000px;
    width: 100%;
    overflow: hidden;
    margin: 0 auto;
    position: relative;
}

.TopBox {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    background: #fff;
    padding-left: 0;
    margin-left: 0;
}

.ul {
    padding-left: 0;
    margin-left: 0;
}

.TopBox li {
    flex-wrap: wrap;
    align-items: center;
    width: 39%;
    font-size: 26px;
    line-height: 160%;
    color: #613712;
    text-align: center;
    font-weight: bold;

}

.TopBox li:last-child {
    width: 61%;
}

.bg1 {
    background-color: #fff;
}

.bg2 {
    background-color: #fff;
}

.bg3 {
    background-color: #fff;
}

.all-time p {
    color: #78502f;
    padding: 20px;
    padding-bottom: 60px;
}

.txtBold p {
    font-size: 24px;
    font-weight: bold;
    color: #78502f;
    line-height: 140%;
    text-align: center;
}

.ul li {
    position: relative;
    margin-bottom: 15px;
    padding-left: 30px;
    font-size: 16px;
    line-height: 160%;
}

.ul li:last-child {
    margin-bottom: 0;
}

.ul li::before {
    content: "";
    position: absolute;
    top: 3px;
    left: 0;
    height: 20px;
    width: 20px;
}

.topIf li {
    font-size: 18px;
    font-weight: bold;
}

.topIf li p {
    font-size: 16px;
    font-weight: normal;
}

.layout-column-txt p strong.TopMix-cl {
    font-weight: bold;
    color: #78502f;
}

.layout-column-img span.txt-bt-img strong {
    color: #000;
    font-weight: bold;
    display: block;
    margin-top: 10px;
    font-size: 18px;
    line-height: 160%;
}

.layout-column-img .txt-bt-fr {
    display: block;
    float: right;
    margin-top: 10px;
}

.topCol ul {
    padding-left: 0;
    margin-left: 0;
}

.topCol ul li {
    width: 32%;
    margin-right: 2%;
    text-align: center;
    font-size: 18px;
    line-height: 160%;
    font-weight: bold;
    color: #fff;
}

.topCol ul li:nth-child(2) .Col-Item {
    background: #748ecd;
}

.topCol ul li:last-child {
    margin-right: 0;
}

.Col-Item {
    min-height: 55px;
    margin-bottom: 10px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.topCol ul li:first-child .Col-Item:first-child {
    background: #FFF47C;
    color: #514940;
}

.topCol ul li:first-child .Col-Item:nth-child(2) {
    background: #e48f24;
    color: #514940;
}

.topCol ul li:first-child .Col-Item:nth-child(3) {
    background: #67bd2e;
    color: #514940;
}

.topCol ul li:last-child .Col-Item:nth-child(1) {
    background: #ef80c7;
    color: #ffffff;
}

.topCol ul li:last-child .Col-Item:nth-child(2) {
    background: #bdbdbd;
    color: #ffffff;
}

.txt-red {
    font-size: 18px;
    line-height: 160%;
    color: #e82c2c;
    font-weight: bold;
}

.ft-infor p {
    text-align: center;
    color: #fff;
}

.ft-infor p a {
    color: #fff;
}

.brcopy-r {
    display: none;
}

.logo-ft a {
    display: block;
    margin-top: 35px;
    text-align: center;
}

/* END CSS T  */

/* ------------------------------------------------------------------------------------------------------------------------------*/

/* SLIDE */

.section_overlay {
    background: rgba(250, 250, 250, .5);
}

.home_text {
    padding-top: 210px;
    padding-bottom: 210px;
}

.home_text h2 {
    color: #010101;
    font-size: 40px;
    text-transform: uppercase;
    letter-spacing: 13px;
}

.home_text h3 {
    font-weight: 400;
    font-size: 14px;
    letter-spacing: 2px;
    color: #404040;
}

.home_text ul {
    padding: 0;
    list-style: none;
    margin: 30px 0 0;
}

.home_text ul li {
    margin-bottom: 20px;
}

.home_text ul li a {
    color: #010101;
    border: 1px solid #010101;
    border-radius: 2px;
    padding: 5px 15px;
    transition: all .3s ease;
    -webkit-transition: all .3s ease;
}

.home_text ul li a:hover {
    text-decoration: none;
    background: #fff;
    padding: 7px 17px;
    font-size: 15px;
}

.scroll_down {
    padding-bottom: 35px;
}

.scroll_down h4 {
    font-size: 12px;
    color: #000;
    font-family: 'Open Sans', sans-serif;
    text-transform: uppercase;
}

/* END SLIDE */

/* ------------------------------------------------------------------------------------------------------------------------------*/

/* KEY FRAME */

@keyframes shake {
    0% {
        transform: translate(3px, 2px) rotate(0deg);
    }

    10% {
        transform: translate(-2px, -3px) rotate(-1deg);
    }

    20% {
        transform: translate(-4px, 0px) rotate(1deg);
    }

    30% {
        transform: translate(0px, 3px) rotate(0deg);
    }

    40% {
        transform: translate(2px, -2px) rotate(1deg);
    }

    50% {
        transform: translate(-2px, 3px) rotate(-1deg);
    }

    60% {
        transform: translate(-4px, 2px) rotate(0deg);
    }

    70% {
        transform: translate(3px, 2px) rotate(-1deg);
    }

    80% {
        transform: translate(-2px, -2px) rotate(1deg);
    }

    90% {
        transform: translate(2px, 4px) rotate(0deg);
    }

    100% {
        transform: translate(2px, -3px) rotate(-1deg);
    }
}

/* END KEY FRAME */

/* ======================= SERVICE STYLE 1 =======================*/

.service-st1-item {
    margin-bottom: 20px;
}

.service-st1-image {
    padding-bottom: 20px;
}

.service-st1-title {
    width: 100%;
    float: left;
    padding-bottom: 10px;
    color: #000000;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    line-height: 26px;
    font-family: 'Amiri', serif;
}

.service-st1-des {
    width: 100%;
    float: left;
    font-size: 14px;
    line-height: 24px;
    text-align: center;
}

/* ======================= END SERVICE STYLE 1 =======================*/

/* ======================= GOOGLE MAP =======================*/

.row-map-st1 iframe {
    width: 100%;
    float: left;
    height: 450px;
    border: none;
}

/* ======================= END GOOGLE MAP =======================*/

/* ======================= NEWS STYLE 1 =======================*/

.row-news-st1 {
    height: 300px;
    overflow: auto;
}

.news-st1-item {
    font-size: 14px;
    line-height: 160%;
    width: 100%;
    float: left;
}

.news-st1-item:nth-child(odd) {
    background-color: #f7f7f7;
    padding: 10px;
    margin-bottom: 0px;
}

.news-st1-item:nth-child(even) {
    background-color: #fff;
    padding: 10px;
    margin-bottom: 0px;
}

.news-st1-date {
    font-weight: bold;
}

.news-st1-arrow {
    padding: 0 20px;
}

/* ======================= END NEWS STYLE 1 ======================= */

/* ======================= TABLE =======================*/

.row-table table {
    width: 100%;
    float: left;
}

.row-table table tr th {
    background: #67bd2e;
    text-align: center;
    padding: 10px;
    border: 1px #eaeaea solid;
    font-size: 16px;
    line-height: 160%;
    font-weight: bold;
    color: #fff;
}

.row-table table tr td {
    padding: 10px 20px;
    vertical-align: middle;
    background: #fff;
    font-size: 16px;
    line-height: 180%;
    text-align: center;
    border: 1px solid #eee;
}

.row-table table tr td:first-child {
    font-weight: bold;
}

.row-table tr td {
    text-align: left;
}

/* ======================= END TABLE =======================*/

/* ======================= FAQ =======================*/

.row-faq .panel-default {
    border: 0;
}

.row-faq .panel-heading {
    padding: 0;
    border: 0 !important;
    background: #f7f7f7 !important;
}

.row-faq .panel-title>a,
.row-faq .panel-title>a:active {
    display: block;
    padding: 15px;
    color: #555;
    font-size: 18px;
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 1px;
    word-spacing: 3px;
    text-decoration: none;
}

.row-faq .panel-heading a:before {
    font-family: 'FontAwesome';
    content: "\f107";
    float: right;
    transition: all 0.5s;
    font-size: 30px;
    color: #19509d;
}

.row-faq .panel-heading.active a:before {
    -webkit-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    transform: rotate(180deg);
}

.row-faq .panel-heading a span {
    display: block;
    padding-right: 30px;
}

.row-faq .panel-heading {
    display: table;
}

.row-faq .icon_question {
    font-size: 20px;
    display: table-cell;
    padding: 15px;
    width: 60px;
    color: #f8b014;
}

.row-faq .panel-title {
    display: table-cell;
    vertical-align: middle;
    line-height: 160%;
    text-align: left;
    width: 95%;
}

.row-faq .panel-title p {
    margin: 0 !important;
}

.row-faq .icon_answer {
    font-size: 20px;
    display: table-cell;
    padding: 15px;
    vertical-align: top;
    width: 60px;
    border: 0 !important;
}

.row-faq .txt_answer {
    width: 95%;
    display: table-cell;
    border: 0 !important;
    color: #555;
    font-size: 15px;
}

/* ======================= END FAQ =======================*/

/* ======================= INSTAGRAM =======================*/

#instagram-ct {
    margin: 0;
    padding: 0;
    overflow: hidden;
    width: 100%;
    float: left;
}

#instagram-ct li {
    list-style: none;
    float: left;
    padding: 1px 1px;
    width: 12.49%;
    border-collapse: collapse;
}

#instagram-ct li a {
    display: block;
}

#instagram-ct li a:hover {
    opacity: 0.5;
}

#instagram-ct li a img {
    width: 100% !important;
    max-width: inherit;
}

/* ======================= END INSTAGRAM =======================*/

/* ======================= BLOG =======================*/

.row_blog {
    width: 100%;
    float: left;
}

.row_blog iframe {
    width: 100%;
    float: left;
    height: 400px;
    border: 0;
}

/* ======================= END BLOG =======================*/

/* Contact */

.wrap-primary-table-st1 input[type=text],
.wrap-primary-table-st1 textarea {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    box-shadow: none;
}

.wrap-primary-table-st1 input[type=text],
.wrap-primary-table-st1 textarea {
    border: none !important;
    border: 1px #ccc solid !important;
}

.wrap-primary-table-st1 input[type=text]:focus,
.wrap-primary-table-st1 textarea:focus,
.wrap-primary-table-st1 select:focus,
.wrap-primary-table-st1 input[type="radio"]:focus,
.wrap-primary-table-st1 input[type="checkbox"]:focus {
    border-radius: 5px;
    outline: none !important;
    box-shadow: none !important;
}

.wrap-primary-table-st1 button {
    border: none !important;
    background: none;
    cursor: pointer;
}

.wrap-primary-table-st1 button:focus {
    outline: none !important;
}

.btn_form {
    padding: 10px 20px;
    color: #fff;
    font-size: 15px;
    min-width: 200px;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    margin-top: 20px;
}

.wrap-primary-table-st1 table {
    width: 100%;
    float: left;
}

.wrap-primary-table-st1 table tr td {
    font-size: 14px;
    line-height: 24px;
    padding: 10px 0;
}

.wrap-primary-table-st1 table tr td .form-group {
    margin-bottom: 0;
}

.wrap-primary-table-st1 table tr td input[type=text],
.wrap-primary-table-st1 table tr td textarea {
    width: 100%;
    float: left;
    border: none;
    border-radius: 5px;
    border: 1px #8d97aa solid;
    padding: 10px;
}

.wrap-primary-table-st1 table tr td input[type=text] {
    height: 37px;
}

.wrap-primary-table-st1 table tr td textarea {
    height: 140px;
    resize: none;
}

.wrap-primary-table-st1 table tr td select {
    width: 100%;
    box-shadow: none !important;
}

.wrap-primary-table-st1 table tr:last-child td {
    text-align: center;
    padding-bottom: 0;
}

#primary-contact form {
    width: 100%;
    float: left;
}

.wrap-primary-table-st1 input[type="radio"],
.wrap-primary-table-st1 input[type="checkbox"] {
    margin: 6px 0 0;
}

.wrap-primary-table-st1 label {
    font-weight: normal;
}

/* End contact */

/* ======================= CONTACT STYLE 1 =======================*/

.contact-form-st1 input[type=text],
.contact-form-st1 textarea {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    box-shadow: none;
}

.contact-form-st1 input[type=text],
.contact-form-st1 textarea {
    border: none !important;
    border: 1px #ccc solid !important;
}

.contact-form-st1 input[type=text]:focus,
.contact-form-st1 textarea:focus,
.contact-form-st1 select:focus,
.contact-form-st1 input[type="radio"]:focus,
.contact-form-st1 input[type="checkbox"]:focus {
    border-radius: 5px;
    outline: none !important;
    box-shadow: none !important;
}

.contact-form-st1 button {
    border: none;
    cursor: pointer;
}

.contact-form-st1 button:focus {
    outline: none !important;
}

.btn-contact-st1 {
    padding: 10px 20px;
    color: #fff;
    font-size: 15px;
    min-width: 200px;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    margin-top: 20px;
    background: #19509d;
}

.btn-contact-st1:hover {
    background: #f8b014;
    color: #fff;
    -webkit-transition: 0.33s ease-in-out;
    -moz-transition: 0.33s ease-in-out;
    -o-transition: 0.33s ease-in-out;
    transition: 0.33s ease-in-out;
}

.contact-form-st1 table {
    width: 100%;
    float: left;
}

.contact-form-st1 table tr td {
    font-size: 14px;
    line-height: 24px;
    padding: 10px 0;
    vertical-align: middle;
}

.contact-form-st1 table tr td .form-group {
    margin-bottom: 0;
}

.contact-form-st1 table tr td input[type=text],
.contact-form-st1 table tr td textarea {
    width: 100%;
    float: left;
    border: none;
    border-radius: 5px;
    border: 1px #8d97aa solid;
    padding: 10px;
}

.contact-form-st1 table tr td input[type=text] {
    height: 37px;
}

.contact-form-st1 table tr td textarea {
    height: 140px;
    resize: none;
}

.contact-form-st1 table tr td select {
    width: 100%;
    box-shadow: none !important;
}

.contact-form-st1 table tr:last-child td {
    text-align: center;
    padding-bottom: 0;
}

#primary-contact form {
    width: 100%;
    float: left;
}

.contact-form-st1 label {
    font-weight: normal;
}

/* ======================= END CONTACT STYLE 1 =======================*/

/* ======================= CONTACT STYLE 2 =======================*/

.contact-form-st2 {
    background-color: #f1f1f1;
    padding: 15px;
}

.contact-form-st2 .form-control {
    height: 43px;
    border-radius: 0px;
    margin-bottom: 20px;
    border: 0px solid #fff;
}

textarea.textare-contact-st2 {
    min-height: 169px !important;
}

.btn-contact-st2 {
    padding: 10px 20px;
    color: #fff;
    font-size: 15px;
    min-width: 200px;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    margin-top: 20px;
    width: 100% !important;
}

.btn-contact-st2:hover {
    background: #fff !important;
    color: #000;
    -webkit-transition: 0.33s ease-in-out;
    -moz-transition: 0.33s ease-in-out;
    -o-transition: 0.33s ease-in-out;
    transition: 0.33s ease-in-out;
}

/* ======================= END CONTACT STYLE 2 =======================*/

/* ------------------------------------------------------------------------------------------------------------------------------*/

/*Testimonial*/

.testimonial {
    padding-top: 130px;
    padding-bottom: 80px;
}

.testimonial .icon:after {
    content: "";
    position: absolute;
    width: 80px;
    height: 80px;
    background-color: #f73b56;
    top: 110px;
    left: 50%;
    -moz-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    margin-left: -40px;
}

.testimonial .icon i {
    color: #fff;
    font-size: 47px;
    position: absolute;
    z-index: 555;
    left: 50%;
    margin-left: -23px;
}

.single_testimonial p {
    color: #404040;
    font-size: 15px;
    letter-spacing: 1px;
    padding: 50px 15px;
}

.single_testimonial h4 {
    color: #404040;
    font-size: 14px;
    text-transform: uppercase;
    font-family: 'Montserrat', sans-serif;
    letter-spacing: 1px;
    margin-bottom: 40px;
}

/*owl-carousel*/



/*Fun Facts*/

.fun_facts {
    background-repeat: no-repeat;
    background-attachment: fixed !important;
    background-size: cover;
}

.fun_facts .section_overlay {
    background: rgba(71, 71, 71, .8);
    padding-bottom: 30px;
}

.single_count {
    padding-top: 120px;
}

.single_count i {
    color: #f73b56;
    font-size: 24px;
}

.single_count h3 {
    font-family: 'Amiri', serif;
    color: #fff;
    font-size: 40px;
    font-weight: bold;
    margin-bottom: 0px;
}

.single_count p {
    font-family: 'Amiri', serif;
    color: #fff;
    font-size: 14px;
    text-transform: uppercase;
    position: relative;
}

.single_count p:before {
    content: "";
    position: absolute;
    width: 16px;
    height: 1px;
    left: 0;
    bottom: -4px;
    background: #bd9828;
}

.logo {
    position: relative;
    margin-top: -40px;
    text-align: center;
}

.logo img {
    width: 100%;
    height: auto;
    margin-top: 30px;
    opacity: .8;
}

.single_image {
    position: relative;
    transition: all 1s;
}

.single_image img {
    width: 100%;
}

.single_image a {
    width: 100%;
    height: 100%;
    display: block;
}

.single_image:hover div.image_overlay {
    opacity: 1;
}

.image_overlay {
    position: absolute;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, .8);
    left: 0;
    top: 0;
    opacity: 0;
    transition: all 1s;
}

.image_overlay .full {
    position: absolute;
    top: 20px;
    right: 20px;
    border-radius: 30px;
    width: 30px;
    height: 30px;
    line-height: 28px;
    margin: 0;
    padding: 0;
    text-align: center;
    text-decoration: none;
    text-transform: uppercase;
}

.image_overlay h2 {
    position: absolute;
    bottom: 28px;
    left: 20px;
    font-size: 25px;
    color: #3d3d3d;
    text-transform: uppercase;
    letter-spacing: 3px;
}

.image_overlay h4 {
    position: absolute;
    bottom: 11px;
    left: 20px;
    color: #3d3d3d;
    font-size: 14px;
    text-transform: uppercase;
}

.no_padding {
    padding-left: 0px;
    padding-right: 0px;
}

.work_title {}

.work_title h1,
.contact_title h1 {
    font-size: 25px;
    color: #3d3d3d;
    letter-spacing: 5px;
    padding-top: 80px;
    text-transform: uppercase;
    margin-bottom: 20px;
}

.work_title img,
.contact_title img {
    margin-bottom: 30px;
}

.work_title p {
    font-size: 14px;
    color: #000;
    margin-bottom: 100px;
}

.last_padding {
    padding-right: 0px;
}

.pad_top {
    padding-top: 2px;
}

.left h2 {
    margin-top: 60px;
    margin-bottom: 20px;
    font-size: 18px;
    color: #000;
    font-weight: bold;
}

.left p {
    margin-bottom: 60px;
    font-size: 14px;
    color: #000;
}

.baton {
    margin-top: 65px;
}

.cs-btn,
.cs-btn:active,
.cs-btn:visited,
.cs-btn:focus {
    color: #fff;
    background-color: #000;
    border-radius: 0px;
    outline: none;
    padding: 10px 40px;
    text-transform: uppercase;
    letter-spacing: 2px;
    transition: all 1s;
}

.call_to_action .container {
    padding-bottom: 60px;
    border-bottom: 1px solid #ddd;
}

#imagelightbox {
    position: fixed;
    z-index: 9999;
}

/* OVERLAY */

#imagelightbox-overlay {
    background-color: #fff;
    background-color: rgba(255, 255, 255, .9);
    /* 色と透明度 */
    position: fixed;
    z-index: 9998;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

/*Contact*/

.single_contact_info {
    padding-bottom: 21px;
}

.single_contact_info h2 {
    text-transform: uppercase;
    color: #3d3d3d;
    font-size: 18px;
    letter-spacing: 3px;
    margin-bottom: 1px;
}

.single_contact_info p {
    font-size: 15px;
    color: #3d3d3d;
}

.contact .container {
    padding-bottom: 40px;
}

.contact_title p {
    font-size: 14px;
    color: #000;
    margin-bottom: 40px;
}

.contact-form {
    background-color: #f1f1f1;
    padding: 30px;
}

.contact-form .form-control {
    height: 43px;
    border-radius: 0px;
    margin-bottom: 20px;
    border: 0px solid #fff;
}

.contact-form #message {
    height: 168px;
}

textarea.form-control {
    min-height: 169px !important;
}

.form_submit {
    width: 100%;
    background: #00008b;
    border-radius: 0px;
    color: #fff;
    padding-top: 13px;
    padding-bottom: 10px;
    transition: all 1s;
    border: none;
}

.form_submit:hover {
    color: #fff;
}

.work-with {
    padding-bottom: 60px;
    padding-top: 10px;
}

.work-with h3 {
    font-size: 14px;
    color: #636363;
    text-transform: uppercase;
}

/*Footer*/

/* footer {
    width: 100%;
    float: left;
    padding: 50px 0;
    margin-top: 0px;
    background-color: #246EA9;
    background-repeat: repeat-x;
    background-position: left top;
    padding: 3.125rem 0 1.5625rem;
} */

.footer_logo {}

.footer_logo img {}

ul.icon_list {
    margin: 0;
    padding: 0;
    list-style: none;
    text-align: center;
    margin-top: 20px;
}

ul.icon_list li a {
    display: inline-block;
    color: #fff;
    border: 1px solid #fff;
    border-radius: 50%;
    text-align: center;
    width: 30px;
    height: 30px;
    text-align: center;
    line-height: 28px;
    transition: all 1s ease;
    -webkit-transition: all 1s ease;
}

ul.icon_list li a:hover {
    transform: rotate(720deg);
    -webkit-transform: rotate(720deg);
}

footer {
    text-align: right;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 2;
}

.ft-infor {
    margin-left: auto;
    display: block;
    float: none;
    margin-bottom: 20px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.ft-infor p {
    text-align: right;
    padding: 0;
    font-size: 16px;
}

header#Home {
    margin-top: 20px;
    position: relative;
    z-index: 2;
}

header#Home .logo h1 {
    margin-top: 15px;
}

.sec_template {
    overflow: hidden;
}

body {
    overflow-x: hidden !important;
}

.sec_template .txt1 {
    font-size: 18px;
    color: #fff;
    margin-top: 10vh;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.sec_template .txt2 {
    font-size: 18px;
    color: #fff;
    margin-top: 8vh;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.sec_template .title_s1 {
    margin-bottom: 20px;
    width: 100%;
}

/* 
ul.icon_list li.ft_fa-facebook a:hover {
    border: 1px solid #3b5998;
}

ul.icon_list li.ft_fa-facebook a:hover i {
    color: #3b5998;
}

ul.icon_list li.ft_fa-twitter a:hover {
    border: 1px solid #55acee;
}

ul.icon_list li.ft_fa-twitter a:hover i {
    color: #55acee;
}

ul.icon_list li.ft_fa-google-plus a:hover {
    border: 1px solid #dd4b39;
}

ul.icon_list li.ft_fa-google-plus a:hover i {
    color: #dd4b39;
}

ul.icon_list li.ft_fa-youtube a:hover {
    border: 1px solid #dd4b39;
}

ul.icon_list li.ft_fa-youtube a:hover i {
    color: #dd4b39;
} */

.copyright_text {
    padding-top: 15px;
    color: #fff;
    font-size: 16px;
}

.copyright_text a {
    color: #636363;
    text-decoration: none;
    font-size: 12px;
}

.img_responsive {
    width: 100%;
    height: auto;
}

/*Scroll*/

#page-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    font-size: 12px;
    z-index: 999999;
}

#page-top a img {
    max-width: 80px;
}

#page-top a:hover {
    text-decoration: none;
    cursor: pointer;
}

.title_style01 {
    text-align: center;
    font-size: 40px;
    font-weight: bold;
    color: #246EA9;
    border-bottom: 2px solid #28397E;
    padding-bottom: 10px;
    margin-bottom: 40px;
}

.div_txt01 {
    text-align: center;
    font-size: 34px;
    font-weight: bold;
    color: #ff0000;
}

.div_txt01 span {
    font-size: 20px;
    color: #000;
}

.all_item {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    margin-top: 30px;
    counter-reset: item;
}

.all_item .item {
    width: 100%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    min-height: 200px;
    margin-bottom: 50px;
    border: 1px solid #28397E;
    /* overflow: hidden; */
    counter-increment: item;
    position: relative;
}

.all_item .item::after {
    /* content: ""; */
    height: 30px;
    width: 50px;
    background-image: url(./assets/images/arrow.png);
    background-position: center center;
    background-size: contain;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 100%);
    -webkit-transform: translate(-50%, 100%);
    -moz-transform: translate(-50%, 100%);
    -ms-transform: translate(-50%, 100%);
    -o-transform: translate(-50%, 100%);
    z-index: 2;
}

.all_item .item:last-child::after {
    content: none;
}

.all_item .item .img {
    width: 30%;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}

.all_item .item .txt {
    width: 70%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    position: relative;
    font-size: 34px;
    font-weight: bold;
    color: #246EA9;
    padding-left: 70px;
}

.all_item .item .txt::after {
    content: counter(item);
    color: #ff0000;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    font-size: 70px;
}

.all_item .item .txt::before {
    content: "";
    width: 0px;
    left: 0;
    top: 0;
    bottom: 0;
    transform: translateX(-100%);
    -webkit-transform: translateX(-100%);
    -moz-transform: translateX(-100%);
    -ms-transform: translateX(-100%);
    -o-transform: translateX(-100%);
    position: absolute;
    border-left: 100px solid transparent;
    border-top: 200px solid #fff;
}

.banner_contact {
    border: 1px solid #28397E;
    padding: 30px 10px;
    border-radius: 20px;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
    -ms-border-radius: 20px;
    -o-border-radius: 20px;
    text-align: center;
    background-image: url(./assets/images/slide1.jpg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    overflow: hidden;
}

.banner_contact::after {
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    bottom: 0;
    background-color: rgba(255, 255, 255, 0.8);
    z-index: 1;
    position: absolute;
}

.banner_contact .title_contact {
    font-size: 32px;
    font-weight: bold;
    color: #28397E;
    margin-bottom: 10px;
    position: relative;
    z-index: 2;
}

.banner_contact .title_contact span {
    font-size: 20px;
    color: #000;
    position: relative;
    z-index: 2;
}

.banner_contact .txt_tel {
    font-size: 30px;
    font-weight: bold;
    color: #ff0000;
    position: relative;
    z-index: 2;
    margin-bottom: 10px;
}

.banner_contact .txt_tel::before {
    content: "\f095";
    font-family: FontAwesome;
}

.banner_contact .txt_web {
    position: relative;
    z-index: 2;
    margin-bottom: 10px;
    font-size: 24px;
    color: #246EA9;
}

.banner_contact .txt_web::before {
    content: "\f05a";
    font-family: FontAwesome;
}

.banner_contact .txt_note {
    position: relative;
    z-index: 2;
    margin-bottom: 10px;
}

body.home.page-template {
    position: relative;
    height: 100vh;
    background-image: url(./assets/images/bg_page.jpeg);
    padding-left: 10px;
    padding-right: 10px;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    position: relative;
}

body.home.page-template::before {
    content: "";
    background-color: rgba(0, 0, 0, 0.2);
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

section {
    position: relative;
    z-index: 2;
}

header#Home .logo img {
    max-width: 316px;
    width: 100%;
}

header#Home .logo h1 {
    color: #fff;
    font-weight: bold;
    text-align: center;
}

.title_s1 span {
    font-size: 24px;
    font-weight: bold;
    color: #fff;
    line-height: 140%;
    border-bottom: 1px #3388B9 dotted;
    display: inline-block;
}

.title_s1 span::first-letter {
    font-size: 30px;
    color: #3388B9;
}

/* .title_s1 span {
    font-size: 18px;
    font-weight: bold;
    position: relative;
    z-index: 1;
}

.title_s1 span::before {
    content: "";
    position: absolute;
    bottom: -3px;
    width: 100%;
    height: 10px;
    display: inline-block;
    background-color: #3388B9;
    z-index: -1;
} */

.fas {
    margin-right: 10px;
    color: #3388B9;
    margin-left: 5px;
    text-shadow: rgb(255, 255, 255) 1px 0px 0px, rgb(255, 255, 255) 0.540302px 0.841471px 0px, rgb(255, 255, 255) -0.416147px 0.909297px 0px, rgb(255, 255, 255) -0.989992px 0.14112px 0px, rgb(255, 255, 255) -0.653644px -0.756802px 0px, rgb(255, 255, 255) 0.283662px -0.958924px 0px, rgb(255, 255, 255) 0.96017px -0.279415px 0px;
}

.span_note {
    font-weight: bold;
    text-shadow: rgb(255, 255, 255) 1px 0px 0px, rgb(255, 255, 255) 0.540302px 0.841471px 0px, rgb(255, 255, 255) -0.416147px 0.909297px 0px, rgb(255, 255, 255) -0.989992px 0.14112px 0px, rgb(255, 255, 255) -0.653644px -0.756802px 0px, rgb(255, 255, 255) 0.283662px -0.958924px 0px, rgb(255, 255, 255) 0.96017px -0.279415px 0px;
    color: #3388B9;
    font-weight: bold;
    font-size: 14px;
}

@media(max-width: 768px), screen and (max-height: 720px) {

    .copyright_text {
        font-size: 11px;
    }

    .top-post li {
        width: 49%;
        margin-right: 2%;
        margin-bottom: 15px;
    }

    .imgFt img {
        display: block;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 15px;
    }

    .imgFt:last-child img {
        margin-bottom: 0;
    }

    .top-post li:last-child,
    .top-post li:nth-child(2) {
        margin-right: 0;
    }

    .top-fb iframe {
        height: 600px;
    }

    .top-img-ip img {
        display: block;
        margin-left: auto;
        margin-right: auto;
        margin-top: 20px;
    }

    .top-scroll-id li {
        width: 100%;
        margin-right: 0;
    }

    .top-scroll-id-more li {
        width: 100%;
        margin-right: 0;
    }

    .top-more-img img {
        display: block;
        margin-left: auto;
        margin-right: auto;
        padding-top: 10px;
    }

}

@media(max-width: 1200px) {
    .title_style01 {
        font-size: 3.333vw;
        padding-bottom: 0.833vw;
        margin-bottom: 3.333vw;
    }

    .slide-top .slide-text p {
        font-size: 2.833vw;
        margin-top: 1.667vw;
    }

    .div_txt01 {
        font-size: 2.833vw;
    }

    .div_txt01 span {
        font-size: 1.667vw;
    }

    .all_item .item .txt::after {
        font-size: 5.833vw;
    }

    .all_item .item .txt {
        font-size: 2.833vw;
        padding-left: 5.833vw;
    }

    .all_item .item .txt::before {
        border-left: 8.333vw solid transparent;
        left: 1px;
    }

    .banner_contact .title_contact {
        font-size: 2.667vw;
        margin-bottom: 0.833vw;
    }

    .banner_contact .title_contact span {
        font-size: 1.667vw;
    }

    .banner_contact .txt_tel {
        font-size: 2.500vw;
        margin-bottom: 0.833vw;
    }

    .banner_contact .txt_web {
        margin-bottom: 0.833vw;
        font-size: 2vw;
    }
}

@media(max-width: 767px), screen and (max-height: 720px) {
    .title_s1 span::first-letter {
        font-size: 20px;
    }
    header#Home .logo img {
        max-width: 220px;
    }
    header#Home .logo h1 {
        font-size: 16px;
    }
    .sec_template .title_s1 {
        margin-bottom: 10px;
    }
    .sec_template .txt2,
    .ft-infor p {
        font-size: 11px;
    }
    .span_note {
        font-size: 12px;
    }


    .copyright_text {
        padding-top: 0;
    }

    .title_s1 span::before {
        height: 5px;
        bottom: 0;
    }

    .title_s1 span {
        font-size: 13px;
    }

    .sec_template .txt1 {
        font-size: 13px;
        margin-top: 5vh;
    }

    .ft-infor {
        margin-bottom: 0;
    }

    .sec_template .txt2 {
        margin-top: 3vh;
    }

   

    .banner_contact .title_contact span {
        font-size: 11px;
    }

    body {
        font-size: 12px;
    }

    .banner_contact .txt_tel {
        font-size: 16px;
        margin-bottom: 10px;
    }

    .banner_contact .txt_web {
        margin-bottom: 10px;
        font-size: 16px;
    }

    .banner_contact {
        padding: 20px 10px;
    }

    .banner_contact .txt_note {
        margin-bottom: 0px;
    }

    .banner_contact .title_contact {
        font-size: 16px;
        margin-bottom: 10px;
    }

    .div_txt01 {
        font-size: 14px;
    }

    .all_item .item {
        min-height: none;
        margin-bottom: 30px;
    }

    .all_item .item .img {
        width: 100%;
        min-height: 150px;
    }

    .all_item .item .txt::before {
        content: none;
    }

    .all_item .item .txt {
        width: 96%;
        font-size: 18px;
        padding-left: 30px;
        margin-left: 2%;
        margin-right: 2%;
        padding-top: 10px;
        padding-bottom: 10px;
    }

    .all_item .item .txt::after {
        font-size: 30px;
    }

    .slide-top .slide-text p {
        font-size: 16px;
        margin-top: 10px;
    }

    .title_style01 {
        font-size: 16px;
        padding-bottom: 5px;
        margin-bottom: 10px;
    }

    /* css t */
    .brcopy-r {
        display: block;
    }

    .top-ser-box li.step01,
    .top-ser-box li.step02,
    .top-ser-box li.step03 {
        background-size: 50px;
        height: auto;
    }

    .top-ser-box li h4 {
        padding-left: 0;
        margin-top: 0;
        margin-bottom: 0;
    }

    .TopBox li {
        padding: 10px;
    }

    .TopBox li,
    .TopBox li:last-child {
        width: 100%;
        font-size: 16px;
    }

    .top-bg-1 span {
        font-size: 11px;
    }

    .all-time p {
        padding: 10px;
        padding-bottom: 60px;
    }

    .imgft-left {
        width: 100%;
        float: left;
        margin-right: 0;
    }

    .imgft-right {
        width: 100%;
        float: left;
        margin-top: 10px;
    }

    .all-time p,
    .top-more-txt,
    li.step01 p,
    .layout-column-txt p {
        font-size: 14px;
        line-height: 160%;
    }

    .table-left tr td:first-child,
    .top-tb2 td:first-child {
        background: #D8D8D8 !important;
        color: #333;
        font-weight: bold;
    }

    .img-ft-last {
        margin-top: 10px;
    }

    .form-cont {
        margin-top: 10px;
    }

    .infor-btn a {
        padding: 10px;
    }

    .infor-box {
        width: 100%;
        float: left;
        margin-right: 0;
    }

    .top-tb-custom-last {
        margin-top: 10px;
    }

    .top-ser-box li {
        margin-top: 20px;
        padding: 10px 0 0 75px;
    }

    .top-tb2 tr td.td-col3 {
        background: #fff !important;
    }

    .row-table table tr td {
        padding: 5px 5px;
    }

    .top-more-img img {
        display: block;
        margin-left: auto;
        margin-right: auto;
        margin-top: 10px;
    }

    .top-bg-1 p {
        padding: 0;
    }

    .top-scroll-id li,
    .top-scroll-id-more li {
        width: 100%;
        margin-right: 0;
    }

    .top-calendar {
        margin-top: 10px;
    }

    .rows-news {
        height: 200px !important;
    }

    .top-box-ser .box-span {
        padding: 10px 0px !important;
    }

    .img-left {
        width: 100%;
        float: left;
        margin-right: 0;
    }

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

    .navbar-right .slide-top .slide-text img {
        max-width: 100%;
        width: 100%;
        display: block;
        margin-left: auto;
        margin-right: auto;
        padding-left: 10px;
        padding-right: 10px;
    }

    .top-fb,
    .top-ins {
        display: none;
    }

    .row_blog {
        padding-bottom: 30px;
    }

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

    .top-news-sp,
    .top-blog-sp {
        display: block;
        width: 100%;
    }

    .top-news-sp img,
    .top-blog-sp img {
        max-width: 220px;
        display: block;
        margin-left: auto;
        margin-right: auto;
    }

    .top-map {
        margin-top: 10px;
    }

    .top-img-sp {
        display: block;
        margin-left: auto;
        margin-right: auto;
        width: 100%;
    }

    .top-img-sp img {
        display: block;
        margin-left: auto;
        margin-right: auto;
        max-width: 160px;
    }

    .row-table table tr td,
    .layout-column-table tr.table-title1 th {
        font-size: 13px;
    }

    .top-fb iframe,
    .top-ins iframe {
        width: 100% !important;
        height: 300px !important;
    }

    .top-fb,
    .top-ins {
        width: 100% !important;
        overflow: hidden !important;
    }

    .table-scroll-sp {
        width: 100%;
        overflow-x: auto !important;
    }

    .table-scroll-sp table {
        min-width: 1140px !important;
    }

    .layout-column-txt span.top-title,
    .layout-column-txt p span.top-cl-b {
        font-size: 18px;
        line-height: 160%;
    }

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

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

    .row-title-style39 h3 {
        font-size: 18px;
    }

    .title-style39::before {
        left: -25px !important;
    }

    .clear-sp {
        display: block;
        clear: both;
    }

    .pd-0-sp {
        padding-left: 0;
        padding-right: 0;
    }

    .top-txt p {
        font-size: 14px;
    }

    footer {
        margin-top: 0px;
    }

    .pd10-sp {
        margin-bottom: 20px;
    }

    .pd-t20-sp {
        margin-top: 10px;
    }

    .navbar-collapse ul {
        background: #fff;
    }

    .top-map iframe {
        width: 100% !important;
        height: 200px;
    }

    .section_overlay h1 {
        margin-top: 5px;
        padding-left: 15px;
    }

    .navbar-default .navbar-toggle {
        border-color: #6dc842;
    }

    /* .owl-carousel {
        margin-top: 65px;
    } */
    .navbar-brand>img {
        height: 60px;
        object-fit: scale-down;
    }

    .top-tb2 tr td {
        width: 100% !important;
        float: left;
        border: none !important;
    }

    .home_text h2 {
        font-size: 30px;
        letter-spacing: 5px;
    }

    .nav>li {
        font-size: 15px;
    }

    .navbar-brand {
        float: none;
        display: block;
    }

    nav li.nav_facebook,
    nav li.nav_twitter,
    nav li.nav_google {
        width: 33.3333333%;
        float: left;
        text-align: center;
        background: #fff;
        border-right: 1px solid #e7e7e7;
    }

    nav li.nav_facebook a,
    nav li.nav_twitter a,
    nav li.nav_google a {
        padding-top: 10px;
        padding-bottom: 10px;
    }

    nav li.nav_google {
        border-right: none;
    }

    .navbar-nav {
        margin: 0 -15px;
    }

    .navbar-nav>li>a {
        border-bottom: 1px solid #fff;
        line-height: 30px;
    }

    .container {
        overflow: hidden;
    }

    .services {
        background-size: 100% auto;
    }

    .services .col-md-3 {
        margin-bottom: 40px;
    }

    .container.map {
        padding: 30px 15px;
    }

    .baton {
        margin-top: 30px;
    }

    .single_count {
        padding-top: 30px;
    }

    .txt-ul {
        margin-top: 20px;
    }

    .txt-ul li {
        font-size: 14px;
    }

    .flex-rows {
        display: -webkit-box;
        display: -moz-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        flex-wrap: wrap;
        align-items: stretch
    }

    .txt-ul li {
        margin-bottom: 7px;
    }

    .navbar-right li:last-child {
        display: none;
    }

    .layout-column-txt p i,
    .layout-column-txt a.phone {
        font-size: 20px;
        padding-left: 5px;
    }

    .all-time p {
        font-size: 14px;
    }

    .layout-column-txt p {
        font-size: 14px;
    }

    .title-recuit h3 {
        font-size: 18px;
        margin-bottom: 20px;
    }

    .rec-txt span {
        font-size: 14px;
        padding: 10px 0;
        line-height: 160%;
    }

    .rec-box ul li {
        width: 100%;
        margin-right: 0;
        margin-bottom: 20px;
    }

    .rec-box ul li:last-child {
        margin-bottom: 0px;
    }

    .rec-title h4 {
        font-size: 18px;
        font-weight: bold;
        color: #eb3178;
        margin-bottom: 5px;
    }

    .rec-title {
        margin-bottom: 10px;
    }

    .rec-box ul li span {
        margin-top: 10px;
        line-height: 160%;
    }

    .row-table .toptb-bd tr td {
        padding: 5px;
    }

    .toptb-bd tr td:first-child {
        text-align: left;
        background: #fff !important;
    }

    /* .layout-column-table {
        padding-left: 0;
        padding-right: 0;
    } */
    .sp-mt-20 {
        margin-top: 20 !important;
    }

    h1,
    .h1,
    h2,
    .h2,
    h3,
    .h3 {
        margin-top: 0px;
        margin-bottom: 0px;
    }

    .top-post li {
        width: 100%;
        float: left;
        margin-bottom: 15px;
    }

    .brPC {
        display: none;
    }

    .top-post a .sub-post {
        padding: 10px 0;
        color: #fff;
        font-size: 14px;
        line-height: 160%;
    }

    .top-post a .tt-post {
        font-size: 16px;
    }

    .top-post a .btn-post {
        background: #fff;
        color: #333;
        font-size: 14px;
        line-height: 160%;
        padding: 10px;
    }

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

    .topCol ul li {
        width: 100%;
        margin-right: 0;
        font-size: 14px;
    }

    .row-title-style31 h4 {
        font-size: 16px;
    }

    .title-style31::first-letter {
        font-size: 16px;
    }

    .topIf li,
    .layout-column-img span.txt-bt-img strong,
    .row-table table tr th {
        font-size: 14px;
    }

    /* end css t */


}

@media screen and (max-width:580px) {
    .row_blog iframe {
        height: 200px;
    }

    .navbar-toggle {
        margin-top: 18px;
    }

    .footer_logo img {
        max-width: 230px;
    }
}

@media screen and (max-width:390px) {
    .row_blog iframe {
        height: 200px;
    }

    .navbar-toggle {
        margin-top: 18px;
    }

    .footer_logo img {
        max-width: 230px;
    }
}