.sp440, .sp640, .sp375, .sp390, .sp425 {
    display: none
}
@media screen and (min-width: 1801px) {
    .ft_bnr {
        padding-right: 90px;
    }
    .contact_note {
        position: relative;
        left: 0;
    }
}
@media screen and (max-width: 1801px) {
    .tb1800 {
        display: none !important;
    }
}
@media screen and (min-width: 751px) {
    .sp {
        display: none !important
    }
    /* NAV */
    .h_box {
        min-width: calc(var(--container) + 30px);
    }
    .hamburger {
        display: none;
    }
    nav {
        margin-left: auto;
        width: auto;
        margin-right: 62px;
    }
    nav .inner {
        width: auto;
        padding: 0;
    }
    .nav_list {
        display: flex;
        justify-content: space-between;
        width: 960px;
    }
    .nav_list > li > a {
        display: flex;
        align-items: center;
        position: relative;
        font-weight: 700;
        padding: 0px;
        height: 60px;
        font-size: 20px;
        color: #000;
    }
    /* CUSTOM */
    .find_a, .find_out {
        cursor: pointer;
    }
    /* HOVER */
    .nav_list > li:hover > a {
        color: var(--scolor);
        text-decoration: none;
    }
    .parent:not(:hover) .sub {
        display: none;
    }
    .parent:hover .sub {
        transform: translate(0, 0);
    }
    .sub a:hover {
        background-color: var(--scolor);
        text-decoration: none;
    }
    .sec_con_btn a:hover, .link_pdf:hover, .btn_contact:hover, .back-btn:hover, .site_top a:hover,.sec05_slide_sub:hover {
        opacity: 0.7;
    }
    .h_contact_mail a:hover {
        background: #000;
    }
    .sec_con_btn a:hover, .link_pdf:hover,.to_top:hover {
        opacity: 0.7;
    }
    .btn a:hover {
        background: #fff;
        color: #000;
    }
    .sec08_btn a:hover {
        background: url("../images/arrow_sm.svg")var(--scolor) no-repeat right 20px center
    }
    .sec09_info dl dd a:hover, .sec07_qa a:hover, .pink_tt a:hover {
        text-decoration: none;
    }
    .h_left {
        flex-shrink: 0;
        padding-top: 2px;
    }
    .sec07_qa dl dd {
        padding-bottom: 15px;
        align-items: flex-start;
    }
    .sec07_qa .icon_a {
        top: -6px;
        position: relative;
    }
    .sec07_qa dl.sub02 {
        margin-bottom: 44px;
    }
    .sec07_qa dl.sub03 {
        margin-bottom: 44px;
    }
    .sec07_qa dl.sub03 dt {
        margin-bottom: 25px;
    }
    .sec07_qa dl.sub04 {
        margin-bottom: 44px;
    }
    .sec07_qa dl.sub04 dt {
        margin-bottom: 25px;
    }
    .sec07_qa dl.sub05 {
        margin-bottom: 44px;
    }
    .sec07_qa dl.sub05 dt {
        margin-bottom: 25px;
    }
    .sec07_qa dl.sub06 {
        margin-bottom: 44px;
    }
    .sec07_qa dl.sub07 dt {
        margin-bottom: 25px;
    }
    .sec07_qa dl.line2 dd {
        min-height: 91px;
    }
    .sec01_list02 li.sub07 .icon {
        left: 3px;
    }
    .sec01_list02 li.sub03 .icon {
        width: 11px;
        left: -4px;
    }
    .sec01_list02 li.sub03 .icon:before {
        right: -23px;
    }
    .sec01_list02 li.sub04 .icon {
        width: 10px;
        left: -1px;
    }
    .sec01_list02 li.sub04 .icon:before, .sec01_list02 li.sub07 .icon:before {
        right: -25px;
    }
    .sec01_list02 li.sub05 .icon:before {
        right: -27px;
    }
    .sec01_list02 li.sub07 .icon, .sec01_list02 li.sub08 .icon, .sec01_list02 li.sub06 .icon, .sec01_list02 li.sub05 .icon {
        width: 11px;
    }
    .sec01_list02 li.sub08 .icon:before, .sec01_list02 li.sub06 .icon:before {
        right: -25px;
    }
    .tb01 tr td + td {
        padding-left: 27px;
        padding-right: 20px;
    }
    .tb01 tr td + td + td {
        padding-left: 32px;
    }
    .sec01_list02 li.sub06 .icon {
        left: 3px;
    }
    .mv_group .tt .lg:first-child-line {
        letter-spacing: -0.08em;
    }
    .mv_group .tt .lg .let.xs {
        font-size: 40px;
    }

}
@media screen and (min-width: 751px) and (max-width: 1800px) {
    .nav_list {
        width: 100%;
    }
    .nav_list li:not(:last-child) {
        margin-right: 20px;
    }
    nav {
        margin: 0 30px;
    }
    .h_box {
        width: calc(100% - 30px);
        min-width: auto;
    }
    .h_inner {
        padding: 0 30px;
    }
    .mv:after {
        background-size: 820px auto;
        width: 820px;
        top: -55px;
    }
    .mv_txt {
        height: 620px;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: center;
        padding: 70px 0 50px 50px;
    }
    .mv_tt01 {
        font-size: 30px;
    }
    .mv_txt h2 {
        font-size: 50px;
        margin-bottom: 0px;
        line-height: 1.2;
        margin-left: 0;
    }
    .mv_txt h2 span {
        font-size: 53px;
    }
    .mv_logo img {
        width: 650px;
    }
    .mv:after {
        background-size: 820px auto;
        width: 820px;
        top: -55px;
    }
    .mv_img {
        right: 40px;
        top: calc(50% - 166px);
        width: 500px;
    }
    .mv_group .img {
        width: 315px;
    }
    .mv_group .tt .sm {
        font-size: 22px;
    }
    .mv_group .tt .lg {
        font-size: 40px;
    }
    .mv_label {
        margin-bottom: 5px;
        margin-left: 0;
    }
    .mv_label li {
        height: 46px;
        font-size: 26px;
        width: 180px;
    }
    .mv_tt_slider {
        top: 603px;
    }
    .mv_img_slider {
        top: 725px;
    }
    .mv {
        height: 638px;
    }
    .mv_txt:after {
        height: 552px;
        right: 0;
        bottom: 0;
        background-size: 600px auto;
        width: 600px;
    }
    .mv_logo {
        margin-bottom: 50px;
    }
    .sec01_list {
        width: 1540px;
    }
    .sec01_list .sub03 {
        right: 215px;
    }
    .sec01_list .sub02 {
        left: 215px;
    }
    .sec01_list .sub04 {
        right: 14px;
    }
    .sec01_list02 li {
        padding-left: 50px;
    }
    .sec01_item_r {
        top: -110px;
    }
    .sec01 {
        margin-bottom: 0;
    }
    .sec02_list {
        padding: 47px 0px 15px 99px;
    }
    .sec02_list li:nth-child(2n) {
        margin-left: 0;
    }
    .sec02_slide {
        width: 100%;
    }
    .sec02_item_r {
        max-width: 1300px;
    }
    .sec02_tt02 {
        width: 460px;
        padding-left: 25px;
    }
    .sec03_item {
        padding: 0 15px;
        justify-content: center;
    }
    .sec03_list li {
        font-size: 18px;
    }
    .sec03_item_l {
        width: 900px;
    }
    .sec03_group {
        right: -10px;
    }
    .sec09 .inner {
        padding: 0 50px;
    }
    .sec09_item {
        width: calc(100% - 100px);
    }
    .to_top {
        width: 50px;
        height: 50px;
    }
    .sec09_item_r {
        padding: 40px 30px 30px 30px;
    }
 
    /*    .g-recaptcha {
        left: calc(50% - 200px);
    }*/
    .idx .box_contact input[type="text"], .idx .box_contact input[type="email"], .idx .box_contact select, .idx .box_contact textarea {
        width: 100%;
    }
    .must1 {
        width: 45px;
        font-size: 14px;
        top: 4px;
    }
    .idx .box_contact textarea::placeholder {
        font-size: 16px;
    }
}
@media screen and (min-width: 751px) and (max-width: 1550px) {
    .mv_img {
        width: 400px;
        top: calc(50% - 100px);
    }
    .nav_list > li > a {
        font-size: 16px;
    }
    .sec01_list {
        width: 1360px;
    }
    .sec01_list .sub02 {
        left: 80px;
    }
    .sec01_list .sub03 {
        right: 155px;
        background-size: 450px auto;
        width: 450px;
        padding-top: 32px;
        padding-left: 5px;
    }
    .sec01_list .sub01 {
        left: -25px;
        top: 200px;
    }
    .sec01_list .sub04 {
        right: -38px;
    }
    .sec01_ttl1 {
        font-size: 50px;
    }
    .sec01_ttl1 .blue {
        font-size: 62px;
    }
    .sec01 .sec_ttl_com01 .img img {
        width: 600px;
    }
    .sec01 .sec_ttl_com01 .tt {
        font-size: 52px;
    }
    .sec01 {
        padding-bottom: 50px;
    }
    .sec03_item_l {
        width: 760px;
    }
    .sec03_icon {
        font-size: 20px;
    }
    .sec03_icon.ic06, .sec03_icon.ic05 {
        background-size: 27px auto;
        background-position: left top 8px;
        padding-left: 40px;
    }
    .sec03_icon.ic05 {
        background-position: left top 10px;
    }
    .sec03_icon.ic04, .sec03_icon.ic02 {
        background-size: 24px auto;
        background-position: left top 7px;
        padding-left: 40px;
    }
    .sec03_icon.ic01 {
        background-position: left top 6px;
    }
    .sec03_icon.ic02 {
        background-position: left top 4px;
    }
    .sec03_img02 {
        position: relative;
        top: 50px
    }
    .sec08 .inner {
        width: 1230px;
    }
    .sec08_item li:not(:last-child) {
        margin-right: 50px;
    }
    .sec03_bb_list li {
        width: 414px;
    }
    .sec03_bb_list .sec03_bb_info .tt {
        font-size: 20px;
        padding-left: 15px;
    }
    .sec03_bb_list .sec03_bb_info {
        margin-left: -95px;
    }
}
@media screen and (min-width: 751px) and (max-width: 1440px) {
    .mv_txt {
        height: 520px;
        padding: 65px 0 50px 50px;
    }
    .mv_txt h2 {
        font-size: 40px;
    }
    .mv_logo img {
        width: 409px;
    }
    .logo_txt {
        font-size: 20px;
        right: 18px;
        bottom: -33px;
    }
    .mv_logo {
        margin-bottom: 45px;
    }
    .mv_group .img {
        width: 285px;
        margin-bottom: 4px;
    }
    .mv_tt02 {
        font-size: 18px;
    }
    .mv_group .tt .sm {
        font-size: 20px;
        margin-bottom: 0;
    }
    .mv_group .tt .lg {
        font-size: 32px;
    }
    .mv_label {
        margin-bottom: 5px;
    }
    .mv_label li {
        height: 44px;
        font-size: 22px;
        width: 141px;
    }
    .mv_tt_slider {
        top: 603px;
    }
    .mv_img_slider {
        top: 725px;
    }
    .mv {
        height: 638px;
    }
    .mv_txt:after {
        height: 547px;
        right: -65px;
        bottom: 0;
        background-size: 600px auto;
        width: 640px;
    }
    .mv_tt_slider {
        top: 475px;
    }
    .mv_img_slider {
        top: 585px;
    }
    .mv {
        height: 540px;
    }
    .mv:after {
        right: 150px;
        height: 535px;
    }
    .mv_img01 {
        bottom: -40px;
        width: 215px;
        height: 207px;
    }
    .sec03_bb_list li:not(:nth-child(3n)) {
        margin-right: 30px;
    }
    .sec01_item_r {
        top: -50px;
        right: -250px;
        width: calc(50% + 100px);
    }
   
}
@media screen and (min-width: 751px) and (max-width: 1435px) {
    .sec03_bb_list li {
        width: 380px;
    }
    .mv_img {
        top: calc(50% - 125px);
    }
    .mv:after {
        background-size: 780px auto;
        width: 780px;
    }
    nav {
        margin: 0 20px;
    }
    .h_contact_mail a {
        width: 240px;
        height: 60px;
        font-size: 18px;
    }
    .mv_tt01 {
        margin-bottom: 10px;
    }
    .sec01_list {
        width: 1230px;
    }
    .sec01_list .sub03 {
        right: 85px;
    }
    .sec01_ttl1 {
        font-size: 36px;
    }
    .sec01_ttl1 .blue {
        font-size: 46px;
    }
    .sec01_ttl1 .sm {
        font-size: 33px;
    }
    .sec02_list {
        padding: 47px 0px 15px 50px;
    }
    .sec02_list li {
        padding-left: 40px;
    }
    .sec02_item_r {
        max-width: 1200px;
    }
    .sec03_item_l {
        width: 625px;
    }
    .sec03_img02 {
        top: 100px;
    }
    .tb01 {
        width: 1200px;
    }
    .pink_tt {
        padding-left: 15px;
        max-width: 1235px;
    }
    .tb01 td.td01:before {
        height: 721px;
    }
    .tb01 th.bg02 {
        width: 230px;
        padding-left: 15px;
        font-size: 18px;
    }
    .tb01 td p {
        padding-left: 30px !important;
        background-size: 20px auto !important
    }
    .tb_ic03 {
        background-position: left center;
    }
    .tb01 th.bg01.w01 {
        width: 335px;
    }
    .tb01 td {
        font-size: 18px;
    }
    .tb_ic01.pl01, .tb_ic02.pl01, .tb_ic04, .tb_ic02.line02, .tb_ic02 {
        background-position: left 0px center;
    }
    .sec01_list .sub04 {
        width: 490px;
        height: 157px;
        right: -15px;
        top: 190px;
        padding-left: 62px;
        background-size: 490px auto;
        padding-top: 29px;
    }
    .sec01_list .sub01 {
        width: 480px;
        left: -5px;
        top: 210px;
        background-size: 480px auto;
        padding-top: 30px;
    }
    .sec01_list .sub02 {
        background-size: 450px auto;
        width: 450px;
        padding-top: 32px;
    }
    .sec01_item_l {
        margin-right: -400px;
        width: calc(50% + 400px);
    }
    .sec03_list li {
        font-size: 17px;
    }
    .sec09_info dl dt {
        width: 160px;
    }
    .sec09_item_r {
        padding: 40px 25px 30px 25px;
    }
    .contact_note {
        font-size: 15px;
    }
    .sec09_info dl dt {
        width: 155px;
    }
    /*======================================================*/
    .idx .box_contact table tr th {
        width: 230px;
        font-size: 20px;
    }
    .idx .box_contact textarea::placeholder {
        font-size: 15px;
    }
}
@media screen and (min-width: 751px) and (max-width: 1200px) {}
/* screen-min:750px */
@media screen and (max-width: 750px) {
    h1, h2, h3, h4, h5, h6, input, button, textarea, select, p, blockquote, th, td, pre, address, li, dt, dd {
        font-size: 14px;
    }
    img {
        max-width: 100%;
        height: auto;
    }
    #wrapper, header, main, footer, .inner {
        width: 100% !important;
        min-width: unset !important
    }
    .pc {
        display: none !important
    }
    body.is_nav {
        overflow: hidden;
    }
    body.mac nav {
        padding-bottom: 160px;
    }
    /* NAV */
    nav {
        display: block;
        position: fixed;
        top: 70px;
        left: 10px;
        width: calc(100% - 20px);
        height: calc(100vh - 80px);
        overflow: auto;
        z-index: 100;
        display: none;
        background: var(--mcolor);
        padding-bottom: 80px;
        border-radius: 0 0 10px 10px;
    }
    nav .inner {
        padding: 0;
    }
    .nav_list {
        flex-direction: column
    }
    .nav_list ul, .nav_list li {
        width: 100%
    }
    .nav_list a {
        display: block;
        padding: 13px 15px 12px;
        color: #fff;
        font-size: 16px;
        font-weight: 600;
        border-bottom: solid 1px #fff
    }
    .hamburger {
        position: absolute;
        right: 20px;
        bottom: 8px;
        font: inherit;
        display: block;
        overflow: visible;
        margin: 0;
        cursor: pointer;
        transition-timing-function: linear;
        transition-duration: .15s;
        transition-property: opacity, filter;
        text-transform: none;
        color: inherit;
        border: 0;
        z-index: 101
    }
    /*=====================================================
                          C U S T O M
    ======================================================*/
    /*============ HEADER ============*/
    .h_left {
        padding-left: 25px;
        width: calc(100% - 20px);
        height: 60px;
        background-color: #fff;
        border-radius: 999px;
        transition: border-radius 0.3s;
        box-shadow: 8px 8px 10px 0 rgba(0, 0, 0, 0.08)
    }
    h1 {
        width: 150px;
    }
    .h_inner {
        padding: 0;
        flex-direction: column;
    }
    .h_box {
        height: 60px;
        width: 100%;
        top: 10px;
        padding-top: 0px;
        background: none;
        border-radius: 0;
        box-shadow: none;
    }
    .is_scroll .h_box {
        padding-top: 0px;
    }
    .is_nav .h_box {
        top: 10px;
    }
    .is_nav .h_box .h_left {
        border-radius: 10px 10px 0 0;
    }
    .tb_scroll {
        overflow: scroll;
    }
    .tb_scroll:not(:last-child) {
        margin-bottom: 0px;
    }
    .tb_scroll table, .tb01 {
        width: 800px;
    }
    .tb_note {
        margin-bottom: 10px;
        color: #999;
        padding: 0 15px;
    }
    /*============ Main ============*/
    main {
        padding-top: 70px;
    }
    /* MAIN VISUAL */
    .mv {
        height: auto;
    }
    .mv_txt h2 {
        font-size: 4.8vw;
        line-height: 8vw;
        margin-bottom: 1vw;
        margin-left: 0;
    }
    .mv_txt h2 span {
        font-size: 7vw;
        margin-right: 0.2vw;
    }
    .mv_tt_slider, .mv_img_slider {
        position: relative;
        top: 0;
    }
    .mv_tt_slider {
        margin-bottom: 15px;
    }
    .mv_img_slider:before {
        position: absolute;
        content: "";
        background: var(--mcolor);
        height: 43px;
        bottom: 3px;
        left: 0;
        width: 100%;
    }
    .mv_txt {
        height: 86vw;
        position: relative;
        padding: 9.5vw 0 0;
    }
    .mv .inner:before {
        height: 10px;
    }
    .mv_img {
        right: 0;
        top: auto;
        bottom: 0;
        width: 65vw;
        left: 0;
        margin: 0 auto;
    }
    .mv_tt01 {
        font-size: 4.5vw;
        margin-bottom: 2vw;
        line-height: 5vw;
    }
    .mv_tt02 {
        font-size: 3vw;
        letter-spacing: 0;
        margin-bottom: 3vw;
        margin-left: 0;
    }
    .mv_logo {
        left: 0;
        width: 41vw;
        margin-bottom: 8vw;
    }
    .mv_group {
        flex-direction: column;
        align-items: flex-start;
    }
    .mv_group .tt {
        padding-bottom: 0;
    }
    .mv_img01 {
        bottom: -3vw;
        width: 20vw;
        height: 18vw;
        left: 5px;
    }
    .mv .logo_txt {
        font-size: 3vw;
        line-height: 4vw;
        right: 2vw;
        bottom: -4.5vw;
    }
    .mv_txt:after {
        background-size: 50vw auto;
        width: 40vw;
        height: 63vw;
        right: 0;
    }
    .mv:after {
        height: 84vw;
        right: -9vw;
        background-size: 75vw auto;
        width: 75vw;
        top: 0;
    }
    .mv:before {
        left: -65px;
        top: -140px;
        background-size: 1200px;
        width: 1200px;
    }
    .mv_tt_slider_sub, .mv_tt_slider_sub.sub03, .mv_tt_slider_sub.sub06, .mv_tt_slider_sub.sub01, .mv_tt_slider_sub.sub02 {
        width: auto;
        font-size: 20px;
        height: 46px;
        padding: 2px 15px 0;
    }
    .mv_tt_slider_sub:not(:last-child), .mv_img_slider_sub:not(:last-child) {
        margin-right: 15px;
    }
    .mv_img_slider_sub {
        width: 200px;
    }
    .mv_img {
        right: 40px;
        top: calc(50% - 166px);
        width: 500px;
    }
    .mv_group .img {
        width: 46vw;
        margin-right: 0;
        margin-bottom: 3vw;
    }
    .mv_group .tt .sm {
        font-size: 4vw;
        margin-bottom: 2vw;
        padding-left: 0;
        line-height: 4vw;
    }
    .mv_group .tt .lg {
        font-size: 6vw;
        line-height: 8vw;
    }
    .mv_label {
        margin-bottom: 4vw;
        margin-left: 0;
    }
    .mv_label li {
        height: 6vw;
        font-size: 3vw;
        width: 20vw;
        line-height: 7vw;
    }
    .mv_label li:not(:last-child) {
        margin-right: 1vw;
    }
    /* sec01 */
    .sec01 {
        margin-bottom: 50px;
        padding-top: 30px;
    }
    .sec01:before {
        width: 1200px;
        left: -210px;
        background-size: 1200px;
    }
    .sec01_en {
        margin-bottom: 40px;
    }
    .logo_txt_sm, .sec02 .logo_txt_sm {
        font-size: 12px;
    }
    .sec_con_tt .logo_txt_sm {
        font-size: 12px;
        right: 4px;
        bottom: -20px;
    }
    .sec01_ttl1 {
        font-size: 24px;
        margin-bottom: 30px;
        position: absolute;
        left: 0;
        right: 0;
        top: 190px;
    }
    .sec01_ttl1 .blue {
        font-size: 30px;
    }
    .sec01_ttl1 .sm {
        font-size: 20px;
    }
    .sec01_list {
        max-width: 580px;
        margin: 0 auto 10px;
        position: relative;
        top: 0;
    }
    .sec01_list .sub01 {
        width: 292px;
        height: 121px;
        padding-right: 0;
        background: url("../images/bb_w01_sp.svg") no-repeat;
        background-size: 292px auto;
        left: 0;
        padding-top: 50px;
        top: 192px;
    }
    .sec01_list .sub02 {
        width: 280px;
        height: 120px;
        padding-right: 0px;
        background-size: 280px auto;
        left: 0;
    }
    .sec01_list .sub03 {
        width: 277px;
        height: 125px;
        padding-right: 0px;
        background-size: 277px auto;
        right: 0;
    }
    .sec01_list .sub04 {
        width: 286px;
        height: 120px;
        background: url("../images/bb_w04_sp.svg") no-repeat;
        background-size: 286px auto;
        right: 0;
        padding-top: 47px;
        padding: 47px 6px 0 0px;
        top: 195px;
    }
    .sec01_list li p {
        font-size: 18px;
    }
    .sec_ttl_com01 .tt, .sec02 .sec_ttl_com01 .tt, .sec03 .sec_ttl_com01 .tt, .sec04 .sec_ttl_com01 .tt {
        font-size: 28px;
        bottom: 0;
        letter-spacing: 0;
        margin-top: 10px;
    }
    .sec01_list li {
        padding-top: 18px;
    }
    .sec01_list li:before {
        left: 15px;
        background-size: 16px auto;
        width: 16px;
        top: 0;
    }
    .sec01_list li.sub01:before {
        top: 31px;
    }
    .sec01_list li.sub04:before {
        top: 29px
    }
    .sec01_list li.sub04:before {
        left: 15px;
    }
    .sec01_txt p {
        font-size: 14px;
    }
    .sec01_txt p:not(:last-child) {
        margin-bottom: 25px;
    }
    .sec01_txt p .pink {
        font-size: 16px;
    }
    .sec01_item {
        flex-direction: column-reverse;
    }
    .sec01_item_r {
        width: 100%;
        top: 0;
        right: 0;
        max-width: 400px;
        margin: 25px auto 0;
    }
    .sec01_item_l {
        margin-right: 0;
        width: 100%;
        margin-top: 30px;
    }
    .sec01_list02 {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
    }
    .sec01_list02 li {
        padding: 7px 15px 7px 10px;
        font-size: 17px;
        line-height: 1.5;
        min-height: 60px;
        margin-bottom: 5px;
        height: auto;
    }
    .sec01_list02 li .pink {
        font-size: 21px;
    }
    .sec01_list02 li .icon {
        margin-right: 20px;
        letter-spacing: 0em;
        top: 0px;
        width: 30px !important;
        flex-shrink: 0;
        font-size: 20px;
    }
    .sec01_list02 li .icon:before {
        width: 1px;
        height: 45px;
        transform: rotate(18deg);
        right: -8px !important;
        bottom: calc(50% - 23px);
    }
    .sec02_content {
        padding-top: 60px;
    }
    .sec02_content:before {
        height: 1170px;
    }
    /* sec02 */
    .sec02 {
        padding-bottom: 20px;
    }
    .sec02 .sec_ttl_com01 .img {
        margin-bottom: 20px;
    }
    .sec02_slide {
        width: 100%;
    }
    .sec02_slide_sub {
        width: 205px;
    }
    .sec02_tt, .sec02_tt02 {
        width: 174px;
        height: 40px;
        padding-left: 10px;
        font-size: 17px;
    }
    .sec02_tt02 {
        width: 400px;
        font-size: 20px;
        top: -21px;
    }
    .sec02_slide_sub:not(:last-child) {
        margin-right: 15px;
    }
    .sec02_item {
        flex-direction: column;
    }
    .sec02_item_r {
        width: calc(100% - 30px);
        height: auto;
        padding-top: 20px;
        padding-bottom: 13px;
        max-width: 100%;
        margin: 0 auto;
    }
    .sec02_item_r:before {
        height: 60px;
        bottom: -59px;
    }
    .sec02_list li {
        font-size: 20px;
        padding-left: 26px;
        margin-bottom: 10px;
        background-size: 19px auto;
        background-position: left top 10px;
        line-height: 1.6;
        width: 100%;
    }
    .sec02_list li:nth-child(2n) {
        margin-left: 0px;
    }
    .sec02_list li span {
        font-size: 22px;
    }
    .sec02_list li .sm {
        font-size: 17px;
    }
    .sec02_list {
        padding: 20px 15px 0;
    }
    .sec_con_tt .ja {
        font-size: 22px;
        text-align: center;
    }
    .sec_con_txt p {
        font-size: 16px;
        text-align: center;
    }
    .sec_con_wrap {
        padding-top: 30px;
    }
    /* sec03 */
    .sec03 {
        border-top-width: 10px;
        padding-top: 40px;
        padding-bottom: 30px;
    }
    .sec03 .sec_ttl_com02 {
        margin-bottom: 15px;
    }
    .sec03_bg {
        font-size: 18px;
        width: 200px;
        height: 42px;
    }
    .sec03_bg.bg01 img {
        width: 100px;
    }
    .sec03_bg .logo_txt_sm {
        font-size: 10px;
    }
    .sec03_bg.bg02 {
        margin-bottom: 25px;
    }
    .sec03_txt_cen.mb01 {
        margin-bottom: 30px;
    }
    .sec03_img, .sec03_img02 {
        padding-left: 0;
        max-width: 500px;
        margin: 0 auto 35px;
    }
    .sec03_img02 {
        margin-bottom: 35px !important;
    }
    .sec03_item {
        padding: 0;
        margin-top: 30px;
        flex-direction: column;
    }
    .sec03_group {
        position: relative;
        right: 0;
        top: 0;
        margin-bottom: 25px;
    }
    .sec03_item_l {
        margin-right: 0;
    }
    .sec03_icon, .sec03_icon.ic03, .sec03_icon.ic04, .sec03_icon.ic05, .sec03_icon.ic06 {
        font-size: 18px;
        letter-spacing: 0em;
        margin-bottom: 8px;
        padding-left: 45px;
    }
    .sec03_icon.ic01 {
        padding-left: 30px;
        background-size: 24px auto;
        background-position: left top 7px;
    }
    .sec03_icon.ic02 {
        padding-left: 30px;
        background-size: 20px auto;
        background-position: left top 4px;
    }
    .sec03_icon.ic03 {
        padding-left: 30px;
        background-size: 25px auto;
        background-position: left top 8px;
    }
    .sec03_icon.ic04 {
        padding-left: 25px;
        background-size: 19px auto;
        background-position: left top 6px;
    }
    .sec03_icon.ic05 {
        padding-left: 27px;
        background-size: 22px auto;
        background-position: left top 7px;
    }
    .sec03_icon.ic06 {
        padding-left: 27px;
        background-size: 22px auto;
        background-position: left top 5px;
    }
    .sec03_list li {
        font-size: 16px;
    }
    .sec03_list li .num {
        font-size: 18px;
    }
    .sec03_list li:before {
        top: 10px;
    }
    .sec03_list {
        top: 0 !important;
        padding-left: 40px;
        margin-bottom: 20px !important;
    }
    .sec03_txt_cen span {
        font-size: 16px;
    }
    .sec03_frame {
        width: 100%;
        height: auto;
        padding: 35px 15px 52px;
        margin-top: 30px;
        border-width: 2px;
    }
    .sec03_frame_tt {
        width: 100%;
        height: auto;
        font-size: 22px;
        letter-spacing: 0em;
    }
    .sec03_frame_img {
        padding-left: 0;
        max-width: 400px;
        margin: 0 auto;
        padding: 0 15px;
    }
    .sec03_frame_txt {
        font-size: 16px;
        margin-bottom: 20px;
    }
    .sec03_frame_img:before {
        height: 260px;
        left: 0;
        bottom: -15px;
        z-index: -1;
        width: 100%;
    }
    .sec03_img_sp {
        max-width: 240px;
        margin: 0 auto 50px;
    }
    .sec03_ttl .img {
        margin-bottom: 20px;
    }
    .sec03_ttl .logo_txt_sm {
        font-size: 14px;
    }
    .sec03_tt {
        margin: 100px auto 2px;
        min-width: inherit;
        font-size: 19px;
        padding: 30px 7px 0;
    }
    .sec03_bb:before {
        height: 230px;
    }
    .sec03_tt span {
        font-size: 21px;
    }
    .sec03_bb_txt .lg {
        font-size: 21px;
    }
    .sec03_bb_txt .sm {
        font-size: 16px;
    }
    .sec03_bb_txt {
        margin-bottom: 25px;
        padding: 0 15px;
    }
    .sec03_bb_list li {
        width: 300px;
        height: 135px;
        margin-bottom: 15px;
    }
    .sec03_bb_list li .img img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    /* sec04 */
    .sec04 {
        border-top-width: 10px;
        padding-top: 50px;
        padding-bottom: 50px;
    }
    .sec04 .inner {
        padding: 0 15px;
    }
    .tb01 th.bg02, .tb01 tr:last-child th.bg02 {
        font-size: 16px;
        height: 60px;
        width: 140px !important;
        padding-left: 10px;
    }
    .tb01 tr th + td {
        border-right-color: #fff;
    }
    .tb01 td p {
        padding-left: 20px !important;
    }
    .tb_ic01, .tb_ic01.pl01, .tb_ic02.pl01 {
        background-position: left top 8px;
        background-size: 13px auto;
    }
    .tb_ic03.line02 {
        background-position: left top 9px;
    }
    .tb_ic01, .tb_ic01.pl01 {
        background-position: left center;
    }
    .tb_ic02, .tb_ic03.line02 {
        background-position: left top 8px;
        background-size: 12px auto;
    }
    .tb_ic03 {
        background-position: left top 9px;
        background-size: 12px auto;
    }
    .tb_ic04 {
        background-position: left center;
        background-size: 13px auto;
    }
    .tb01 td {
        font-size: 14px;
        padding-left: 10px;
        padding-right: 2px;
    }
    .tb_ic02.line02 {
        background-position: left 0px center;
    }
    .tb01 {
        margin-top: 10px;
        margin-bottom: 15px;
    }
    .tb01 td.td01 {
        width: 200px;
        padding-top: 11px;
    }
    .tb01 th.bg01.w01, .tb01 th.bg01 {
        width: 200px;
    }
    .tb01 td.td01:before {
        height: 494px;
        border-width: 2px;
        width: calc(100% + 3px);
    }
    .pink_tt {
        font-size: 15px;
        padding: 0 15px;
    }
    /* sec05 */
    .sec05_slide {
        margin-bottom: 50px;
    }
    .sec05 {
        padding-top: 50px;
        padding-bottom: 50px;
    }
    .sec05_ttl {
        font-size: 26px;
        margin-bottom: 30px;
    }
    .sec05_slide_sub {
        margin: 0 10px;
    }
    .sec05_slide_sub {
        width: 280px;
                padding-bottom: 35px;
        background-size: 24px auto;
        background-position: right 10px bottom 10px;
    }
    .sec05_tt {
        margin-bottom: 7px;
        padding: 10px 10px 0 15px;
    }
    .sec05_txt {
        padding-left: 15px;
        line-height: 2;
        padding-right: 10px;
    }
    .sec05_img .cate {
        min-width: 100px;
        height: 36px;
        line-height: 37px;
        font-size: 16px;
    }
    /* sec06 */
    .sec06_ttl {
        font-size: 26px;
        letter-spacing: 0em;
        margin-bottom: 30px;
    }
    .sec06_item {
        max-width: 100%;
        margin-bottom: 35px;
    }
    .sec06_item {
        justify-content: space-between;
        width: 100%;
        flex-wrap: wrap;
        max-width: 395px;
    }
    .sec06_item li:not(:last-child) {
        margin-right: 20px;
    }
    .sec06_item li:nth-child(2n) {
        margin-right: 0;
    }
    .sec06_item li {
        margin-bottom: 30px;
        margin-right: 20px;
        width: 180px;
        height: 180px;
    }
    .sec06_item li:nth-child(5) {
        margin: 0 auto;
    }
    .sec06_item li:not(:last-child):before {
        right: -26px;
        top: calc(50% - 12px);
        background-size: 16px auto;
    }
    .sec06_icon {
        height: 76px;
    }
    .sub03 .sec06_icon {
        height: 66px;
    }
    .sec06_tt {
        font-size: 17px;
    }
    .sub03 .sec06_icon {
        margin-bottom: 9px;
    }
    /* sec07 */
    .sec07 {
        padding-top: 35px;
        padding-bottom: 15px;
    }
    .sec07_ttl {
        font-size: 26px;
        margin-bottom: 25px;
    }
    .sec07_qa dl dt {
        height: auto;
        font-size: 18px;
        letter-spacing: 0em;
        min-height: 60px;
        padding: 5px 10px;
        line-height: 1.4;
    }
    .sec07_qa .icon_q, .sec07_qa .icon_a {
        width: 36px;
        height: 36px;
        font-size: 20px;
        margin-right: 12px;
    }
    .sec07_qa .icon_a {
        position: relative;
        top: 0;
        align-self: flex-start;
    }
    .sec07_qa dl dd {
        padding: 0 10px 20px;
        min-height: 48px;
        align-items: center;
    }
    .sec07_qa dl dd .txt p {
        line-height: 1.8;
    }
    /* sec08 */
    .sec08 {
        padding-top: 35px;
        padding-bottom: 55px;
    }
    .sec08_ttl {
        font-size: 26px;
        margin-bottom: 35px;
    }
    .sec09 {
        padding-top: 45px;
        padding-bottom: 45px;
    }
    .sec09_ttl {
        font-size: 26px;
        margin-bottom: 10px;
    }
    .sec09_item {
        width: 100%;
        margin: 30px auto 0;
        padding: 0 15px;
        flex-direction: column-reverse;
    }
    .sec09_item_l, .sec09_item_r {
        width: 100%;
    }
    .sec09_info dl dt, .sec09_info dl dd {
        font-size: 16px;
    }
    .sec09_info dl dt {
        padding-left: 0px;
        width: 125px;
        flex-shrink: 0;
    }
    .sec09_item_r {
        margin-left: 0;
        height: auto;
        padding: 20px 15px;
        margin-bottom: 40px;
        min-height: auto;
    }
    .sec09_info dl {
        padding: 10px 15px 10px 10px;
    }
    .map {
        height: 299px;
        margin-bottom: 40px;
    }
    .btn a {
        width: 280px;
        height: 60px;
        font-size: 18px;
    }
    /*============ FOOTER ============*/
    footer {
        margin-bottom: 50px;
    }
    address {
        padding: 15px 20px 15px;
        font-size: 15px;
    }
    .ft_bnr {
        width: 100%;
        max-width: 400px;
        margin: 0 auto;
        height: auto;
        padding: 20px 10px;
    }
    .sec_contact:before {
        height: 100%;
        background-size: cover;
        width: 100%;
        left: 0;
    }
    .sec_contact {
        height: auto;
        padding: 18px 0px 50px;
    }
    .sec_con_btn {
        width: 100%;
    }
    .sec_contact .inner {
        flex-direction: column;
    }
    .g_fmail {
        margin-left: 0;
        margin-top: 0;
        margin-bottom: 0px;
        justify-content: center;
        min-height: inherit;
    }
    /*    .g-recaptcha {
        left: 0;
        right: 0;
        margin: 0 auto;
        text-align: center;
        max-width: 305px;
        zoom: 0.8;
        bottom: 90px;
    }*/
    .g-recaptcha > div {}
    .sec_ttl_com01, .sec_ttl_com01.sec02_ttl, .sec_ttl_com01.sec03_ttl, .sec04 .sec_ttl_com01 {
        flex-direction: column;
        align-items: center;
        margin-bottom: 20px;
    }
    .sec_ttl_com01 img, .sec_con_tt .img {
        width: 240px !important;
    }
    .sec_con_tt {
        align-items: center;
        margin-bottom: 15px;
    }
    .sec_ttl_com02 {
        font-size: 22px;
        letter-spacing: 0em;
        margin-bottom: 25px;
        line-height: 1.4;
    }
    .sec_con_tt .img {
        margin-bottom: 25px;
        width: 210px !important;
    }
    .sec_con_btn a {
        width: 100%;
        height: 70px;
        font-size: 20px;
        padding-right: 0;
        padding: 0 15px;
        max-width: 400px;
        margin: 22px auto 0;
    }
    .sec_con_btn a span {
        padding-left: 40px;
        background-size: 27px auto;
    }
    /* TO TOP */
    .to_top {
        width: 50px;
        height: 50px;
        right: 6px;
        bottom: 54px;
    }
    .h_contact_mail_sp a {
        margin: 30px auto 0;
        width: 280px;
    }
    .sp_contact {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        height: 50px;
        position: fixed;
        left: 0;
        z-index: 99;
        bottom: -65px;
        transition: all 0.3s;
        background: var(--scolor);
    }
    .sp_contact.show {
        bottom: 0;
    }
    .h_contact_mail a {
        height: 60px;
        font-size: 18px;
    }
    .sp_contact .h_contact_mail a {
        background: none;
    }
    /*============ END 750 ============ */
    .idx .box_contact table tr {
        flex-direction: column;
    }
    .idx .box_contact table tr th {
        width: 100%;
        text-align: left !important;
        border: none;
        font-size: 18px;
        padding-right: 0;
        padding-bottom: 0;
    }
    .must1 {
        margin: 5px 0px 0px 5px;
        width: 50px;
        font-size: 13px;
        padding-bottom: 0px;
        height: 26px;
        position: absolute;
        right: 0;
    }
    .idx .box_contact select {
        background-size: 30px auto;
        background-position: right 6px center;
        font-size: 17px;
        padding-left: 15px;
    }
    .idx .box_contact input[type="text"], .idx .box_contact input[type="email"], .idx .box_contact select {
        height: 50px;
    }
    .idx .box_contact input[type="text"], .idx .box_contact input[type="email"], .idx .box_contact select, .idx .box_contact textarea {
        width: 100%;
    }
    .idx .box_contact table tr td {
        width: 100%;
    }
    .idx .wpcf7-list-item label {
        font-size: 16px;
    }
    .btn_contact {
        width: 250px;
    }
	.grecaptcha-badge {
	bottom: 160px!important;
}
}
@media screen and (min-width: 641px) and (max-width: 750px) {
    .sec08_item li:not(:last-child) {
        margin-right: 15px;
    }
    .sec08_item li {
        width: calc(33.333% - 10px);
        padding: 13px 10px 0;
    }
    .sec08_tt {
        font-size: 16px;
        margin-bottom: 20px;
    }
    .sec08_item li:before {
        width: 3px;
    }
    .sec08_btn a {
        margin-right: auto;
    }
    .sec03_bb_list li:not(:nth-child(3n)) {
        margin-right: 0px;
    }
    .sec03_bb_list li:not(:nth-child(2n)) {
        margin-right: 15px;
    }
    .sec03_bb_list li .img {
        width: 190px;
    }
    .sec03_bb_list .sec03_bb_info .tt {
        font-size: 18px;
        padding-left: 12px;
    }
}
@media screen and (min-width: 375px) and (max-width: 750px) {
    .sec06_item li:nth-child(2n):before {
        display: none;
    }
}
@media screen and (max-width: 640px) {
    .sp640 {
        display: block !important;
    }
    .sec01_list {
        max-width: 410px;
        height: 290px;
        margin-bottom: 30px;
    }
    .sec01_list .sub01 {
        background: url("../images/bb_w01_sp.png") no-repeat;
    }
    .sec01_list .sub02 {
        background: url("../images/bb_w02_sp.png") no-repeat left top;
    }
    .sec01_list .sub03 {
        background: url("../images/bb_w03_sp.png") no-repeat;
    }
    .sec01_list .sub04 {
        background: url("../images/bb_w04_sp.png") no-repeat;
    }
    .sec01_list .sub01 {
        height: 117px;
        background-size: 218px auto;
        width: 218px;
        left: -10px;
    }
    .sec01_list .sub02 {
        height: 114px;
        background-size: 211px auto;
        width: 211px;
        left: -10px;
    }
    .sec01_list .sub03 {
        height: 114px;
        background-size: 211px auto;
        width: 211px;
        right: -4px;
    }
    .sec01_list .sub04 {
        height: 114px;
        background-size: 214px auto;
        width: 214px;
        padding-top: 29px;
        right: -4px;
        top: 201px;
    }
    .sec01_list li p {
        font-size: 14px;
    }
    .sec01_list li {
        padding-top: 13px;
    }
    .sec01_list .sub01 {
        padding-top: 38px;
        padding-right: 5px;
    }
    .sec01_ttl1 {
        top: 174px;
    }
    .sec01_list li:before {
        left: 10px;
        background-size: 10px auto;
        width: 10px;
        top: 0px;
    }
    .sec01_list li.sub01:before {
        top: 23px;
    }
    .sec01_list li.sub04:before {
        top: 16px;
    }
    .sec03_frame_tt {
        font-size: 20px;
    }
    .sec08_item {
        flex-direction: column;
    }
    .sec08_tt {
        font-size: 18px;
        margin-bottom: 15px;
    }
    .sec08_item li:not(:last-child) {
        margin-right: 0;
        margin-bottom: 20px;
    }
    .sec08_item li {
        width: 100%;
        min-height: 160px;
        padding-left: 15px;
        padding-top: 13px;
    }
    .sec02_list li {
        font-size: 15px;
        background-size: 19px auto;
        background-position: left top 5px;
    }
    .sec02_list li span {
        font-size: 18px;
    }
    .sec03_bb_list li:not(:nth-child(3n)) {
        margin-right: 0;
    }
    .sec03_bb_list {
        padding: 0 15px;
        max-width: 450px;
    }
    .sec03_bb_list li {
        width: 100%;
        height: 135px;
        margin-bottom: 20px;
    }
    .sec03_bb_list .sec03_bb_info .tt {
        font-size: 22px;
        padding-left: 15px;
    }
    .sec03_bb_list li .img {
        width: 190px;
    }
    .sec03_bb:before {
        height: 290px;
    }
    .sec02_content:before {
        height: 1050px;
    }
}
/* screen-max:440px */
@media screen and (max-width: 440px) {
    .sp440 {
        display: block !important;
    }
    .pc440 {
        display: none !important
    }
    .sec03_frame_tt {
        font-size: 5vw;
        line-height: 13vw;
    }
    .sec09_info dl dt, .sec09_info dl dd {
        font-size: 14px;
    }
    .sec09_info dl dt {
        width: 105px;
    }
    .sec03_frame_img:before {
        height: 53vw;
    }
    .sec03_bb_list {
        max-width: 385px;
    }
    .sec_contact:before {
        height: 100%;
        background-size: cover;
        width: 750px;
        left: 0;
    }
    .sec03_bb_list .sec03_bb_info {
        height: 85px;
    }
}
@media screen and (max-width: 425px) {
    .sp425 {
        display: block !important;
    }
    .sec01_list {
        max-width: 345px;
        height: 225px;
    }
    .sec01_list li p {
        font-size: 12px;
    }
    .sec01_list .sub02 {
        height: 114px;
        background-size: 175px auto;
        width: 175px;
        padding-top: 10px;
    }
    .sec01_list .sub03 {
        height: 114px;
        background-size: 175px auto;
        width: 175px;
        padding-top: 10px;
    }
    .sec01_list .sub04 {
        height: 114px;
        background-size: 183px auto;
        width: 183px;
        padding-top: 24px;
        right: -13px;
        top: 153px;
    }
    .sec01_list .sub01 {
        background-size: 188px auto;
        width: 188px;
        left: -8px;
        padding-top: 32px;
        top: 145px;
    }
    .sec01_list li.sub01:before {
        top: 20px;
    }
    .sec01_list li.sub04:before {
        top: 18px;
    }
    .sec01_ttl1 {
        top: 145px;
    }
    .sec01_list02 li {
        font-size: 3.9vw;
    }
    .sec01_list02 li .pink {
        font-size: 5vw;
    }
    .sec_con_btn a {
        font-size: 16px;
        padding-right: 0;
        padding: 0 12px;
        max-width: 300px;
    }
    .sec_con_btn a span {
        padding-left: 28px;
        background-size: 22px auto;
        background-position: left top 3px;
    }
    .sec_ttl_com01 .tt, .sec02 .sec_ttl_com01 .tt, .sec03 .sec_ttl_com01 .tt, .sec04 .sec_ttl_com01 .tt {
        font-size: 24px;
    }
    .sec_ttl_com02 {
        font-size: 19px;
    }
    .sec02_tt02 {
        width: calc(100% - 10px);
    }
    .sec02_list li {
        font-size: 15px;
        background-position: left top 7px;
        padding-left: 21px;
        background-size: 16px auto;
    }
    .sec02_list li span {
        font-size: 17px;
    }
    .sec01_list02 {
        clip-path: polygon(0 0, 83.8% 0%, 100% 100%, 0% 100%);
    }
    .sec06_item {
        max-width: 345px;
    }
    .sec06_item li {
        width: 160px;
        height: 160px;
    }
}
@media screen and (max-width: 391px) {
    .sp390 {
        display: block !important;
    }
}
@media screen and (min-width: 375px) and (max-width: 425px) {
    .sec06_icon {
        height: 55px;
    }
    .sub03 .sec06_icon {
        height: 50px;
    }
    .sec06_icon img {
        height: 80%;
        width: auto;
    }
    .sec06_tt {
        font-size: 15px;
    }
    .sec06_item li:not(:last-child):before {
        right: -21px;
    }
    .sub01 .sec06_icon img {
        width: 50px;
    }
    .sub02 .sec06_icon img {
        width: 50px;
    }
    .sub03 .sec06_icon img {
        width: 50px;
    }
    .sub04 .sec06_icon img {
        width: 50px;
    }
    .sub05 .sec06_icon img {
        width: 50px;
    }
}
/* screen-max: 360px */
@media screen and (max-width: 374px) {
    .sp375 {
        display: block !important;
    }
    .sec01_list02 li .icon {
        width: 16px !important;
        font-size: 16px;
        left: 0 !important;
    }
    .sec01_list {
        max-width: 290px;
        height: 225px;
    }
    .sec01_list .sub03 {
        width: 155px;
        background-size: 155px auto;
        padding-top: 10px;
        right: -10px;
    }
    .sec01_list .sub02 {
        background-size: 155px auto;
        width: 155px;
        padding-top: 10px;
        left: -10px;
        padding-right: 2px;
    }
    .sec01_list li p {
        font-size: 11px;
        letter-spacing: -0.02em;
    }
    .sec01_list .sub01 {
        background-size: 160px auto;
        width: 160px;
        left: -10px;
        padding-top: 28px;
        top: 145px;
    }
    .sec01_list .sub01 p, .sec01_list .sub04 p {
        font-size: 10px;
    }
    .sec01_list .sub04 {
        background-size: 154px auto;
        width: 154px;
        padding-top: 20px;
        right: -11px;
    }
    .sec01_list li.sub01:before {
        top: 16px;
    }
    .sec01_list li.sub04:before {
        top: 9px;
    }
    .sec01_ttl1 .blue {
        font-size: 26px;
    }
    .sec01_ttl1 {
        font-size: 20px;
    }
    .sec01_ttl1 .sm {
        font-size: 18px;
    }
    .sec02_list li:last-child {
        background-position: left top 5px;
    }
    .sec02_tt02 {
        font-size: 18px;
    }
    .sec03_tt {
        font-size: 17px;
    }
    .sec03_bb_txt .lg {
        font-size: 18px;
    }
    .sec03_bb_txt .sm {
        font-size: 14px;
    }
    .sec02_list li {
        white-space: nowrap;
    }
    .sec03_icon.ic01 {
        font-size: 17px;
    }
    .sec03_bb_list .sec03_bb_info .tt {
        font-size: 17px;
    }
    .sec03_bb_list .sec03_bb_info {
        height: 80px;
    }
    .sec09_info dl dt, .sec09_info dl dd {
        font-size: 12px;
    }
    .sec09_info dl dt {
        width: 84px;
    }
    .sec09_info dl dd a {
        padding-right: 24px;
        background-size: 14px auto;
    }
    .sec_ttl_com02 {
        font-size: 18px;
    }
    .sec03 .sec_ttl_com01 .tt {
        font-size: 22px;
    }
    .sec06_item {
        flex-direction: column;
        align-items: center;
    }
    .sec06_item li:not(:last-child) {
        margin-right: 0;
        margin-bottom: 50px;
    }
    .sec06_item li:not(:last-child):before {
        right: 0;
        top: auto;
        bottom: -30px;
        left: 0;
        margin: 0 auto;
        transform: rotate(90deg);
    }
    .sec06_tt {
        font-size: 18px;
        letter-spacing: 0em;
    }
    .sec06_item li {
        width: 210px;
        height: 210px;
    }
    .sec06_icon {
        height: 98px;
        margin-bottom: 7px;
    }
    .sub03 .sec06_icon {
        height: 84px;
    }
    address {
        font-size: 12px;
    }
    .to_top {
        width: 45px;
        height: 45px;
        right: 4px;
        bottom: 54px;
    }
    .contact_note {
        font-size: 12px;
    }
}