@charset "UTF-8";

/* CSS Document */

@media screen and (max-width: 800px) {
    .header .header_content .navgation ul {
        width: 75vw;
        padding: 0;
        justify-content: space-between;
    }
    .header .header_content .navgation ul li {
        padding: 0px;
    }
    .logo {
        width: 15vw;
    }
    .header .header_content .navgation ul li:last-child {
        padding: 1% 2%;
    }
    .header .header_content .navgation ul li a {
        font-size: 1.9vw;
    }
    /* top banner section */
    .top-banner {
        padding: 5% 10% 40%;
    }
    .fv-content {
        width: 90%;
        padding: 5%;
        border-radius: 4vw;
    }
    .fv-content h3 {
        font-size: 4vw;
    }
    .fv-content h6 {
        font-size: 2.5vw;
    }
    .fv-content button {
        width: 80%;
        margin: 5%;
        padding: 3%;
        border-radius: 3vw;
    }
    .fv-content button a p {
        font-size: 2.5vw;
    }
    .fv-content button a h4 {
        font-size: 3.5vw;
    }
    p.tel-contact {
        font-size: 2.5vw;
        padding-bottom: 3%;
    }
    .fv-content .tel img {
        width: 6vw;
        padding: 1% 5% 0 0;
    }
    .fv-content .tel h2 {
        font-size: 7vw;
    }
    /* problem section */
    .problem {
        padding: 10% 5%;
    }
    h6.sec-title {
        font-size: 4vw;
    }
    .problem-boxes {
        padding: 5% 0;
        display: block;
    }
    .problem-box {
        width: 86%;
        padding: 5% 7%;
        margin-bottom: 3%;
        border-radius: 1vw;
    }
    .problem-box img {
        width: 9vw!important;
    }
    .problem-box h6 {
        font-size: 3vw;
        padding-left: 7%;
    }
    .problem-content p {
        font-size: 3.5vw;
    }
    /* service section */
    .service {
        padding: 10% 5%;
    }
    .service h6.sec-title {
        padding-bottom: 5%;
    }
    .service-txt {
        font-size: 2.5vw;
        padding-bottom: 3%;
    }
    .service-box {
        padding: 3% 0;
    }
    .service-box h6 {
        font-size: 4vw;
        width: 7vw;
        height: 7vw;
    }
    .service-box-inner {
        margin-left: 5%;
        padding: 5% 3%;
        border-radius: 3vw;
        width: 80%;
        border: 1vw solid var(--primary-color);
    }
    .service-box-inner:last-child img {
        width: 10vw;
    }
    .service-box-txt {
        padding-left: 3%;
    }
    .service-box-txt h4 {
        font-size: 3.5vw;
        padding-bottom: 0;
    }
    .service-box-txt p {
        font-size: 2.5vw;
    }
    /* point section */
    .point {
        padding: 10% 5%;
    }
    .point-boxes {
        margin-top: 5%;
        padding: 5%;
        border-radius: 3vw;
    }
    .point-box {
        padding: 3% 0;
    }
    .point-box h6 {
        font-size: 4vw;
        width: 6vw;
        height: 6vw;
        border: 1vw solid var(--primary-color);
    }
    .point-txt {
        padding-left: 5%;
        width: 80%;
    }
    .point-txt h4 {
        font-size: 3.5vw;
        /* margin-top: -2%; */
    }
    .point-txt p {
        font-size: 2.5vw;
    }
    /* btn contact section  */
    .btn-contact {
        padding: 10% 5%;
    }
    .btn-contact button {
        border-radius: 2vw;
        width: 75%;
        margin-top: 0;
        padding: 3% 0;
        margin-bottom: 0;
    }
    .btn-contact button a p {
        font-size: 3vw;
    }
    .btn-contact button a h4 {
        font-size: 4vw;
    }
    /* case section */
    .case {
        padding: 10% 5%;
    }
    .case-content .sec-title {
        padding-bottom: 5%;
    }
    .case-box {
        margin-bottom: 5%;
        border-radius: 3vw;
        border: 1vw solid var(--primary-color);
    }
    .case-box h6 {
        font-size: 3.5vw;
        padding: 3%;
        border-top-left-radius: 2vw;
        border-top-right-radius: 2vw;
        margin: -1px;
    }
    .case-box-inner {
        padding: 5%;
        display: block;
    }
    .case-box-inner img {
        width: 100%;
    }
    .case-box-txt {
        width: 100%;
        padding: 5% 0;
    }
    .case-box-txt h6 {
        font-size: 3.5vw;
        padding: 0;
    }
    .case-box-txt p {
        padding: 2% 0 5%;
        font-size: 2.5vw;
        line-height: normal;
    }
    /* faq section  */
    .faq {
        padding: 10% 5%;
    }
    .faq-content .sec-title {
        padding-bottom: 5%;
    }
    .faq-box {
        margin-bottom: 5%;
    }
    .ques,
    .ans {
        padding: 2% 4%;
    }
    .ques h6,
    .ans h6 {
        font-size: 3.5vw;
    }
    .ques p {
        font-size: 2.5vw;
        padding-left: 5%;
    }
    .ans p {
        font-size: 2.5vw;
        padding-left: 5%;
    }
    /* flow section */
    .flow {
        padding: 10% 5%;
    }
    .flow-content .sec-title {
        padding-bottom: 5%;
    }
    .flow-content {
        max-width: 100%;
    }
    .flow-boxes {
        padding: 4%;
        border-radius: 3vw;
        border: 1vw solid var(--primary-color);
    }
    .flow-box {
        margin-bottom: 5%;
        width: 100%;
    }
    .flow-box:first-child img {
        width: 20%;
    }
    .flow-box:first-child .flow-box-txt {
        padding-left: 3%;
        width: 77%;
    }
    .flow-box img {
        width: 15%;
    }
    .flow-box .flow-box-txt {
        padding-left: 8%;
        width: 77%;
    }
    .flow-box-txt h6 {
        font-size: 3.5vw;
        padding-bottom: 3%;
    }
    /* contact section */
    .contact {
        padding: 10% 5%;
    }
    .contact-content .sec-title {
        padding-bottom: 5%;
    }
    .contact-content {
        max-width: 100%;
    }
    .contact-txt {
        font-size: 3vw;
        padding-bottom: 5%;
    }
    .contact-line {
        margin-bottom: 3%;
        font-size: 4vw;
    }
    .contact-line p {
        font-size: 3vw;
    }
    .contact-line input {
        width: -webkit-fill-available;
        padding: 2%;
        font-size: 3vw;
    }
    .contact-line textarea {
        width: -webkit-fill-available;
        padding: 2%;
        font-size: 3vw;
        height: 30vw;
    }
    .privacy-check h6,
    .privacy-check p,
    .privacy-check p a {
        font-size: 3vw;
    }
    .privacy-check p input {
        width: 3vw;
        height: 3vw;
        margin-right: 2%;
    }
    .contact-box button {
        margin: 5% auto 0;
        width: 50%;
        border-radius: 1vw;
        font-size: 4vw;
        padding: 3% 0;
    }
    .contact-line input::placeholder,
    .contact-line textarea::placeholder {
        font-size: 3vw;
        color: #999;
    }
    /* footer section */
    footer {
        display: block;
        padding: 3% 0;
    }
    .footer-menu {
        text-align: center;
    }
    .footer-menu ul {
        display: block;
        margin: 2% 0;
    }
    .footer-menu ul li {
        padding: 0;
        font-size: 4vw;
    }
    .footer-menu ul li a {
        font-size: 2vw;
    }
    footer p {
        text-align: center;
        font-size: 2vw;
    }
    /* thank you page */
    .thanks-body {
        margin: 10%;
    }
}

@media screen and (max-width: 950px) {
    .flow-box-txt p {
        font-size: 2.5vw;
        line-height: normal;
    }
}

@media screen and (max-width: 768px) {
    .header .menu_btn {
        display: block;
    }
    .header .navgation {
        display: none;
    }
    .pc {
        display: none!important;
    }
    .sp {
        display: block!important;
    }
    p {
        font-size: 4vw;
        /* line-height: 7vw!important; */
    }
    /* header */
    .header .header_content {
        display: flex;
        padding: 3% 4%;
        justify-content: space-between;
    }
    .overlay-content ul li a {
        color: white;
        font-size: 4vw;
    }
    .logo {
        width: 50%;
    }
    .header_entry {
        font-size: 3vw;
    }
    .menu_btn .container {
        padding: 0 0 0 20%;
    }
    .overlay {
        width: 100%!important;
    }
    .hamburger-header {
        padding: 0 3% 0 0;
    }
    .hamburger {
        padding: 2% 0 5% 7%;
    }
    .hamburger a {
        align-items: flex-end;
    }
    .hamburger a p {
        font-size: 3vw;
        line-height: 3vw!important;
    }
    .hamburger_entry a {
        font-size: 3vw;
    }
    .overlay-content ul.main-menu li {
        padding: 5% 3%;
    }
    .overlay-content ul.main-menu li a {
        font-size: 3.5vw!important;
    }
    .sub-menu li a {
        font-size: 3vw!important;
    }
    .overlay-content ul.main-menu {
        margin: 5% 7% 5% 7%;
    }
    .overlay-content p {
        font-size: 2vw;
    }
}