/* Shared
------------------------------------------------ */
@font-face {
    font-family: "Yu Gothic M";
    src: local("Yu Gothic Medium");
}

@font-face {
    font-family: "Yu Gothic M";
    src: local("Yu Gothic Bold");
    font-weight: bold;
}

body {
    box-sizing: border-box;
    font-size: 1.6rem;
    font-family: -apple-system, BlinkMacSystemFont, "游ゴシック体", YuGothic, "Yu Gothic M", "游ゴシック Medium", "Yu Gothic Medium", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", HiraKakuProN-W3, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "Helvetica Neue", HelveticaNeue, Helvetica, Arial, "Segoe UI", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    font-feature-settings: "palt"1, "pkna"1, "pwid"1, "hkna"1, "pnum"1;
    line-height: 1.9;
    letter-spacing: 0.1em;
    font-weight: 400;
    overflow-x: hidden;
}

.center {
    text-align: center;
}

#wrap {
    box-sizing: border-box;
    overflow: hidden;
}

.section {
    box-sizing: border-box;
}

.docs-section {
    box-sizing: border-box;
    border-top: none;
}

button.button-contact,
.button.button-contact,
.button {
    border-radius: 100px;
    font-size: 2rem;
    line-height: 4.7rem;
    height: 5rem;
    padding: 0 15px;
}

.footer-bar button.button-contact,
.footer-bar .button.button-contact,
.footer-bar .button {
    font-size: 1.6rem;
    height: 4rem;
    line-height: 4rem;
    display: none;
}

@media all and (-ms-high-contrast:none) {

    *::-ms-backdrop,
    .button {
        padding-top: 4px;
    }

    /* IE11 */
}

.button.button-contact,
button.button-contact,
input[type="submit"].button-contact,
input[type="reset"].button-contact,
input[type="button"].button-contact {
    color: #FFF;
    background-color: #8EC31F;
    border: 2px solid #fff;
    box-shadow: 0 0 0 2px #8EC31F;
}

.button.button-contact:hover,
button.button-contact:hover,
input[type="submit"].button-contact:hover,
input[type="reset"].button-contact:hover,
input[type="button"].button-contact:hover,
.button.button-contact:focus,
button.button-contact:focus,
input[type="submit"].button-contact:focus,
input[type="reset"].button-contact:focus,
input[type="button"].button-contact:focus {
    color: #FFF;
    background-color: #8EC31F;
    border: 2px solid #fff;
    0;
    box-shadow: 0 0 0 2px #8EC31F;
}

/* Typography
-------------------------------------------------- */
h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: -apple-system, BlinkMacSystemFont, "游ゴシック体", YuGothic, "Yu Gothic M", "游ゴシック Medium", "Yu Gothic Medium", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", HiraKakuProN-W3, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "Helvetica Neue", HelveticaNeue, Helvetica, Arial, "Segoe UI", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    margin-top: 0;
    line-height: 1.5;
    margin-bottom: 1.8rem;
    font-weight: 400;
    display: block;
}

h1 {
    font-size: 4.0rem;
    line-height: 1.2;
    letter-spacing: -.1rem;
}

h2 {
    font-size: 4.0rem;
    line-height: 1.25;
    letter-spacing: -.1rem;
}

h3 {
    font-size: 2.4rem;
    line-height: 1.5;
    letter-spacing: -.0rem;
    margin-bottom: 2.0rem;
    font-weight: 800;
}


h4 {
    font-size: 2.0rem;
    line-height: 1.35;
    letter-spacing: -.08rem;
}

h5 {
    font-size: 1.8rem;
    line-height: 1.5;
    letter-spacing: -.05rem;
}

h6 {
    font-size: 1.5rem;
    line-height: 1.6;
    letter-spacing: 0;
}

/*　hr
-------------------------------------*/


.fadein {
    opacity: 0;
    transform: translate(0, 150px);
    transition: all 500ms;
}


.fadein.scrollin {
    opacity: 1;
    transform: translate(0, 0);
}

#point > div .fadein:nth-of-type(2) {
    -moz-transition-delay: 200ms;
    -webkit-transition-delay: 200ms;
    -o-transition-delay: 200ms;
    -ms-transition-delay: 200ms;
}

#point > div .fadein:nth-of-type(3) {
    -moz-transition-delay: 400ms;
    -webkit-transition-delay: 400ms;
    -o-transition-delay: 400ms;
    -ms-transition-delay: 400ms;
}


.orange {
    position: relative;
    box-sizing: border-box;
    background-color: #F08300;
    padding: 20px;
    border-radius: 10px;
    margin-bottom: 2rem;
    min-height: 300px;
}

.orange p {
    display: block;
    margin: 0 auto;
    width: 90%;
}
}


.pic-num {
    display: block;
    position: absolute;
    top: -20px;
    left: 10px;
}


.pic-num img {
    width: 70px;
    height: 70px;
}

.l-box {
    position: relative;
    box-sizing: border-box;
    border-top: 0;
    border-left: 0;
    border-bottom: 0;
    border-radius: 0;
    border-right: 0;
    margin-right: 0;
    margin-bottom: 6rem;
    padding: 30px 0 20px;

}

.r-box {
    position: relative;
    box-sizing: border-box;
    border-top: 0;
    border-left: 0;
    border-right: 0;
    border-bottom: 0;
    border-radius: 0;
    margin-left: 0;
    margin-right: 0;
    padding: 30px 0 20px;
}

.lb {
    margin: 0
}

.rb {
    margin-left: 0;
}

.rb .b2c {
    margin-left: 0;
}

.l-box img,
.r-box img {
    padding: 20px 0;
}

.l-box .kw {
    padding: 0;
    position: absolute;
    right: -82px;
    top: 48px;
}

.l-box h5,
.r-box h5 {
    margin-bottom: 0;
    display: inline-block;
    box-sizing: border-box;
    padding: 5px 25px;
    border-radius: 5px;
    background-color: #fff;
    position: absolute;
    top: -22px;
}

.l-box h5 {
    border: 2px solid #afafaf;
    font-weight: 800;
}

.r-box h5 {
    border: 2px solid #F08300;
    color: #F08300;
    font-weight: 800;
}

.g-box {
    display: block;
    box-sizing: border-box;
    padding: 10px 15px;
    border-radius: 5px;
    background-color: #f0f0f0;
    text-align: left;
    font-size: 1.4rem;
}

.o-box {
    display: block;
    box-sizing: border-box;
    padding: 10px 15px;
    border-radius: 5px;
    background-color: #fff5da;
    text-align: left;
    font-size: 1.4rem;
}

.o-box span {
    color: #F08300;
}

.red {
    color: #F08300;
}

.scroll-box {
    position: relative;
    box-sizing: border-box;
    width: 100%;
    text-align: center;
}

a.scroll-next {
    color: #fff;
    text-decoration: none;

}

a.scroll-next span {
    position: absolute;
    bottom: -30px;
    left: 50%;
    width: 30px;
    height: 30px;
    margin-left: -12px;
    border-left: 10px solid #fff;
    border-bottom: 10px solid #fff;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -webkit-animation: sdb 1.5s infinite;
    animation: sdb 1.5s infinite;
    box-sizing: border-box;
}

@-webkit-keyframes sdb {
    0% {
        -webkit-transform: rotate(-45deg) translate(0, 0);
        opacity: 0;
    }

    50% {
        opacity: 1;
    }

    100% {
        -webkit-transform: rotate(-45deg) translate(-20px, 20px);
        opacity: 0;
    }
}

@keyframes sdb {
    0% {
        transform: rotate(-45deg) translate(0, 0);
        opacity: 0;
    }

    50% {
        opacity: 1;
    }

    100% {
        transform: rotate(-45deg) translate(-20px, 20px);
        opacity: 0;
    }
}

.header-bar {
    box-sizing: border-box;
    width: 100%;
    height: 6.5rem;
    background-color: transparent;
    z-index: 110;
    padding: 0;
    position: relative;
    top: 0;
}

.footer-bar {
    box-sizing: border-box;
    width: 100%;
    height: 9rem;
    z-index: 110;
    padding: 0;
    position: fixed;
    bottom: 0;
    background-color: #fff;
    box-shadow: 0 -2px 2px 0 rgba(0, 0, 0, .14), 0 -3px 1px -2px rgba(0, 0, 0, .2), 0 -1px 5px 0 rgba(0, 0, 0, .12);
    text-align: center;
}

.under {
    background-color: #fff;
    /*    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .14), 0 3px 1px -2px rgba(0, 0, 0, .2), 0 1px 5px 0 rgba(0, 0, 0, .12); */
    transition-duration: .4s;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    transition-property: max-height, box-shadow;
}



#phone-box-footer a,
#phone-box-footer,
#phone-box {
    font-family: -apple-system, BlinkMacSystemFont, "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
    letter-spacing: 0.1rem;
    font-feature-settings: "palt"1, "pkna"1, "pwid"1, "hkna"1, "pnum"1;
    letter-spacing: .1rem;
    z-index: 200;
    color: #F08300;
    text-decoration: none;
}

#phone-box {
    position: fixed;
    display: flex;
    align-items: center;
    text-align: center;
    margin-left: -2rem;
    margin-bottom: 1rem;
}

#phone-box-footer {
    position: relative;
    display: inline;
}

#phone-box-footer img,
#phone-box img {
    margin-right: 10px;
}

#phone-box-footer img {
    margin-left: 1rem;
    width: 2rem;
    height: auto;
    margin-top: -0.8rem;
}

#phone-box-footer a,
#phone-box-footer span,
#phone-box span {
    margin-right: 1rem;
    font-size: 2.4rem;
    font-weight: 800;
}

#phone-box-footer a #phone-box-footer span,
#phone-box-footer span {
    font-size: 2.0rem;
}

#phone-box-footer span.tx,
#phone-box span.tx {
    font-size: 1.6rem;
    font-weight: 400;
    margin-right: 0;
}

#phone-box-footer span.tx {
    font-size: 1.4rem;
}

#phone-box span.tx {
    visibility: hidden;
    display: none;
}

#title-box {
    display: inline-block;
    box-sizing: border-box;
    text-align: left;
    margin-bottom: 0;
    position: relative;
}

.scroll-img {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.siteimg {
    width: 920px;
}

.service-title {
    display: block;
    box-sizing: border-box;
    margin-bottom: 2rem;
}

.service-title img {
    width: 100%;
}

.surplus {
    font-family: "Gothic MB101 Bold", -apple-system, BlinkMacSystemFont, "游ゴシック体", YuGothic;
    font-size: 1.7rem;
    font-weight: 800;
    color: #333;
    padding-left: 11px;
    letter-spacing: .3rem;
    margin: 10px 0 0 0;
    text-align: center;
}

.surplus p {
    font-size: 2rem;
    margin-bottom: 1rem;
}

.surplus .start {
    font-size: 2.6rem;
    letter-spacing: -.1rem;
    padding-top: 0;
}

#details .box-wrapper {
    padding-top: 6rem;
}

#catch {
    color: #F08300;
    font-family: "Gothic MB101 Bold", -apple-system, BlinkMacSystemFont, "游ゴシック体", YuGothic;
    font-size: 19px;
    font-weight: 800;
    margin-bottom: 0;
    text-align: left;
    letter-spacing: .7rem;
    padding-left: 11px;
    text-shadow: #fff 1px 1px 10px, #fff -1px 1px 10px,
        #fff 1px -1px 10px, #fff -1px -1px 10px;
}

.small-hero {
    font-size: 2rem;
    letter-spacing: 6px;
    margin-bottom: 0;
}

#acceptance {
    position: absolute;
    right: 0;
    top: -60px;
}

img.acceptance {
    display: block;
    width: 70px;
    height: auto;
    z-index: 200;
}

/* footer */
#footer {
    box-sizing: border-box;
    margin: 0;
    padding: 2rem 0 1rem;
    color: #666;
    display: none;
    visiblity: visible;
}

#footer:after {
    content: "";
    display: table;
    clear: both;
}


.accordion {
    list-style-type: none;
    padding: 0;
    margin: 0;
    text-align: left;
    border-top: 1px dotted #F08200;
}

.accordion .inner {
    display: none;
}

.accordion p {
    font-size: 1.6rem;
    cursor: pointer;
    padding: 10px;
    margin-bottom: 0;
}

.accordion li p.ac:hover {
    text-decoration: none;
}

.accordion p.ac {
    /*	background: #ee7800; */
    background-color: transparent;
    border-bottom: 1px dotted #F08200;
    font-weight: 800;
    line-height:1.4;
		color:#F08200;
}

.accordion li {
    padding-top: 0;
    margin: 0;
}

.accordion li:first-child {
    padding-top: 5px;
    margin: 0;
}

.accordion .inner {
    list-style-type: none;
    padding: 0;
    margin: 0;
    text-align: left;
}

.accordion .inner li {
    display: block;
    box-sizing: border-box;
    padding: 10px 10px;
    margin: 0;
}

.accordion .inner li.content {
    background-color: #f9f9f9;
}

/* Box */
.box-wrapper {
    box-sizing: border-box;
    margin-top: 4rem;
    padding: 40px 30px;
    background-color: #fff;
    border: 1px solid #eee;
    border-radius: 6px;
    padding: 20px 10px;
    margin-bottom: 3rem;
}

.mb20 {
    padding-bottom: 20px;
    margin-bottom: 2rem;
}

.no-border {
    border: 0;
    margin-top: 0;
    margin-bottom: 0;
}

.no {
    display: flex;
    align-items: center;
    box-sizing: border-box;
    background-color: #FDE8D0;
    margin-bottom: 0;
    height: 60px;
    padding-left: 10px;
    line-height: 1.3;
    text-align: left;
    font-weight:800;
}

.no span {
    height: 30px;
    width: 30px;
    border-radius: 50%;
    line-height: 30px;
    text-align: center;
    background-color: #fff;
    margin-right: 10px;
}

.arrow {
    position: relative;
    width: 100%;
}

.flow-content {
    font-size: 1.6rem;
    text-align: left;
    display: block;
    margin-top: 1.5rem;
    box-sizing: border-box;
    line-height: 1.5;
    margin-left: 2rem;
}

.box-container {
    box-sizing: border-box;
    width: 100%;
    background-color: #FDE8D0;
    border-radius: 6px 6px 6px 6px;
    z-index: 1;
    margin-bottom: 0;
    padding: 0;
    height: 150px
}

.box-content {
    display: block;
    box-sizing: border-box;
    width: 100%;
    background-color: transparent;
    padding: 9px;
    line-height: 1.5;
    font-size: 1.4rem;
    color: #727172;
    text-align: left;
    border-radius: 0;
    z-index: 1;
    margin-bottom: 0;
}

.box-title {
    display: block;
    box-sizing: border-box;
    width: 100%;
    height: 60px;
    background-color: #F08200;
    border-radius: 6px 6px 0 0;
    z-index: 100;
    margin-bottom: 0;
    line-height: 1.5;
    font-size: 1.4rem;
    color: #FFF;
    text-align: left;
    padding: 9px;
}


/* table */

table {
    border-collapse: separate;
    border-spacing: 5px;
    margin-bottom: 0;
}

th:first-child,
td:first-child {
    padding-left: 15px;
}


th,
td {
    border-bottom: none;
    width: 100%;
    display: block;
    box-sizing: border-box;
}

th {
    background-color: #fde8d0;
}

td {
    background-color: #fff;
}

td.odd,
td {
    padding: 15px 15px 30px 15px;
}

.container {
    max-width: 960px;
}

#overview .container {
    padding-left: 0;
    padding-right: 0;
}

.header {
    margin-top: 6rem;
    text-align: center;
}


.docs-header {
    text-transform: uppercase;
    font-size: 1.4rem;
    letter-spacing: .2rem;
    font-weight: 600;
}

.docs-section {
    /*  border-top: 1px solid #eee; */
    border-top: none;
    padding: 4rem 0;
    margin-bottom: 0;
}

.value-img {
    display: block;
    text-align: center;
    margin: 2.5rem auto 0;
}

.grid .columns {
    background: #EEE;
    text-align: center;
    border-radius: 4px;
    font-size: 1rem;
    text-transform: uppercase;
    height: 30px;
    line-height: 30px;
    margin-bottom: .75rem;
    font-weight: 600;
    letter-spacing: .1rem;
}

.docs-content .row,
.docs-content.row,
.docs-content form {
    margin-bottom: 0;
}

.docs-content h1,
.docs-conetnt h2,
.docs-content h3,
.docs-content h4,
.docs-content h5,
.docs-content h6 {
    margin-bottom: 1rem;
}

.heading-font-size {
    font-size: 1.2rem;
    color: #999;
    letter-spacing: normal;
}


#page_top.view,
#side-appli.view {
    visibility: visible;
}

/* Hero
------------------------------------------------ */
.hero {
    position: relative;
    text-align: center;
    box-sizing: border-box;
    background-image: url("../images/hero-back.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    z-index: 1;
    padding-top: 6rem;
    background-position: center bottom;
}

.hero::after {
    content: '';
    background-color: rgba(255, 255, 255, 0.4);
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    z-index: -1;
}

.hero {
    width: 100vw;
    height: auto;
    min-height: 100vh;
}

img.yamato-kun {
    display: none;
}

.container {
    max-width: 100%;
}

#contact-form label {
    max-width: 450px;
    text-align: left;
}


.container {
    /*  z-index: 2000; */
}

textarea,
select,
fieldset,
input[type="email"],
input[type="number"],
input[type="search"],
input[type="text"],
input[type="tel"],
input[type="url"],
input[type="password"],
textarea {
    max-width: 260px;
}

.mobile {
    visibility: visible;
    display: initial;
}

#contact-form .hero {
    padding-bottom: 4rem;
    margin-bottom: 4rem;
}

.l-box .kw {
    visibility: hidden;
}

.noview-mobile {
    display: none;
    visibility: hidden;
}

#phone-box {
    display: none;
    visibility: hidden;
}


.footer-bar,
#phone-box-footer span.tx {
    display: none;
}

/**/
a,
.mdl-button {
    -webkit-tap-highlight-color: transparent;
    -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
}

.mdl-button {
    background: transparent;
    border: none;
    border-radius: 2px;
    color: rgb(0, 0, 0);
    position: relative;
    height: 36px;
    margin: 0;
    min-width: 64px;
    padding: 0 16px;
    display: inline-block;
    font-family: "Roboto", "Helvetica", "Arial", sans-serif;
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    line-height: 1;
    letter-spacing: 0;
    overflow: hidden;
    will-change: box-shadow;
    transition: box-shadow 0.2s cubic-bezier(0.4, 0, 1, 1), background-color 0.2s cubic-bezier(0.4, 0, 0.2, 1), color 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    outline: none;
    cursor: pointer;
    text-decoration: none;
    text-align: center;
    line-height: 36px;
    vertical-align: middle;
}

.mdl-button::-moz-focus-inner {
    border: 0;
}

.mdl-button:hover {
    background-color: rgba(158, 158, 158, 0.20);
}

.mdl-button:focus:not(:active) {
    background-color: rgba(0, 0, 0, 0.12);
}

.mdl-button:active {
    background-color: rgba(158, 158, 158, 0.40);
}

.mdl-button.mdl-button--colored {
    color: rgb(63, 81, 181);
}

.mdl-button.mdl-button--colored:focus:not(:active) {
    background-color: rgba(0, 0, 0, 0.12);
}

.mdl-button--fab {
    border-radius: 50%;
    font-size: 24px;
    height: 56px;
    margin: auto;
    min-width: 56px;
    width: 56px;
    padding: 0;
    overflow: hidden;
    background: rgba(158, 158, 158, 0.20);
    box-shadow: 0 1px 1.5px 0 rgba(0, 0, 0, 0.12), 0 1px 1px 0 rgba(0, 0, 0, 0.24);
    position: relative;
    line-height: normal;
}

.mdl-button--fab:active {
    box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
    background-color: rgba(158, 158, 158, 0.40);
}

.mdl-button--fab:focus:not(:active) {
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.18), 0 8px 16px rgba(0, 0, 0, 0.36);
    background-color: rgba(158, 158, 158, 0.40);
}

.mdl-button--fab.mdl-button--colored {
    background: rgb(255, 64, 129);
    color: rgb(255, 255, 255);
}

.mdl-button--fab.mdl-button--colored:hover {
    background-color: rgb(255, 64, 129);
}

.mdl-button--fab.mdl-button--colored:focus:not(:active) {
    background-color: rgb(255, 64, 129);
}

.mdl-button--fab.mdl-button--colored:active {
    background-color: rgb(255, 64, 129);
}

.mdl-button--fab:active {
    box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
    background-color: rgba(158, 158, 158, 0.40);
}

.mdl-button--fab:focus:not(:active) {
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.18), 0 8px 16px rgba(0, 0, 0, 0.36);
    background-color: rgba(158, 158, 158, 0.40);
}

.mdl-button--fab.mdl-button--colored {
    background: rgb(255, 64, 129);
    color: rgb(255, 255, 255);
}

.mdl-button--fab.mdl-button--colored:hover {
    background-color: rgb(255, 64, 129);
}

.mdl-button--fab.mdl-button--colored:focus:not(:active) {
    background-color: rgb(255, 64, 129);
}

.mdl-button--fab.mdl-button--colored:active {
    background-color: rgb(255, 64, 129);
}



/**/
.mdl-button--fab {
    font-size: 42px;
}

.mdl-button--fab.mdl-button--colored {
    background-color: #f08300;
    padding-top: 3px;
    position: absolute;
    bottom: initial;
    left: 50%;
    margin-left: -28px;
    padding-top: 6px;
    box-sizing: border-box;
}

.mdl-button--fab.mdl-button--colored:hover,
.mdl-button--fab.mdl-button--colored:focus:not(:active),
.mdl-button--fab.mdl-button--colored:active {
    background-color: #ffa645;
}

#payment .box-wrapper {
    margin-bottom: 3rem;
}


#footer-logo {
    display: none;
}

#point .box-wrapper,
#flow .box-wrapper {
    margin-bottom: 2rem;
}

.pic-point img {
    width: 200px;
    height: auto;
}

.orange p.pic-point {
    margin-bottom: 3rem;
}

.pic-num img {
    position: absolute;
    left: 5%;
}

.no-mobile {
	display:none;
	visibility:hidden;
}
.service-title {
    margin-bottom: 0;
}
.surplus {
    margin: 0;
}
.surplus p {
    line-height: 1.2;
    margin-bottom: 2rem;
}
.scroll-box {
    margin-bottom:1.5rem;
}
@media (min-width: 400px) {
    .container {
        width: 100%;
        padding: 0;
        margin-left: 0;
        margin-right: 0;
    }

    .box-wrapper {
        overflow: hidden;
    }

    h3 {
        font-size: 2rem;
    }
.surplus {
    margin: 10px 0 0 0;
}
.surplus p {
    line-height: 1.9;
    margin-bottom: 1rem;
}
.service-title {
    margin-bottom: 2rem;
}
.no-mobile {
	display:initioal;
	visibility:visible;
}
.scroll-box {
    margin-bottom:0;
}
.mdl-button--fab.mdl-button--colored {
    bottom: 30%;
}
}

@media (min-width: 550px) {

    .header {
        margin-top: 18rem;
    }

    .value-props {
        margin-top: 9rem;
        margin-bottom: 7rem;
    }

    .value-img {
        margin-bottom: 1rem;
    }

    .docs-section {
        padding: 6rem 0;
    }

    .one-third.column {
        width: 100%;
    }

    .three.columns {
        width: 100%;
    }

    .column,
    .columns {
        margin-left: 0;
    }

    .one-half.column {
        width: 100%;
    }

    .orange {
        margin-bottom: 4rem;
        height: auto;
        min-height: auto;
    }

    #contact-form label {
        text-align: left;
    }

    .section {
        padding: 12rem 0 3rem;
    }

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

    #container {
        width: 100%;
        margin-left: 0;
        margin-right: 0;
        padding-left: 3rem;
        padding-right: 3rem;
    }

    .box-wrapper {
        overflow: hidden;
    }



}

/* Larger than tablet */
@media (min-width: 750px) {

    .g-box {
        height: 145px;
    }

    .o-box {
        height: 145px;
    }
    .surplus {
        display: block;
    }

    .surplus p {
        display: inline;
        vertical-align: top;
        margin-bottom: 0;
        line-height: 1;
        padding-top: 5px;
        width: 100%;
				text-align: center;
    }

    .surplus .start {
        padding-left: 10px;
        font-size: 2.6rem;
        letter-spacing: -.1rem;
        padding-top: 0;
    }

.accordion p.ac {
    line-height:1.6;
}
    #footer-logo {
        display: block;
    }
.no {
	font-weight: initial;
}
    .footer-bar button.button-contact,
    .footer-bar .button.button-contact,
    .footer-bar .button {
        display: initial;
    }

    .header-bar {
        position: relative;
    }

    .mobile {
        visibility: hidden;
        display: none;
    }

    .noview-mobile {
        display: inline;
        visibility: visible;
    }

    .footer-bar .noview-mobile {
        display: none;
        visibility: hidden;
    }

    #footer {
        display: block;
    }

    .surplus {
        margin: -10px 0 0 0;
    }

    .surplus .start {
        padding-left: 24px;
        font-size: 3.2rem;
    }

    .hero {
        padding: 12rem 0 0;
    }

    .container {
        max-width: 750px;
        margin: 0 auto;
    }

    .hero {
        position: relative;
        width: auto;
        height: 100vh;
        min-height: auto;
        padding: 10rem 0 0rem;
        text-align: center;
        background-position: center center;
    }

    #contact-form .hero {
        height: auto;
        padding-bottom: 12rem;
    }

    .hero .container {
        max-width: 750px;
        width: 100%;
    }

    .scroll-box {
        margin-top: 12rem;
    }

    a.scroll-next span {
        position: absolute;
        bottom: 20%;
    }

    button.button-contact,
    .button.button-contact,
    .button {
        padding: 0 40px;
    }

    #title-box {
        margin-bottom: 8rem;
    }

    #point {
        padding: 6rem 0 3rem;
    }


    #contact-form #title-box {
        margin-bottom: 0;
    }

    #phone-box-footer {
        position: absolute;
        display: flex;
        align-items: center;
        text-align: left;
        margin-left: 1rem;
        margin-bottom: 1rem;
        margin-top: 1.2rem;

    }

    #phone-box {
        display: flex;
        visibility: visible;
        position: absolute;
        right: 20px;
        top: 10px;
    }

    .yamto-kun-box {
        position: relative;
        width: 100%;
    }

    img.yamato-kun {
        display: block;
        position: absolute;
        top: 190px;
        right: 0;
        width: 180px;
        height: auto;
    }

    .service-title {
        max-width: 560px;
        margin-bottom: 0;
    }

    #acceptance {
        top: 0;
        left: 94%;
    }

    img.acceptance {
        width: 110px;
    }

    .section {
        padding: 12rem 0 3rem;
    }

    .lb {
        margin-left: 0 !important;
    }

    .rb {
        margin-top: 6rem;
    }

    .l-box {
        margin-bottom: 6rem;
        padding: 30px 20px 20px;

    }

    .r-box {
        padding: 30px 20px 20px;
    }

    .orange p {
        margin-bottom: 1rem;
    }

    h1.logo {
        margin: 0;
        padding-left: 10px;
        position: relative;
    }

    #footer-logo .logo {
        margin: 0;
        padding-left: 10px;
    }

    .section-description {
        max-width: 60%;
        margin-left: auto;
        margin-right: auto;
    }


    .categories {
        padding: 15rem 0 8rem;
    }

    .mdl-button--fab.mdl-button--colored {
        bottom: 20%;
    }


    h3::before {
        content: '';
        display: inline-block;
        width: 4.0rem;
        height: 3.7rem;
        background-image: url(../images/ico01.png);
        background-size: contain;
        vertical-align: middle;
        margin-right: 1rem;
    }

    h3.service-title::before {
        content: none;
    }

    h3 {
        font-size: 3rem;
        font-weight: 400;
        line-height: 1.3;
        letter-spacing: -.1rem;
    }

    .footer-bar {
        height: 6.5rem;
    }

    .footer-bar a.button {
        position: absolute;
        right: 1rem;
        top: 12px;
    }

    #faq.values {
        padding-bottom: 10rem;
    }

    .pic-num img {
        position: absolute;
        left: 30%;
    }

}

@media all and (-ms-high-contrast:none) {

    *::-ms-backdrop,
    #side-appli {
        right: 0;
    }

    /* IE11 */
}

@supports (-ms-ime-align:auto) {
    #side-appli {
        right: 0;
    }
}


/* Bigger than 1000 */


@media (min-width: 1000px) {

    th,
    td {
        background-color: #fff;
    }

    th.odd,
    td.odd {
        background-color: #fde8d0;
        width: 100%;
        display: block;
        box-sizing: border-box;
    }

    .pic-num img {
        position: relative;
        left: 0;
    }

    .section {
        padding: 10rem 0 10rem;
    }

    h1.logo {
        position: relative;
    }

    #acceptance {
        top: 0;
    }

    #faq.values {
        padding-bottom: 6rem;
    }

    #phone-box-footer img {
        margin-top: 0;
    }

    .footer-bar a.button {
        position: absolute;
        right: 1rem;
        top: 12px;
    }

    .box-wrapper {
        padding: 40px 30px 0;
        margin-bottom: 3rem;
    }

    #faq .box-wrapper {
        padding-bottom: 40px;
    }

    th.odd,
    td.odd {
        display: table-cell;
        background-color: #fde8d0;
        width: auto;
        padding: 12px 15px;
    }

    th,
    td {
        display: table-cell;
        border-bottom: none;
        width: auto;
        padding: 12px 15px;
    }

    th {
        width: 20%;
    }

    table {
        margin-bottom: 20px;
    }

    .flow-content {
        width: 17rem;
    }

    .arrow {
        width: 19rem;
    }

    .arrow::after {
        content: "";
        border-top: 30px solid transparent;
        border-bottom: 30px solid transparent;
        border-left: 20px solid #FDE8D0;
        top: 0;
        right: -20px;
        position: absolute;
    }

    .one-third.column {
        width: 30.6666666667%;
    }

    .three.columns {
        width: 22%;
    }

    .column,
    .columns {
        margin-left: 4%;
    }

    .one-half.column {
        width: 48%;
        margin-left: 0;
    }

    .hero {
        position: relative;
        width: auto;
        height: 100vh;
        min-height: auto;
        padding: 10rem 0 0rem;
        text-align: center;
        background-position: center top;
    }

    .hero.hero-form {
        height: auto;
    }

    .hero .container {
        width: 100%;
        max-width: 960px;
    }

    .hero-inner {
        position: relative;
        margin-top: 0rem;
    }

    #title-box {
        margin-bottom: 2rem;
    }

    #phone-box span.tx {
        visibility: visible;
        display: inline;
    }

    .scroll-box {
        margin-top: 4rem;
    }

    .hero-form .hero-inner {
        margin-top: 0;
    }

    .l-box {
        border-top: 2px solid #afafaf;
        border-left: 2px solid #afafaf;
        border-bottom: 2px solid #afafaf;
        border-right: 2px dotted #afafaf;
        border-radius: 10px 0 0 10px;
        margin-left: 1%;
    }

    .r-box {
        border-top: 2px solid #F08300;
        border-right: 2px solid #F08300;
        border-bottom: 2px solid #F08300;
        border-left: 0;
        border-radius: 0 10px 10px 0;
    }

    .rb {
        margin-top: 0;
    }


    #details .box-wrapper {
        padding-top: 70px;
    }

    .l-box .kw {
        visibility: visible;
				width: 31%;
    }

    .container {
        max-width: 90%;
    }


    .section {
        padding: 21rem 0 10em;
    }

    .mtop-1 {
        margin-bottom: 2rem;
    }

    .yamto-kun-box {
        position: relative;
        width: 100%;
    }

    img.yamato-kun {
        display: block;
        position: absolute;
        top: 180px;
        right: 50px;
        width: 240px;
        height: auto;
    }

    .service-title {
        max-width: 750px;
        margin-bottom: 0;
    }

    .footer-bar .noview-mobile {
        display: initial;
        visibility: visible;
    }

    #contact-form .hero {
        padding-bottom: 4rem;
        margin-bottom: 4rem;
        margin-top: 0;
        padding-top: 12rem;
    }

    .r-box .b2c {
        margin-left: 30px;
    }

    .lb {
        margin-left: 2% !important;
        margin-right: 0;
    }

    .g-box {
        height: 145px;
    }

    .o-box {
        height: 145px;
    }

    .orange {
        margin-bottom: 0rem;
       	min-height:39rem;
    }

    #contact-form label {
        text-align: right;
    }

    #contact-form label.linein {
				max-width: none;
				text-align: left;
    }

    #contact-form label.tit {
        display: inline;
				text-align: left;
				max-width:auto;
    }

    .pic-num {
        position: absolute;
        top: -23px;
        left: -100px;
    }

    .scroll-img {
        width: 100%;
        overflow: hidden;
    }

    .footer-bar {
        position: fixed;
        display: none;
    }

}


@media (min-width:1170px) {

    .container,
    .hero .container {
        width: 100%;
        max-width: 1170px;
    }

    img.yamato-kun {
        top: 70px;
    }

    #phone-box span.tx {
        visibility: visible;
        display: inline;
    }

    #phone-box-footer span.tx {
        display: inline;
    }

    .g-box {
        height: 130px;
    }

    .o-box {
        height: 130px;
    }
}

/* Sections
------------------------------------------------ */
.section {
    padding: 6rem 0 6rem;
    text-align: center;
}

.section-heading,
.section-description {
    margin-bottom: 1.2rem;
}

#footer-logo .logo,
h1.logo {
    display: block;
    box-sizing: border-box;
    width: 32rem;
    padding: 8px 0 0 0;
    position: relative;
    z-index: 2;
}

h1.logo {
    margin-left: 1rem;
}

h1.logo img {
    width: 26rem;
}

#footer-logo img {
    width: 18rem;
}

/* Values
------------------------------------------------ */
.values {
    background-color: #FFF5DA;
    background-size: cover;
    color: #606060;
    padding-bottom: 5rem;
}

.value-multiplier {
    margin-bottom: .5rem;
    color: #11DFC7;
}

.value-heading {
    margin-bottom: .3rem;
}

.value-description {
    opacity: 1;
    font-weight: 300;
    color: #fff;
    text-align: left;
    font-size: 1.4rem;
}

/* Help
------------------------------------------------ */
.get-help {
    border-bottom: 1px solid #ddd;
}

/* Categories
------------------------------------------------ */
.categories {
    background-color: #7ebeab;
    background-size: cover;
    color: #fff;
}

.categories .section-description {
    margin-bottom: 4rem;
}


#page_top {
    position: fixed;
    right: 4rem;
    bottom: 11rem;
    opacity: 1;
    visibility: hidden;
    z-index: 200;
}


/* Bigger than 550 */
@media (min-width: 550px) {}


.nodisp {
    display: none;
}

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

#contact-form h1.logo {
    width: 160px;
}

#contact-form #hero h3 {
    font-family: "Gothic MB101 Bold", -apple-system, BlinkMacSystemFont, "游ゴシック体", YuGothic;
    font-size: 19px;
    font-weight: 800;
    margin-bottom: 0;
    text-align: center;
    letter-spacing: .6rem;
    padding-left: 11px;
}


button.mfp_prev,
button.mfp_next{
	display: inline-block;
	padding: 8px 15px;
	border-radius: 5px;
	margin: 0px 5px;
	list-style: none;
	font-size: 14px;
}
button.mfp_prev,
button.mfp_next{
	box-shadow: none;
	color: #999;
	padding: 5px 40px!important;
}
button.mfp_prev,
button.mfp_next{
/*	box-shadow: 0px 1px 6px #000; */
	background-size: 100% 100%;
	background-color: #0068B7;
	border: solid 2px #0068B7;
	font-weight: bolder;
	color: #FFF;
	text-shadow: 0px 1px 3px #000;
	height: 5rem;
	border-radius:100px;
}
form#mailformpro {
    padding-bottom: 30px;
}

textarea#mfp_element_51 {
	max-width: 100%;
	min-height: 100px;
}

.line01 {
	width:100%;
	display:block;
	box-sizing: border-box;
	border:2px solid #ddd;
	padding:20px 30px 20px;
}
p.tit {
	display: inline-block;
	width: 100%;
  text-align: center;
  font-weight: bold;
}
label.linein {
	font-weight: normal;
}
.line01 input[type="email"], 
.line01 input[type="number"], 
.line01 input[type="search"], 
.line01 input[type="text"], 
.line01 input[type="tel"], 
.line01 input[type="url"], 
.line01 input[type="password"], 
.line01 textarea, 
.line01 select {
	margin-bottom: 0.5em;
	height: 38px;
    padding: 6px 2px;
    background-color: #fff;
    border: 1px solid #D1D1D1;
    border-radius: 4px;
    box-shadow: none;
    box-sizing: border-box;
}
ul#mfp_phase_stat li.mfp_active_phase {
	background-image: none!important;
}

ul#mfp_phase_stat li.mfp_active_phase {
	box-shadow:none!important;
	text-shadow:none!important;
}
ul#mfp_phase_stat li.mfp_inactive_phase {
	box-shadow:none!important;
	text-shadow:none!important;
}

p.li-inner {
  margin:.5rem 0 1.5rem 3rem!important;
}
.li-inner span {
  display:block;important;
  margin:0!important;
  padding:0!important;
  font-size:100%!important;
}

