@charset "utf-8";
.container {
  position: relative;
  background: url("../img/dept/general_medicine/bgCol03.jpg") repeat-x center 600px;
  background-size: cover;
  overflow: inherit;
  box-sizing: border-box;
}
.container:before {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  content: '';
  width: 100%;
  height: 600px;
    background: url("../img/dept/checkups/main_pc.jpg") no-repeat center 90px;
  background-size: 100% auto;
  z-index: -1;
}
.pnkz ul li, .pnkz ul li a {
  color: #FFF;
}
.pnkz ul li:not(:last-of-type):after {
  border-top: 1px solid #FFF;
  border-right: 1px solid #FFF;
}
.page-ttl {
  padding: 50px 0 70px 0;
  box-sizing: border-box;
  color: #FFF;
}
.sec_ttl, .ttl {
  position: relative;
  text-align: center;
  font-size: 3rem;
  font-weight: 700;
  color: #001f4b;
  margin-bottom: 35px;
}
.ttl02 {
    position: relative;
    text-align: left;
    font-size: 2.3rem;
    font-weight: 700;
    color: #001f4b;
    margin-bottom: 25px;
}
.ttl02 span {
    font-size: 2.8rem;
    font-weight: 700;
    color: #c42629;
    margin-right: 20px;
    vertical-align: bottom;
}
.ttl03 {
    height: 50px;
    padding-top: 30px;
    position: relative;
    text-align: center;
    font-size: 1.8rem;
    font-weight: 700;
    background-color: #001f4b;
    color: #fff;
    margin-bottom: 25px;
    border-radius: 20px;
}
.ttl04 {
    height: 50px;
    padding-top: 30px;
    position: relative;
    text-align: center;
    font-size: 1.8rem;
    font-weight: 700;
    background-color: #001f4b;
    color: #fff;
    margin:  50px 0 25px;
    border-radius: 20px;
}
.ttl05 {
    position: relative;
    text-align: center;
    font-size: 3rem;
    font-weight: 700;
    color: #001f4b;
    margin-bottom: 25px;
}
.sec_ttl {
  font-size: 3.2rem;
  margin: 30px 0;
}
.ttl:before {
  display: inline-block;
  vertical-align: middle;
  content: '';
  margin: 0 20px 0 0;
  background-size: 100% auto !important;
}
.text, .pc_text_center {
  font-size: 1.5rem;
  line-height: 1.64;
}
.pc_text_center {
  text-align: center;
}
.text_sec {
    text-align: left;
    padding: 0 35px;
    margin-bottom: 30px;
}
.text_sec p {
    font-size: 1.5rem;
    line-height: 1.785;
}
span.atten {
  font-weight: 600;
  color: #c42629;
  line-height: 1.785;
}
.ico {
  text-align: center;
}
.ico img {
  height: 55px;
  width: auto;
}
.xsm {
  font-size: 1.2rem;
}
.sm {
  font-size: 1.5rem;
}
#exam01, #exam02, #exam03, #exam04, #exam05, #exam06 {
  max-width: 1200px;
  padding: 70px 100px 100px 100px;
  background: #FFF;
  box-sizing: border-box;
}
#exam01 .btn_wrap, #exam02 .btn_wrap, #exam03 .btn_wrap, #exam04 .btn_wrap, #exam05 .btn_wrap6, #exam06 .btn_wrap {
  margin: 45px auto 0 auto;
}
#exam01 .btn_wrap .btn, #exam02 .btn_wrap .btn, #exam03 .btn_wrap .btn, #exam04 .btn_wrap .btn, #exam05 .btn_wrap .btn, #exam06 .btn_wrap .btn {
  max-width: 390px;
  margin: 0 auto;
}
.bg_blue {
  background: rgba(202, 202, 202, .22);
}
.bg_pink {
  background: rgba(231, 168, 169, .2);
}
.anchor {
  display: block;
  padding-top: 50px;
  margin-top: -50px;
}
.pc-flex {
  display: flex;
}
@media screen and (max-width : 767px) {
  .container {
    background: none;
    overflow: visible;
  }
  .container:before {
    display: none;
  }
  .pnkz ul li {
    color: #001f4b;
  }
  .pnkz ul li a {
    color: #99a5b7;
  }
  .pnkz ul li:not(:last-of-type):after {
    border-top: 1px solid #99a5b7;
    border-right: 1px solid #99a5b7;
  }
  .page-ttl {
    color: #001f4b;
    padding: 4% 0;
  }
    .sec_ttl {
        font-size: 2.4rem;
        margin: 2% 0 3%;
    }
  .ttl {
    font-size: 5.867vw;
    margin-bottom: 8%;
    line-height: 1.5;
  }
    .ttl05 {
        margin-bottom: 6%!important;
        line-height: 1.3;
        font-size: 2.4rem;
        text-align: center;
    }
  .ttl:before {
    display: block;
    margin: 0 auto 5% auto;
  }
  .text {
    font-size: 3.733vw;
  }
  .pc_text_center {
    text-align: left;
  }
  #sec01.inner, #exam01, #exam02, #exam03, #exam04, #exam05, #exam06 {
    width: 100%;
    max-width: inherit;
    padding: 10% 4% 14% 4%;
  }
  .pc-flex {
    display: block;
  }
    .ico img {
        height: 95px;
        width: auto;
    }
}
/* ------------------------------
section
------------------------------ */
#sec01,#sec02 {
    max-width: 1200px;
    padding-top: 70px;
    background: #FFF;
    margin: 0 auto;
    box-sizing: border-box;
}
#sec03 {
    max-width: 1200px;
    padding: 100px;
    background: #FFF;
    margin: 0 auto;
    box-sizing: border-box;
}
#sec04 {
    max-width: 1200px;
    padding: 0 100px;
    background: #FFF;
    margin: 80px auto;
    box-sizing: border-box;
}
#sec05,#sec06 {
    max-width: 1200px;
    padding: 0 70px;
    background: #FFF;
    margin: 0 auto;
    box-sizing: border-box;
}
.page-img {
  text-align: center;
  margin: 0 auto;
}
.lead {
  font-size: 1.5rem;
  line-height: 1.785;
  text-align: center;
}
.btn_wrap.page-link {
  width: 100%;
  max-width: 480px;
  margin: 55px auto 0;
}
.btn_wrap {
  margin: 55px 0 100px 0;
}
.btn_wrap.page-link .btn {
  background: #c42629;
  font-size: 2rem;
  border-radius: 12px;
  padding: 28px 30px;
  text-align: center;
  box-sizing: border-box;
}
.round_box_border {
  max-width: 100%;
  max-width: inherit;
  margin: 30px auto 0;
  background: #FFF;
    padding: 4em;
  border: 1px solid #001f4b;
  border-radius: 16px;
  box-sizing: border-box;
}
.round_box_border .ttl {
    font-size: 2.2rem;
}
.round_box_border .ttl02 {
    font-size: 2.2rem;
    text-align: center;
    margin: 30px auto;
}
.check_list {
  max-width: 600px;
  margin: 30px auto 60px;
}
.point_list {
    max-width: 700px;
    margin: 30px auto 60px;
}
.check_list li {
  position: relative;
  font-size: 1.5rem;
  line-height: 1.7;
  font-weight: 500;
  color: #001f4b;
  padding-left: 22px;
  box-sizing: border-box;
}
.point_list li {
    position: relative;
    list-style: initial;
    font-size: 1.5rem;
    line-height: 1.65;
    font-weight: 500;
    color: #001f4b;
    box-sizing: border-box;
    margin-bottom: 20px;
}
.check_list li + li {
  margin-top: 10px;
}
.point_list li + li {
    margin-top: 10px;
}
.check_list li:before {
  position: absolute;
  left: 0;
  top: 6px;
  display: block;
  content: '';
  background: url("../img/online/ico_check.svg") no-repeat center center;
  background-size: 100% auto;
  width: 16px;
  height: 14px;
}
.point_list li:before {
    position: absolute;
    left: 0;
    top: 6px;
    display: block;
    content: '';
    background-size: 100% auto;
    width: 16px;
    height: 14px;
}
.round_box_border .note {
  font-size: 1.5rem;
  line-height: 1.64;
}
.btn_wrap.page-link .btn + .btn {
  margin-top: 30px;
}
@media screen and (max-width : 767px) {
    #sec01 {
        margin: 0;
        padding: 0;
    }
    #sec02 {
        margin-top: 50px;
        padding: 0;
    }
    #sec03 {
        width: 100%;
        padding: 1em;
        background: #FFF;
        margin: 50px auto;
        box-sizing: border-box;
    }
    #sec04 {
        width: 100%;
        padding: 0 1em;
        background: #FFF;
        margin: 50px auto;
        box-sizing: border-box;
    }
    #sec05 {
        width: 100%;
        padding: 0;
        background: #FFF;
        margin: 0 auto;
        box-sizing: border-box;
    }
    #sec06 {
        width: 100%;
        background: #FFF;
        padding: 0;
        margin: 0 auto;
        box-sizing: border-box;
    }
    .page-img {
        margin-bottom: 4%;
        filter: brightness(115%);
    }
    .lead {
        font-size: 3.733vw;
        margin-bottom: 3%;
        text-align: left;
    }
    .round_box_border {
        max-width: 100%;
        max-width: inherit;
        margin: 30px auto 0;
        background: #FFF;
        padding: 1.5em 1.3em 2.3em;
        border: 1px solid #001f4b;
        border-radius: 16px;
        box-sizing: border-box;
    }
    .btn_wrap.page-link {
        width: 92%;
        max-width: inherit;
    }
    .btn_wrap.page-link .btn {
        padding: 7% 7%;
        font-size: 4.267vw;
        box-sizing: border-box;
    }
    .btn_wrap.page-link .btn + .btn {
        margin-top: 4%;
    }
    .btn_wrap.page-link {
        margin: 30px auto 0 auto;
    }
    .ico img {
        height: 10.8vw!important;
        width: auto;
    }
    .round_box_border .ttl {
        font-size: 2.2rem;
        margin-bottom: 20px;
    }
    .round_box_border .ttl02 {
        font-size: 2.2rem;
        text-align: center;
        margin: 30px auto 20px;
    }
    .check_list {
        max-width: 600px;
        margin: 0 auto;
    }
}
/* ------------------------------
sec02
------------------------------ */
.note span.atten {
    font-weight: 800;
    color: #001f4b;
    border-bottom: 1px solid;
}
.disease_contents {
    margin-bottom: 50px;
}
.disease {
    width: 50%;
    margin: 20px auto;
}
.disease02 {
    width: 100%;
    margin: 20px auto;
}
.disease_left {
    width: 40%;
    float: left;
}
.disease_right {
    width: 58%;
    float: right;
}
.disease_left02 {
    width: 21%;
    float: left;
}
.disease_right02 {
    width: 76%;
    float: left;
}
.disease_right03 {
    float: left;
    padding-right: 2.6em;
}
.disease_right04 {
    width: auto;
    float: left;
    padding-right: 2.6em;
    padding-top: 25px;
}
.disease_right h3,.disease_right02 h3,.disease_right03 h3,.disease_right04 h3 {
    font-size: 1.8rem;
    font-weight: 700;
    color: #001f4b;
    margin-bottom: 10px;
}
.disease_title {
    font-size: 1.5rem!important;
    font-weight: 700;
    color: #001f4b;
    margin: 15px 0 5px;
}
.disease_right ul,.disease_right02 ul,.disease_right03 ul,.disease_right04 ul {
    padding-left: 25px;
}
.disease_right li,.disease_right02 li,.disease_right03 li,.disease_right04 li {
    font-size: 1.5rem;
    line-height: 1.785;
    color: #001f4b;
    list-style: initial;
}
.disease_right ul li a,.disease_right02 ul li a,.disease_right03 ul li a,.disease_right04 ul li a {
    color: #001f4b;
    text-decoration: underline;
}
.disease_right ul li a:hover {
    color: #c42629;
    text-decoration: underline;
}
.disease_right02 ul li a:hover {
    color: #c42629;
    text-decoration: underline;
}
.disease_right03 ul li a:hover {
    color: #c42629;
    text-decoration: underline;
}
.disease_ico {
    width: 140px;
    height: 140px;
    position: relative;
    background: #FFF;
    box-shadow: 4px 4px 8px 2px rgba(114, 114, 114, 0.3);
    border-radius: 80px;
    box-sizing: border-box;
}
.disease_ico .ico {
    position: absolute;
    top: 50%;
    left: 51%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}
.disease_ico .ico img {
    height: 85px;
}
.inspection {
    width: 100%;
    margin: 20px 10px;
}
.inspection h3 {
    width: 40%;
    margin: 0 auto 20px;
    color: #001f4b;
    font-size: 1.3em;
    font-weight: 700;
    text-align: center;
}
@media screen and (max-width : 767px) {
    .text_sec {
        text-align: left;
        padding: 0;
        margin: 30px auto;
    }
    .disease,.disease02 {
        width: 100%;
        margin: 0 auto;
        clear: both;
    }
    .ttl02 {
        clear: both;
        text-align: left;
        font-size: 2.3rem;
        font-weight: 700;
        color: #001f4b;
        margin-bottom: 20px;
    }
    .ttl03 {
        clear: both;
        height: auto;
        text-align: center;
        padding-top: 30px;
        line-height: 1.3;
        font-size: 1.8rem;
        font-weight: 700;
        padding: 1em;
        background-color: #001f4b;
        color: #fff;
        border-radius: 20px;
        margin-bottom: 10px;
    }
    .disease_ico {
        width: 23vw;
        height: 23vw;
        position: relative;
        background: #FFF;
        box-shadow: 4px 4px 8px 2px rgba(114, 114, 114, 0.3);
        border-radius: 100px;
        box-sizing: border-box;
    }
    .disease_left {
        width: 32%;
        float: left;
        margin-bottom: 30px;
    }
    .disease_right {
        width: 63%;
        float: right;
        margin-bottom: 30px;
    }
    .disease_right li {
        font-size: 1.4rem;
        line-height: 1.7;
        color: #001f4b;
        list-style: initial;
    }
    .disease_left02 {
        width: 32%;
        float: left;
        margin-bottom: 30px;
    }
    .disease_right02,.disease_right03,.disease_right04 {
        width: 63%;
        float: right;
        margin-bottom: 30px;
        padding: 0;
    }
    .point_list {
        padding: 0 35px;
        margin: 20px auto 50px;
    }
    .inspection {
        width: 100%;
        margin: 50px 10px;
    }
}
/* ------------------------------
sec03
------------------------------ */
#sec03 .inner{
    max-width: 1200px;
    padding: 54px 100px 94px 88px;
    background: #FFF;
    box-sizing: border-box;
    margin-bottom: 107px;
}
#sec03 .box{
    margin-top: 40px;
}
#sec03 .lead{
    font-size: 1.5rem;
    line-height: 1.785;
    letter-spacing: 0.05em;
    text-align: center;
    margin-bottom: 57px;
}
#sec03 .flex-box{
    display: grid;
    grid-template-rows: auto 14px auto 20px auto;
    grid-template-columns: 320px 40px 426px 20px 1fr;
}
#sec03 .flex-box + .flex-box{
    margin-top: 60px;
}
#sec03 .flex-box .img{
    grid-row: 1/6;
    grid-column: 1/2;
    width: 320px;
    height: 320px;
    border-radius: 15px;
    overflow: hidden;
    box-shadow: 5px 5px 7px rgba(144,144,144,0.3);
    margin: 0;
}
.object-fit-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    font-family: 'object-fit: cover;';
    filter: brightness(140%);
}
#sec03 .flex-box .name_wrap{
    grid-row: 1/2;
    grid-column: 3/6;
}
#sec03 .flex-box .name{
    font-size: 1.2rem;
    font-weight: 500;
    color: #001f4b;
    padding-top:11px;
    line-height: 1.3;
}
#sec03 .flex-box .name span{
    display: block;
    margin-bottom: 4px;
    font-size: 2.4rem;
    letter-spacing: 0.05em;
    font-weight: normal;
}
#sec03 .flex-box .potision{
    border-bottom: 1px solid #001f4b;
    padding-bottom: 6px;
    margin-top: 17px;
    font-size: 1.4rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.3;
    color: #082248;
}
#sec03 .flex-box .list_ttl{
    font-size: 1.4rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    margin-bottom: 10px;
    line-height: 1;
    color: #082248;
}
#sec03 .flex-box .career_wrap{
    grid-row: 3/4;
    grid-column: 3/4;
}
#sec03 .flex-box dt,
#sec03 .flex-box dd,
#sec03 .flex-box ul li{
    font-size: 1.2rem;
    font-weight: 500;
    color: #001f4b;
    line-height: 1.85;
}
#sec03 .flex-box .career_wrap dl{
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
}
#sec03 .flex-box .career_wrap dt{
    width: 50px;
}
#sec03 .flex-box .career_wrap dd{
    width: calc(100% - 50px);
}
#sec03 .flex-box .qualification_wrap{
    grid-row: 3/4;
    grid-column: 5/6;
    font-size: 1.2rem;
    font-weight: 500;
    color: #001f4b;
    line-height: 1.85;
}
#sec03 .flex-box .specialized_wrap{
    grid-row: 5/6;
    grid-column: 3/5;
}
#sec03 .flex-box .specialized_wrap .list_ttl{
    margin-bottom: 13px;
}
#sec03 .flex-box .specialized_wrap ul{
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}
#sec03 .flex-box .specialized_wrap li{
    display: inline-block;
    text-align: center;
    vertical-align: middle;
    margin-right: 5px;
    margin-bottom: 7px;
    color: #FFF;
    font-size: 1.2rem;
    background: rgba(0,31,75,.5);
    padding: 0 13px 2px 13px;
    border-radius: 16px;
    box-sizing: border-box;
}
@media screen and (max-width : 767px){
    .pc_wrapper{
        display: block;
        justify-content: space-between;
    }

    #sec03.inner{
        max-width: inherit;
        padding: 6% 0 0;
        margin-bottom: 15vw;
    }
    .page-img{ margin-bottom: 4%;}

    #sec03 .lead{
        font-size: 3.733vw;
        margin-bottom: 5%;
        text-align: left;
    }
    #sec03 .box{
        width: 100%;
        margin: 0 auto;
    }
    #sec03 .flex-box{
        grid-template-rows: auto 6vw auto 4vw auto 4vw auto;
        grid-template-columns: 32vw 5vw 1fr;
        box-shadow: 3px 3px 9px rgba(144,144,144,0.3);
        padding: 5vw 5vw 9vw;
        border-radius: 8px;
    }
    #sec03 .flex-box + .flex-box{
        margin-top: 5.6vw;
    }
    #sec03 .flex-box .img{
        grid-row: 1/2;
        grid-column: 1/2;
        width: 32vw;
        height: 32vw;
        border-radius: 5px;
        box-shadow: none;
    }
    #sec03 .flex-box .name_wrap{
        grid-row: 1/2;
        grid-column: 3/4;
    }
    #sec03 .flex-box .name{
        padding-top: 4vw;
        font-size: 2.6vw;
    }
    #sec03 .flex-box .name span{
        font-size: 5.6vw;
        margin-bottom: 0.5vw;
    }
    #sec03 .flex-box .potision{
        border-bottom: none;
        padding-bottom: 0;
        margin-top: 4vw;
        font-size: 2.9vw;
        line-height: calc(34/22);
    }
    #sec03 .flex-box .list_ttl{
        font-size: 3.4vw;
        margin-bottom: 2vw;
    }
    #sec03 .flex-box .career_wrap{
        grid-row: 3/4;
        grid-column: 1/4;
        padding-bottom: 4vw;
        border-bottom: 1px solid #001f4b;
    }
    #sec03 .flex-box dt,
    #sec03 .flex-box dd,
    #sec03 .flex-box ul li{
        font-size: 2.4vw;
        line-height: 1.65;
    }
    #sec03 .flex-box .career_wrap dt{
        width: 10vw;
    }
    #sec03 .flex-box .career_wrap dd{
        width: calc(100% - 10vw);
    }
    #sec03 .flex-box .qualification_wrap{
        grid-row: 5/6;
        grid-column: 1/4;
        padding-bottom: 4vw;
        border-bottom: 1px solid #001f4b;
        font-size: 2.4vw;
    }
    #sec03 .flex-box .specialized_wrap{
        grid-row: 7/8;
        grid-column: 1/4;
    }
    #sec03 .flex-box .specialized_wrap .list_ttl{
        margin-bottom: 2.5vw;
    }
    #sec03 .flex-box .specialized_wrap li{
        margin-right: 5px;
        margin-bottom: 7px;
        font-size: 2.933vw;
        background: rgba(0,31,75,.5);
        padding: 0 15px 2px 15px;
        border-radius: 14px;
    }
}
/* ------------------------------
sec04
------------------------------ */

/* ------------------------------
table01
------------------------------ */
td p {
    font-size: 100%;
}
.schedule_table td{
    text-align: center;
    vertical-align: middle;
    padding: 8px;
    color: #333;
    word-break: break-all;
    background-color: #fff;
    border: 1px solid #595959;
}
.schedule_table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 30px;
}
.schedule_table a {
    font-weight: bold;
}
.schedule_table th{
    width: 100%;
    vertical-align: middle;
    border-collapse: collapse;
    font-size: 1.15em;
    text-align: center;
    background-color: #394B6C;
    border: 1px solid #898989;
    color: #fff;
    font-weight: 700;
}
.schedule_table th {
    width: 10%;
}
.schedule_table th .schedule_table_header {
    width: auto;
    background-color: #394B6C;
    border: 1px solid #898989;
    color: #fff;
    font-weight: 700;
}
.schedule_table_time {
    width: auto;
    background-color: #6A7891!important;
}
.schedule_table_other {
    width: auto;
}
.schedule_table_other02 {
    width: auto;
    background-color: #EAEAEA!important;
}
/* ------------------------------
table02
------------------------------ */
.schedule_table02 td{
    text-align: center;
    vertical-align: middle;
    padding: 0 5px;
    color: #333;
    word-break: break-all;
    background-color: #fff;
    border: 1px solid #595959;
}
.schedule_table02 {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 30px;
}
.schedule_table02 a {
    font-weight: bold;
}
.schedule_table02 th{
    width: 100%;
    vertical-align: middle;
    border-collapse: collapse;
    font-size: 1.15em;
    text-align: center;
    background-color: #C35E5A;
    border: 1px solid #595959;
    color: #fff;
    font-weight: 700;
}
.schedule_table02 th {
    width: 10%;
}
.schedule_table02 th .schedule_table02_header {
    width: auto;
    background-color: #C35E5A;
    border: 1px solid #595959;
    color: #fff;
    font-weight: 700;
}
.schedule_table02_time {
    width: auto;
    background-color: #D28683!important;
}
.schedule_table02_other {
    width: auto;
}
.schedule_table02_other02 {
    width: auto;
    background-color: #EAEAEA!important;
}
.schedule_table02_time_b {
    width: auto;
    padding: 25px 5px!important;
    background-color: #D28683!important;
}
.schedule_table02_other_b {
    width: auto;
    padding: 25px 5px!important;
}
.schedule_table02_other02_b {
    width: auto;
    padding: 25px 5px!important;
    background-color: #EAEAEA!important;
}
/* ------------------------------
table03
------------------------------ */
.schedule_table03 td{
    text-align: center;
    vertical-align: middle;
    padding: 20px 5px;
    color: #333;
    word-break: break-all;
    background-color: #fff;
    border: 1px solid #595959;
}
.schedule_table03 {
    width: 100%;
    border-collapse: collapse;
}
.schedule_table03 a {
    font-weight: bold;
}
.schedule_table03 th{
    width: 100%;
    vertical-align: middle;
    border-collapse: collapse;
    font-size: 1.15em;
    text-align: center;
    background-color: #848484;
    border: 1px solid #595959;
    color: #fff;
    font-weight: 700;
}
.schedule_table03 th {
    width: 10%;
}
.schedule_table03 th .schedule_table03_header {
    width: auto;
    background-color: #848484;
    border: 1px solid #898989;
    color: #fff;
    font-weight: 700;
}
.schedule_table03_time {
    width: auto;
    background-color: #C1C1C1!important;
}
.schedule_table03_other {
    width: auto;
}
.schedule_table03_other02 {
    width: auto;
    background-color: #EAEAEA!important;
}
/* ------------------------------
table04
------------------------------ */
td p {
    font-size: 100%;
}
.contents_table td{
    text-align: left;
    vertical-align: middle;
    padding: 8px 20px;
    font-size: 1.1em;
    color: #333;
    word-break: break-all;
    background-color: #fff;
    border: 1px solid #081E48;
}
.contents_table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 30px;
}
.contents_table a {
    font-weight: bold;
}
.contents_table th{
    width: 100%;
    vertical-align: middle;
    border-collapse: collapse;
    font-size: 1.1em;
    padding: 8px 20px;
    text-align: center;
    background-color: #637691;
    border: 1px solid #081E48;
    color: #fff;
    font-weight: 700;
}
.contents_table th {
    width: 10%;
}
.contents_table th .contents_table_header {
    width: auto;
    background-color: #637691;
    border: 1px solid #081E48;
    color: #fff;
    font-weight: 700;
}
.contents_table_header02 {
    width: auto;
    background-color: #EDEDED!important;
    border: 1px solid #081E48;
    color: #333!important;
    font-weight: 700;
    text-align: left!important;
}
.contents_table_time {
    width: auto;
    background-color: #637691!important;
}
.contents_table_other {
    width: auto;
}
.contents_table_other02 {
    width: auto;
    background-color: #081E48!important;
}
@media screen and (max-width: 767px) {
    td p {
        font-size: 100%;
    }
    .contents_table th{
        vertical-align: middle;
        border-collapse: collapse;
        font-size: 1.1em;
        font-weight: 700;
        padding: 8px 10px;
        text-align: center;
        background-color: #637691;
        border: 1px solid #081E48;
        color: #fff;
    }
    .contents_table td{
        text-align: left;
        vertical-align: middle;
        padding: 8px 10px;
        font-size: 1.1em;
        font-weight: 500;
        color: #333;
        word-break: break-all;
        background-color: #fff;
        border: 1px solid #081E48;
    }
    .schedule_table {
        width: 100%;
        border-collapse: collapse;
    }
    .schedule_table th {
        width: 100%;
        vertical-align: middle;
        border-collapse: collapse;
        padding: 3px;
        font-size: 0.75em;
        text-align: center;
        background-color: #394B6C;
        border: 1px solid #898989;
        color: #fff;
        font-weight: 700;
    }
    .schedule_table td {
        text-align: center;
        vertical-align: middle;
        padding: 3px;
        font-size: 0.75em;
        font-weight: 500;
        color: #303030;
        word-break: break-all;
        background-color: #fff;
        border: 1px solid #ccc;
    }
    .schedule_table th {
        width: 12%;
    }
    .schedule_table_heade {
        width: auto;
    }
    .schedule_table_time {
        width: auto;
        background-color: #6A7891!important;
    }
    .schedule_table_other {
        width: auto;
    }
    .schedule_table_other02 {
        width: auto;
        background-color: #EAEAEA;
    }
    .schedule_table02 td{
        text-align: center;
        vertical-align: middle;
        padding: 3px;
        color: #333;
        font-size: 0.75em;
        font-weight: 500;
        word-break: break-all;
        background-color: #fff;
        border: 1px solid #595959;
    }
    .schedule_table02 {
        width: 100%;
        border-collapse: collapse;
        margin-bottom: 30px;
    }
    .schedule_table02 a {
        font-weight: bold;
    }
    .schedule_table02 th{
        width: 100%;
        vertical-align: middle;
        border-collapse: collapse;
        font-size: 0.75em;
        text-align: center;
        background-color: #C35E5A;
        border: 1px solid #595959;
        color: #fff;
        font-weight: 700;
    }
    .schedule_table02 th {
        width: 12%;
    }
    .schedule_table02 th .schedule_table02_header {
        width: auto;
        background-color: #C35E5A;
        border: 1px solid #595959;
        color: #fff;
        font-weight: 700;
    }
    .schedule_table02_time {
        width: auto;
        background-color: #D28683!important;
    }
    .schedule_table02_other {
        width: auto;
    }
    .schedule_table02_other02 {
        width: auto;
        background-color: #EAEAEA!important;
    }
    .schedule_table02_time_b {
        width: auto;
        padding: 5px!important;
        background-color: #D28683!important;
    }
    .schedule_table02_other_b {
        width: auto;
        padding: 5px!important;
    }
    .schedule_table02_other02_b {
        width: auto;
        padding: 5px!important;
        background-color: #EAEAEA!important;
    }
    .schedule_table03 td{
        text-align: center;
        vertical-align: middle;
        padding: 3px;
        color: #333;
        font-size: 0.75em;
        font-weight: 500;
        word-break: break-all;
        background-color: #fff;
        border: 1px solid #595959;
    }
    .schedule_table03 {
        width: 100%;
        border-collapse: collapse;
    }
    .schedule_table03 a {
        font-weight: bold;
    }
    .schedule_table03 th{
        width: 100%;
        vertical-align: middle;
        border-collapse: collapse;
        font-size: 0.75em;
        text-align: center;
        background-color: #848484;
        border: 1px solid #595959;
        color: #fff;
        font-weight: 700;
    }
    .schedule_table03 th {
        width: 12%;
    }
    .schedule_table03 th .schedule_table03_header {
        width: auto;
        background-color: #848484;
        border: 1px solid #898989;
        color: #fff;
        font-weight: 700;
    }
    .schedule_table03_time {
        width: auto;
        background-color: #C1C1C1!important;
    }
    .schedule_table03_other {
        width: auto;
    }
    .schedule_table03_other02 {
        width: auto;
        background-color: #EAEAEA!important;
    }
}
/* ------------------------------
sec05
------------------------------ */
#sec05 {
    position: relative;
    margin-top: 100px;
}
#sec05 .bg_parallax {
    background: url("../img/index/bg-medical_treatment_pc@2x.jpg") no-repeat 0 0/cover, #fff;
}
#sec05.bg .bg_parallax + .wrap {
    position: relative;
    top: 290px;
    padding-top: 105px;
    padding-bottom: 105px;
    margin-bottom: 132px;
    z-index: 2;
}
#sec05 .bg .wrap {
    padding-left: 80px;
    padding-right: 80px;
}
#sec05 .subttl {
    width: 100%;
    max-width: 495px;
    margin: 0 auto 45px auto;
    text-align: center;
    color: #001f4b;
    font-size: 1.4rem;
    font-weight: 500;
}
#sec05 .subttl span {
    display: block;
    text-align: center;
    font-size: 3.2rem;
    font-weight: 400;
    border-bottom: 1px solid #001f4b;
    padding-bottom: 25px;
    margin-bottom: 15px;
    box-sizing: border-box;
}
#sec05 .lead {
    text-align: center;
    font-size: 1.8rem;
    line-height: 1.86;
    letter-spacing: 0.1rem;
    margin-bottom: 70px;
}

.page-mental .sec03 .lead {
    font-size: 1.6rem;
}

.department_wrap {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-bottom: 80px;
}

.page-mental .department_wrap {
    justify-content: center;
    margin-bottom: 90px;
}

.department_wrap .box {
    width: 32%;
    max-width: 320px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 21px 30px 20px 30px;
    box-sizing: border-box;
}

.page-clinic .department_wrap .box {
    display: block;
    text-align: center;
    width: 23.5%;
    max-width: 235px;
}

.page-mental .department_wrap .box {
    margin-right: 2%;
}
.page-mental .department_wrap .box:nth-of-type(4n) {
    margin-right: 0;
}

#sec05 .box {
    position: relative;
    background: #FFF;
    box-shadow: 4px 4px 8px 2px rgba(114, 114, 114, 0.3);
    border-radius: 16px 0 16px 16px;
    margin-bottom: 22px;
    margin-right: 12px;
    box-sizing: border-box;
}

.page-clinic .sec03 .box {
    padding-bottom: 100px;
}

#sec05 .box:before {
    position: absolute;
    right: 0;
    top: 0;
    display: block;
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 21px 21px 0;
}
#sec05 .department_wrap .box:before {
    border-color: transparent #001f4b transparent transparent;
}
#sec05 .specialty_wrap .box:before {
    border-color: transparent #c42629 transparent transparent;
}

.department_wrap .box .img {
    width: 36%;
    text-align: center;
}

.page-clinic .department_wrap .box .img {
    margin: 0 auto;
}

.department_wrap .box .img img {
    margin: 0 auto;
}
.department_wrap .box h4 {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    margin-left: 10px;
    font-size: 2rem;
    line-height: 1.45;
    font-weight: 500;
    color: #001f4b;
}

.page-clinic .department_wrap .box h4 {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 15px;
    margin: 0 auto;
    margin-left: 0;
    text-align: center;
    font-size: 2.1rem;
    height: 72px;
}

.page-mental .department_wrap .box h4 span {
    display: block;
    font-size: 1.7rem;
}

.ico_txt_wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: -30px;
    margin-bottom: 50px;
}
.ico_txt_wrap li {
    position: relative;
    font-size: 1.8rem;
    font-weight: 500;
}
.ico_txt_wrap li + li {
    margin-left: 30px;
}
.ico_txt_wrap li:before {
    position: relative;
    top: -2px;
    display: inline-block;
    vertical-align: middle;
    content: "";
    background-size: 100% auto !important;
    margin-right: 15px;
}
.ico_txt_wrap li.possible {
    color: #001f4b;
}
.ico_txt_wrap li.possible:before {
    background: url("../img/index/ico_online_possible.svg") no-repeat center center;
    width: 31px;
    height: 25px;
}
.ico_txt_wrap li.impossible {
    color: #c42629;
}
.ico_txt_wrap li.impossible:before {
    background: url("../img/index/ico_online_impossible.svg") no-repeat center center;
    width: 34px;
    height: 33px;
}
@media screen and (max-width: 767px) {
    #sec05 {
        padding-bottom: 0;
        margin: 0 auto;
    }
    #sec05 .bg_parallax::before {
        background: url("../img/index/bg-medical_treatment_sp.jpg") no-repeat center center/cover, #fff;
    }
    #sec05.bg .bg_parallax + .wrap {
        top: 0;
        padding: 7% 0 1% 0;
        margin-bottom: 0;
    }
    #sec05 .lead, #sec05 .specialty_wrap, #sec05 .gray_box {
        padding-left: 5%;
        padding-right: 5%;
    }
    .bg_parallax .ttl_wrap .sec-ttl {
        padding: 13% 0 13% 45px;
    }
    .bg_parallax .ttl_wrap .sec-ttl .num {
        font-size: 9.333vw;
    }
    #sec05 .subttl {
        width: 44vw;
        max-width: inherit;
        margin: 0 auto 8% auto;
        font-size: 3.467vw;
    }
    #sec05 .subttl span {
        font-size: 5.333vw;
        padding-bottom: 15px;
        margin-bottom: 11px;
    }
    #sec05 .lead {
        font-size: 3.733vw;
        text-align: left;
        margin-bottom: 10%;
    }
    .department_wrap {
        margin-bottom: 10%;
    }
    .page-mental .department_wrap {
        margin-bottom: 8%;
    }
    .department_wrap .box {
        position: relative;
        width: 32%;
        max-width: inherit;
        padding: 6% 5px 15% 5px;
    }
    .page-clinic .department_wrap .box {
        width: 46%;
        max-width: inherit;
    }
    .page-clinic .sec03 .box {
        padding-bottom: 20%;
        margin: 2%;
    }
    .page-mental .department_wrap .box {
        display: flex;
        width: 100%;
        max-width: inherit;
        padding-top: 5%;
        padding-bottom: 5%;
    }
    .department_wrap .box:nth-of-type(even), .specialty_wrap .box:nth-of-type(even) {
        background: #f2f4f6;
    }
    #sec05 .box {
        display: block;
        border-radius: 14px 5px 14px 5px;
        box-shadow: 2px 2px 6px 0px rgba(114, 114, 114, 0.3);
        margin-bottom: 2%;
        margin-right: 1.3%;
    }
    #sec05 .box:before {
        position: absolute;
        right: 0;
        top: 0;
        display: block;
        content: "";
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 0 21px 21px 0;
    }
    .department_wrap .box .img {
        width: 76%;
        margin: 0 auto;
    }
    .page-mental .department_wrap .box .img {
        width: 23%;
        margin: 0;
    }
    .department_wrap .box .img img {
        width: 50%;
    }
    .department_wrap .box h4 {
        position: absolute;
        left: 0;
        right: 0;
        bottom: 6%;
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
        height: 11vw;
        font-size: 3.2vw;
        line-height: 1.45;
        margin-top: 0;
        margin-left: 0;
    }
    .page-clinic .department_wrap .box h4 {
        bottom: 8%;
        height: 12vw;
        font-size: 4.267vw;
    }
    .page-mental .department_wrap .box h4 {
        position: relative;
        display: block;
        left: auto;
        bottom: auto;
        height: auto;
        text-align: left;
    }
    .page-mental .department_wrap .box h4 span {
        display: inline;
        font-size: 4.267vw;
    }
    .department_wrap .box .txt {
        width: 54%;
    }
    .department_wrap .box .txt p {
        font-size: 3.2vw;
    }
    .ico_txt_wrap {
        flex-direction: column;
        margin: -5% auto 7% auto;
    }
    .ico_txt_wrap li {
        font-size: 3.733vw;
    }
    .ico_txt_wrap li + li {
        margin-left: 0;
        margin-top: 10px;
    }
}
/* ------------------------------
reserve_wrap
------------------------------ */
.reserve_wrap{
    max-width: 1000px;
    margin-top: 60px;
    margin-bottom: 80px;
    background: rgba(202,202,202,.22);
    border-radius: 16px;
    padding: 65px 20px 88px 20px;
    box-sizing: border-box;
}
.reserve_wrap h2,
.reserve_wrap02 h2{
    position: relative;
    text-align: center;
    font-size: 2.4rem;
    letter-spacing: .25rem;
    color: #001f4b;
    font-weight: 700;
    margin: 0 auto 15px auto;
}
.reserve_wrap h2:before{
    position: relative;
    top: -5px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 20px;
    content: '';
    background: url("../img/pcr/ico_reserve.svg") no-repeat center center;
    width: 48px;
    height: 72px;
}

.reserve_wrap p{
    text-align: center;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.6;
}
.reserve_wrap p.atten{
    margin-top: 15px;
    text-align: center;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.6;
    color: #d3001d;
}

.reserve_wrap .btn_wrap{
    margin: 30px auto 35px auto;
}
.reserve_wrap .btn_wrap span{
    color: #fff;
}
.reserve_wrap02 .btn_wrap{
    margin: 58px auto 0 auto;
}
.reserve_wrap .btn_wrap .btn,
.reserve_wrap02 .btn_wrap .btn{
    position: relative;
    max-width: 390px;
    margin: 0 auto;
    padding: 2px 10px 17px 10px;
}
.reserve_wrap .btn_wrap .btn+.btn,
.reserve_wrap02 .btn_wrap .btn+.btn{ margin-top: 20px;}

.reserve_wrap .btn_wrap .btn span,
.reserve_wrap02 .btn_wrap .btn span{
    position: relative;
}
.reserve_wrap .btn_wrap .btn span:before,
.reserve_wrap02 .btn_wrap .btn span:before{
    position: relative;
    top: 7px;
    display: inline-block;
    margin-right: 15px;
    content: '';
    background-size: 100% auto !important;
    width: 27px;
    height: 27px;
}
.reserve_wrap .btn_wrap .btn.ico_appointment span:before,
.reserve_wrap02 .btn_wrap .btn.ico_appointment span:before{
    background: url("../img/pcr/ico_appointment.svg") no-repeat center center;
}
.reserve_wrap .btn_wrap .btn.ico_pcr_form span:before,
.reserve_wrap02 .btn_wrap .btn.ico_pcr_form span:before{
    background: url("../img/pcr/ico_pcr_form.svg") no-repeat center center;
}
.reserve_wrap .tel_wrap{
    width: 100%;
    max-width: 390px;
    margin: 15px auto 0 auto;
    background: #c42629;
    padding: 11px 10px 17px 10px;
    border-radius: 10px;
    box-sizing: border-box;
}
.reserve_wrap .tel_wrap p{
    text-align: center;
    color: #FFF!important;
}
.reserve_wrap .tel_wrap p.tel{
    font-size: 2.1rem;
    font-weight: 700;
    letter-spacing: .2rem;
    color: #FFF!important;
}
.reserve_wrap .tel_wrap p.tel span{
    position: relative;
    color: #FFF!important;
}
.reserve_wrap .tel_wrap p.tel span:before{
    position: relative;
    display: inline-block;
    vertical-align: middle;
    margin-right: 13px;
    content: '';
    background: url("../img/common/ico-tel_white.svg") no-repeat center center;
    background-size: 100% auto;
    width: 20px;
    height: 20px;
    color: #FFF!important;
}
.reserve_wrap .tel_wrap p.tel-txt{
    font-size: 1.4rem;
    font-weight: 500;
}

@media screen and (max-width : 767px){
    .reserve_wrap{
        width: 100%;
        max-width: inherit;
        margin-top: 8%;
        margin-bottom: 12%;
        border-radius: 0;
        padding: 12% 0;
        box-sizing: border-box;
    }
    .reserve_wrap02{
        width: 100%;
        margin-top: 12%;
        margin-bottom: 12%;
        background: rgba(202,202,202,.22);
        padding: 12% 0;
        box-sizing: border-box;
    }
    .reserve_wrap .reserve_in{
        width: 92%;
        margin: 0 auto;
        padding: 12% 5%;
        background: #FFF;
        box-shadow: 5px 5px 10px -4px rgb(114 114 114 / 30%);
        border-radius: 13px;
        box-sizing: border-box;
    }
    .reserve_wrap02 .reserve_in{
        width: 92%;
        margin: 0 auto;
        box-sizing: border-box;
    }

    .reserve_wrap h2,
    .reserve_wrap02 h2{
        margin: 0 auto 8% auto;
    }
    .reserve_wrap h2:before {
        position: relative;
        top: 0;
        right: -3vw;
        display: block;
        margin: 0 auto 4% auto;
        background-size: 100% auto;
        width: 14vw;
        height: 20vw;
    }
    .reserve_wrap p{
        font-size: 3.733vw;
        font-weight: 400;
        line-height: 1.64;
    }

    .reserve_wrap .btn_wrap{
        margin: 6% auto 8% auto;
    }
    .reserve_wrap02 .btn_wrap{
        margin: 6% auto 0 auto;
    }
    .reserve_wrap .btn_wrap .btn,
    .reserve_wrap02 .btn_wrap .btn{
        max-width: inherit;
        margin: 0 auto;
        padding: 1vw 10px 4.7vw 10px;
        border-radius: 50px;
    }
    .reserve_wrap .btn_wrap .btn+.btn,
    .reserve_wrap02 .btn_wrap .btn+.btn{ margin-top: 4%;}

    .reserve_wrap .btn_wrap .btn span:before,
    .reserve_wrap02 .btn_wrap .btn span:before{
        top: 1.5vw;
        display: inline-block;
        margin-right: 15px;
        width: 7vw;
        height: 7vw;
    }

    .no-whitebox.reserve_wrap .reserve_in{
        background: none;
        box-shadow: none;
        padding: 0;
    }
    /*    .no-whitebox.reserve_wrap h2:before,
    .no-whitebox.reserve_wrap p{ display: none;}*/
    .reserve_wrap p.atten{
        margin: 10px auto 0 auto;
        font-size: 3.733vw;
    }
    .reserve_wrap .tel_wrap{
        width: 100%;
        max-width: inherit;
        padding: 0;
        border-radius: 50px;
    }
    .reserve_wrap .tel_wrap p.tel a{
        display: block;
        padding: 2.7vw 10px 3.0vw 10px;
        border-radius: 50px;
        background: #c42629;
    }
    .reserve_wrap .tel_wrap p.tel,
    .reserve_wrap .tel_wrap p.tel a{
        font-size: 4.533vw;
        letter-spacing: .2rem;
        color: #FFF;
        padding: 2.5vw 10px;
    }
    .reserve_wrap .tel_wrap p.tel span:before{
        margin-right: 13px;
        width: 20px;
        height: 20px;
    }
    .reserve_wrap .tel_wrap p.tel-txt{
        display: none;
    }
    .reserve_wrap .tel_wrap p.tel span{ position: relative;}
    .reserve_wrap .tel_wrap p.tel span:before{
        position: relative;
        display: inline-block;
        vertical-align: middle;
        margin-right: 13px;
        content: '';
        background: url("../img/common/ico-tel_white.svg") no-repeat center center;
        background-size: 100% auto;
        width: 20px;
        height: 20px;
        margin-bottom: 4px;
    }
}
/* ------------------------------
tabarea
------------------------------ */
.tabarea,.tabarea02 {
  margin: 0 auto;
/*  padding: 75px 0;*/
}
.tabarea .ttl {
  color: #001f4b;
  font-size: 2.1rem;
  text-align: center;
  font-weight: bold;
}
.tabarea02 .ttl {
    color: #001f4b;
    font-size: 2.1rem;
    text-align: center;
    font-weight: bold;
}
.tabarea .tab_wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 13px 30px;
  margin-top: 34px;
  margin: 0 auto 80px;
}
.tabarea02 .tab_wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 13px 30px;
    margin-top: 34px;
    margin: 0 auto;
}
.tabarea a {
  cursor: pointer;
  border-radius: 8px;
  padding: 17px 25px 17px 17px;
  color: #001f4b;
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 1.3;
  text-align: center;
  width: calc((100% - 60px) / 2);
  box-shadow: 5px 5px 7px rgba(144, 144, 144, 0.3);
  background: url(../img/common/ico-arrow.svg) no-repeat right 17px center / 8px auto;
  transition: opacity 0.3s ease;
  box-sizing: border-box;
  margin-top: 15px;
}
.tabarea02 a {
    cursor: pointer;
    border-radius: 8px;
    padding: 17px 25px 17px 17px;
    color: #001f4b;
    font-weight: 500;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    line-height: 1.3;
    text-align: center;
    width: calc((100% - 60px) / 3);
    box-shadow: 5px 5px 7px rgba(144, 144, 144, 0.3);
    background: url(../img/common/ico-arrow.svg) no-repeat right 17px center / 8px auto;
    transition: opacity 0.3s ease;
    box-sizing: border-box;
    margin-top: 15px;
}
.tabarea .tab.js-active {
  background-color: #f2f4f6;
}
.tab.js-tab {
  background-color: #fff;
}
.tabarea .tab:hover {
  opacity: 0.7;
}
@media screen and (max-width : 767px) {
    .tabarea,.tabarea02 {
        margin: 0 auto;
    }
    .tabarea a,.tabarea02 a {
        width: 100%!important;
        cursor: pointer;
        border-radius: 8px;
        padding: 17px 25px 17px 17px;
        color: #001f4b;
        font-weight: 500;
        font-size: 1.6rem;
        letter-spacing: 0.05em;
        line-height: 1.3;
        text-align: center;
        box-shadow: 5px 5px 7px rgba(144, 144, 144, 0.3);
        background: none;
        transition: opacity 0.3s ease;
        box-sizing: border-box;
    }
    .tabarea .tab_wrap {
        width: 100%;
    }
    .tabarea02 .tab_wrap {
        width: 100%;
    }
    .tabarea .ttl {
        font-size: 5.3vw;
    }
    .tabarea02 .ttl {
        font-size: 5.3vw;
    }
    .tabarea .tab_wrap {
        gap: 2vw 2%;
    }
    .tabarea02 .tab_wrap {
        gap: 2vw 2%;
    }
    .tabarea .tab {
        border-radius: 4px;
        padding: 3.5vw 8vw 3.5vw 5vw;
        font-size: 3.77vw;
        font-weight: bold;
        background: url(../img/common/ico-arrow.svg) no-repeat right 4vw center / 1.8vw auto;
    }
    .tabarea02 .tab {
        border-radius: 4px;
        padding: 3.5vw 8vw 3.5vw 5vw;
        font-size: 3.77vw;
        font-weight: bold;
        background: url(../img/common/ico-arrow.svg) no-repeat right 4vw center / 1.8vw auto;
    }
    .tab.js-tab {
        background-color: #fff;
    }
}

/* ------------------------------
panelarea
------------------------------ */
.panelarea {
  width: 1000px;
  margin: 44px auto 0;
  box-shadow: 5px 5px 7px rgba(144, 144, 144, 0.3);
  border-radius: 8px;
  padding: 57px 50px 96px;
  box-sizing: border-box;
}
.panelarea .panel {
  display: none;
}
.panelarea .panel.js-show {
  display: block;
}
.panelarea .panelttl {
  color: #001f4b;
  font-size: 2.4rem;
  letter-spacing: 0.1em;
  text-align: center;
}
.panelarea .item {
  margin-top: 57px;
}
.panelarea .btn_panel {
  width: 200px;
  margin: 61px auto 0;
}
.panelarea .btn_panel a {
  position: relative;
  width: 100%;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  letter-spacing: 0.05em;
  font-weight: 500;
  color: #FFF;
  background: #001f4b;
  border-radius: 100vh;
  box-sizing: border-box;
  padding-left: 10px;
}
.panelarea .btn_panel a::before {
  position: absolute;
  left: 31px;
  top: 50%;
  margin-top: -4px;
  display: block;
  content: '';
  background: url(../img/common/ico-arrow_white.svg) no-repeat center center;
  background-size: 100% auto;
  width: 10px;
  height: 9px;
  transform: rotate(-90deg);
}
.panelarea .dept_contact {
  margin-top: 80px;
}
@media screen and (max-width : 767px) {
  .panelarea {
    width: 100%;
    margin: 8% auto 0;
    border-radius: 4px;
    padding: 7vw 5vw 16vw;
  }
  .panelarea .panelttl {
    font-size: 6.4vw;
  }
  .panelarea .item {
    margin-top: 9%;
  }
  .panelarea .btn_panel {
    width: 100%;
    margin: 16% auto 0;
  }
  .panelarea .btn_panel a {
    height: 13.3vw;
    font-size: 4.2vw;
    letter-spacing: 0.025em;
    padding-left: 2vw;
  }
  .panelarea .btn_panel a::before {
    left: 8vw;
    margin-top: -1.5vw;
    width: 4vw;
    height: 3vw;
  }
  .panelarea .dept_contact {
    margin-top: 22%;
  }
}
/* ------------------------------
exam01
------------------------------ */
#exam01 .text {
  margin-bottom: 50px;
}
#exam01 picture {
  text-align: center;
}
.covid_btn {
  line-height: normal;
  border-radius: 12px;
}
@media screen and (max-width : 767px) {
  .reason_wrap.wrap {
    margin-bottom: 0;
    width: 100%;
    padding: 30px 20px;
  }
  .price-img {
    padding: 0;
    margin: 30px 0;
  }
  .treatment_cat {
    width: 120px;
  }
  .ty_price {
    font-size: 2.5rem;
  }
  .type {
    padding-top: 10px;
  }
}
/* ------------------------------
exam02
------------------------------ */
#exam02 .check_list {
  margin: 0 auto;
}
#exam02 .round_box_border {
  padding: 20px;
  margin-top: 30px;
  max-width: 800px;
}
#exam02 .check_list_wrap.aos-init.aos-animate {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
/* ------------------------------
exam03
------------------------------ */
.infection {
    margin: 20px 10px;
}
.acc_wrap {
  border: 2px solid #001f4b;
}
.acc_wrap + .acc_wrap {
  margin-top: 20px;
}
.acc_wrap .acc_btn {
  padding: 14px 20px 15px 20px;
}
.acc_wrap .acc_btn:before, .acc_wrap .acc_btn:after {
  position: absolute;
  right: 15px;
  top: 50%;
  display: block;
  content: '';
  border-radius: 12px;
  background: #c42629;
}
.acc_wrap .acc_btn:before, .acc_wrap .acc_btn:after {
  background: #001f4b;
}
.acc_wrap .acc_btn:before {
  width: 16px;
  height: 2px;
}
.acc_wrap .acc_btn:after {
  width: 2px;
  height: 16px;
  margin-top: -7px;
  margin-right: 7px;
  transition: .4s;
}
.acc_wrap .acc_btn.on:after {
  transform: rotate(-90deg);
}
.acc_wrap .acc_btn {
  position: relative;
  padding: 14px 20px 15px 20px;
  cursor: pointer;
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
}
.acc_wrap .acc_btn {
  padding: 10px 10px 12px 10px;
}
#exam03 .acc_wrap .acc_btn {
  display: none;
}
.acc_wrap .acc_btn:before, .acc_wrap .acc_btn:after {
  right: 15px;
}
.acc_wrap .acc_btn:before {
  width: 18px;
}
.acc_wrap .acc_btn:after {
  height: 18px;
  margin-top: -8px;
  margin-right: 8px;
}
.acc_wrap .acc_btn p {
  font-size: 1.8rem;
  font-feature-settings: "palt";
  padding-left: 5px;
  font-weight: 700;
  color: #c42629;
}
.acc_wrap .acc_btn p {
  color: #001f4b;
}
.acc_wrap .acc_cnts {
  display: none;
  padding: 0 30px 40px 30px;
  box-sizing: border-box;
}
.acc_cnts p {
    color: #001f4b;
    font-size: 1.4rem;
    margin-top: -15px;
}
#exam03 .acc_cnts {
  display: block;
  height: 400px;
}
#exam03 h3, #exam04 h3 {
  font-size: 2rem;
  font-feature-settings: "palt";
  padding-left: 5px;
  font-weight: 700;
  color: #001f4b;
  text-align: center;
  margin: 20px 0;
}
.acc_close_btn {
  margin: 35px auto 0 auto;
  width: 108px;
  height: 4px;
  background: #c42629;
  cursor: pointer;
  border-radius: 15px;
}
.acc_close_btn {
  background: #001f4b;
}
.acc_close_btn.pc {
  text-align: center;
  width: auto;
  height: auto;
  background: none;
  border-radius: 0;
}
.acc_close_btn.pc p {
  position: relative;
  display: inline-block;
  text-align: center;
  font-size: 1.5rem;
  font-weight: 500;
  color: #c42629;
}
.acc_close_btn.pc p {
  color: #001f4b;
}
#exam03 .acc_close_btn.pc p {
  display: none;
}
.acc_close_btn.pc p:after {
  display: block;
  content: '';
  margin: 5px auto 0 auto;
  width: 68px;
  height: 2px;
  background: #c42629;
}
.acc_close_btn.pc p:after {
  background: #001f4b;
}
.acc_close_btn.pc span {
  position: relative;
  padding: 0 5px 0 16px;
  box-sizing: border-box;
}
.acc_close_btn.pc span:before, .acc_close_btn.pc span:after {
  position: absolute;
  left: 0;
  top: 11px;
  display: inline-block;
  content: '';
  width: 12px;
  height: 1px;
  background: #c42629;
  transform: rotate(45deg);
}
.acc_close_btn.pc span:before, .acc_close_btn.pc span:after {
  background: #001f4b;
}
.acc_close_btn.pc span:after {
  transform: rotate(-45deg);
}
.test_item ul {
  overflow: hidden;
}
.test_item li {
  font-size: 1.4rem;
  font-weight: 600;
  text-align: center;
  line-height: 1.5rem;
  width: 31%;
  height: 58px;
  border-radius: 16px;
  background: rgba(153, 165, 183, .2);
  box-sizing: border-box;
  padding: 22px 10px 5px 10px;
  margin: 10px 8px;
  float: left;
}
.test_item li p {
    text-align: center;
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 1.2;
    margin-top: -9px;
}
.text01 {
    padding-top: -10px!important;
}
.test_item li.two_lines {
  padding: 20px 10px;
}
.test_item li:nth-last-child(1) {
  margin-bottom: 30px;
}
.infection .btn_wrap {
  max-width: 390px;
  margin: 0 auto;
}
@media screen and (max-width : 767px) {
  .pc_wrapper.wrapper02 {
    padding-top: 0;
  }
  .acc_wrap + .acc_wrap {
    margin-top: 6%;
  }
  .acc_wrap .acc_cnts, .exam03 .acc_wrap .acc_cnts {
    display: none;
      padding: 0 3% 13%;
  }
  .acc_wrap .acc_btn p {
    font-size: 4.267vw;
  }
    .acc_close_btn {
        margin: 0 auto;
        width: 24vw;
        background: #fff;
    }
    .acc_wrap p {
        text-align: center;
        font-size: 3.433vw;
        font-weight: 500;
    }
    .acc_close_btn.pc span:before, .acc_close_btn.pc span:after {
        position: absolute;
        left: 0;
        top: 11px;
        display: inline-block;
        content: '';
        width: 12px;
        height: 1px;
        background: #c42629;
        transform: rotate(45deg);
    }
    .acc_close_btn.pc span:before, .acc_close_btn.pc span:after {
        background: #001f4b;
    }
    .acc_close_btn.pc span:after {
        transform: rotate(-45deg);
    }
    .acc_close_btn.pc span {
        position: relative;
        padding: 0 5px 0 16px;
        box-sizing: border-box;
    }
    .acc_close_btn.pc span:before, .acc_close_btn.pc span:after {
        position: absolute;
        left: 0;
        top: 11px;
        display: inline-block;
        content: '';
        width: 12px;
        height: 1px;
        background: #c42629;
        transform: rotate(45deg);
    }
    .acc_close_btn.pc span:before, .acc_close_btn.pc span:after {
        background: #001f4b;
    }
    .acc_close_btn.pc span:after {
        transform: rotate(-45deg);
    }
  .test_item li {
    font-size: 1.1rem;
  }
  #exam03 .infection {
    width: 100%;
    margin: 20px 0;
  }
  #exam03 .acc_wrap .acc_btn {
    display: block;
  }
  #exam03 h3, #exam04 h3 {
    display: none;
  }
  #exam03 .acc_cnts {
    height: auto;
  }
    .test_item li {
        font-weight: 600;
        text-align: center;
        line-height: 1.5rem;
        width: 46%;
        height: auto!important;
        border-radius: 16px;
        background: rgba(153, 165, 183, .2);
        box-sizing: border-box;
        padding: 1em;
        margin: 5px 5px;
        float: left;
    }
    .test_item li:nth-last-child(1) {
        margin-bottom: 0;
    }
    .infection {
        margin: 20px auto;
    }
}
/* ------------------------------
exam04
------------------------------ */
#exam04 .infection {
  width: 33%;
  margin: 20px 10px;
}
#exam04 .acc_wrap .acc_btn, #exam04 .acc_close_btn.pc p {
  display: none;
}
#exam04 .acc_wrap .acc_cnts {
  display: block;
  height: 330px;
  padding: 0 15px;
}
#exam04 .pc .btn {
  font-size: 1.4rem;
  letter-spacing: 0;
}
@media screen and (max-width : 767px) {
  #exam04 .ttl {
    margin-bottom: 10%;
  }
  #exam04 .infection {
    width: 100%;
    margin: 20px 0;
  }
  #exam04 .acc_wrap .acc_btn {
    padding: 10px 10px 12px 10px;
    display: block;
  }
  #exam04 .acc_close_btn.pc p {
    display: block;
  }
  #exam04 .acc_wrap .acc_cnts, #exam04 h3 {
    display: none;
  }
  #exam04 .acc_wrap .acc_cnts {
    height: auto;
    padding: 0 20px 5% 20px;
  }
}
/* ------------------------------
exam05
------------------------------ */
#exam05 .btn_wrap {
  margin-bottom: 0;
}
.ins_list table {
  width: 100%;
  margin-top: 30px;
  margin-bottom: 10px;
  border: 1px solid #001F4B;
}
table, td, th {
  font-size: 1.3rem;
  font-weight: 600;
  border-collapse: collapse;
  padding: 6px;
  height: 25px;
  line-height: initial;
}
th {
  background: rgba(0, 31, 75, .6);
  color: #fff;
  padding-left: 10px;
}
th.price {
  text-align: right;
  padding-right: 10px;
}
td.service_ttl_rd_80 {
  background-color: rgba(196, 38, 41, 0.8);
  color: #fff;
  width: 10%;
  position: relative;
}
td.service_ttl_bu_80 {
  background-color: rgba(0, 31, 75, 0.8);
  color: #fff;
  width: 10%;
  position: relative;
}
td.service_ttl_rd_80 img, td.service_ttl_bu_80 img {
  position: absolute;
  top: 20px;
  left: 20px;
  width: 40%;
}
td.service_ttl_gr {
  background: rgba(51, 51, 51, .60);
  color: #fff;
}
td.service_ttl_rd {
  background-color: rgba(196, 38, 41, 0.6);
  color: #fff;
}
td.service_ttl_bu {
  background-color: rgba(0, 31, 75, 0.6);
  color: #fff;
  line-height: 1.5em;
}
.even {
  background: #fbf8f0;
}
.odd {
  background: #fefcf9;
}
.price_right {
  text-align: right;
  width: 50%;
}
.ty_ttl, .ty_price {
  font-weight: 700;
  color: #001f4b;
  padding-bottom: 20px;
}
.pr_area {
  display: flex;
  justify-content: space-between;
  padding-top: 7px;
}
.pr_ttl {
  font-size: 1.5rem;
}
.pr_price {
  font-size: 1.5rem;
  vertical-align: text-bottom;
}
.line .pr_ttl {
  position: absolute;
  padding-right: 1rem;
  padding-bottom: 0;
  background-color: white;
}
.line .pr_price {
  right: 0;
  position: absolute;
  padding-left: 1rem;
  padding-bottom: 0;
  background-color: white;
}
@media screen and (max-width : 767px) {
  table.price_area {
    width: 100%;
  }
  table.price_area, td, th, .pr_ttl, .pr_price {
    font-size: 1.2rem;
  }
  td.service_ttl_rd_80 img, td.service_ttl_bu_80 img {
    position: absolute;
    top: 14px;
    left: 0;
    width: 70%;
  }
  td, th {
    padding: 6px;
    height: 20px;
  }
}
/* ------------------------------
exam06
------------------------------ */
.others_item {
  overflow: hidden;
  margin: 30px 0;
}
.others_item li {
  font-size: 1.2rem;
  font-weight: 600;
  text-align: center;
  line-height: 1.5rem;
  width: 19%;
  height: 60px;
  border-radius: 16px;
  background: rgba(153, 165, 183, .2);
  box-sizing: border-box;
  padding: 23px 5px 5px 5px;
  margin: 5px 4px;
  float: left;
}
.others_item li.two_lines {
  padding: 15px 2px;
}
@media screen and (max-width : 767px) {
  .others_item li {
    width: 47%;
    height: 50px;
    padding: 18px 5px 5px 5px;
  }
  .others_item li.two_lines {
    padding: 10px 2px;
  }
}
/* ------------------------------
exam07
------------------------------ */
#exam07 {
  background: rgba(153, 165, 183, .5);
  padding: 70px 10px;
  margin: 75px 40px;
}
#exam07 .text {
  margin: 20px 30px;
}
.case {
  background: #FFF;
  border-radius: 16px;
  /* overflow: hidden; */
  box-shadow: 2px 2px 10px -2px rgb(114 114 114 / 30%);
  box-sizing: border-box;
  width: 50%;
  height: 530px;
  padding: 30px 50px;
  margin: 0 10px;
}
.case h3 {
  font-size: 1.8rem;
  border-bottom: 1px solid #001f4b;
  padding-bottom: 11px;
}
.case p {
  font-size: 1.5rem;
  margin-bottom: 30px;
}
.case ul li {
  font-size: 1.4rem;
  line-height: 1.64;
  margin-bottom: 6px;
  list-style: disc;
  color: #001f4b;
}
.case_wrap {
  margin: 30px 0;
}
.case_wrap ul li span {
  color: #333;
}
#exam07 .text {
  margin: 0 auto;
}
@media screen and (max-width : 767px) {
  #exam07 {
    padding: 35px 0 45px 0;
    margin: 0 auto;
  }
  .case {
    width: 100%;
    padding: 5% 10% 10% 10%;
    margin: 20px auto;
    height: auto;
  }
  .case h3 {
    font-size: 2.2rem;
  }
}
/* ------------------------------
vaccine
------------------------------ */
.vaccine_item li {
  width: 24%;
}
@media screen and (max-width : 767px) {
  .vaccine_item li {
    width: 47%;
  }
}
/* ------------------------------
price
------------------------------ */
table.price_area {
  width: 90%;
  margin: 0 auto;
  margin-bottom: 10px;
}
.price_area td, .price_area th {
  font-size: 1.5rem;
  font-weight: 600;
  border: 1px solid #595959;
  border-collapse: collapse;
}
td.service_ttl_rd_80 {
  background-color: rgba(196, 38, 41, 0.8);
  color: #fff;
  width: 10%;
  position: relative;
}
td.service_ttl_bu_80 {
  background-color: rgba(0, 31, 75, 0.8);
  color: #fff;
  width: 10%;
  position: relative;
}
td.service_ttl_rd_80 img, td.service_ttl_bu_80 img {
  position: absolute;
  top: 20px;
  left: 20px;
  width: 40%;
}
td.service_ttl_gr {
  background: rgba(51, 51, 51, .60);
  color: #fff;
}
td.service_ttl_rd {
  background-color: rgba(196, 38, 41, 0.6);
  color: #fff;
}
td.service_ttl_bu {
  background-color: rgba(0, 31, 75, 0.6);
  color: #fff;
  line-height: 1.5em;
}
td, th {
  padding: 5px;
  height: 25px;
}
.price_area th {
  background: #001F4B;
  color: #fff;
  text-align: center;
}
.even {
  background: #fbf8f0;
}
.odd {
  background: #fefcf9;
}
.price_right {
  text-align: right;
  width: 50%;
}
.ty_ttl, .ty_price {
  font-weight: 700;
  color: #001f4b;
  padding-bottom: 20px;
}
.pr_area {
  display: flex;
  justify-content: space-between;
  padding-top: 7px;
}
.pr_ttl {
  font-size: 1.5rem;
}
.pr_price {
  font-size: 1.5rem;
  vertical-align: text-bottom;
}
.line .pr_ttl {
  position: absolute;
  padding-right: 1rem;
  padding-bottom: 0;
  background-color: white;
}
.line .pr_price {
  right: 0;
  position: absolute;
  padding-left: 1rem;
  padding-bottom: 0;
  background-color: white;
}
@media screen and (max-width : 767px) {
  table.price_area {
    width: 100%;
  }
  .price_area td, .price_area th, .pr_ttl, .pr_price {
    font-size: 1.2rem;
  }
  td.service_ttl_rd_80 img, td.service_ttl_bu_80 img {
    position: absolute;
    top: 14px;
    left: 0;
    width: 70%;
  }
  td, th {
    padding: 6px;
    height: 20px;
  }
}