@media screen and (min-width: 641px) {
    .mainvisual_content {
        height: calc(100vh - 119px);
        min-height: 640px;
    }

    .mainvisual_item {
        min-height: 600px;
        height: 100%;
    }
}

@media only screen and (max-width: 1600px) {
    .box01_01 > p {
        max-width: 68vw;
    }

    .box02_01 > p {
        max-width: 66vw;
    }

    .box02_02 {
        margin-top: 0;
    }

    .box02 .c-title01 {
        padding-bottom: 45px;
    }
}

@media only screen and (max-width: 1500px) {
    .mainvisual_content {
        padding: 30px 25px 44px 60px;
    }

    .mainvisual_content h2 {
        font-size: 40px;
    }

    .mainvisual_content .txt01,
    .mainvisual_content .txt03 {
        font-size: 36px;
    }

    .mainvisual_content .txt02 {
        font-size: 28px;
    }

    .box03_02_img {
        width: 58%;
    }

    .box03_02_content {
        width: 45%;
        padding: 30px 30px 100px 30px;
    }

    .box03_02_content .c-btn02 {
        bottom: 35px;
        right: 30px;
    }

    .box03_02_content > span {
        font-size: 50px;
        top: -25px;
    }

    .box03_02_content h4 {
        font-size: 28px;
        margin-bottom: 25px;
    }

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

    .box03_02_content ul li > span.label-item {
        padding: 6px 5px 9px 5px;
    }

    .box03_02_content ul.label li {
        padding-left: 75px;
    }
}

@media only screen and (max-width: 1360px) {
    .mainvisual_content {
        padding: 30px 55px 44px 55px;
    }
}

@media only screen and (min-width: 641px) and (max-width: 1366px) {
    .logo {
        margin-left: 1%
    }

    .header_right {
        padding-right: 1%
    }
    .box02 .c-title01{
        margin-right: 2%
    }

    .box02_02_item2 .box02_02_title {
        left: -3%;

    }

    .box02_02_title h4 {
        font-size: 25px;
    }

    .box02_02_title h4 span {
        font-size: 28px;
    }

    .box02_02_item2 .box02_02_left .c-btn03 {
        margin-right: 1px
    }

    .box02_02_title {
        margin-top: 0;
    }

    .box02_02_item1 .box02_02_left .btn2 {
        margin-left: 2px
    }

    .box02_02_item1 .container {
        background-position: 40% 100%;
    }

    .box03_02_content h4 {
        font-size: 24px
    }

}

@media only screen and (max-width: 1200px) {

    .box01_01 > p,
    .box02_01 > p {
        max-width: 100%;
    }

    .box01_01 > p,
    .box03_01 > p {
        padding-right: 25px;
    }

    .box02_01 > p {
        padding-left: 25px;
    }

    .box01_02,
    .box02_02_item,
    .box04 .container,
    .box_contact_wrap,
    #footer .container {
        padding-left: 25px;
        padding-right: 25px;
    }

    .box01_02_item {
        width: 370px;
    }

    .box01_02_item p:not(.img) {
        padding: 0 30px;
        line-height: 1.9;
    }

    .box02_02_title h4 {
        font-size: 24px;
    }

    .box02_02_title h4 span {
        font-size: 34px;
    }

    .box02_02_item2 .box02_02_title {
        left: 0;
    }

    .box02_02_item2 .box02_02_left .c-btn03 {
        margin-right: 0;
    }

    .box04_item {
        width: 560px;
    }

    .f_box01 {
        width: 370px;
    }

    /******************under***********************/
     /* .under #content {
    padding: 20px    10px
    }*/

}

@media only screen and (max-width: 640px) {

    h1,
    h2,
    h3,
    h4,
    h5,
    h6,
    input,
    button,
    textarea,
    select,
    p,
    blockquote,
    th,
    td,
    pre,
    address,
    li,
    dt,
    dd {
        font-size: 140%;
    }



    #wrapper {
        min-width: 100%
    }

    .container {
        width: 100%
    }

    .pc {
        display: none
    }

    .sp {
        display: block
    }

    /******************Component********************************/
    .c-title01,
    .box02 .c-title01,
    .box03 .c-title01 {
        width: 300px;
        height: 160px;
        padding: 36px 25px;
    }

    .box01 .c-title01 {
        margin-left: 0;
    }

    .box02 .c-title01 {
        margin-right: 0;
    }

    .c-title01 h3 {
        font-size: 24px;
        margin-bottom: 10px;
    }

    .c-title01 > span {
        font-size: 12px;
        margin-bottom: 8px;
    }

    .c-title01 > .c-btn02 a {
        border: none;
        border-bottom: 1px solid #fff;
        width: 130px;
        padding: 0px 35px 0px 15px;
        font-size: 13px;
    }

    .c-title01 .c-btn02 a:after {
        content: "";
        background: url(../images/index_icon03-1.png) no-repeat center;
        background-size: contain;
        width: 13px;
        height: 12px;
        top: 50%;
        right: 25px;
    }

    .c-title01 .c-btn02 a:hover:after {
        background: url(../images/index_icon04-1.png) no-repeat center;
        background-size: contain;
    }

    .c-btn02 a {
        padding: 6px 30px 7px 30px;
        font-size: 14px;
        width: 200px;
    }

    .c-btn03 a {
        font-size: 14px;
        padding: 15px 40px 15px 30px;
    }

    .c-btn03:after {
        display: none;
    }

    /******************Header********************************/
    #header {
        padding: 10px 3%;
        height: 65px;
        display: flex;
        align-items: center;
        -webkit-box-shadow: 0px 8px 8px -8px rgba(0, 0, 0, 0.3);
        -moz-box-shadow: 0px 8px 8px -8px rgba(0, 0, 0, 0.3);
        box-shadow: 0px 8px 8px -8px rgba(0, 0, 0, 0.3);
        min-width: 100%;
    }

    .header_content {
        margin: 0;
    }

    .header_top {
        display: none;
    }

    .logo {
        margin: 0;
    }

    /******************Gnavi********************************/

    #gnavi {
        display: none;
        position: fixed;
        top: 65px;
        left: 0;
        width: 100%;
        height: calc(100% - 65px);
        background: #e3e3e3;
        overflow-y: auto;
    }

    .gnavi_sp {
        display: block;
    }

    .gnavi_pc {
        display: none;
    }

    .gnavi_sp > li {
        border-bottom: 1px solid #ccc;
        text-align: center;
    }

    .gnavi_sp > li:first-child {
        border-top: 1px solid #ccc;
    }

    .gnavi_sp > li a,
    .gnavi_sp > li span {
        display: block;
        width: 100%;
        padding: 10px;
        font-weight: 500;
    }

    .gnavi_sp > li:last-child span {
        padding: 0;
    }

    .gnavi_sp > li.over {
        position: relative;
    }

    .gnavi_sp .submenu {
        display: none;
        background: #fff;
    }

    .gnavi_sp .submenu > li {
        border-bottom: 1px solid #ccc;
        text-align: center;
    }

    .gnavi_sp .submenu > li:first-child {
        border-top: 1px solid #ccc;
    }

    .gnavi_sp .submenu > li:last-child {
        border-bottom: none;
    }

    .gnavi_sp > li.over:after {
        display: block;
        position: absolute;
        content: '';
        padding: 3px;
        border-right: 2px solid #b12433;
        border-bottom: 2px solid #b12433;
        border-top: 0 solid transparent;
        border-left: 0 solid transparent;
        transform: rotate(45deg);
        top: 20px;
        right: 20px;
        transition: all 0.5s ease;
        width: 0;
        height: 0;
        background: transparent;
    }

    .gnavi_sp > li.over.active:after {
        transform: rotate(-135deg);
    }

    .icon_menu {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        background: #b12433;
        color: #fff;
        width: 65px;
        height: 65px;
        position: absolute;
        top: 0;
        right: 0;
    }

    .icon_menu > span {
        display: block;
        font-size: 11px;
        letter-spacing: 1px;
        margin-top: -16px;
    }

    .icon_menu_item {
        display: inline-block;
        width: 40px;
        z-index: 90;
        overflow: hidden;
        position: relative;
        text-align: center;
        height: 34px;
        margin-top: 12px;
    }

    .icon_menu_item span {
        display: block;
        background: #fff;
        width: 85%;
        height: 3px;
        position: relative;
        margin: 0 auto 22px;
    }

    .icon_menu_item span:after,
    .icon_menu_item span:before {
        content: "";
        left: 0;
        right: 0;
        position: absolute;
        height: 3px;
        width: 100%;
        background: #fff;
        -webkit-transition: all ease 0.3s;
        -moz-transition: all ease 0.3s;
        -ms-transition: all ease 0.3s;
        transition: all ease 0.3s;
    }

    .icon_menu_item.active span:after {
        transform: rotate(405deg);
        bottom: -8px
    }

    .icon_menu_item.active span:before {
        transform: rotate(-45deg);
        top: 8px
    }

    .icon_menu_item.active span {
        background: transparent;
        margin-top: 5px
    }

    .icon_menu_item span:after {
        bottom: -20px;
    }

    .icon_menu_item span:before {
        top: 10px;
    }

    #close {
        display: block;
        background: #FF0302;
        color: #fff;
        font-weight: bold;
        text-align: center;
        cursor: pointer;
        font-size: 16px;
        padding: 15px;
    }

    #mainvisual {
        margin-top: 65px;
        display: block;
    }

    .mainvisual_slider {
        width: 100%;

    }

    .mainvisual_item {
        height: 380px;
    }

    .mainvisual_content {
        display: block;
        height: auto;
        width: calc(100% - 40px);
        margin-left: auto;
        margin-right: 0;
        padding: 25px;
        margin-top: -100px;
        position: relative;
        z-index: 2;
        max-width: 400px;
    }

    .mainvisual_content h2 {
        font-size: 30px;
        line-height: 1.4;
    }

    .mainvisual_content .txt01,
    .mainvisual_content .txt03 {
        font-size: 24px;
    }

    .mainvisual_content .txt02 {
        font-size: 20px;
    }

    .mainvisual_content .txt01 {
        background-size: 115px 2px;
    }

    .mainvisual_content.main_title {
        height: auto;
    }

    .mainvisual_contact.pc {
        display: none!important;
    }

    .mainvisual_contact_sp {
        cursor: pointer;
        position: relative;
        z-index: 5;
        animation: remove-fixed 0.3s linear;
        width: 100%;
        margin: 20px auto 0;
        transition: all 0.5s ease;
        background: #fff;
        font-size: 10px;
        font-weight: 700;
        padding: 8px 10px;
        text-align: center;
        transition: transform 0.5s;
        display: inline-block;
        color: #fff;
    }
    .mainvisual_contact_sp img {
        width: 100%;
    }

    .mainvisual_contact_sp .ttl {
        background-color: #b12433;
        height: auto;
        padding: 8px 10px 10px;
        border-radius: 5px;
        font-size: 13px;
        margin-bottom: 0;
        color: #fff;
    }
    


    .box01 {
        padding: 60px 0 40px 0;
        position: relative;
        z-index: 1;
    }

    .box01_01 {
        display: block;
    }

    .box01_01 > p {
        max-width: 100%;
        padding: 20px 3%;
    }

    .box01_02_item {
        margin-top: 0;
        width: 100%;
        margin-bottom: 20px;
        max-width: 450px;
        padding: 25px 25px 65px 25px;
    }

    .box01_02_item .img img {
        width: 100%;
    }

    .box01_02 {
        flex-wrap: wrap;
        justify-content: center;
        padding-left: 3%;
        padding-right: 3%;
    }

    .box01_02_item h5 {
        font-size: 20px;
        margin-bottom: 5px;
        padding: 0 20px;
    }

    .box01_02_item > span {
        font-size: 11px;
        padding: 0px 20px;
        margin-bottom: 12px;
    }

    .box01_02_item p.img {
        margin-bottom: 14px;
    }

    .box01_02_item p:not(.img) {
        padding: 0 20px;
        line-height: 1.8;
    }

    .box01_02_item:first-child p:not(.img) {
        padding: 0 20px;
    }

    .box01_02_item .c-btn02 {
        bottom: 25px;
    }

    .box01:after {
        display: none;
    }

    .box02 {
        padding: 0 0 25px 0;
    }

    .box02_01 {
        flex-wrap: wrap;
    }

    .box02_01 > p {
        max-width: 100%;
        padding: 20px 3%;
    }

    .box02_02_item .container {
        flex-wrap: wrap;
        padding: 8px 0 0 0;
    }

    .box02_02_title {
        height: 150px;
        padding: 50px 0;
        margin-top: 0;
        margin-bottom: 265px;
    }

    .box02_02_title h4 {
        font-size: 16px;
        background: #fff;
        text-align: left;
    }

    .box02_02_item2 .box02_02_title h4 {
        line-height: 1.5;
    }

    .box02_02_item2 .box02_02_title h4 span {
        font-size: 20px;
    }

    .box02_02_title h4 span {
        font-size: 24px;
    }

    .box02_02_title a {
        font-size: 13px;
        padding-bottom: 5px;
    }

    .box02_02_title::after {
        width: 150px;
    }

    .box02_02_item1 .container {
        background: url(../images/index_bg08.png) no-repeat;
        background-size: 500px;
        background-position: 55px 0px;
    }

    .box02_02_item {
        padding-left: 3%;
        padding-right: 3%;
        background: #fff;
        height: auto;
        margin-bottom: 20px;
    }

    .box02_02_left,
    .box02_02_right {
        width: 100%;
    }

    .box02_02_item1 .box02_02_left .btn1,
    .box02_02_item1 .box02_02_left .btn2,
    .box02_02_item1 .box02_02_left .btn3,
    .box02_02_item1 .box02_02_right .btn1,
    .box02_02_item1 .box02_02_right .c-btn03,
    .box02_02_item2 .box02_02_left .c-btn03,
    .box02_02_right .btn2,
    .box02_02_right .btn1 {
        margin: 0 auto;
        margin-bottom: 15px;
        width: calc(100% - 20px);
    }

    .box02_02_item2 .box02_02_left {
        justify-content: flex-start;
    }

    .box02_02_item2 .container {
        background-size: 325px;
        background-position: calc(100% - 10px) 0px;
    }

    .box02_02_item2 .box02_02_title h4 {
        margin-bottom: 5px;
        letter-spacing: 0;
    }

    .box02_02_title h4 {
        letter-spacing: 0;
    }

    .box02_02_item2 .box02_02_right {
        padding: 0 0px;
    }

    .box02_02_item2 .box02_02_title {
        margin-bottom: 246px;
    }


    .box03 {
        background: none;
        padding: 0 0 10px 0;
    }

    .box03_01 {
        display: block;
        top: 0;
    }

    .box03_01 > p {
        padding: 20px 3%;
    }

    .box03_02 {
        margin-top: 0;
    }

    .box03_02_item {
        margin-bottom: 30px;
        flex-wrap: wrap;
    }

    .box03_02_img {
        width: 100%;
    }

    .box03_02_content,
    .box03_02_item:nth-child(odd) .box03_02_content,
    .box03_02_item .box03_02_content {
        width: 90%;
        padding: 20px 20px 80px 20px;
        margin: 0 auto;
        margin-top: -30px;
    }

    .box03_02_content > span {
        font-size: 32px;
        top: 23px;
        left: 20px;
    }

    .box03_02_content h4 {
        font-size: 20px;
        display: inline-block;
        margin-bottom: 20px;
        padding-left: 40px;
        line-height: 1.4;
    }

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

    .box03_02_content ul li > span.label-item {
        padding: 5px 5px 7px 5px;
        width: 40px;
        top: 2px;
    }

    .box03_02_content ul.label li {
        padding-left: 48px;
    }

    .box03_02_content .c-btn02 {
        bottom: 25px;
        right: 25px;
    }

    .box04 {
        padding: 35px 0 10px 0;
    }

    .box04 .container {
        flex-wrap: wrap;
        padding-left: 3%;
        padding-right: 3%;
    }

    .box04_item {
        width: 100%;
    }

    .box04_item {
        padding: 30px 20px 35px 20px;
        margin-bottom: 30px;
    }

    .box04_item h3 {
        font-size: 20px;
        padding-left: 16px;
        background-size: 4px 100%;
        line-height: 1.25;
        margin-bottom: 30px;
        letter-spacing: 0px;
    }

    .box04_item h3 span {
        font-size: 14px;
        top: -2px;
        margin-left: 10px;
    }

    .box04_item:last-child h3 {
        padding-left: 12px;
        margin-left: 0;
    }

    .box04_item:last-child h3 span {
        margin-left: 10px;
    }

    .list_post dl {
        padding: 15px 0 15px 0;
    }

    .list_post dt,
    .list_post dd {
        font-size: 14px;
    }

    .list_post {
        max-height: 460px;
        margin-bottom: 25px;
    }

    .list_post dt .date {
        position: relative;
        top: 2px;
    }

    .list_post dd a {
        line-height: 2em;
    }

    .box04 .c-btn02 a {
        width: 260px;
        padding: 10px 35px 10px 35px;
    }

    .box04_item_double_row {
        display: block;
    }

    /*******************************************************/
    /******************Footer********************************/
    #footer {
        padding: 0;
        margin-bottom: 55px
    }

    .f_box01 {
        width: 100%;
    }

    .f_box02,
    .f_box03,
    .f_box04 {
        display: none;
    }

    .f_box01 .f_logo {
        display: none;
    }

    .copyright {
        font-size: 10px;
        position: relative;
        display: block;
        text-align: center;
        padding: 14px 14px 13px 0;
    }

    #totop {
        bottom: 60px;
        right: 10px
    }

    #totop a {
        height: 35px;
        width: 35px;
    }

    /*******************************************************/
    /******************Under********************************/
    /*******************************************************/
    .under #content {
        padding: 20px 3%;
        width: 100%
    }

    .under .container {
        padding: 0 3%;
    }

    .under #main {
        width: 100%
    }

    .image_r,
    .image_l {
        text-align: center;
        margin: 0 auto 22px;
        float: none
    }

    .under .section,
    .under section {
        margin-bottom: 35px
    }

    .under #mainvisual {
        height: 70vw;
        background: url(../images/under_bg_sp.jpg) top right no-repeat;
        background-size: cover;
    }

    .page-id-51 #mainvisual,
    .page-id-57 #mainvisual {
        background: url(../images/contact_bg_sp.jpg) center no-repeat;
        background-size: cover;
    }

    .problem_bg #mainvisual {
        background: url(../images/problem_bg_sp.jpg) center no-repeat;
        background-size: cover;
    }

    .service_bg #mainvisual {
        background: url(../images/service_bg.jpg) top left no-repeat;
        background-size: cover;
    }

    .yoshin_bg #mainvisual {
        background: url(../images/yoshin_bg_sp.jpg) top left no-repeat;
        background-size: cover;
    }

    .about_bg #mainvisual {
        background: url(../images/about_bg_sp.jpg) top left no-repeat;
        background-size: cover;
    }

    .information_bg #mainvisual {
        background: url(../images/information_bg_sp.jpg) top left no-repeat;
        background-size: cover;
    }



    .under #mainvisual .container {
        width: 80%;
    }

    .under #mainvisual h2 {
        text-align: center;
        font-size: 22px;
        text-shadow: 2px 2px 8px #fff, 2px 2px 8px #fff, 2px 2px 8px #fff, 2px 2px 8px #fff, 2px 2px 8px #fff, 2px 2px 8px #fff, 2px 2px 8px #fff, 2px 2px 8px #fff, 2px 2px 8px #fff;
    }

    .under #mainvisual h2 span {
        text-shadow: none;
    }

    .topic_path_bx {
        margin-bottom: 25px;
        padding: 10px 0;
    }

    .under .box04 {
        margin-top: -25px;
    }

    .under .box04 .list_post {
        height: auto;
    }

    .under_tbl th:after {
        display: none;
    }

    .under h3 {
        font-size: 20px;
    }

    .under h4 {
        font-size: 17px;
    }

    .ttl_lg {
        font-size: 20px;
    }

    .ttl_sm {
        font-size: 17px;
    }

    .under_list {
        margin: 0 0 0 10px;
    }

    .under_btn_ls {
        justify-content: center;
    }

    .under_list li {
        padding: 0 0 0 20px;
    }

    .under_btn_ls li:first-child {
        margin: 0 0 10px 0;
    }

    .under_list li:before {
        top: 9px;
        width: 12px;
        height: 12px;
    }

    .under_bnr {
        width: 100%;
    }

    .under_bnr:nth-child(2n+1) {
        margin-right: 0;
    }

    .under_bnr a {
        padding: 25px 10px;
        box-shadow: inset 640px 0 0 0 rgba(255, 248, 241, 0.5);
        font-size: 16px;
    }

    .anchor_link li {
        width: 100%;
    }

    .anchor_link li:not(:last-child) {
        margin-right: 0;
    }

    .anchor_link .under_btn {
        width: 100%;
        text-align: center;
    }

    .under_frame {
        padding: 20px;
    }

    .video {
        height: 300px;
    }

    .under_tbl th,
    .under_tbl td {
        padding: 10px;
    }

    .under_number span {
        left: 5px;
        width: 30px;
        height: 30px;
        font-size: 16px;
    }

    .under_number dt,
    .under_number dd {
        padding: 10px 10px 10px 40px;
    }

    .problem .under_btn_ls {
        justify-content: flex-start;
    }

    .problem h4 {
        padding: 0 0 0 30px;
    }

    .problem h4:before {
        width: 20px;
        height: 30px;
    }

    /***********diep*********/
    .anchor_link li:nth-child(n) {
        width: 100%;
        margin: 0 0 20px 0
    }

    .anchor_link li:last-child {
        margin-bottom: 0
    }

    .under_frm {
        padding: 20px
    }

    .map_con iframe {
        height: 290px
    }

    .btn_center [class*="u_button"] {
        min-width: 100%
    }

    .btn_right,
    .btn_left {
        text-align: center;
    }

    .sec_img {
        display: flex;
        flex-flow: wrap
    }

    .sec_img [class *='image_'] {
        order: 1;
        width: 100%;
    }

    .sec_img h4 {
        order: 0;
        width: 100%;
    }

    .sec_img .txt {
        order: 4
    }

    .under_list li:nth-child(n) {
        display: block;
        width: 100%
    }

    p.strong:before {
        top: 10px;
    }

    /******************under********************************/
    /*******************************************************/
    .blog_content {
        margin-bottom: 25px;
    }

    .blog_item {
        padding: 10px;
        flex-wrap: wrap;
    }

    .blog_date {
        display: block;
        margin-bottom: 7px;
        padding: 2px 5px;
        font-size: 13px;
    }

    .blog_title {
        display: block;
        width: 100%;
        font-size: 14px;
    }

    .wp-pagenavi {
        margin-bottom: 25px;
    }

    .wp-pagenavi span,
    .wp-pagenavi a {
        margin: 0 2px;
        padding: 6px 12px 8px;
        font-size: 14px;
    }

    .under_contact li {
        width: 265px;
        margin: 7px !important;
    }

    .under_contact li:first-child {
        margin: 0 0 20px 0;
    }

    .under_contact p:first-child {
        padding: 5px 15px;
        font-size: 20px;
    }

    .under_contact p span:nth-child(1) {
        padding: 2px 4px 3px 4px;
        font-size: 12px;
    }

    .under_contact p span:nth-child(2),
    .under_contact p a:nth-child(2) {
        font-size: 20px;
    }
    
    .wp_form {
        margin-bottom: 30px;
    }

    .wp_form .under_tbl th,
    .wp_form .under_tbl td {
        display: block;
        width: 100%;
    }

    .wp_form .under_tbl td {
        padding: 20px;
        border: none;
    }

    .wp_form tr:last-child td {
        border-bottom: 1px solid #333;
    }

    .wp_form tr:not(:last-child) input,
    .wp_form textarea {
        width: 100%;
    }

    .blog_next_prev {
        margin-bottom: 50px;
    }


    .wp_form tr:last-child .horizontal-item label {
        padding-left: 22px;
        position: relative;
        display: block;
    }

    .wp_form tr:last-child .horizontal-item label input {
        position: absolute;
        left: 0;
        top: 8px;
    }

    .utit_ico02 {
        padding-left: 46px;
    }

    [class*="utit_ico0"]:before {
        top: -10px
    }

    .utit_ico02:before {
        top: 0;
        width: 76px;
        height: 45px;
    }

    .utit_ico03 {
        padding-left: 66px
    }

    .utit_ico03:before {
        width: 74px;
        height: 64px;
    }

    .br {
        padding-left: 0;
        display: block
    }

    .button_fix {
        position: fixed;
        bottom: 0;
        left: 0;
        width: 100%;
        display: flex;
        z-index: 9;
				gap: 1px;
				background: #fff;
    }

    .button_fix a {
        width: 100%;
        display: flex;
        padding: 15px 10px;
        align-items: center;
        justify-content: center;
        color: #fff;
        font-weight: 500;
        font-size: 16px;
				text-align: center;
				line-height: 1.45;
    }
		
		.button_fix_btn01 {
			background: #2378b0;
		}
		
		.button_fix_btn02 {
			background: #B12433;
		}

    .button_fix a:first-child span {
        background: url(../images/icon_document_white.svg) no-repeat 0 55%;
        padding-left: 35px;
        display: inline-block;
        background-size: 22px;
    }

    .button_fix a:nth-child(2) span {
        background: url(../images/icon_mail_white.svg) no-repeat 0 55%;
        padding-left: 35px;
        display: inline-block;
        background-size: 22px;
    }

    #footer .grp_menu {
        display: none
    }

    .f_logo {
        margin: 30px auto 0
    }

    .title-icon-1 {
        padding-left: 33px;
        background: url(../images/title-icon-1.png) left top 1px / 25px no-repeat;
    }

    .title-icon-2 {
        padding-left: 38px !important;
        background-size: 20px !important;
        background-position: left 8px top 9px !important;
        padding-right: 10px !important;
    }

    .title-icon-2.icon-2 {
        background-position: left 8px top 9px !important;
    }
    
    .sec_yoshin .list_st li a{
        padding: 10px 12px;
    }
    
    .sec_yoshin .list_st p:first-child {
        width: 50%;
    }

    .contact .flex-content .col-left {
        width: 100%;
        margin-right: 0;
    }

    .contact .flex-content .mwform-checkbox-field {
        display: block;
        margin-left: 0;
    }

    .contact .flex-content .mwform-checkbox-field label {
        display: flex;
        align-items: center;
    }

    .contact .flex-content .mwform-checkbox-field label input {
        width: auto;
    }

    .note_form {
        padding: 20px;
    }
}

@media only screen and (max-width:525px) {
    .box02_02_item1 .container {
        background: url(../images/index_bg08.png) no-repeat;
        background-size: 360px;
        background-position: 55px 0px;
    }

    .box02_02_title {
        margin-bottom: 148px;
    }

    .box02_02_item2 .container {
        background-size: 220px;
        background-position: calc(100% - 10px) 0px;
    }

    .box02_02_item2 .box02_02_title {
        margin-bottom: 115px;
    }
}

@media only screen and (max-width:414px) {
    .c-sp {
        display: block;
    }

    .c-pc {
        display: none;
    }

    .gnavi_sp > li a,
    .gnavi_sp > li span {
        font-size: 13px;
    }

    .under_btn::after {
        right: 10px;
    }

    .under_btn {
        padding: 10px 32px 10px 10px;
        font-size: 14px;
    }

    [class*="fnt_st_"] {
        font-size: 17px
    }
    
    .button_fix a {
        font-size: 13px;
    }
}

@media only screen and (max-width:375px) {
    .mainvisual_content {
        padding: 20px;
    }

    .box02_02_item1 .container {
        background: url(../images/index_bg08.png) no-repeat;
        background-size: 265px;
        background-position: 55px 0px;
    }

    .box02_02_item2 .container {
        background-size: 190px;
        background-position: calc(100% + 45px) 0px;
    }

    .box02_02_title::after {
        width: 134px;
    }

    .box02_02_title {
        height: 134px;
        padding: 45px 0;
        margin-bottom: 83px;
    }

    .box02_02_title h4 {
        margin-left: 0;
    }

    .box02_02_title h4 span {
        font-size: 20px;
    }

    .box02_02_item2 .box02_02_title {
        padding: 40px 0;
    }

    .box02_02_item2 .box02_02_title {
        margin-bottom: 94px;
    }

    .box02_02_item .c-btn03 {
        width: 100% !important;
    }

    .box03_02_content,
    .box03_02_item:nth-child(odd) .box03_02_content,
    .box03_02_item .box03_02_content {
        width: 94%;
        padding: 15px 15px 80px 15px;
    }

    .box03_02_content > span {
        top: 19px;
    }

    .box03_02_content ul li {
        font-size: 12px;
    }

    .box03_02_content ul li > span.label-item {
        top: 1px;
    }
}


.text_try {
    text-align: center;
}


@media screen and (max-width: 640px) {
    .text_try {
      text-align: left;/* 640px�ȉ����ƍ��񂹂ɂȂ� */
    }
    }

/* 20210210�@�g�[�V���[�ǋL���@*/

.br_try {
  display: inline; /* �p�\�R�����́Abr�^�O��\�������s���� */
}

@media screen and (max-width: 640px) {
    .br_try { /* 640px�ȉ��̂Ƃ�br�^�O�\�����Ȃ������s���Ȃ� */
        display: none; }
    }
