body {
    font: 17px/1.8 Shuei MaruGo L,'YuGothic', '游ゴシック', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic ProN', sans-serif;
    font-weight: 500;
    /* font-feature-settings: "palt"; */
    letter-spacing: .08em;
    line-height: 1.8;
    *font-size: small;
    *font: x-small;
    color: #000;
    -webkit-font-smoothing: antialiased;
    margin: 0;
    background-color: #fff;
}

*,
*:before,
*:after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
}

html {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 62.5%;/*rem算出をしやすくするために*/
}

.btn-orignal {
    position: relative;
    border-radius: 100px;
    font-weight: bold;
    color: #fff;
    border: 2px solid #fff;
    text-decoration: none;
    transition: .3s;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    background-image: linear-gradient(150deg, rgba(231, 70, 40, 1), rgba(242, 130, 0, 1));
}

.btn-orignal::after {
    position: absolute;
    top: -1px; bottom: -1px;
    left: -1px; right: -1px;
    background: linear-gradient(150deg,rgba(231, 70, 40, 1),rgba(242, 130, 0, 1)) 1;
    content: '';
    z-index: -1;
    border-radius: 22px;
}

.btn-orignal:hover {
    border: 2px solid #F28200;
    background-image: linear-gradient(150deg, rgba(255, 255, 255, 1), rgba(255, 255, 255, 1));
    color: #F28200;
 }

.navbar {
    padding: 0;
    font-size: 14px;
}

.container-fluid {
    background-color: #fff;
    padding: 10px 40px;
}

.navbar-light .navbar-nav .nav-link{
    font-weight: bold;
    color: #000;
    padding: 0 10px;
    transition: .3s;
}
  
.navbar-light .navbar-nav .nav-link:hover{
    opacity: 0.6;
}

.navbar-toggler-icon {
    width: 2.5em;
    height: 2.5em;
}

.navbar-light .navbar-nav .nav-link-btn{
    margin: -10px 15px 0 5px;
    padding: 12px 22px 14px;
    font-size: 14px;
}

.navbar-light .navbar-nav .nav-link-login {
    color: #F28200;
    text-decoration: none;
    transition: .2s;
}

.navbar-light .navbar-nav .nav-link-login:hover {
    opacity: 0.6;
}

.me-auto-left {
    margin-left: auto!important;
    margin-right: 17px;
}

@media screen and (max-width: 991px) {
    .navbar {
        padding: 0;
        font-size: 14px;
    }

    .navbar-nav {
        font-size: 16px;
    }

    .navbar-brand {
        margin-right: 0;
    }

    .navbar-light .navbar-nav .nav-link {
        padding: 0 5px;
    }

    .navbar-light .navbar-nav .nav-link-btn{
        font-size: 14px;
        margin: 4px -10px 4px 0;
    }

    .nav-pc {
        display: none;
    }

    .pc {
        display: none;
    }

    .main-text h1.mobile {
        font-size: 5.2vw;
    }
}

@media screen and (min-width: 992px) {
    .nav-mobile {
        display: none;
    }

    .mobile {
        display: none;
    }
}

@media screen and (max-width: 1201px) {
    .navbar {
        padding: 0;
        font-size: 12px;
    }

    .navbar-brand {
        margin-right: 0;
    }

    .navbar-light .navbar-nav .nav-link {
        padding: 0 5px;
    }

    .navbar-light .navbar-nav .nav-link-btn{
        font-size: 12px;
    }
}

#main-img img {
    display: block;
    margin: 0 auto 10px;
    max-width: 1300px;
    width: 100%;
    padding-top: 60px;
}

@media screen and (max-width: 991px) {
    #main-img img {
        padding-top: 120px;
    }
}

.main-text {
    display: block;
    margin: 0 auto 0;
    max-width: 1400px;
    width: 100%;
}

.main-text h1 {
    font-size: 42px;
    text-align: center;
}

.main-text h3 {
    font-size: 24px;
    text-align: center;
    padding-top: 25px;
    width: 95%;
    margin: auto;
    line-height: 1.5;
}

.main-text h3 span {
    font-size: 16px;
}

.main-text p {
    padding-top: 20px;
    width: 75%;
    margin: auto;
    font-size: 1.2vw;
}

.main-text-mobile h1 {
    font-size: 42px;
    text-align: center;
    color: #EC6A20;
    padding-top: 40px;
}
.main-text-mobile p {
    text-align: center;
    padding: 40px 20px 20px;
}

#content-feature {
    margin: -100px 0 0;
    padding: 100px 0 100px;
    background-color: #FDF5E4;
}

#content-feature img {
    display: block;
    margin: 0 auto 20px;
    max-width: 300px;
    width: 100%;
}

#content-feature h1 {
    font-size: 38px;
    text-align: center;
    padding-bottom: 45px;
}

.main-feature {
    width: 100%;
    max-width: 1300px;
    margin: auto;
}

.float-feature {
    float: left;
    width: 33%;
}

.float-feature-center {
    float: left;
    width: 33%;
}

.tbl-feature {
    width: 100%;
    max-width: 460px;
}

.tbl-feature tr td {
    text-align: center;
}

#content-feature .tbl-feature img {
    max-width: 380px;
    width: 100%;
    padding: 0 5px;
}

#content-feature .tbl-feature .num-radu img {
    margin-bottom: 40px;
    width: 110px;
    text-align: center;
}

.tbl-feature h3 {
    font-size: 26px;
    text-align: center;
    padding-top: 5px;
    margin: auto;
    line-height: 1.5;
}

.tbl-feature .tr-text {
    padding: 25px 28px;
    text-align: left;
}

@media screen and (max-width: 859px) {
    .float-feature,
    .float-feature-center {
        clear: both;
        width: 100%;
        padding-bottom: 30px;
    }
    
    .tbl-feature {
        width: 100%;
        max-width: 800px;
    }
}

.div-feature {
    width: 100%;
    max-width: 1250px;
    margin: 50px auto 0;
    padding: 40px;
    background-color: #fff;
    border-radius: 15px;
    box-shadow: 10px 15px 25px 0 rgb(0 0 0 / 20%);
}

#content-feature .div-feature img {
    margin-right: 38px;
    padding: 20px 10px;
}

.div-feature h3 {
    font-size: 26px;
    margin-bottom: 20px;
    line-height: 1.5;
}

.flot-left {
    float: left;
}

@media screen and (max-width: 859px) {
    .flot-left {
        float: none;
    }

    #content-feature .div-feature img {
        margin: 0 auto;
        padding: 20px 10px;
    }

    #content-feature .div-feature h3 {
        text-align: center;
        padding: 10px 0;
    }
}

.content-contact {
    background:linear-gradient(#F28200, #E74628);
    padding: 60px 0 160px;
    position: relative;
    z-index: 0;
    margin: 0;
}

.content-contact h1 {
    font-size: 42px;
    text-align: center;
    color: #fff;
    letter-spacing: -0.20em;
}

.content-contact p {
    text-align: center;
    color: #fff;
    letter-spacing: 0.05em;
}

.content-contact .div-contact {
    width: 100%;
    max-width: 1140px;
    margin: 50px auto;
    padding: 0 20px;
    position:absolute; 
    top: 78%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

.content-contact .div-contact .div-contact-bak {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    padding: 45px 10px;
    background-color: #fff;
    border-radius: 15px;
    box-shadow: 10px 15px 25px 0 rgb(0 0 0 / 20%);
}

.tbl-contact .btn-contact,
#content-contact-input .btn-contact,
#content-download .btn-download {
    font-size: 18px;
    max-width: 400px;
    width: 100%;
    height: 58px;
    padding-bottom: 7px;
    margin: auto;
}

.content-contact .tbl-contact p {
    font-size: 38px;
    color: #EC6A20;
    margin: 0;
}

.content-contact .tbl-contact span {
    font-size: 18px;
}

.tbl-contact {
    width: 100%;
    max-width: 1050px;
    margin: auto;
}

.tbl-contact tr {
    display: block;
    float: left;
    width: 50%;
}

.tbl-contact tr td {
    font-size: 20px;
    text-align: center;
    display: block;
    padding: 0 10px;
}

.tbl-contact .thead-contact {
    display: block;
    float: left;
    width: 50%;
}

.tbl-contact .td-contact-01,
.tbl-contact .td-contact-02 {
    padding: 10px 0 30px;
}

@media screen and (max-width: 724px) {
    .content-contact .div-contact .div-contact-bak {
        padding: 5px 10px;
    }

    .tbl-contact {
      width: 100%;
    } 
    .tbl-contact .thead-contact {
        width: 100%;
    }
    .tbl-contact tr,
    .tbl-contact td{
      display: block;
      width: 100%;
      position: relative;
    }

    .tbl-contact tr td {
        width: 100%;
    }

    .tbl-contact .td-contact-01 {
        padding: 20px 0 10px;
    }

    .tbl-contact .td-contact-02 {
        padding: 20px 0 0;
    }
}


#content-solution,
#content-plice{
    margin: 60px auto 140px;
    padding-top: 130px;
}

#content-faq {
    margin: -20px auto 140px;
    padding-top: 140px;
}

.content-title {
    text-align: center;
    margin: auto;
}

.content-title p {
    font-size: 26px;
    color: #EC6A20;
    margin: 0;
}

.content-title h1 {
    font-size: 40px;
    padding-bottom: 60px;
}

.div-solution {
    width: 100%;
    max-width: 1250px;
    margin: 40px auto 0;
}

.num-solution {
    font-family: "DIN 2014 Narrow";
    font-size: 116px;
    opacity: 0.4;
    color: #F8B62D;
    position: absolute;
    left: -60px;
    top: -50px;
}

.text-solution {
    position: relative;
    padding: 0 30px 0 60px;
    
}

.text-solution h3 {
    font-size: 32px;
    padding-bottom: 40px;
    line-height: 1.5;
}

.text-solution h3 span {
    font-size: 18px;
    padding-left: 10px;
}

.text-solution p {
    line-height: 2.1;
}

.div-solution img {
    max-width: 700px;
    width: 100%;
}

.tbl-solution-01,
.tbl-solution-03 {
    margin-left: 90px;
}

.tbl-solution-02,
.tbl-solution-04 {
    margin-left: 40px;
}

.tbl-solution-01,
.tbl-solution-02,
.tbl-solution-03,
.tbl-solution-04 {
    margin-bottom: 60px;
}

.width55 {
    width: 55%;
}

.width50 {
    width: 50%;
}

.width45 {
    width: 45%;
}

.div-solution .btn-solution {
    font-size: 18px;
    max-width: 400px;
    width: 100%;
    height: 58px;
    padding-bottom: 7px;
    margin: auto;
}


@media screen and (max-width: 1110px) {
    .solution-pc {
        display: none;
    }

    .solution-mobile {
        display: visible;
        text-align: center;
        padding: 0 20px;
    }

    .div-solution-mobile {
        width: 100%;
        max-width: 600px;
        margin: 0 auto 60px;
    }

    .num-solution-mobile {
        font-family: "DIN 2014 Narrow";
        font-size: 116px;
        opacity: 0.4;
        color: #F8B62D;
    }
}

@media screen and (min-width: 1110px) {
    .solution-mobile {
        display: none;
    }
}

#content-video {
    width: 100%;
    max-width: 1250px;
    margin: 0 auto 60px;
    padding: 0 20px;
}

.line-gray {
    border: 1px solid #B4B4B4;
    opacity: 0.7;
    margin-bottom: 100px;
}

.div-vido {
    width: 100%;
    max-width: 1080px;
    margin: 60px auto 60px;
    padding: 0 20px;
}

.div-video-text {
    max-width: 600px;
    width: 100%;
    margin: 80px auto 100px;
    padding: 0 0 10px 10px;
    border-bottom: 8px solid #EC6A20;
}

.div-video-text h1 {
    font-size: 40px;
}

.div-video-text span {
    font-size: 46px;
}

#content-plice .div-plice-pc,
#content-plice .div-plice-mobile {
    width: 100%;
    max-width: 1100px;
    margin: 10px auto 0;
    padding: 40px;
    background-color: #FDF5E4;
    border-radius: 15px;
}

#content-plice .tbl-plice-01,
#content-plice .tbl-plice-02  {
    width: 100%;
    max-width: 850px;
    margin: 40px auto 20px;
}

#content-plice .tbl-plice-01 tr td {
    text-align: center;
}

#content-plice .tbl-plice-01 tr td h3,
#content-plice .div-plice-mobile h3 {
    font-size: 36px;
}

#content-plice .tbl-plice-01 tr td .plice-plus {
    font-size: 56px;
}

.width18 {
    width: 18%;
}

.width10 {
    width: 10%;
}

.width35 {
    width: 35%;
}

/* #content-plice .tbl-plice-01 .plice-radu {
    font-size: 28px;
    width: 100%;
    max-width: 120px;
    line-height: 1.3;
    padding: 24px 0;
    color: #fff;
    background: linear-gradient(150deg, rgba(231, 70, 40, 1), rgba(242, 130, 0, 1));
    border-radius: 100px;
} */

#content-plice .tbl-plice-01 .plice-radu img {
    width: 100%;
    max-width: 130px;
}

#content-plice .tbl-plice-02 tr td h3 {
    font-size: 28px;
}

#content-plice .tbl-plice-02 tr td img {
    width: 100%;
    max-width: 650px;
}

.div-plice p {
    text-align: center;
}


@media screen and (max-width: 851px) {
    .div-plice-pc {
        display: none;
    }

    .div-plice-mobile img {
        width: 100%;
    }
}

@media screen and (min-width: 851px) {
    .div-plice-mobile {
        display: none;
    }
}


#content-flow {
    /* margin-top: -30px; */
    /* padding: 110px 0 20px; */
    padding: 200px 0 20px;
    background-color: #F4F4F4;
}

#content-flow .tbl-flow {
    width: 100%;
    max-width: 1150px;
    margin: 20px auto 60px;
}

#content-flow .tbl-flow tr td {
    text-align: center;
}

#content-flow .tbl-flow .td-righttri {
    width: 60px;
    font-size: 42px;
    color: #707070
}

#content-flow .tbl-flow tr td img {
    width: 100%;
    max-width: 260px;
}

#content-flow .tbl-flow .td-flow {
    padding: 20px 10px;
    text-align: left;
    line-height: 2.1;
}

.div-flow-mobile img {
    max-width: 300px;
    width: 100%;
}

@media screen and (max-width: 851px) {
    .div-flow-pc {
        display: none;
    }

    .div-flow-mobile table {
        max-width: 560px;
        width: 100%;
        margin: 0 auto;
        text-align: center;
    }

    .div-flow-mobile .td-righttri{
        font-size: 42px;
        color: #707070;
        padding-bottom: 40px;
        
    }

    .div-flow-mobile .td-flow {
        text-align: left;
        padding: 50px 30px;
    }
}

@media screen and (min-width: 851px) {
    .div-flow-mobile {
        display: none;
    }
}


#content-faq .tbl-faq {
    width: 100%;
    max-width: 1100px;
    margin: 20px auto 60px;
}

#content-faq .tbl-faq .td-q,
#content-faq .tbl-faq .td-a 
{
    width: 60px;
    font-size: 38px;
    font-family: "Arial";
    font-weight: bold;
    vertical-align: top;

}

#content-faq .tbl-faq .td-q {
    color: #707070;
}

#content-faq .tbl-faq .td-a {
    color: #EC6A20;
}

#content-faq .tbl-faq h4 {
    font-size: 24px;
}

#content-faq .div-faq {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    padding: 60px 50px;
    background-color: #F4F4F4;
    border-radius: 20px;
}

.faq-title {
    text-align: center;
    margin: auto;
}

.faq-title h1 {
    font-size: 40px;
    padding-bottom: 20px;
}

#content-contact-input {
    margin-top: -40px;
    padding: 100px 0 60px;
    background-color: #FDF5E4;
}

#content-contact-input p {
    text-align: center;
}

#content-contact-input .tbl-contact-input {
    width: 100%;
    max-width: 880px;
    margin: 30px auto;
}

#content-contact-input .tbl-contact-input tr td {
    padding: 10px 15px;
}

#content-contact-input .tbl-contact-input .td-rigth {
    width: 220px;
    text-align: right;
    vertical-align: top;
}

#content-contact-input .tbl-contact-input .error {
    color: red;
}

#content-foot {
    width: 100%;
    padding: 60px 80px 50px;
    letter-spacing: -1em;
}

#content-foot .footer-logo,
#content-foot .footer-link {
    display: inline-block;
    width: 50%;
    box-sizing: border-box;
    letter-spacing: 0;
}

#content-foot p {
    font-family: "YuGothic";
    font-size: 16px;
    margin: 0;
}

#content-foot .footer-link {
    text-align: right;
}

#content-foot .footer-link li{
    display: inline-block;
    list-style: none;
    padding: 0 5px;
    font-size: 16px;
}

#content-foot .footer-link li a{
    text-decoration: none;
    color: #000;
    transition: .3s;
}

#content-foot .footer-link li a:hover{
    opacity: 0.6;
}

#copylite {
    font-size: 12px;
    color: #4a4949;
    padding: 0 40px 65px;
    text-align: right;
}

@media screen and (max-width: 905px) {
    #content-foot {
        width: 100%;
        padding: 60px 20px 40px;
    }

    #content-foot .footer-link {
        display: none;
    }
    #content-foot .footer-logo {
        width: 100%;
    }
}
@media screen and (min-width: 906px) {
    #content-foot .footer-link {
        display: visible;
    }
}


/* プライバシーポリシーページ */
#content-policy {
    width: 100%;
    max-width: 1000px;
    margin: 20px auto;
    padding: 110px 20px;
}

/* お客様のお声 */
#content-review {
    width: 100%;
    max-width: 1000px;
    margin: 20px auto;
    padding: 110px 20px;
}

#content-review .content-title h1 {
    font-size: 34px;
    color: #EC6A20;
    margin: 0;
    padding-bottom: 20px;
}

#content-review .content-title p {
    font-size: 22px;
    color: black;
    text-align: left;
    margin-bottom: 70px;
}

#content-review .tbl-review {
    margin: 20px 0 60px;
}

#content-review .tbl-review .tbl-review-info {
    width: 260px; 
    text-align: center;
    vertical-align: top;
    padding-top: 30px;
}

#content-review .tbl-review .tbl-review-info img{
    margin-bottom: 10px;
    text-align: center;
}

#content-review .tbl-review .tbl-review-info p{
    margin: 0;
    line-height: 1.5;
}

#content-review .tbl-review .tbl-review-comment div {
    margin: 0 0 0 20px;
    background-color: #f3f3f3;
    padding: 0 30px 30px;
    border-radius: 15px;
    position: relative;
}

#content-review .tbl-review .tbl-review-comment div:before {
    content: "";
    position: absolute;
    top: 14%;
    left: -33px;
    margin-top: -15px;
    border: 15px solid transparent;
    border-right: 20px solid #f3f3f3;
  }

#content-review .tbl-review .tbl-review-comment div h2 {
    color: #EC6A20;
    padding: 20px 0 10px;
}

#content-review .tbl-review .tbl-review-comment div p {
    font-size: 17px;
    line-height: 1.6;
}

@media screen and (max-width: 860px) {
    #content-review .tbl-review {
        width: 100%;
    }

    #content-review .tbl-review td {
        display: block;
        width: 100%;
    }

    #content-review .tbl-review .tbl-review-info {
        width: 100%; 
        padding-top: 0;
    }

    #content-review .tbl-review .tbl-review-comment div {
        margin: 20px 0 0 0;
    }

    #content-review .tbl-review .tbl-review-comment div:before {
        content: "";
        position: absolute;
        top: -12px;
        left: 27%;
        border: 12px solid transparent;
        border-bottom: 15px solid #f3f3f3;
      }
}


/* 製品のご紹介 */
#content-product {
    width: 100%;
    max-width: 1200px;
    margin: 20px auto;
    padding: 110px 10px 60px;
}

#content-product .tbl-product {
    width: 100%;
    max-width: 1150px;
    margin: 0 auto 40px;
    border-collapse: separate;
    border-spacing: 25px;
}

#content-product .tbl-product tr td {
    width: 50%;
    text-align: center;
    background-color: #FDF5E4;
    border-radius: 20px;
    padding: 0 20px 40px;
    box-shadow: 10px 15px 25px 0 rgb(0 0 0 / 20%);
}

@media screen and (max-width: 860px) {
    #content-product .div-product {
        padding: 0 20px;
    }

    #content-product .tbl-product {
        width: 100%;
        border-collapse:collapse;
        padding: 0 20px;
    }

    #content-product .tbl-product tr td {
        display: block;
        width: 100%;
        margin: 30px 0 0;
    }
}


#content-product .tbl-product img {
    width: 100%;
    max-width: 320px;
}

#content-product .tbl-product h3 {
    font-size: 38px;
}

#content-product .tbl-product .p-orange {
    font-size: 20px;
    color: #EC6A20;
    padding: 10px;
}

#content-product .tbl-product ul li {
    font-size: 15px;
    text-align: left;
}

#content-product h4 {
    text-align: center;
    line-height: 1.5;
}

#content-product .product-pc {
    font-size: 2.4vw;
}

#content-product .tbl-product-video {
    margin: 60px 20px 0;
    font-size: 20px;
}

@media screen and (max-width: 520px) {
    #content-product .tbl-product ul li {
        font-size: 2.6vw;
    }
}

@media screen and (max-width: 720px) {
    #content-product .tbl-product ul li {
        font-size: 2.6vw;
    }

    #content-product .tbl-product-video {
        margin: 60px 10px 0;
        font-size: 2.4vw;
        word-wrap: break-word;
        overflow:hidden;
    }
}

@media screen and (min-width: 1227px) {
    #content-product .product-pc {
        font-size: 30px;
    }
}

#content-download {
    background-color: #F4F4F4;
    padding: 60px 20px;
}

#content-download .div-download {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    background-color: #fff;
    padding: 50px;
    border-radius: 20px;
    background-image: url('../img/product5.png');
    background-position: right -35px top -15px;
	background-repeat: no-repeat;
    background-size: 305px;
}

#content-download .div-download p {
    font-size: 20px;
    text-align: center;
    padding-bottom: 40px;
}

.shokhiyo {
    position: absolute;
    left: -150px;
}

@media screen and (max-width: 854px) {
    .shokhiyo {
        position: relative;
        left: 0;
    }

    #content-download .div-download p {
        padding-bottom: 0;
    }
}

/* 運営会社 */
#content-company {
    width: 100%;
    max-width: 1200px;
    margin: 20px auto;
    padding: 110px 20px 60px;
}

#content-company .line-orange {
    width: 3px;
    background-color: #EC6A20;;
    height: 40px;
    margin: 20px auto 0;
}

#content-company .title-company{
    font-size: 28px;
    text-align: center;
    padding: 20px 20px 50px;
    clear: left;
}

#content-company .div-company,
#content-company .div-greeting {
    text-align: center;
    padding-bottom: 80px;
}

#content-company .img-company {
    float: left;
    padding: 0 60px;
}

#content-company .text-company {
    float: left;
    text-align: left;
}

#content-company .img-greeting {
    float: right;
    padding: 0 60px;
    width: 40%;
}

#content-company .text-greeting {
    float: right;
    text-align: left;
}

#content-company .img-company img {
    width: 100%;
    max-width: 180px;
}

#content-company .text-company p {
    line-height: 2.1;
}

#content-company .div-greeting .img-greeting img {
    width: 100%;
    max-height: 420px;
    border-radius: 20px;
}

#content-company .div-greeting .text-greeting {
    width: 60%;
    max-width: 600px;
    font-size: 16px;
}

#content-company .div-greeting .text-greeting .name-greeting {
    width: 100%;
    max-width: 600px;
    font-size: 20px;
    text-align: right;
    padding-top: 30px;
}

#content-company .div-greeting .text-greeting .name-greeting span {
    font-size: 16px;
    padding-right: 20px;
}

#content-company .div-greeting .text-greeting .name-greeting .spn-orange {
    font-size: 16px;
    padding-left: 20px;
    font-family: "DIN 2014 Narrow";
    color: #EC6A20;
    vertical-align: text-top;
}

@media screen and (max-width: 828px) {
    #content-company .img-company {
        clear: both;
        width: 100%;
    }

    #content-company .text-company {
        clear: both;
        padding-top: 40px;
    }
}

@media screen and (max-width: 776px) {
    #content-company .img-greeting {
        float: none;
        width: 60%;
        margin: 0 auto;
        padding: 0;
    }

    #content-company .div-greeting .img-greeting img {
        max-width: 190px;
    }
    
    #content-company .text-greeting {
        clear: both;
        padding-top: 40px;
    }

    #content-company .div-greeting .img-greeting img {
        width: 100%;
        max-height: 420px;
    }

    #content-company .div-greeting .text-greeting {
        width: 100%;
    }
}

#content-philosophy {
    clear: right;
    font-size: 20px;
    padding: 80px 20px;
    line-height: 2.3;
    text-align: center;
    background-image: url(../img/philosophy.jpg);
    background-size: cover; 
    background-position: right center;
    background-repeat: no-repeat;
    background-color: rgba(255,255,255,0.5);
    background-blend-mode: lighten;
}

#content-philosophy h3,
#content-overview h3 {
    font-size: 32px;
    padding-bottom: 40px;
}

#content-overview {
    width: 100%;
    max-width: 1000px;
    margin: 80px auto;
    padding: 20px 10px;
    text-align: center;
}

#content-overview img {
    padding: 40px 0 60px;
}

#content-overview .tbl-overview {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
    text-align: left;
}

#content-overview .tbl-overview tr td {
    padding: 15px 10px;
    border-bottom: 1px solid #B4B4B4;
}

.width120 {
    width: 180px;
    vertical-align: top;
}

#map {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto 90px;
    padding: 0 20px;
}

#map .map-overview {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
}

#map .map-overview iframe {
    width: 100%;
    min-height: 400px;
    border-radius: 20px;
}

@media screen and (max-width: 1452px) {
    .main-text h1 {
        font-size: 3.2vw;
    }

    .main-text h3 {
        font-size: 1.6vw;
    }

    .main-text h3 span {
        font-size: 2.1vw;
    }
}

@media screen and (max-width: 693px) {
    #content-overview .tbl-overview  tr td {
        display: block;
        width: 100%;
        font-size: 16px;
    }

    #content-overview .tbl-overview  tr td.width120 {
        border: none;
        padding-bottom: 0;
    }

    #content-contact-input .text-contact-input {
        padding: 0 20px;
        text-align: left;
    }

    #content-plice .div-plice-mobile .h3-plice {
        font-size: 24px;
    }

    #content-video .content-video-mobile {
        font-size: 36px;
    }
}

@media screen and (max-width: 932px) {
    #content-video .content-video-pc {
        display: none;
    }
}

@media screen and (min-width: 932px) {
    #content-video .content-video-mobile {
        display: none;
    }
}

@media screen and (min-width: 1043px) {
    #content-feature .div-feature .feature-mobile {
        display: none;
    }
}

@media screen and (max-width: 1043px) {
    .main-text p {
        width: 85%;
    }

    #content-feature .div-feature .feature-pc {
        display: none;
    }

    #content-download .div-download {
        background-position: right -22px top -15px;
        background-size: 270px;
    }
}

@media screen and (max-width: 932px) {
    #content-download .div-download {
        background-position: right -16px top -15px;
        background-size: 240px;
    }
}

@media screen and (max-width: 884px) {
    .div-video-text h1 {
        font-size: 3.8vw;
    }
    
    .div-video-text span {
        font-size: 4.8vw;
    }
    
    .div-flow-mobile img {
        max-width: 250px;
    }

    #content-contact-input .tbl-contact-input .td-rigth {
        font-size: 1.8vw;
        padding: 10px 0;
        max-width: 170px;
    }

    #content-download .div-download {
        background-position: right -16px top -15px;
        background-size: 220px;
    }
}

@media screen and (max-width: 737px) {
    /* 製品紹介 */
    #content-download .div-download {
        padding: 50px 0;
    }

    #content-download .div-download .speck-pc {
        display: none;
    }

    /* 運営会社 */
    #map {
        padding: 0;
        margin: 0;
    }

    #map .map-overview {
        height: 340px;
    }

    #map .map-overview iframe {
        border-radius: 0;
        min-height: 340px;

    }

}

@media screen and (min-width: 737px) {
    /* 製品紹介 */
    #content-download .div-download .speck-mobile {
        display: none;
    }
}

@media screen and (max-width: 654px) {
    #content-feature h1 {
        font-size: 5.6vw;
        padding-bottom: 10px;
    }
    
    .div-video-text h1 {
        font-size: 4.4vw;
    }
    
    .div-video-text span {
        font-size: 6.6vw;
    }
    
    .div-flow-mobile img {
        max-width: 250px;
    }
}

@media screen and (max-width: 634px) {    
    .main-text-mobile h1 {
        font-size: 6.7vw;
    }

    .text-solution h3 {
        font-size: 5.3vw;
    }

    .div-vido {
        padding: 0;
    }

    #content-faq .div-faq {
        padding: 60px 25px;
    }

    .faq-title h1 {
        font-size: 6.6vw;
        padding-bottom: 20px;
    }

    .tbl-contact-input {
        width: 100%;
    }
    .tbl-contact-input td {
        display: block;
        width: 100%;
    }

    #content-contact-input .tbl-contact-input .td-rigth {
        max-width: 100%;
        text-align: left;
        font-size: 14px;
        padding: 10px 20px;
    }
}

@media screen and (max-width: 504px) {
    .main-text-mobile p {
        padding: 40px 7px 20px;
    }

    #content-feature .div-feature h3 {
        font-size: 5.8vw;
    }

    .content-contact .div-contact .div-contact-bak {
        padding: 5px 10px 15px;
    }

    .content-title p {
        font-size: 4.3vw;
    }

    .content-title h1 {
        font-size: 7.3vw;
    }

    .num-solution-mobile {
        font-size: 100px;
        height: 155px;
    }

    .text-solution {
        padding: 0 5px;
    }

    #content-plice .div-plice-mobile .h3-plice {
        font-size: 4.6vw;
    }

    .div-flow-mobile img {
        max-width: 200px;
    }

    .div-flow-mobile .td-flow {
        padding: 50px 15px;
    }

    #content-faq .div-faq {
        padding: 60px 15px;
    }

    #content-video .content-video-mobile {
        font-size: 7.4vw;
    }


    /* 製品紹介 */
    #content-product .div-product {
        padding: 0;
    }

    #content-product .tbl-product h3 {
        font-size: 9.8vw;
    }

    #content-product .tbl-product .p-orange {
        font-size: 5.3vw;
        padding: 10px 0;
    }

    #content-download .div-download p {
        font-size: 4.2vw;
    }

    #content-download .div-download .shokhiyo-nedan {
        font-size: 3.4vw;
    }
}

@media screen and (max-width: 450px) {
    body {
        font-size: 14px;
    }

    .container-fluid {
        padding: 10px 10px;
    }

    .navbar-light .navbar-nav .nav-link-btn {
        margin: 8px -10px 4px 0;
    }
    .navbar-light .navbar-nav .nav-link-btn {
        padding: 10px 16px 12px;
    }

    .div-feature {
        margin: 0 auto;
        padding: 30px 15px;
    }
    
    #content-plice .div-plice-pc, #content-plice .div-plice-mobile {
        padding: 40px 20px;
    }

    #content-faq .tbl-faq h4 {
        font-size: 20px;
    }

    #content-faq .tbl-faq .td-q, #content-faq .tbl-faq .td-a {
        width: 40px;
        font-size: 32px;
    }

    #content-foot .footer-logo p {
        font-size: 3.8vw;
    }

    #content-foot {
        padding: 60px 10px 20px;
    }

    #copylite {
        padding: 0 15px 40px;
    }

}

@media screen and (min-width: 460px) {
    /* 運営会社 */
    .company-mobile {
        display: none;
    }
}

@media screen and (max-width: 460px) {
    /* 運営会社 */
    .company-pc {
        display: none;
    }

    #content-philosophy p {
        font-size: 4.3vw;
    }

    #content-overview .tbl-overview tr td {
        font-size: 3.2vw;
        padding: 15px 5px;
    }
}

@media screen and (max-width: 430px) {
    .tbl-contact .td-contact-01,
    .tbl-contact .td-contact-02 {
        font-size: 5.3vw;
    }

    #content-company .div-greeting .text-greeting .name-greeting span {
        font-size: 14px;
        padding-right: 10px;
    }

    #content-company .div-greeting .text-greeting .name-greeting {
        font-size: 18px;
    }

    #content-company .div-greeting .text-greeting .name-greeting .spn-orange {
        font-size: 14px;
        padding-left: 10px;
    }

}

#topBtn {
    /*-----必須-----*/
    position: fixed;
    bottom: 100px;
    right: 10px;
     
    /*-----装飾-----*/
    width: 64px;
    height: 64px;
    line-height: 64px;
    text-align: center;
    background: linear-gradient(150deg, rgba(231, 70, 40, 1), rgba(242, 130, 0, 1));;
    color: #fff;
    border-radius: 100px;
}

.insta {
    max-width: 200px;
    position: absolute;
    top: 87px;
    right: 20px;
}