@font-face {
  font-family: YuGothicM;
  src: local(Yu Gothic Medium),
       local(Yu Gothic);
  font-weight: 500;
}

body {
    font-family: "游ゴシック体", YuGothic, "YuGothic M",'Meiryo UI', Meiryo, 'メイリオ', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', sans-serif!important;
    font-weight: 300;
    font-size: 14px;
    line-height: 1.6;
    color: #fff;
    background: #f5f5f5
}
@media screen and (max-width:992px) {
    body {
        font-size: 1pc
    }
}
a {
    color: #222;
    -webkit-transition: 0.5s;
    -o-transition: 0.5s;
    transition: 0.5s
}
a:active,
a:focus,
a:hover {
    color: #ccc;
    outline: 0;
    text-decoration: none !important
}
p {
    font-size: 14px;
    color: #222;
    margin-bottom: 1.5em;
    line-height: 1.8em
}
h1,
h2,
h3,
h4,
h5,
h6 {
    color: #000;
    font-family: "游ゴシック体", YuGothic, "YuGothic M",'Meiryo UI', Meiryo, 'メイリオ', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', sans-serif;
    font-weight: 400;
    margin: 0 0 40px
}
@media screen and (max-width:480px) {
    figure figcaption {
        width: 100%
    }
}
::-webkit-selection {
    color: #fff;
    background: #228896
}
::-moz-selection {
    color: #fff;
    background: #228896
}
::selection {
    color: #fff;
    background: #228896
}
.center {
    text-align: center
}
#page {
    width: 100%;
    overflow: hidden;
    position: relative;
    background-color: #fff
}
.float-tel {
    position: fixed;
    right: 1%;
    bottom: 1%;
    z-index: 5;
    background: rgba(51, 51, 51, .9);
    border-radius: 5px;
    padding: 20px 40px 0;
    text-align: center
}
@media screen and (max-width:768px) {
    .float-tel {
        height: 5pc;
        width: 100%;
        position: fixed;
        right: 0;
        bottom: 0;
        z-index: 5;
        background: rgba(51, 51, 51, .9);
        border-radius: 0;
        padding: 7px 35px 0;
        text-align: center
    }
}
.float-tel > p {
    color: #fff
}
#aside {
    background: #576573;
    padding-top: 20px;
    padding-bottom: 20px;
    width: 22%;
    position: fixed;
    bottom: 0;
    top: 0;
    left: 0;
    overflow-y: hidden;
    z-index: 6;
    -webkit-transition: 0.5s;
    -o-transition: 0.5s;
    transition: 0.5s
}
@media screen and (max-width:1200px) {
    #aside {
        width: 30%
    }
}
@media screen and (max-width:768px) {
    #aside {
        width: 270px;
        -moz-transform: translateX(-270px);
        -webkit-transform: translateX(-270px);
        -ms-transform: translateX(-270px);
        -o-transform: translateX(-270px);
        transform: translateX(-270px)
    }
}
@media screen and (max-width:480px) {
    #aside {
        padding-top: 60px
    }
}
#aside #logo {
    text-align: center;
    font-family: Roboto, Arial, sans-serif;
    font-weight: 700;
    margin-bottom: 1.0em;
    text-transform: uppercase;
    font-size: 38px
}
@media screen and (max-width:768px) {
    #aside #logo {
        margin-bottom: 0.5em
    }
}
#aside #logo a {
    color: #000
}
#aside #logo a span {
    font-weight: 300;
    color: rgba(0, 0, 0, .5)
}
#aside #main-menu ul {
    text-align: center;
    margin: 0;
    padding: 0
}
@media screen and (max-width:768px) {
    #aside #main-menu ul {
        margin: 0 0 2em
    }
}
#aside #main-menu ul li {
    margin: 0 0 25px;
    padding: 0;
    list-style: none
}
#aside #main-menu ul li a {
    color: #fff;
    text-decoration: none;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-size: 15px;
    font-weight: bold;
    position: relative;
    padding: 10px;
    letter-spacing: 0.2em;
    font-family: Roboto, Arial, sans-serif;
    -webkit-transition: 0.3s;
    -o-transition: 0.3s;
    transition: 0.3s
}
#aside #main-menu ul li a:after {
    content: "";
    position: absolute;
    height: 2px;
    bottom: 7px;
    left: 10px;
    right: 10px;
    background-color: #5fc6d4;
    visibility: hidden;
    -webkit-transform: scaleX(0);
    -moz-transform: scaleX(0);
    -ms-transform: scaleX(0);
    -o-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    -moz-transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    -ms-transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    -o-transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275)
}
#aside #main-menu ul li a:hover {
    text-decoration: none;
    color: #ccc
}
#aside #main-menu ul li a:hover:after {
    visibility: visible;
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1)
}
#aside #main-menu ul li.active a {
    color: #ccc
}
#aside #main-menu ul li.active a:after {
    visibility: visible;
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    -ms-transform: scaleX(1);
    -o-transform: scaleX(1);
    transform: scaleX(1)
}
#aside .footer {
    position: absolute;
    bottom: 10px;
    font-size: 14px;
    text-align: center;
    width: 100%;
    font-weight: 400;
    color: #fff;
    padding: 0 20px
}
@media screen and (max-width:767px) {
    #aside .footer {
        position: absolute;
        bottom: 10px;
    }
}
.tips {
    padding-top: 10px;
    font-size: 15px
}
.footer > p {
    color: #fff;
    margin-bottom: -5px;
    text-align: center;
}
.tel-nmb > a,
.tips {
    color: #fff;
    font-weight: 700
}
.tel-nmb > a {
    font-size: 2pc;
    letter-spacing: 0.1em;
    text-indent: -0.5em
}
.fa-phone-square {
    padding-left: 30px
}
.copyright {
    font-size: 9pt
}
img.main-logo {
    width: 210px;
    max-width: 100%;
    height: auto
}
@media screen and (max-width:450px) {
    img.main-logo {
        display: block;
    margin: 0 auto;
    }
}
img.monolith-img {
    margin: 0 auto
}
@media screen and (min-width:481px) {
    .mobile {
        display: none
    }
}
@media screen and (max-width:480px) {
    .pc {
        display: none
    }
}
@media screen and (min-width:481px) {
    .pc-vanish {
        display: none
    }
}
@media screen and (max-width:480px) {
    .mobile-vanish {
        display: none
    }
}
.stripe {
    position: fixed;
    background-image: url('../images/01.png');
    background-repeat: repeat;
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto
}
.bread {
    padding-left: 1em;
    margin-top: -40px
}
.bread-p,
.bread-p > a {
    font-size: 13px
}
.bread-p > a {
    color: #222
}
.bread-p > a:hover {
    color: #ccc
}
.portfolio-page-header {
    background-image: url('../images/portfolio/portfolio_header_bg.jpg')
}
#main {
    width: 78%;
    background-image: url(../images/bg.jpg);
    background-attachment: fixed;
    background-size: cover;
    overflow: hidden;
    float: right;
    -webkit-transition: 0.5s;
    -o-transition: 0.5s;
    transition: 0.5s;
}
@media screen and (max-width:1200px) {
    #main {
        width: 70%
    }
}
@media screen and (max-width:991px) {
    #main {
        background: #fff;
    }
}
@media screen and (max-width:768px) {
    #main {
        width: 100%
    }
}
#main .narrow-content {
    position: relative;
    width: 100%;
    margin: 0 auto;
    padding: 3% 0;
    clear: both
}
@media screen and (max-width:768px) {
    #main .narrow-content {
    width: 100%;
    padding: 1em 0em;
    }
}
.module,
.module-small {
    position: relative;
    padding: 30px 15px;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover
}
.page-module {
    position: relative;
    padding: 40px 15px;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover
}
.header-img {
    max-width: 100%;
    height: auto;
    margin-bottom: 20px
}
.module-subtitle {
color: #fff;
    line-height: 1.7em;
    font-size: 16px;
    text-align: left;
    text-shadow: 1px 1px 3px #0c0c0c;
}
a.thumnail {
    display: block;
    float: left;
    overflow: hidden;
    width: 100%
}
img {
    height: auto;
    -webkit-transition: all 0.25s ease-in-out;
    transition: all 0.25s ease-in-out;
    vertical-align: bottom
}
.img-responsive {
    margin: auto;
}
figure {
    margin: 0;
    overflow: hidden;
    position: relative;
    text-align: center
}
figcaption {
    background-color: rgba(0, 0, 0, .6);
    color: #fff;
    opacity: 0;
    font-size: 14px;
    line-height: 1.8em;
    position: absolute;
    text-align: left;
    -webkit-transition: all 0.25s ease-in-out;
    transition: all 0.25s ease-in-out;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    padding: 5% 10%
}
h1, .h1 {
    font-size: 12px!important;
    color: #fff!important;
    text-align: center!important;
    line-height: 1.5em!important;
    margin-top: 0!important;
    margin-bottom: -10px!important;
}

.col-md-12.col-sm-12.col-xs-12.about-wrap {
    margin-top: 10px;
    background: #e0e8e8;
    margin-bottom: 3%;
    position: relative;
}
.col-md-12.col-sm-12.col-xs-12.sub-about-wrap {
    margin-top: 10px;
    background: #e0e8e8;
    margin-bottom: 6%;
    position: relative;
}
.about-inner{
    width: 88%;
    margin: 0 auto;
    position: relative;
    top: -50px;
    z-index: 1;
}
.about-left{
    position: absolute;
    top: 110px;
        width: 27%;
}
.about-center{
    width: 46%;
    margin: 90px 0 -20px 27%;
    padding: 0 35px 0 40px;
    float: left;
}
.about-right{
    float: right;
        width: 27%;
}
img.about-img-left{
    padding: 10px;
}
img.about-img-right{
    padding: 10px;
}
img.about-img-center {
    display: none;
}




@media screen and (min-width: 1120px) and (max-width: 1400px) {
    .about-center {
        padding: 0 15px 0 20px;
    }
    .about-left {
        position: absolute;
        top: 365px;
        width: 27%;
    }    
}


@media screen and (min-width: 992px) and (max-width: 1119px) {
    .about-inner {
        width: 100%;
        margin: 0 auto;
        position: relative;
        top: 0;
        z-index: 1;
    }
    .about-left {
        width: 0%;
        display: none;
    }
    .about-center {
        width: 100%;
        margin: 30px 0 30px 0%;
        padding: 0 10px 0 10px;
        float: none;
    }
    .about-right {
        float: none;
        width: 0;
        display: none;
    }
    img.about-img-center {
        display: block;
        width: 30%;
        float: right;
    }
    img.about-img-center.img-responsive {
        padding: 0 10px;
    }
}
    
    
@media screen and (max-width: 991px) {
    .about-inner {
        width: 100%;
        margin: 0 auto;
        position: relative;
        top: 0;
        z-index: 1;
    }
    .about-left {
        width: 0%;
        display: none;
    }
    .about-center {
        width: 100%;
        margin: 30px 0 30px 0%;
        padding: 0;
        float: none;
    }
    .about-right {
        float: none;
        width: 0;
        display: none;
    }
    img.about-img-center {
        display: block;
        width: 30%;
        float: right;
    }    
}

@media screen and (max-width:767px) {
    nav#main-menu {
        margin-top: 20px;
    }
    #aside #main-menu ul li {
        margin: 0 0 22px;
        padding: 0;
        list-style: none;
    }
    h1, .h1 {
        font-size: 12px!important;
        margin-top: 10px!important;
    }
img.about-img-center {
    display: block;
    width: 70%;
    float: none;
    margin: 0 auto 20px;
    /* padding: 10px; */
}
}

.chief-name {
    text-align: right;
    margin-top: 30px;
}

.top-chief-text>p{
    font-size: 14px;
}
.chief-text {
    margin-top: -10px
}
.chief-area {
    text-align: center;
    margin-top: 10%;
    margin-bottom: 10%;
}
.chief-btn {
    margin-top: 15px
}
.chief-btn:hover {
    background: #3a8f9a;
    color: #fff;
    border: solid 2px #3a8f9a;
    border-radius: 5px
}
.blog-btn,
.chief-btn {
    font-size: 16px;
    display: inline-block;
    padding: 1.5em 5.0em;
    text-decoration: none;
    font-weight: bold;
    color: #3a8f9a;
    border: solid 1px #3a8f9a;
    transition: 0.3s;
    background: #fff;
}
.blog-btn,.chief-btn:hover {
    background: #3a8f9a;
    color: #fff;
    border-radius: 0;
    border: solid 1px #3a8f9a;
}
@media screen and (max-width:767px) {
    .blog-btn, .chief-btn {
    display: block;
    padding: 1.5em 2.5em;
    background: #fff;
    text-align: center;
    }

    .col-md-12.col-sm-12.col-xs-12.about-wrap {
        margin-top: -10px;
    }
    .module, .module-small {
        position: relative;
        padding: 10px 15px;
        background-repeat: no-repeat;
        background-position: 50% 50%;
        background-size: cover;
    }
}
.price-container {
    padding: 2% 0;
}
.price-wrap {
    background: #fff;
    width: 31%!important;
    margin-left: 1%!important;
    margin-right: 1%!important;
    margin-bottom: 30px;
    border: 1px solid #cccccc;
    padding: 0!important;
}
h2.price-h {
    font-size: 18px;
    font-weight: bold;
    margin: 0;
    padding: 20px 5px 10px;
    border-bottom: 1px solid #3a8f9a;
}
img.price-img {
    max-width: 100%;
}
.price-img-wrap{
    padding: 0!important;
}
p.price-p {
    font-size: 15px;
    padding: 5px;
    color: #377780;
}
p.price-ex {
    font-size: 13px;
    line-height: 1.6em;
    padding: 10px 0 5px;
    color: #505050;
}
@media screen and (max-width: 991px) {
    .price-img-wrap {
        margin-bottom: 10px;
    }
}
@media screen and (max-width: 767px) {
    .price-wrap {
        background: #fff;
        width: 100%!important;
        margin-left: 0%!important;
        margin-right: 0%!important;
        margin-bottom: 10px;
        border: 1px solid #cccccc;
        padding: 0!important;
    }    
}

span.red {
    color: red!important;
    font-weight: 700
}
.divider-w {
    border-top: 1px solid #ccc;
    margin: 0;
    width: 100%;
    margin: 20px 0
}

.width-section {
    position: relative;
    width: 100%;
    margin: 0 auto;
    padding: 2%;
    clear: both
}
p.intro-p-w{
    color: #fff;
    padding: 0 10px;
    margin-bottom: 15px;
}
p.intro-p{
    color: #222;
    padding: 0 10px;
    margin-bottom: 15px;
}
.blog-title {
    margin: 0 auto
}
.blog {
    margin-top: 3%;
    padding-left: 0
}
.blog > p {
    color: #fff
}
.works-wrap {
    margin-top: 2%
}
img.works-img-responsive{
    display: block;
    max-width: 100%;
    height: auto;
    margin: 0 auto;
}

.results-sub {
    padding: 0 10%
}
.results-img {
    text-align: center;
    padding: 10px;
    max-width: 100%;
    max-height: 100%
}
.results-p {
    padding: 15px
}
.client-logo,
.gallery-caption,
.gallery-image img,
.gallery-image:after,
.post-images-slider,
.post-thumbnail,
.post-video,
.price-table,
.team-detail,
.team-image:after,
.work-caption,
.work-image > img,
.work-image:after {
    transition: all 0.3s ease-in-out 0
}
.post {
    margin: 0 0 40px;
    border: 1px solid #cccccc;
}
h2.post-title {
    margin: 0;
    font-size: 12px;
    padding: 5px;
    color: #5a7b79;
    border-bottom: 1px solid #5a7b79;
}
h2.post-know-title {
    margin: 0;
    font-size: 16px;
    line-height: 1.4;
    padding: 5px 10px 0;
    color: #5a7b79;
}
h3.post-title {
    font-size: 15px;
    text-align: right;
    margin: 2px 0 0;
    padding: 5px;
}

.post-header {
    margin: 0 0 10px
}
a.works-link {
    color: #333;
    display: block;
}
a.works-link:hover {
    color: #333;
    opacity: 0.7;
    transition: 0.3s;
}

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

h2.post-title > a {
    color: #fff
}
h2.post-title > a:hover {
    color: #bdbdbd
}
.reslut-lt-area {
    text-align: center;
}
p.know-p{
    text-align: left;
}
h2.know-sub-h2 {
    font-size: 24px;
    font-weight: bold;
    padding-bottom: 10px;
    border-bottom: 2px solid #3a8f9a;
    margin-bottom: 20px;
}
h3.know-sub-h3 {
    font-size: 20px;
    font-weight: bold;
    color: #226a73;
    margin-bottom: 15px;
}
@media screen and (max-width:767px) {
    .post-title, .post-title-sub {
        line-height: 1.4;
        font-size: 15px;
        margin: 0;
    }
    p.intro-p-w,p.intro-p{
        text-align: left;
        font-size: 14px;
            padding: 0 20px;
    }
    p.intro-p{
        text-align: left;
        font-size: 14px;
        padding: 0 10px;
    }
    .works-wrap {
        margin-top: 10%
    }
    .post-images-slider, .post-thumbnail, .post-video {
        margin: 0 0 10px;
    }
    .post-header {
        margin: 0 0 -10px;
    }
    h3.post-title {
        font-size: 15px;
        text-align: right;
        margin: 2px 0 15px;
        padding: 5px;
    }
    h2.post-know-title {
        margin: 0;
        font-size: 14px;
        line-height: 1.4;
        padding:5px 10px 20px;
        color: #5a7b79;
    }
    h2.know-sub-h2 {
        font-size: 22px;
        line-height: 1.4;
    }
    h3.know-sub-h3 {
    font-size: 18px;
    line-height: 1.4;
    }
}
h2.works-h {
    font-size: 18px;
    font-weight: bold;
    margin: 10px 0 20px;
    color: #3a8f9a;
    line-height: 1.7;
}
img.other-img {
    margin: 5% 0 0;
}
.works-img-wrap {
    display: block;
    margin: 0 auto 10px;
    width: 58%;
}
img.works-img-col2 {
    padding: 5px;
    width: 48%;
}
img.works-img-col3 {
    padding: 5px;
    width: 31.5%;
}
@media screen and (max-width: 991px) {
    .works-img-wrap {
        width: 80%;
    }
}
@media screen and (max-width: 767px){
    .works-img-wrap {
        width: 100%;
    }
img.works-img-col2 {
    padding: 5px 5px 5px 0px;
    width: 100%;
    max-width: 100%;
    display: block;
    margin: 0 auto;
}
img.works-img-col3 {
    padding: 5px 0px 5px 0px;
    width: 100%;
    max-width: 100%;
    display: block;
    margin: 0 auto;
}
}

.works-grid {
    list-style: none;
    padding: 0;
    margin: 0
}
.works-grid.works-grid-gut {
    margin: 0 0 0 -10px
}
.works-grid.works-grid-gut .work-item {
    padding: 0 0 10px 10px
}
.work-item {
    width: 50%;
    float: left;
    margin: 0
}
.works-grid-3 .work-item {
    width: 33.3333%
}
.container .works-grid-3 .work-item {
    width: 33.2%
}
.works-grid-4 .work-item {
    width: 25%
}
.works-grid-5 .work-item {
    width: 20%
}
.work-item > a {
    display: block
}
.work-image,
.work-item > a {
    position: relative;
    overflow: hidden
}
.work-image img {
    display: block;
    overflow: hidden;
    width: 100%
}
.work-image:after {
    display: block;
    content: "";
    height: 100%;
    top: 0
}
.work-caption,
.work-image:after {
    position: absolute;
    width: 100%;
    left: 0
}
.work-caption {
    padding: 0 20px;
    opacity: 0;
    bottom: 100%;
    text-align: center;
    overflow: hidden
}
.work-title {
    font-size: 18px;
    color: #fff;
    margin: 0 0 10px
}
.work-descr {
    color: #555
}
.work-item:hover .work-image:after {
    background: rgba(0, 0, 0, .6)
}
.work-item:hover .work-image > img {
    -webkit-transform: scale(1.1)rotate(2deg);
    -ms-transform: scale(1.1)rotate(2deg);
    transform: scale(1.1)rotate(2deg)
}
.work-item:hover .work-caption {
    bottom: 50%;
    opacity: 1;
    z-index: 2;
    -webkit-transform: translateY(50%);
    -ms-transform: translateY(50%);
    transform: translateY(50%)
}
.works-grid.works-hover-w .work-title {
    color: #111
}
.works-grid.works-hover-w .work-item:hover .work-image:after {
    background: hsla(0, 0%, 100%, 0.8)
}
.works-grid.works-hover-g .work-image:after {
    opacity: 0
}
.works-grid.works-hover-g .work-descr {
    color: #fff
}
.works-grid.works-hover-g .work-item:hover .work-image:after {
    background: #6fe29e;
    background: linear-gradient(135deg, rgba(111, 226, 158, .8) 0, rgba(91, 218, 209, .8) 100%);
    filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#6fe29e',endColorstr='#5bdad1',GradientType=1))
    opacity: 1
}
.sliding-portfolio .work-item {
    width: 100%
}
h3.works-name {
    margin-top: 50px;
    margin-bottom: 50px
}
.works-inner {
    margin-top: 5em
}

table.price-table {
    margin-top: 0;
    margin-bottom: 25px;
    border-collapse: separate;
    border-spacing: 0;
    text-align: left;
    line-height: 1.5;
    font-size: 15px;
    width: 100%;
    border-top: #9a9a9a 1px solid;
    border-left: #9a9a9a 1px solid;
}
table.price-table th {
    width: 150px;
    padding: 10px;
    font-weight: 700;
    vertical-align: middle;
    color: #fff;
}
table.price-table td {
    padding: 15px;
    vertical-align: middle;
    background: #fff;
    color: #222
}
td.price {
    font-size: 15px;
    text-align: left;
    width: 20%;
}
h2.price-title {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 15px;
}
p.table-ex {
    font-size: 13px;
    line-height: 1.5em;
    text-align: right;
}
.price-area {
    text-align: center
}
.price-btn {
    margin-top: 2%;
    font-size: 18px;
    display: inline-block;
    font-weight: bold;
    padding: 1.0em 2.0em;
    text-decoration: none;
    color: #3a8f9a;
    border: solid 2px #3a8f9a;
    border-radius: 5px;
    background: #fff;
    opacity: .9;
    filter:alpha(opacity980);
    -moz-opacity: .9;
    transition: 0.4s
}
.price-btn:hover {
    background: #3a8f9a;
    border: solid 2px #3a8f9a;
    border-radius: 5px;
    color: #fff
}
img.img-responsive.drt {
    margin: 40px auto;
    max-width: 100%;
}
h3.price-h {
    margin-top: 3em;
    margin-bottom: 2em;
    font-weight: 700
}
.price-text {
    padding: 0 3%;
    margin-bottom: 5em
}
p.cntact-p.center {
    font-size: 14px;
    margin-top: 20px;
}
section table {
    width: 100%
}
section td,
section th {
    padding: 10px;
    border-right: 1px solid #9a9a9a;
    border-bottom: 1px solid #9a9a9a;
}
section th {
    background: #3a8f9a
}
table.price-table th {
    width: 22%;
    text-align: left
}
@media only screen and (max-width:767px) {
    table.price-table {
        margin: 0
    }
    table.price-table td,
    table.price-table th {
        width: 100%;
        display: block;
        border-top: 0
    }
    table.price-table tr:first-child th {
        border-top: 1px solid #ddd
    }
    p.table-ex {
        font-size: 9px;
        line-height: 1.5em;
        text-align: left;
        margin: 10px 5px 30px;
    }
    p.cntact-p.center {
        font-size: 11px;
        text-align: left;
        padding: 0 10px;
        margin-top: 20px;
    }
}
.parallax-bg {
    margin-top: 150px;
    margin-bottom: 30px;
    background-attachment: fixed;
    background-size: cover;
    background-position: center;
    background-image: url('../images/blog-bg.jpg')
}
.testimonials-slider {
    position: relative;
    padding: 10px 0 60px
}
.blog-area {
    text-align: center;
    margin-bottom: -10%
}
.blog-btn {
    margin-top: 2%;
    font-size: 18px;
    display: inline-block;
    font-weight: bold;
    padding: 1.0em 2.0em;
    text-decoration: none;
    color: #3a8f9a;
    border: solid 2px #3a8f9a;
    border-radius: 5px;
    background: #fff;
    opacity: .9;
    filter:alpha(opacity980);
    -moz-opacity: .9;
    transition: 0.4s
}
.blog-btn:hover {
    background: #3a8f9a;
    border: solid 2px #3a8f9a;
    border-radius: 5px;
    color: #fff
}
.contact {
    margin-bottom: 2%
}
.area {
    margin-bottom: 2%
}
p.contact-btn {
    text-align: center;
    font-size: 15px
}
.bread-wrap {

}
ol.bread {
    font-size: 13px;
    margin: 0 0 0px 0px;
}
li.bread-list {
    float: left;
    list-style: none;
}
li.bread-list>a {
    color: #333333;
}
img.material-img {
    display: block;
    margin: 0px auto 50px;
    padding: 10px;
    max-width: 100%;
}
h2.material-h {
    font-size: 24px;
    text-align: center;
    font-weight: bold;
}
@media only screen and (min-width: 768px){
.res-table {
    width: 100%;
    margin: 10px auto 100px;
    font-size: 15px;
    border-left: #cccccc 1px solid;
    border-top: #cccccc 1px solid;
}
.res-table tr {
    border-bottom: #cccccc 1px solid;
}
.res-table th {
    width: 22%;
    padding: 15px 12px;
    display: table-cell;
    border-right: #cccccc 1px solid;
    text-align: left;
    color: #fff;
    background-color: #3a8f9a;
}
.res-table td {
    width: 78%;
    padding: 15px 12px;
    display: table-cell;
    text-align: left;
}
}
@media only screen and (max-width: 767px){
.res-table {
    width: 100%;
    margin: 0px auto 40px;
    border-left: #cccccc 1px solid;
    border-top: #cccccc 1px solid;
    border-bottom: #cccccc 1px solid;
}
.res-table th {
    padding: 10px;
    display: block;
    background-color: #3a8f9a;
    color: #fff;
    border-right: 1px solid #cccccc;
    border-bottom: none;
}
.res-table td {
    padding: 10px;
    display: block;
    text-align: left;
    border-right: 1px solid #cccccc;
    border-bottom: none;
    border-top: none;
}

}
.form-group {
    margin-bottom: 15px
}
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0
}
.form-control {
    font-family: Roboto Condensed, sans-serif;
    text-transform: none;
    letter-spacing: 2px;
    font-size: 11px;
    height: 33px;
    border: 1px solid #eaeaea;
    border-radius: 2px;
    transition: all 0.4s ease-in-out 0;
    background: #fff
}
.help-block {
    display: block;
    margin-top: 5px;
    margin-bottom: 10px;
    color: #737373
}
label {
    display: inline-block;
    max-width: 100%;
    margin-bottom: 5px;
    font-weight: 700
}

form#mail_form #textid.active {
    background-color:#FFF8E1;
    color: #000;
    box-shadow:0px 0px 5px rgba(84,189,245,1);
}
.text-danger {
    color: #a94442
}
.btn.btn-d {
    background: #5f91ff;
    color: #fff
}
.btn.btn-round {
    border-radius: 7px
}
.btn {
    border-radius: 0;
    font-family: Roboto Condensed, sans-serif;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 11px;
    padding: 8px 37px
}
.btn,
a {
    transition: all 0.125s ease-in-out 0
}
.btn-block {
    display: block;
    width: 100%
}
.btn.btn-d:hover {
    background: #2469ff;
    color: #fff
}
.footer-wrap {
    position: relative;
    width: 100%;
    margin: 0 auto;
    padding: 3% 1% 12%;
    clear: both;
}
.bg-dark {
    background: #455d5f;
}
.sidebar .widget {
    margin-bottom: 60px
}
.sidebar .widget-title {
    color: #111
}
.widget .widget-title {
border-bottom: 2px solid #ffffff;
    width: 50%;
    font-size: 16px;
    padding: 10px 5px 10px;
    margin: 0 0 10px;
    color: #fff;
}
.widget > p {
    font-size: 14px;
    color: #fff;
    padding: 5px 10px;
    line-height: 1.8em;
}
.widget ul {
    list-style: none;
    padding: 10px;
    margin-bottom: 20px;
    color: #fff;
    line-height: 1.8em;
}
.bg-dark a {
    color: #fff
}
.bg-dark a:hover {
    color: #ccc
}
.widget .icon-list li {
    padding: 5px 0
}
.widget .icon-list li a:before {
    content: "\00BB";
    color: #fff;
    padding-right: 5px
}
.widget-posts li {
    margin: 0 0 15px
}
.widget-posts li:last-child {
    margin: 0
}
.widget-posts-image {
    float: left;
    width: 4pc
}
.widget-posts-body {
    margin-left: 74px
}
#hero {
    min-height: 500px;
    background: #fff url(../images/loader.gif)no-repeat center center;
    width: 100%;
    float: left;
    clear: both
}
#hero .btn {
    font-size: 24px
}
#hero .btn.btn-primary {
    padding: 14px 30px !important
}
#hero .flexslider {
    border: 0;
    z-index: 1;
    margin-bottom: 0
}
#hero .flexslider .slides {
    position: relative;
    overflow: hidden
}
#hero .flexslider .slides .overlay {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    content: '';
    background: rgba(0, 0, 0, .3)
}
#hero .flexslider .slides li {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: bottom center;
    min-height: 500px;
    position: relative
}
#hero .flexslider .flex-control-nav {
    bottom: 20px;
    z-index: 5;
    right: 20px;
    float: right;
    width: auto
}
#hero .flexslider .flex-control-nav li {
    display: block;
    margin-bottom: 10px
}
#hero .flexslider .flex-control-nav li a {
    background: hsla(0, 0%, 100%, 0.2);
    box-shadow: none;
    width: 9pt;
    height: 9pt;
    cursor: pointer
}
#hero .flexslider .flex-control-nav li a.flex-active {
    cursor: pointer;
    background: transparent;
    border: 2px solid #228896
}
#hero .flexslider .flex-direction-nav {
    display: none
}
#hero .flexslider .slider-text {
    display: table;
    opacity: 0;
    min-height: 500px;
    z-index: 3
}
#hero .flexslider .slider-text > .slider-text-inner {
    display: table-cell;
    vertical-align: middle;
    min-height: 700px;
    padding: 2em
}
@media screen and (max-width:768px) {
    #hero .flexslider .slider-text > .slider-text-inner {
        text-align: center
    }
}
#hero .flexslider .slider-text > .slider-text-inner h1,
#hero .flexslider .slider-text > .slider-text-inner h2 {
    margin: 0;
    padding: 0;
    color: #fff;
    font-family: Roboto, Arial, sans-serif
}
#hero .flexslider .slider-text > .slider-text-inner h1 {
    margin-bottom: 20px;
    font-size: 45px;
    line-height: 1.3;
    font-weight: 100;
    font-family: Roboto, Arial, sans-serif
}
@media screen and (max-width:768px) {
    #hero .flexslider .slider-text > .slider-text-inner h1 {
        font-size: 28px
    }
}
#hero .flexslider .slider-text > .slider-text-inner h2 {
    font-size: 18px;
    line-height: 1.5;
    margin-bottom: 30px;
    font-weight: 300
}
#hero .flexslider .slider-text > .slider-text-inner h2 a {
    color: rgba(34, 136, 150, .8);
    border-bottom: 1px solid rgba(34, 136, 150, .7)
}
#hero .flexslider .slider-text > .slider-text-inner .heading-section {
    font-size: 50px
}
@media screen and (max-width:768px) {
    #hero .flexslider .slider-text > .slider-text-inner .heading-section {
        font-size: 30px
    }
}
#hero .flexslider .slider-text > .slider-text-inner s .lead {
    font-size: 20px;
    color: #fff
}
#hero .flexslider .slider-text > .slider-text-inner s .lead .icon-heart {
    color: #d9534f
}
#hero .flexslider .slider-text > .slider-text-inner .btn {
    font-size: 9pt;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: #fff;
    padding: 22px 30px !important;
    border: 0;
    font-weight: 500
}
#hero .flexslider .slider-text > .slider-text-inner .btn.btn-learn {
    background: #fff;
    color: #000
}
#hero .flexslider .slider-text > .slider-text-inner .btn.btn-learn:hover {
    color: #fff
}
@media screen and (max-width:768px) {
    #hero .flexslider .slider-text > .slider-text-inner .btn {
        width: 100%
    }
}
.bg-color {
    width: 100%;
    float: left;
    background: #fff
}
body.offcanvas {
    overflow-x: hidden
}
body.offcanvas #aside {
    -moz-transform: translateX(0);
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
    width: 100%;
    background: #555;
    z-index: 4;
    position: fixed
}
body.offcanvas #main,
body.offcanvas .nav-toggle {
    top: 0;
    left: -270px;
    -moz-transform: translateX(270px);
    -webkit-transform: translateX(270px);
    -ms-transform: translateX(270px);
    -o-transform: translateX(270px);
    transform: translateX(270px)
}
.services {
    margin-top: 5px
}
.services ul {
    list-style: none;
    padding: 0;
    margin: 0
}
.blog-entry {
    width: 100%;
    float: left;
    background: #fff
}
@media screen and (max-width:768px) {
    .blog-entry {
        margin-bottom: 30px
    }
}
.blog-entry .blog-img {
    width: 100%;
    float: left;
    overflow: hidden;
    position: relative;
    z-index: 1;
    margin-bottom: 25px
}
.blog-entry .blog-img img {
    position: relative;
    max-width: 100%;
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -ms-transform: scale(1.2);
    -o-transform: scale(1.2);
    transform: scale(1.2);
    -webkit-transition: 0.9s;
    -o-transition: 0.9s;
    transition: 0.9s
}
.blog-entry .desc {
    padding: 25px
}
.blog-entry .desc h3 {
    font-size: 15px;
    text-transform: uppercase;
    margin-bottom: 10px;
    letter-spacing: 1px;
    line-height: auto
}
.blog-entry .desc h3 a {
    color: #000;
    text-decoration: none
}
.blog-entry .desc span {
    display: block;
    margin-bottom: 20px;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(0, 0, 0, .4) !important
}
.blog-entry .desc span small i {
    color: #e6e6e6
}
.blog-entry .desc .lead {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: #000
}
.blog-entry:hover .blog-img img {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1)
}
li.blog-li > a {
    font-size: 18px;
    color: #fff
}
li.blog-li > a:hover {
    font-size: 18px;
    color: #bdbdbd
}
.work {
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    position: relative;
    height: 270px;
    width: 100%;
    display: table;
    overflow: hidden
}
@media screen and (max-width:768px) {
    .work {
        height: 25pc
    }
}
@media screen and (max-width:480px) {
    .work {
        height: 270px
    }
}
.work .desc {
    display: table-cell;
    vertical-align: middle;
    height: 270px;
    background: #fff;
    opacity: 0;
    -webkit-transition: 0.3s;
    -o-transition: 0.3s;
    transition: 0.3s
}
.work .desc h3 {
    font-size: 14px;
    -webkit-transform: translate3d(0, -15px, 0);
    transform: translate3d(0, -15px, 0)
}
.work .desc h3,
.work .desc span {
    -webkit-transition: -webkit-transform 0.3 s, opacity 0.3s;
    transition: transform 0.3 s, opacity 0.3s
}
.work .desc span {
    display: block;
    color: #999;
    font-size: 9pt;
    -webkit-transform: translate3d(0, 15px, 0);
    transform: translate3d(0, 15px, 0)
}
@media screen and (max-width:768px) {
    .work .desc {
        opacity: 1;
        background: transparent !important
    }
    .work .desc h3 {
        color: #fff
    }
    .work .desc h3,
    .work .desc span {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0)
    }
}
.work:hover .desc {
    opacity: 1
}
.work:hover .desc h3,
.work:hover .desc span {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0)
}
.lead {
    font-size: 18px;
    line-height: 1.5
}
.heading-colored {
    color: #228896;
    font-size: 30px
}
.cards {
    padding: 1em 0;
    background: #e6e6e6
}
@media screen and (max-width:768px) {
    .cards {
        padding: 1em 0
    }
}
.cards .flex-wrap {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap
}
.cards .flex-wrap > div {
    width: 49.5%;
    margin-right: 1%;
    background: #fff;
    padding: 30px;
    margin-bottom: 10px
}
.cards .flex-wrap > div:nth-of-type(1) {
    float: left
}
.cards .flex-wrap > div:nth-of-type(2) {
    float: right;
    margin-right: 0
}
@media screen and (max-width:992px) {
    .cards .flex-wrap > div {
        width: 100%;
        margin-right: 0
    }
}
.cards .flex-wrap .card p:last-child {
    margin-bottom: 0
}
.cards .flex-wrap .card h5 {
    text-transform: uppercase;
    font-size: 9pt;
    letter-spacing: 0.2em;
    padding: 4px 8px;
    background: #ebebeb;
    display: -moz-inline-stack;
    display: inline-block;
    zoom: 1;
    *display: inline
}
.counter .number {
    font-size: 75pt;
    color: #228896;
    font-weight: 400;
    margin: 0;
    padding: 0;
    line-height: .7
}
.counter .number.left {
    float: left;
    width: 30%
}
@media screen and (max-width:768px) {
    .counter .number.left {
        width: 100%;
        line-height: 1.2
    }
}
.counter .text {
    float: right;
    text-align: left;
    width: 70%
}
@media screen and (max-width:768px) {
    .counter .text {
        width: 100%;
        text-align: center
    }
}
.counter .text h3 {
    margin: 0;
    padding: 0;
    position: relative
}
.counter .text h3.border-bottom:after {
    content: "";
    width: 50px
}
.social {
    padding: 0;
    margin: 0;
    text-align: center
}
.social li {
    padding: 0;
    margin: 0;
    list-style: none
}
.social li,
.social li a {
    display: -moz-inline-stack;
    display: inline-block;
    zoom: 1;
    display: inline
}
.social li a {
    font-size: 22px;
    color: #000;
    padding: 10px;
    -webkit-border-radius: 7px;
    -moz-border-radius: 7px;
    -ms-border-radius: 7px;
    border-radius: 7px
}
@media screen and (max-width:768px) {
    .social li a {
        padding: 10px 8px
    }
}
.social li a:hover {
    color: #228896
}
.social li a:active,
.social li a:focus,
.social li a:hover {
    outline: 0;
    text-decoration: none;
    color: #228896
}
#map {
    width: 100%;
    height: 700px
}
@media screen and (max-width:768px) {
    #map {
        height: 200px
    }
}
.more-contact {
    background: #fafafa
}
.feature {
    text-align: left;
    width: 100%;
    float: left;
    margin-bottom: 40px;
    position: relative
}
.feature .icon {
    position: absolute;
    top: 0;
    left: 0;
    width: 75pt;
    height: 75pt;
    display: table;
    text-align: center;
    background: rgba(0, 0, 0, .05);
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    -ms-border-radius: 50%;
    border-radius: 50%
}
.feature .icon i {
    display: table-cell;
    vertical-align: middle;
    color: #228896;
    font-size: 40px;
    height: 75pt
}
@media screen and (max-width:1200px) {
    .feature .icon i {
        font-size: 40px
    }
}
.feature .text {
    padding-left: 90pt;
    width: 100%
}
.feature .text h2,
.feature .text h3 {
    margin: 0;
    padding: 0
}
.feature .text h3 {
    font-weight: 500;
    margin-bottom: 20px;
    color: rgba(0, 0, 0, .8);
    font-size: 14px;
    letter-spacing: 0.2em;
    text-transform: uppercase
}
.feature.feature-sm .text {
    margin-top: 30px
}
.feature.feature-sm .icon i {
    color: #228896;
    font-size: 40px
}
@media screen and (max-width:1200px) {
    .feature.feature-sm .icon i {
        font-size: 28px
    }
}
.heading {
    font-size: 18px;
    margin-bottom: 2em;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 2px
}
.heading.light {
    color: #fff
}
.heading span {
    display: block
}
@media screen and (max-width:768px) {
    .heading {
        margin-bottom: 1em
    }
}
.btn {
    margin-right: 4px;
    margin-bottom: 4px;
    font-family: Roboto, Arial, sans-serif;
    font-size: 18px;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 1px;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    -ms-border-radius: 0;
    border-radius: 0;
    -webkit-transition: 0.5s;
    -o-transition: 0.5s;
    transition: 0.5s;
    padding: 8px 20px !important
}
.form-control {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    box-shadow: none;
    background: transparent;
    border: 2px solid rgba(0, 0, 0, .5);
    height: 54px;
    font-size: 18px;
    font-weight: 300;
    -webkit-border-radius: 7px;
    -moz-border-radius: 7px;
    -ms-border-radius: 7px;
    border-radius: 7px;
    background: #fff
}
.form-control:active,
.form-control:focus {
    outline: 0;
    box-shadow: none;
    border-color: #228896
}
#message {
    height: 130px
}
.nav-toggle {
    cursor: pointer;
    text-decoration: none
}
.nav-toggle.active i:after,
.nav-toggle.active i:before,
.nav-toggle.dark.active i:after,
.nav-toggle.dark.active i:before {
    background: #000
}
.nav-toggle:active,
.nav-toggle:focus,
.nav-toggle:hover {
    outline: 0;
    border-bottom: 0 0 !important
}
.nav-toggle i {
    display: -moz-inline-stack;
    display: inline-block;
    zoom: 1;
    *display: inline;
    width: 30px;
    height: 2px;
    font: bold 14px/.4 Helvetica;
    text-transform: uppercase;
    text-indent: -55px
}
.nav-toggle i:after,
.nav-toggle i:before {
    content: '';
    width: 30px;
    height: 2px;
    background: #000;
    position: absolute;
    left: 0;
    -webkit-transition: 0.2s;
    -o-transition: 0.2s;
    transition: 0.2s
}
.nav-toggle i,
.nav-toggle.dark i {
    position: relative;
    color: #000;
    background: #000;
    transition: all 0.2s ease-out
}
.nav-toggle.dark i:after,
.nav-toggle.dark i:before {
    background: #000;
    -webkit-transition: 0.2s;
    -o-transition: 0.2s;
    transition: 0.2s
}
.nav-toggle i:before {
    top: -7px
}
.nav-toggle i:after {
    bottom: -7px
}
.nav-toggle:hover i:before {
    top: -10px
}
.nav-toggle:hover i:after {
    bottom: -10px
}
.nav-toggle.active i {
    background: transparent
}
.nav-toggle.active i:before {
    top: 0;
    -webkit-transform: rotateZ(45deg);
    -moz-transform: rotateZ(45deg);
    -ms-transform: rotateZ(45deg);
    -o-transform: rotateZ(45deg);
    transform: rotateZ(45deg)
}
.nav-toggle.active i:after {
    bottom: 0;
    -webkit-transform: rotateZ(-45deg);
    -moz-transform: rotateZ(-45deg);
    -ms-transform: rotateZ(-45deg);
    -o-transform: rotateZ(-45deg);
    transform: rotateZ(-45deg)
}
.nav-toggle {
    position: fixed;
    left: 0;
    top: 0;
    z-index: 7;
    cursor: pointer;
    opacity: 1;
    visibility: hidden;
    padding: 10px 20px;
    -webkit-transition: 0.5s;
    -o-transition: 0.5s;
    transition: 0.5s
}
@media screen and (max-width:768px) {
    .nav-toggle {
        opacity: 1;
        visibility: visible
    }
}
@media screen and (max-width:480px) {
    .col-xs-12 {
        float: none;
        width: 100%
    }
}
p.tel-p01 {
    font-size: 15px;
    margin: 0 auto
}
@media screen and (max-width:991px) {
    p.tel-p01 {
        font-size: 14px
    }
}
p.tel-p02 {
    font-size: 18px;
    margin-bottom: 14px;
    color: #ffa41a;
    font-weight: 700
}
@media screen and (max-width:991px) {
    p.tel-p02 {
        display: none
    }
}
@media screen and (max-width:991px) {
    .tel-nmb > a {
        font-size: 22px
    }
}
h3.knowledge-h {
    font-size: 25px;
    font-weight: 700;
    margin-bottom: 30px
}
img.knowledge-float {
    float: right;
    padding: 0 20px 15px
}
p.knowledge-link {
    text-align: right
}
img.knowledge-img {
    padding: 5px 20px 10px
}
h4.knowledge-sub-h {
    font-size: 20px;
    font-weight: 700;
    margin-top: 5px;
    margin-bottom: 30px
}
.footer-fix {
    width: 100%;
    text-align: right;
    position: fixed;
    bottom: 0;
    padding: 10px 0;
    z-index: 5;
    background: rgba(0, 0, 0, .7);
    padding: 5px 10px 5px 23%;
}
.flexbox {
    display: flex;
    align-items: center;
    justify-content: center;
}
.footer-fix .flexbox {
    padding: 0 80px;
}
.footer-fix .flexbox .item{
    padding: 5px 5px;
}
.footer-fix .flexbox .item img{
    max-width: 100%;
}
.footer-line-img_sp {
    display: none;
}
/*img.footer-mail-img.footer-fix-img {
    padding-right: 8px
}
img.footer-tel-img {
    margin-right: -30px;
    padding-right: 15px
}*/
img.footer-logo-img {
    padding-right: 10px
}
img.footer-fix-img {
    max-width: 100%
}
ul.blog-ul {
    list-style: none
}
span.bold {
    font-weight: 700
}
div#random3 {
    height: 569px;
    max-width: 100%;
    max-height: 100%;
}

/* インスタグラム */
#team + .parallax-bg {
    margin-bottom: 0px;
}
section#instagram {
    background: #e0e8e8;
}
.instagram_wrap {
    position: relative;
    padding: 20px 0 20px;
}
.gallery{
    display: flex;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
}
.gallery-item{
    flex: 1 1 20%;
    -ms-flex: 1 1 20%;
    max-width: 20%;
}
.gallery-item img{
    max-width: 100%;
    height: auto;
}
#instagram .chief-btn {
    margin-top: 30px;
}
/*  おすすめ屋根材 */
.contents_title {
    font-size: 18px;
    text-align: center;
    margin-top: 20px; 
    font-weight: 600;
}
.contents_list {
    padding: 0;
}
.contents_list li {
    display: inline-block;
    text-align: center;
    margin: 0 10px;
 }
.contents_list li .maru {
    width: 160px;
    height: 160px;
    border-radius: 50%;
}
.contents_list li p {
    background-color: #5a7b79;
    padding: 3px 15px;
    font-size: 12px;
    margin-top: 5px; 
    font-weight: 600;
    color: #fff;
    transition: all 0.25s ease-in-out;
}
.contents_list li:hover .maru, .contents_list li:hover p {
    opacity: 0.7;
}
.recommend .point-h {
    font-size: 24px;
    font-weight: bold;
    padding-bottom: 10px;
    border-bottom: 2px solid #3a8f9a;
    margin-top: 40px;
    margin-bottom: 15px;
}
.recommend h4 {
    font-size: 20px;
    font-weight: bold;
    color: #226a73;
    margin-bottom: 15px;
    margin-top: 30px;
}
section#ds, section#supergr {
    background: rgba(255, 255, 255, 0.7);
}
.recommend .list {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0;
}
.recommend .btns {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    margin: 0 auto 30px;
}
.recommend ul li {
    list-style-type: none;
    padding: 10px;
}
section.recommend img {
    max-width: 100%;    
}
.recommend .chief-btn {
    padding: 1.0em 30px;
}
.recommend  .post-more {
    text-align: left;
    margin: 30px 0;
}

.more-link-sub:after {
  content: "\00BB";
  color: #5a7b79;
  padding-left: 5px;
}
a.more-link-sub {
    color: #5a7b79;
    font-size: 14px;
    border: 1px solid #ccc;
    padding: 5px 15px;
    font-weight: 600;
}
a.more-link-sub:hover {
    color: #fff;
    background-color: #5a7b79;
}
.more-link-sub:hover:after {
    color: #fff;
}
@media screen and (max-width: 991px){
    .recommend h4{
        margin-top: 25px;
        font-size: 19px;
    }
}
@media screen and (max-width:991px) {
    img.footer-logo-img {
        display: none
    }
    .gallery-item{
        flex: 1 1 33.33%;
        -ms-flex: 1 1 33.33%;
        max-width: 33.33%;
    }
}

@media screen and (min-width: 768px) and (max-width: 991px){
    .module, .module-small {
        position: relative;
        padding: 20px 15px;
    }
    p.intro-p,p.intro-p-w{
        text-align: left;
    }
    p.cntact-p.center {
        font-size: 11px;
        margin-top: 20px;
    }
    form#mail_form dl dt {
        font-size: 11px;
    }
    .works-wrap {
        margin-top: 6%;
    }
    .post-title, .post-title-sub {
        font-size: 12px;
    }
    .parallax-bg {
        margin-top: 120px;
    }
    .testimonials-slider {
        position: relative;
        padding: 0px 0 0px;
    }
    .reslut-lt-area {
        text-align: center;
        padding-bottom: 45px;
    }
    .chief-area {
        text-align: center;
        margin-top: 10%;
        margin-bottom: 17%;
    }
    table.price-table,table.price-table td{
        font-size: 11px;
    }
    p {
        font-size: 14px;
        text-align: left;
    }
    #aside .footer {
        position: absolute;
        bottom: 110px;
    }
    .module-subtitle {
        color: #fff;
        line-height: 1.8em;
        font-size: 14px;
        text-align: left;
        text-shadow: 1px 1px 3px #0c0c0c;
    }
    .footer-fix .flexbox {
        padding: 0 0px;
    }
}

a > img.blog-bnr:hover {
    opacity: 0.8;
}
@media screen and (min-width:768px) {
    .hero.sp {
        display: none;
    }
}
@media screen and (max-width: 1200px) {
    .footer-fix {
        padding: 5px 10px 5px 31%;
    }
}
@media screen and (max-width: 991px) {
    img.footer-logo-img{
        display: none;
    }
}
@media screen and (max-width:767px) {
    .footer-fix {
        width: 100%;
        text-align: right;
        position: fixed;
        top: 0;
        height: 55px;
        z-index: 5;
        background: hsla(0, 0%, 100%, 0.7);
        padding: 10px 5px 10px 60px;
    }
    .footer-fix .flexbox {
        padding: 0 0px;
    }
     .footer-fix .flexbox .item {
        padding: 0 3px;
        margin-top: 0px;
    }
    .footer-fix .flexbox .item img {
        max-height: 50px;
    }
    .footer-line-img_pc {
        display: none;
    }
    .footer-line-img_sp {
        display: block;
    }
    img.main-logo {
        width: 150px;
        max-width: 100%;
        height: auto;
    }
    p {
        font-size: 14px;
        text-align: left;
        padding: 5px;
    }
    .sp-center {
        text-align: center;
        margin: 0 auto 15px;
    }
    h3.taihu {
        font-size: 18px;
    }
    table.price-table td,
    table.price-table th {
        font-size: 13px;
    }
    td.price {
        text-align: right;
    }
    .contact {
        margin-bottom: 6%;
    }
    .parallax-bg {
        margin-top: 150px;
        margin-bottom: 30px;
    }
    .blog-btn {
        margin-top: 13%;
    }
    .testimonials-slider {
        position: relative;
        padding: 10px 0 80px;
    }
    form#mail_form textarea {
        display: block;
        width: 100%!important;
        max-width: 100%!important;
    }
    .col-xs-12{
        position: relative;
        /* min-height: 1px; */
        padding-left: 10px!important;
        padding-right: 10px!important;
    }
    .module-subtitle {
        color: #fff;
        line-height: 1.8em;
        font-size: 13px;
        text-align: left;
        text-shadow: 1px 1px 3px #0c0c0c;
    }
    ol.bread {
        font-size: 12px;
        margin: 0 0 0px 0px;
    }
    h2.material-h {
        font-size: 18px;
        text-align: center;
        font-weight: bold;
    }
    .hero.pc {
        display: none;
    }
}
