@charset "UTF-8";
/*=============================================*/
/*Font import */
/*=============================================*/
@import url(https://use.fontawesome.com/releases/v5.10.2/css/all.css);
@import url(https://fonts.googleapis.com/css2?family=Oswald:wght@300;500;600&display=swap);
@import url(https://fonts.googleapis.com/earlyaccess/notosansjp.css);
/*=============================================*/
/*Reset CSS*/
/*=============================================*/
article, aside, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, main {
    display: block;
}

blockquote, body, dd, div, dl, dt, fieldset, figure, form, h1, h2, h3, h4, h5, h6, input, li, ol, p, pre, td, textarea, th, ul {
    margin: 0;
    padding: 0;
    font-weight: normal;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

li {
    list-style: none;
}

a,
a:link {
    text-decoration: none;
}

img {
    max-width: 100%;
    height: auto;
    border: 0;
    height: auto;
    vertical-align: bottom;
    -webkit-backface-visibility: hidden;
}

button, input, select, textarea {
    margin: 0;
    padding: 0;
    background: none;
    border: none;
    border-radius: 0;
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

select::-ms-expand {
    display: none;
}

input[type="radio"]::-ms-check,
input[type="checkbox"]::-ms-check {
    display: none;
}

i {
    font-style: normal;
}

textarea {
    resize: none;
    font-family: sans-serif;
}

* {
    box-sizing: border-box;
}

/*=============================================*/
/*Common Base*/
/*=============================================*/
html {
    font-size: 62.5%;
    overflow: auto;
}

body {
    margin: auto;
    width: auto;
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
    -webkit-text-size-adjust: 100%;
    -moz-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    -o-text-size-adjust: 100%;
    text-size-adjust: 100%;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
}

a, b, dd, dt, li, p, span, td, th {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.2;
    color: #333;
}

h1, h2, h3, h4, h5, h6 {
    color: #333;
}

.sp_only {
    display: none !important;
}

@media screen and (max-width: 767px) {
    .sp_only {
        display: block !important;
    }
    .pc_only {
        display: none !important;
    }
}

.center {
    margin: auto;
    text-align: center;
    line-height: 180%;
}

.clearfix::after {
    content: "";
    display: block;
    clear: both;
}

/*=============================================*/
/*  layout  Base                        */
/*=============================================*/
.main_width {
    width: 96%;
    max-width: 1110px;
    margin: auto;
}

.main_width.size780 {
    max-width: 780px;
}

.main_width.size960 {
    max-width: 960px;
}

.main_width.size700 {
    max-width: 700px;
}

section {
    padding: 80px 0;
}

/********************************************/
/*layout Base */
/********************************************/
/***************************/
/**Color */
/***************************/
.co_navy {
    color: #002B57;
}

.co_blue {
    color: #0A6ABA;
}

/***************************/
/**bg */
/***************************/
.bg_navy {
    background-color: #002B57;
}

.bg_blue {
    background-color: #0A6ABA;
}

.bg_light_blue {
    background-color: #E8F6FD;
}

/***************************/
/**ico */
/***************************/
.ico_tel {
    display: inline-block;
    position: relative;
    padding-left: 0.9em;
    font-size: 2.8rem;
    color: #002B57;
    font-family: 'Oswald', sans-serif;
    font-weight: 600;
}

.ico_tel:before {
    position: absolute;
    top: 0;
    right: auot;
    bottom: 0;
    left: 0;
    font-family: "Font Awesome 5 Free";
    width: 1em;
    height: 1em;
    margin: auto;
    line-height: 1em;
    content: '\f879';
    font-weight: bold;
    font-size: 0.7em;
    font-style: normal;
}

/********************************************/
/* ttl */
/********************************************/
.center_border_ttl {
    position: relative;
    margin-bottom: 3em;
    text-align: center;
    font-size: 2.3rem;
    font-family: 'Noto Sans JP',"Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", sans-serif;
    font-weight: 700;
    color: #002B57;
    letter-spacing: 0.05em;
}

.center_border_ttl:after {
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1em;
    content: '';
    width: 10em;
    height: 2px;
    margin: auto;
    background-color: #0A6ABA;
}

.center_border_en_ttl {
    margin-bottom: 1.5em;
    text-align: center;
    font-size: 3.0rem;
}

.center_border_en_ttl span {
    display: inline-block;
    position: relative;
    padding: 0 3.5em;
    font-size: 1em;
    font-family: 'Noto Sans JP',"Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", sans-serif;
    font-weight: 700;
    letter-spacing: 0.1em;
}

.center_border_en_ttl span:after, .center_border_en_ttl span:before {
    position: absolute;
    top: 0;
    bottom: 0;
    content: '';
    width: 3em;
    height: 1px;
    background-color: #002B57;
    margin: auto;
}

.center_border_en_ttl span:before {
    left: 0;
}

.center_border_en_ttl span:after {
    right: 0;
}

.center_border_en_ttl small {
    display: block;
    color: #0A6ABA;
    font-size: 0.5em;
    font-family: 'Oswald', sans-serif;
    font-weight: 300;
    letter-spacing: 0.2em;
}

.square_ttl {
    position: relative;
    margin-bottom: 1em;
    padding-left: 35px;
    font-size: 2.2rem;
    font-family: 'Noto Sans JP',"Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", sans-serif;
    font-weight: 700;
    color: #002B57;
    letter-spacing: 0.1em;
}

.square_ttl:before {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    content: '';
    width: 29px;
    height: 25px;
    margin: auto;
    background: url(../img/common/ico-ttl-square.svg) no-repeat center/100%;
}

.square_ttl small {
    font-size: 0.6em;
}

.jp_en_ttl {
    margin-bottom: 1.5em;
    font-size: 2.5rem;
    font-family: 'Noto Sans JP',"Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", sans-serif;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: #002B57;
}

.jp_en_ttl span {
    color: inherit;
    font-size: 1em;
    margin-right: 1em;
}

.jp_en_ttl small {
    display: inline-block;
    font-family: 'Oswald', sans-serif;
    font-weight: 300;
    color: #0A6ABA;
    font-size: 0.7em;
}

.the_content h2,
.border_left_ttl {
    margin-bottom: 1em;
    padding-bottom: 0.4em;
    border-bottom: 1px solid #0A6ABA;
    font-size: 2.0rem;
    line-height: 1.3;
    font-family: 'Noto Sans JP',"Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", sans-serif;
    font-weight: 700;
    color: #002B57;
    letter-spacing: 0.1em;
}

.the_content h3,
.blue_square_ttl {
    position: relative;
    margin-bottom: 1em;
    padding-left: 1.5em;
    font-size: 2.0rem;
    font-family: 'Noto Sans JP',"Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", sans-serif;
    font-weight: 700;
    letter-spacing: 0.1em;
}

.the_content h3:before,
.blue_square_ttl:before {
    position: absolute;
    left: 0;
    top: 0.3em;
    content: '';
    width: 1em;
    height: 1em;
    line-height: 1em;
    background-color: #0A6ABA;
}

/********************************************/
/* btn */
/********************************************/
.hover_slide_black a {
    position: relative;
    overflow: hidden;
}

.hover_slide_black a:before {
    position: absolute;
    left: -130%;
    top: 0;
    content: '';
    width: 120%;
    height: 150%;
    background-color: #333;
    transform: skewX(-20deg);
    -webkit-transform: skewX(-20deg);
    -moz-transform: skewX(-20deg);
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}

.hover_slide_black a span {
    position: relative;
    z-index: 1;
}

.hover_slide_black a:hover:before {
    left: -10%;
}

.hover_slide_black.blue_ver a:before {
    background-color: #0A6ABA;
}

.base_blue_btn {
    display: block;
}

.base_blue_btn a {
    display: block;
    padding: 1.5em 1em;
    background-color: #0A6ABA;
    text-align: center;
}

.base_blue_btn a span {
    color: #fff;
    font-size: 1.7rem;
    font-weight: bold;
}

.base_blue_btn.map_ver span {
    position: relative;
    padding-right: 2em;
}

.base_blue_btn.map_ver span:after {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: auto;
    font-family: "Font Awesome 5 Free";
    width: 1em;
    height: 1em;
    margin: auto;
    line-height: 1em;
    content: '\f3c5';
    font-weight: bold;
}

.arrow_base_btn {
    display: inline-block;
    text-align: center;
}

.arrow_base_btn a {
    position: relative;
    display: block;
    font-size: 1.6rem;
    color: #0A6ABA;
    padding: 1.4em 2em;
    font-weight: bold;
    border: 1px solid #0A6ABA;
    -webkit-transition: all 0.9s;
    transition: all 0.9s;
    background-color: #fff;
}

.arrow_base_btn a span {
    font-size: 1em;
    color: inherit;
}

.arrow_base_btn a:before {
    position: absolute;
    right: 1em;
    bottom: 0.5em;
    content: '';
    width: 95px;
    height: 15px;
    background: url(../img/common/arrow-navy-right.svg) no-repeat center/100%;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    z-index: 1;
}

.arrow_base_btn a:hover {
    background-color: #0A6ABA;
    color: #fff;
}

.arrow_base_btn a:hover:before {
    right: 0.3em;
    background: url(../img/common/arrow-navy-right-hover.svg) no-repeat center/100%;
}

.arrow_base_btn a {
    overflow: hidden;
}

.arrow_base_btn a:after {
    position: absolute;
    left: -130%;
    top: 0;
    content: '';
    width: 120%;
    height: 150%;
    background-color: #0A6ABA;
    transform: skewX(-20deg);
    -webkit-transform: skewX(-20deg);
    -moz-transform: skewX(-20deg);
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
}

.arrow_base_btn a span {
    position: relative;
    z-index: 1;
}

.arrow_base_btn a:hover:after {
    left: -10%;
}

.target_blank span {
    position: relative;
    display: inline-block;
    padding-right: 1.3em;
}

.target_blank span:after {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: auto;
    font-family: "Font Awesome 5 Free";
    width: 1em;
    height: 1em;
    margin: auto;
    line-height: 1em;
    content: '\f35d';
    font-weight: bold;
}

/*=============================================*/
/*media query    SmartPhone */
/*=============================================*/
@media screen and (max-width: 767px) {
    /***************************/
    /**ico */
    /***************************/
    .ico_tel {
        font-size: 2.0rem;
    }
    /********************************************/
    /* btn */
    /********************************************/
    .base_blue_btn a span {
        font-size: 1.5rem;
    }
    .arrow_base_btn a {
        font-size: 1.4rem;
    }
    .arrow_base_btn a:before {
        width: 75px;
        height: 9px;
    }
    /********************************************/
    /* ttl */
    /********************************************/
    .center_border_ttl {
        font-size: 1.8rem;
    }
    .center_border_ttl:after {
        width: 7em;
    }
    .center_border_en_ttl {
        font-size: 2.2rem;
    }
    .square_ttl {
        font-size: 1.7rem;
        padding-left: 25px;
    }
    .square_ttl:before {
        width: 20px;
        height: 17px;
    }
    .jp_en_ttl {
        font-size: 2.2rem;
    }
    .jp_en_ttl span {
        margin-right: 0;
    }
    .jp_en_ttl small {
        display: block;
    }
    .the_content h2,
    .border_left_ttl {
        font-size: 1.8rem;
    }
    .the_content h3,
    .blue_square_ttl {
        font-size: 1.7rem;
    }
}

/*=============================================*/
/*  layout                               */
/*=============================================*/
/********************************************/
/*header */
/********************************************/
.header_main {
    position: relative;
    width: 96%;
    max-width: 1500px;
    margin: auto;
}

.header_main .logo {
    position: absolute;
    left: 0;
    top: 0;
    width: 230px;
    padding: 70px 30px;
    background-color: #fff;
    -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.16);
    -moz-box-shadow: 0 0 10px rgba(0, 0, 0, 0.16);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.16);
    z-index: 1;
}

.header_main .main_catch {
    padding: 0.3em 0 0.3em 245px;
    font-size: 1.2rem;
    font-weight: bold;
    letter-spacing: 0.05em;
    line-height: 1.5;
}

.header_main .sab_nav {
    float: right;
    margin-bottom: 20px;
    padding: 0 0 0 245px;
}

.header_main .sab_nav .tel {
    display: inline-block;
    margin-right: 40px;
    vertical-align: middle;
}

.header_main .sab_nav .btn {
    display: inline-block;
    vertical-align: middle;
}

.header_main .sab_nav .btn a {
    display: block;
    color: #fff;
    background-color: #0A6ABA;
    padding: 0.5em 2em;
    font-weight: bold;
}

.header_main .sab_nav .btn a span {
    color: inherit;
    font-size: 1em;
    letter-spacing: 0.05em;
}

.header_main .main_nav {
    width: 100%;
    float: right;
    padding: 0 0 30px 245px;
    text-align: right;
}

.header_main .main_nav ul li {
    display: inline-block;
}

.header_main .main_nav ul li a {
    display: block;
    position: relative;
    font-size: 1.4rem;
    font-weight: bold;
    padding: 0.5em 1.5em;
}

.header_main .main_nav ul li a span {
    font-size: 1em;
    letter-spacing: 0.05em;
}

.header_main .main_nav ul li a:after {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    content: '';
    width: 1px;
    height: 60%;
    background-color: #333;
    margin: auto;
}

.header_main .main_nav li a span {
    display: block;
    position: relative;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
}

.header_main .main_nav li a span:after {
    position: absolute;
    left: 0;
    bottom: -0.7em;
    content: '';
    width: 0;
    height: 2px;
    background-color: #0A6ABA;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}

.header_main .main_nav li a:hover span:after {
    width: 110%;
}

.header_main .main_nav li a:hover span {
    color: #0A6ABA;
}

header .sp_nav {
    display: none;
}

/********************************************/
/*Footer */
/********************************************/
.footer_info {
    position: relative;
}

.footer_info .footer_info_box {
    display: -ms-flexbox;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
}

.footer_info .left {
    width: 50%;
}

.footer_info .right {
    width: 50%;
    background-color: #E8F6FD;
}

.footer_info .g_map {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.footer_info .g_map iframe {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
}

.footer_info .right .inner {
    width: 90%;
    max-width: 500px;
    padding: 80px 0 80px 60px;
}

.footer_info .right .logo {
    max-width: 180px;
    margin-bottom: 30px;
}

.footer_info .right .info {
    font-size: 1.5rem;
}

.footer_info .right .info p {
    margin-bottom: 1em;
    font-weight: bold;
    font-size: 1em;
    line-height: 1.8;
}

.footer_info .right .info p:last-child {
    margin-bottom: 0;
}

.footer_info .right .base_blue_btn {
    margin: 20px 0;
}

.footer_info .right .tel_box {
    margin-bottom: 20px;
}

.footer_info .right .tel_box li {
    margin-bottom: 10px;
    color: #002B57;
}

.footer_info .right .tel_box li small {
    font-size: 1.6rem;
    font-weight: bold;
    color: inherit;
}

.footer_info .right .tel_box li b {
    font-size: 3.0rem;
    font-family: 'Oswald', sans-serif;
    font-weight: 600;
    color: inherit;
    letter-spacing: 0.05em;
}

.footer_info .go_to_top {
    position: absolute;
    right: 60px;
    bottom: 0;
    width: 120px;
    height: 65px;
}

.footer_bottom {
    padding: 70px 0 60px;
}

.footer_bottom .inner {
    margin-bottom: 60px;
}

.footer_bottom .left {
    width: 45%;
    float: left;
    margin-right: 5%;
}

.footer_bottom .right {
    width: 50%;
    float: right;
}

.footer_bottom .left .logo {
    width: 80%;
    max-width: 180px;
    margin-bottom: 20px;
}

.footer_bottom .left .info {
    margin-bottom: 1em;
    line-height: 1.8;
}

.footer_bottom .left .tel_box {
    display: inline-block;
}

.footer_bottom .left .tel_box a {
    display: block;
    border: 1px solid #002B57;
    padding: 0.5em 1em;
}

.footer_bottom .right .footer_nav_list {
    letter-spacing: -1em;
}

.footer_bottom .right .footer_nav_list > * {
    letter-spacing: normal;
}

.footer_bottom .right .footer_nav_list li {
    display: inline-block;
    margin-right: 4%;
    margin-bottom: 1em;
    font-size: 1.5rem;
    width: 48%;
}

.footer_bottom .right .footer_nav_list li:nth-child(2n) {
    margin-right: 0;
}

.footer_bottom .right .footer_nav_list li a {
    display: block;
    font-size: 1em;
    padding: 0.2em 0;
    font-weight: bold;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
}

.footer_bottom .right .footer_nav_list li a:hover {
    color: #0A6ABA;
}

.footer_bottom .copyright {
    text-align: center;
    font-size: 1.3rem;
    padding: 3em 0 0;
}

.footer_contact_btn_list {
    text-align: center;
}

.footer_contact_btn_list li {
    display: inline-block;
    margin-right: 2em;
    vertical-align: top;
}

.footer_contact_btn_list li:last-child {
    margin-right: 0;
}

.footer_contact_btn_list li a {
    display: block;
    background-color: #0A6ABA;
    color: #fff;
    padding: 1em 2em 1em 2em;
    overflow: hidden;
    font-size: 1.5rem;
}

.footer_contact_btn_list li a span {
    position: relative;
    display: inline-block;
    padding-left: 1.5em;
    font-size: 1em;
    color: inherit;
}

.footer_contact_btn_list li a span:before {
    position: absolute;
    top: 0;
    right: auto;
    bottom: 0;
    left: 0;
    font-family: "Font Awesome 5 Free";
    width: 1em;
    height: 1em;
    margin: auto;
    line-height: 1em;
    content: '\f2b6';
    font-weight: lighter;
}

.footer_contact_btn_list .reserve a {
    background-color: #002B57;
}

.footer_contact_btn_list .reserve a span:before {
    content: '\f073';
    font-weight: bold;
}

.footer_contact_btn_list .online a {
    /*            background-color: $navy; */
}

.footer_contact_btn_list .online a span:before {
    content: '\f109';
    font-weight: bold;
}

.footer_contact_btn_list .instagram a {
    background-color: #002B57;
}

.footer_contact_btn_list .instagram a span:before {
    content: '\f16d';
    font-family: "Font Awesome 5 Brands";
}

/********************************************/
/*fix_btn*/
/********************************************/
.fix_btn {
    position: fixed;
    right: 0;
    top: 0;
    height: 100%;
    z-index: 2;
}

.fix_btn .btn_list {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-40%) translateX(-100%);
}

.fix_btn .btn_list li {
    width: 50px;
    margin-bottom: 15px;
}

.fix_btn .btn_list li:last-child {
    margin-bottom: 0;
}

.fix_btn .btn_list li a {
    display: block;
    position: relative;
}

.fix_btn .btn_list li a:before {
    position: absolute;
    left: 0;
    top: 0;
    content: '';
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0);
    -webkit-transition: all 0.9s;
    transition: all 0.9s;
}

.fix_btn .btn_list li a:hover:before {
    background-color: rgba(255, 255, 255, 0.3);
}

/*=============================================*/
/*  @Top Page                        */
/*=============================================*/
/********************************************/
/*main_visual_block*/
/********************************************/
.main_visual_block {
    padding-top: 0;
    padding-bottom: 0;
}

.main_visual_block .main_slide_box {
    position: relative;
}

.main_visual_block .main_ttl {
    position: absolute;
    left: 2.5em;
    bottom: 6em;
    font-size: 3.0rem;
}

.main_visual_block .main_ttl .ttl {
    font-size: 1em;
    font-family: 'Noto Sans JP',"Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", sans-serif;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.05em;
    line-height: 1.8;
}

/********************************************/
/*top_about_block*/
/********************************************/
.left_img_right_txt_box .left,
.top_about_block .about_box .left {
    width: 45%;
    float: left;
    margin-right: 3%;
}

.left_img_right_txt_box .right,
.top_about_block .about_box .right {
    width: 52%;
    float: right;
}

.left_img_right_txt_box .right .inner,
.top_about_block .right .inner {
    width: 90%;
    max-width: 600px;
}

.left_img_right_txt_box .right .txt,
.top_about_block .right .txt {
    margin-bottom: 2em;
    font-size: 1.5rem;
}

.left_img_right_txt_box .right .txt p,
.top_about_block .right .txt p {
    font-size: 1em;
    line-height: 2;
    letter-spacing: 0.1em;
    text-align: justify;
    text-justify: inter-ideograph;
}

.left_img_right_txt_box .right .btn_list li,
.top_about_block .right .btn_list li {
    margin-bottom: 15px;
}

.left_img_right_txt_box .right .btn_list li .arrow_base_btn,
.top_about_block .right .btn_list li .arrow_base_btn {
    width: 100%;
    max-width: 450px;
}

/********************************************/
/*top_medical_block*/
/********************************************/
.top_medical_block .medical_list {
    display: -ms-flexbox;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}

.top_medical_block .medical_list li {
    position: relative;
    width: 48%;
    margin-bottom: 40px;
}

.top_medical_block .medical_list li:nth-child(2), .top_medical_block .medical_list li:nth-child(4), .top_medical_block .medical_list li:nth-child(6) {
    margin-right: 4%;
}

.top_medical_block .medical_list li.wide_ver {
    width: 100%;
}

.top_medical_block .medical_list li .img img {
    width: 100%;
    height: auto;
}

.top_medical_block .medical_list .txt_zone {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    min-height: 50%;
    background-color: rgba(255, 255, 255, 0.8);
    padding: 25px 30px 50px;
}

.top_medical_block .medical_list .txt_zone .txt p {
    font-size: 1.5rem;
    line-height: 2;
    letter-spacing: 0.05em;
    text-align: justify;
    text-justify: inter-ideograph;
}

.top_medical_block .medical_list .wide_ver .txt_zone {
    width: 35%;
    height: 100%;
    left: auto;
    right: 0;
}

.arrow_txt_link,
.top_medical_block .medical_list .arrow {
    display: inline-block;
    position: absolute;
    right: 0;
    bottom: 0;
    padding: 0 5em 1.2em 0;
    font-size: 1.8rem;
    font-family: 'Oswald', sans-serif;
    font-weight: 300;
    color: #002B57;
    letter-spacing: 0.1em;
}

.arrow_txt_link:after,
.top_medical_block .medical_list .arrow:after {
    position: absolute;
    right: 1.5em;
    bottom: 0.5em;
    content: '';
    width: 95px;
    height: 15px;
    background: url(../img/common/arrow-navy-right.svg) no-repeat center/100%;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}

.top_medical_block .medical_list li a {
    display: block;
}

.top_medical_block .medical_list li a .img {
    overflow: hidden;
}

.top_medical_block .medical_list li a .img img {
    -webkit-transition: all 0.2s;
    transition: all 0.2s;
}

.top_medical_block .medical_list li a:hover .img img {
    transform: scale(1.1);
}

.top_medical_block .medical_list li a:hover .arrow:after {
    right: 0.5em;
}

.top_medical_block .arrow_base_btn {
    width: 90%;
    max-width: 450px;
}

/********************************************/
/*top news schedule */
/********************************************/
.column_2_box {
    padding: 80px 0;
}

.column_2_box .left {
    width: 44%;
    float: left;
    margin-right: 6%;
}

.column_2_box .right {
    width: 50%;
    float: right;
}

.top_news_block {
    padding: 0;
}

.top_news_block .news_list li {
    margin-bottom: 1em;
    padding-bottom: 1em;
    border-bottom: 1px solid #0A6ABA;
}

.top_news_block .news_list li .date {
    width: 5em;
    float: left;
    padding-top: 0.2em;
    font-size: 1.5rem;
    color: #707070;
    font-family: 'Oswald', sans-serif;
    font-weight: 300;
}

.top_news_block .news_list li .ttl {
    padding-left: 6em;
    font-size: 1.6rem;
}

.top_news_block .news_list li .ttl a {
    display: block;
    font-size: 1em;
    font-weight: bold;
    color: #002B57;
    line-height: 1.6;
}

.top_schedule_box .img {
    margin: 50px 0 8px;
}

.top_schedule_box p {
    text-align: center;
    font-size: 1.3rem;
}

/********************************************/
/*top_message_block */
/********************************************/
.top_message_block .img {
    margin-bottom: 30px;
}

.top_message_block .txt {
    margin-bottom: 3em;
    font-size: 1.6rem;
}

.top_message_block .txt p {
    font-size: 1em;
    line-height: 2.5;
    letter-spacing: 0.05em;
    text-align: justify;
    text-justify: inter-ideograph;
}

.top_message_block .arrow_base_btn {
    width: 90%;
    max-width: 450px;
}

/********************************************/
/* Aside bnr_block */
/********************************************/
.bnr_block {
    padding: 100px 0;
}

.bnr_block .bnr_column_2_list {
    display: -ms-flexbox;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
}

.bnr_block .bnr_column_2_list li {
    width: 48%;
    margin-right: 4%;
    text-align: center;
}

.bnr_block .bnr_column_2_list li:nth-child(2n) {
    margin-right: 0;
}

.bnr_block .bnr_column_2_list li a {
    display: block;
}

.bnr_block .bnr_column_2_list li span {
    display: block;
    padding: 1em 0.5em 1.5em;
    font-size: 2.0rem;
    font-family: 'Noto Sans JP',"Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", sans-serif;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: #fff;
}

.bnr_block .bnr_column_2_list li .img {
    margin: 20px 20px 0;
    overflow: hidden;
}

.bnr_block .bnr_column_2_list li a {
    position: relative;
}

.bnr_block .bnr_column_2_list li a:after {
    position: absolute;
    right: 2em;
    bottom: 1em;
    content: '';
    width: 95px;
    height: 15px;
    background: url(../img/common/arrow-navy-right-hover.svg) no-repeat center/100%;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
}

.bnr_block .bnr_column_2_list li a .img img {
    -webkit-transition: all 0.2s;
    transition: all 0.2s;
}

.bnr_block .bnr_column_2_list li a:hover .img img {
    transform: scale(1.1);
}

.bnr_block .bnr_column_2_list li a:hover:after {
    right: 0.5em;
}

/*=============================================*/
/*media query    Tablet */
/*=============================================*/
@media screen and (max-width: 1024px) {
    /*=============================================*/
    /*  layout                               */
    /*=============================================*/
    /********************************************/
    /*header */
    /********************************************/
    .header_main .logo {
        width: 180px;
        padding: 50px 30px;
    }
    .header_main .main_catch {
        padding: 0.3em 0 0.3em 190px;
        font-size: 1.1rem;
    }
    .header_main .sab_nav {
        margin-bottom: 10px;
        padding: 0 0 0 190px;
    }
    .header_main .main_nav {
        padding: 0 0 30px 190px;
    }
    .header_main .main_nav ul li a {
        font-size: 1.1rem;
        padding: 1em 1.2em;
    }
    /*=============================================*/
    /*  @Top Page                        */
    /*=============================================*/
    /********************************************/
    /*main_visual_block*/
    /********************************************/
    .main_visual_block .main_ttl {
        bottom: 2em;
        font-size: 3.5vw;
    }
    /********************************************/
    /*top_medical_block*/
    /********************************************/
    .top_medical_block .medical_list .txt_zone {
        padding: 25px 20px 50px;
    }
    .top_medical_block .medical_list .txt_zone .txt p {
        font-size: 1.3rem;
    }
    .top_medical_block .medical_list .wide_ver .txt_zone {
        width: 45%;
    }
}

/*=============================================*/
/*media query    Tablet ipad 5.7inch */
/*=============================================*/
/*=============================================*/
/*media query    SmartPhone */
/*=============================================*/
@media screen and (max-width: 767px) {
    /*=============================================*/
    /*Common Base*/
    /*=============================================*/
    a, b, dd, dt, li, p, span, td, th {
        font-size: 13px;
        font-size: 1.3rem;
    }
    /*=============================================*/
    /*  layout  Base                        */
    /*=============================================*/
    section {
        padding: 40px 0;
    }
    /*=============================================*/
    /*  layout                               */
    /*=============================================*/
    /********************************************/
    /*header */
    /********************************************/
    .header_main {
        padding-bottom: 10px;
    }
    .header_main .logo {
        position: static;
        left: 0;
        top: 0;
        width: 35%;
        padding: 5px 0 0;
        background-color: transparent;
        -webkit-box-shadow: none;
        -moz-box-shadow: none;
        box-shadow: none;
    }
    .header_main .main_catch {
        padding: 0.3em 0 0.3em 0;
        font-size: 1.0rem;
    }
    .header_main .sab_nav {
        display: none;
    }
    .header_main .main_nav {
        display: none;
    }
    /********************************************/
    /*  Sp-menu*/
    /********************************************/
    header .inner {
        position: relative;
    }
    .nav-fixed {
        position: fixed;
        width: 100%;
        z-index: 999;
    }
    .fixed {
        position: absolute;
        width: 100%;
        height: 100%;
        overflow: hidden;
    }
    .sp-menu-trigger,
    .sp-menu-trigger span {
        display: inline-block;
        transition: all .4s;
        box-sizing: border-box;
        cursor: pointer;
    }
    .sp-menu-trigger {
        position: absolute;
        top: 0;
        right: 0;
        width: 40px;
        height: 40px;
        background-color: #fff;
        z-index: 2;
    }
    .sp-menu-trigger span {
        position: absolute;
        background: #002B57;
        width: 23px;
        height: 2px;
        left: 0;
        right: 0;
        margin: auto;
    }
    .sp-menu-trigger span:nth-of-type(1) {
        top: 10px;
    }
    .sp-menu-trigger span:nth-of-type(2) {
        top: 0;
        bottom: 0;
    }
    .sp-menu-trigger span:nth-of-type(3) {
        bottom: 10px;
    }
    .sp-menu-trigger.active span:nth-of-type(3),
    .sp-menu-trigger.active span:nth-of-type(2),
    .sp-menu-trigger.active span:nth-of-type(1) {
        opacity: 0;
    }
    header .sp_nav {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        background-color: rgba(255, 255, 255, 0.9);
        width: 100%;
        height: 100%;
        -webkit-overflow-scrolling: touch;
        z-index: 9998;
        overflow-y: scroll;
        padding: 20px 20px 60px;
        box-sizing: border-box;
        text-align: center;
    }
    header .sp_nav li:first-child a:before,
    header .sp_nav li a:after {
        content: none;
    }
    header .sp_nav li {
        display: block;
        margin-bottom: 10px;
        border: 1px solid #ccc;
    }
    header .sp_nav li.close {
        margin-top: 20px;
        background-color: #ccc;
        border: 1px solid #ccc;
        padding: 1em;
        cursor: pointer;
    }
    header .sp_nav li.close:before {
        content: "\f00d";
        font-family: "Font Awesome 5 Free";
        font-weight: bold;
        margin-right: 0.5em;
    }
    header .sp_nav li a {
        display: block;
        padding: 1em 0;
        border-left: 0;
        font-weight: bold;
    }
    header .sp_nav li.en {
        border: 1px soldi #0A6ABA;
    }
    header .sp_nav li.en a {
        background-color: #0A6ABA;
        color: #fff;
    }
    header .sp_nav li.en a span {
        font-size: 1em;
        color: inherit;
    }

    header .sp_nav li.rehaHP {
        border: 1px soldi #35a6ba;
    }
    header .sp_nav li.rehaHP a {
        background-color: #35a6ba;
        color: #fff;
    }
    header .sp_nav li.rehaHP a span {
        font-size: 1em;
        color: inherit;
    }


    header .sp_nav li.tel {
        border: 1px solid #002B57;
    }
    /********************************************/
    /*Footer */
    /********************************************/
    .footer_info .footer_info_box {
        display: block;
    }
    .footer_info .left {
        width: 100%;
    }
    .footer_info .right {
        width: 100%;
    }
    .footer_info .g_map {
        padding-bottom: 62.5%;
    }
    .footer_info .right .inner {
        width: 90%;
        max-width: 100%;
        margin: auto;
        padding: 30px 0 30px;
    }
    .footer_info .right .logo {
        max-width: 150px;
        margin: 0 auto 20px;
    }
    .footer_info .right .info {
        font-size: 1.3rem;
    }
    .footer_info .right .tel_box li small {
        font-size: 1.3rem;
    }
    .footer_info .right .tel_box li b {
        font-size: 2.4rem;
    }
    .footer_info .go_to_top {
        background-color: #E8F6FD;
        position: static;
        width: 100%;
        height: auto;
        text-align: center;
    }
    .footer_info .go_to_top img {
        width: 50%;
        max-width: 100px;
    }
    .footer_bottom {
        padding: 50px 0 50px;
    }
    .footer_bottom .inner {
        margin-bottom: 40px;
    }
    .footer_bottom .left {
        width: 90%;
        float: none;
        margin: 0 auto 30px;
    }
    .footer_bottom .right {
        width: 100%;
        float: none;
    }
    .footer_bottom .left .logo {
        width: 50%;
        max-width: 150px;
        margin-bottom: 15px;
    }
    .footer_bottom .right .footer_nav_list {
        letter-spacing: -1em;
    }
    .footer_bottom .right .footer_nav_list > * {
        letter-spacing: normal;
    }
    .footer_bottom .right .footer_nav_list li {
        font-size: 1.3rem;
    }
    .footer_bottom .copyright {
        font-size: 1.2rem;
        padding: 3em 0 3em;
        line-height: 1.7;
    }
    .footer_contact_btn_list ul {
        letter-spacing: -1em;
    }
    .footer_contact_btn_list ul > * {
        letter-spacing: normal;
    }
    .footer_contact_btn_list li {
        display: inline-block;
        width: 48%;
        margin-right: 4%;
        margin-bottom: 15px;
        /*
                    &:last-child {
                        width: 80%;
                        margin-right: auto;
                    }
*/
    }
    .footer_contact_btn_list li:nth-child(2n) {
        margin-right: 0;
    }
    .footer_contact_btn_list li a {
        padding: 1.5em 2em 1.5em 2em;
        font-size: 1.3rem;
    }
    .footer_contact_btn_list li.online {
        width: 80%;
    }
    /********************************************/
    /*fix_btn*/
    /********************************************/
    .fix_btn {
        right: 0;
        top: auto;
        bottom: 0;
        width: 100%;
        height: auto;
    }
    .fix_btn .btn_list {
        letter-spacing: -1em;
        width: 100%;
        position: static;
        transform: none;
    }
    .fix_btn .btn_list > * {
        letter-spacing: normal;
    }
    .fix_btn .btn_list li {
        display: inline-block;
        width: 33.333%;
        margin-bottom: 0;
        vertical-align: bottom;
    }
    /*=============================================*/
    /*  @Top Page                        */
    /*=============================================*/
    /********************************************/
    /*main_visual_block*/
    /********************************************/
    .main_visual_block .main_ttl {
        left: 1.5em;
        bottom: 1.5em;
        font-size: 3.7vw;
    }
    /********************************************/
    /*top_about_block*/
    /********************************************/
    .left_img_right_txt_box .left,
    .top_about_block .about_box .left {
        width: 100%;
        float: none;
        margin: 0 auto 15px;
    }
    .left_img_right_txt_box .right,
    .top_about_block .about_box .right {
        width: 90%;
        margin: auto;
        float: none;
    }
    .left_img_right_txt_box .right .inner,
    .top_about_block .right .inner {
        width: 100%;
        max-width: 100%;
    }
    .left_img_right_txt_box .right .txt,
    .top_about_block .right .txt {
        font-size: 1.4rem;
    }
    .left_img_right_txt_box .right .btn_list li,
    .top_about_block .right .btn_list li {
        margin-bottom: 10px;
    }
    /********************************************/
    /*top_medical_block*/
    /********************************************/
    .top_medical_block .medical_list {
        display: block;
    }
    .top_medical_block .medical_list li {
        width: 100%;
        margin-bottom: 30px;
    }
    .top_medical_block .medical_list li:nth-child(2), .top_medical_block .medical_list li:nth-child(4) {
        margin-right: auto;
    }
    .top_medical_block .medical_list li .img img {
        width: 100%;
        height: auto;
    }
    .top_medical_block .medical_list .txt_zone {
        position: static;
        padding: 15px 30px 40px;
    }
    .top_medical_block .medical_list .txt_zone .txt p {
        font-size: 1.3rem;
    }
    .top_medical_block .medical_list .wide_ver .txt_zone {
        width: 100%;
    }
    .top_medical_block .medical_list .arrow {
        padding: 0 4em 1.2em 0;
        font-size: 1.4rem;
    }
    .top_medical_block .medical_list .arrow:after {
        width: 75px;
        height: 10px;
    }
    /********************************************/
    /*top news schedule */
    /********************************************/
    .column_2_box {
        padding: 40px 0;
    }
    .column_2_box .left {
        width: 100%;
        float: none;
        margin: 0 auto 80px;
    }
    .column_2_box .right {
        width: 100%;
        float: none;
    }
    .top_news_block .news_list li .date {
        float: none;
        width: 100%;
        margin-bottom: 0.5em;
        font-size: 1.4rem;
    }
    .top_news_block .news_list li .ttl {
        padding-left: 0;
        font-size: 1.5rem;
    }
    .top_schedule_box .img {
        margin: 10px 0 8px;
    }
    .top_schedule_box p {
        text-align: left;
        font-size: 1.2rem;
        line-height: 1.7;
    }
    /********************************************/
    /*top_message_block */
    /********************************************/
    .top_message_block .img {
        margin-bottom: 15px;
    }
    .top_message_block .txt {
        width: 90%;
        margin: 0 auto 3em;
        font-size: 1.4rem;
    }
    .top_message_block .txt p {
        line-height: 2;
    }
    /********************************************/
    /* Aside bnr_block */
    /********************************************/
    .bnr_block {
        padding: 40px 0;
    }
    .bnr_block .bnr_column_2_list {
        display: block;
    }
    .bnr_block .bnr_column_2_list li {
        width: 90%;
        margin: 0 auto 15px;
        text-align: left;
    }
    .bnr_block .bnr_column_2_list li:nth-child(2n) {
        margin-right: auto;
    }
    .bnr_block .bnr_column_2_list li a {
        letter-spacing: -1em;
    }
    .bnr_block .bnr_column_2_list li a > * {
        letter-spacing: normal;
    }
    .bnr_block .bnr_column_2_list li span {
        display: inline-block;
        width: 50%;
        padding: 0 0 1.5em;
        font-size: 1.6rem;
        letter-spacing: 0.1em;
    }
    .bnr_block .bnr_column_2_list li .img {
        display: inline-block;
        width: 47%;
        margin: 0 3% 0 0;
        padding: 10px;
        vertical-align: middle;
    }
    .bnr_block .bnr_column_2_list li a:after {
        right: 1em;
        width: 75px;
        height: 10px;
    }
}

/********************************************/
/*2023-12-13追加 */
/********************************************/
.button-049 {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 300px;
    margin: 0 auto;
    padding: .9em 2em;
    border: 2px solid #fff;
    border-radius: 5px;
    box-shadow: 0 0 0 3px #2589d0;
    background-color: #2589d0;
    color: #fff;
    font-weight: 600;
    font-size: 1.5em;
}

.button-050 {
    display: flex;
    justify-content: center;
    align-items: center;
    width: auto;
    margin: 0 auto;
    padding: .9em 2em;
    border: 2px solid #fff;
    border-radius: 5px;
    box-shadow: 0 0 0 3px #2589d0;
    background-color: #2589d0;
    color: #fff;
    font-weight: 600;
    font-size: 1.5em;
}

/********************************************/
/*2023-12-4追加 */
/********************************************/
.table_style1{
  width: 100%;
  border-collapse:separate;
  border-spacing: 0;
}

.table_style1 th:first-child{
  border-radius: 5px 0 0 0;
}

table th:last-child{
  border-radius: 0 5px 0 0;
  border-right: 1px solid #3c6690;
}

.table_style1 th{
  text-align: center;
  color:white;
  background: linear-gradient(#829ebc,#225588);
  border-left: 1px solid #3c6690;
  border-top: 1px solid #3c6690;
  border-bottom: 1px solid #3c6690;
  box-shadow: 0px 1px 1px rgba(255,255,255,0.3) inset;
  width: 50%;
  padding: 10px 0;
  font-size:18px;
  font-weight:bold;
}

.table_style1 td{
  text-align: center;
  border-left: 1px solid #a8b7c5;
  border-bottom: 1px solid #a8b7c5;
  border-top:none;
  box-shadow: 0px -3px 5px 1px #eee inset;
  width: 50%;
  padding: 10px 0;
}

.table_style1 td:last-child{
  border-right: 1px solid #a8b7c5;
}

.table_style1 tr:last-child td:first-child {
  border-radius: 0 0 0 5px;
}

.table_style1 tr:last-child td:last-child {
  border-radius: 0 0 5px 0;
}

/*color*/
.white	{color:#FFF;}
.black	{color:#000;}
.red	{color:#F00;}
.g9		{color:#999;}
.green	{color:#696;}
.gerry	{color:#CCC;}
.pink	{color:#c69;}
.blue	{color:#69c;}
.yellow	{color:#c96;}
.bro	{color:#cbae86;}

/*margin*/
.mt1	{margin-top:  1px;}
.mt2	{margin-top:  2px;}
.mt3	{margin-top:  3px;}
.mt4	{margin-top:  4px;}
.mt5	{margin-top:  5px;}
.mt6	{margin-top:  6px;}
.mt7	{margin-top:  7px;}
.mt8	{margin-top:  8px;}
.mt9	{margin-top:  9px;}
.mt10	{margin-top: 10px;}
.mt15	{margin-top: 15px;}
.mt18	{margin-top: 18px;}
.mt20	{margin-top: 20px;}
.mt25	{margin-top: 25px;}
.mt30	{margin-top: 30px;}
.mt40	{margin-top: 40px;}
.mt45	{margin-top: 45px;}
.mt50	{margin-top: 50px;}
.mt60	{margin-top: 60px;}
.mt70	{margin-top: 70px;}
.mt80	{margin-top: 80px;}
.mt90	{margin-top: 90px;}
.mt100	{margin-top:100px;}

/*font*/
.bold	{font-weight:bold;}
.normal	{font-weight:normal;}
.fs6	{font-size: 6px;}
.fs7	{font-size: 7px;}
.fs8	{font-size: 8px;}
.fs9	{font-size: 9px;}
.fs10	{font-size:10px;}
.fs11	{font-size:11px;}
.fs12	{font-size:12px;}
.fs13	{font-size:13px;}
.fs14	{font-size:14px;}
.fs15	{font-size:15px;}
.fs16	{font-size:16px;}
.fs17	{font-size:17px;}
.fs18	{font-size:18px;}
.fs19	{font-size:19px;}
.fs20	{font-size:20px;}
.lh100	{line-height:100%;}
.lh110	{line-height:110%;}
.lh120	{line-height:120%;}
.lh130	{line-height:130%;}
.lh140	{line-height:140%;}
.lh150	{line-height:150%;}
.lh160	{line-height:160%;}
.lh170	{line-height:170%;}
.lh180	{line-height:180%;}
.lh190	{line-height:190%;}
.lh200	{line-height:200%;}

/*convenience*/
.block	{display:block;}
.inline	{display:inline;}
.cb		{clear:both;}
.fl		{float:left;}
.fr		{float:right;}
.tl		{text-align:left;}
.tc		{text-align:center;}
.tr		{text-align:right;}

/********************************************/
/*2023-12-29追加 点滅させる */
/********************************************/
@keyframes text05 {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.text05 {
  animation: text05 1.5s linear infinite alternate;
}


/****************************************************/
/*DropDown*/
/****************************************************/
.header_main .main_nav .child {
    position: absolute;
    background-color: rgba(255, 255, 255, 0.8);
    z-index: 1;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    transform: translateY(10px);
  }
  .header_main .main_nav .child li {
    display: block;
    text-align: left;
    border-bottom: 1px solid #ccc;
  }
  .header_main .main_nav .child li a {
    display: block;
    padding: 0.6em 2em;
  }
  .header_main .main_nav .child li a:after {
    content: none;
  }
  
  .header_main .main_nav .dropdown:hover .child {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
  
  @media screen and (max-width: 767px) {
    .header_main .sp_nav .toggle_list {
      border: 0;
    }
    .header_main .sp_nav .btn {
      padding: 1em 0;
      border: 1px solid #ccc;
    }
    .header_main .sp_nav .child {
      display: none;
    }
    .header_main .sp_nav .child li {
      text-align: left;
      border: 0;
    }
    .header_main .sp_nav .child li a {
      padding-bottom: 0;
    }
    .header_main .sp_nav .btn {
      position: relative;
    }
    .header_main .sp_nav .btn:after, .header_main .sp_nav .btn:before {
      position: absolute;
      right: 10px;
      top: 0;
      bottom: 0;
      content: "";
      width: 1em;
      height: 1px;
      margin: auto;
      background-color: #353F66;
      -webkit-transition: all 0.3s;
      transition: all 0.3s;
    }
    .header_main .sp_nav .btn:after {
      transform: rotate(-90deg);
    }
    .header_main .sp_nav .btn.active:after {
      transform: rotate(0);
    }
  }
  