@charset "UTF-8";
@media only screen and (max-width: 750px) {
  p {
    padding-top: 0;
  }
  a {
    padding: 0;
  }
  ul {
    padding-top: 0;
  }
  ul li {
    padding-top: 0;
  }
  * {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  a {
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
  }
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
  .idpoint {
    width: 1px;
    height: 1px;
    position: absolute;
    top: -51px;
    left: 0;
  }
  #subMenu {
    display: none;
  }
  .submenulist{
    display: none;
  }
  #mainContents p {
    padding-top: 0;
  }
  #mainContents .annotation {
    line-height: 1.4 !important;
  }
  #mainContents p.annotation {
    font-size: 1.2rem !important;
    text-indent: -1.2em;
    padding-left: 1.2em;
    padding-top: 0;
    color: #111 !important;
  }
  #mainContents p.annotation.noindent {
    text-indent: 0 !important;
    padding-left: 0 !important;
  }
  #mainContents ul.annotation.noindent li {
    text-indent: 0 !important;
    padding-left: 0 !important;
  }
  #mainContents a {
    padding: 0;
  }
  #mainContents .pdfIcon a {
    padding-left: 31px;
  }
  #mainContents ul {
    padding-top: 0;
  }
  #mainContents ul li {
    padding-top: 0;
  }
  #mainContents * {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  #mainContents a {
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
  }
  #mainContents .pc {
    display: none !important;
  }
  #mainContents .sp {
    display: blocl !important;
  }
  #mainContents .font_en {
    font-family: "Barlow Condensed", sans-serif;
    font-weight: 500;
    font-style: normal;
  }
  #mainContents .btn_type01 {
    display: block;
    color: #111;
    border: 1px solid #ddd;
    border-radius: 50px;
    background-color: #fff;
    font-size: 16px;
    font-weight: 500;
    line-height: 20px;
    padding: 13px 40px 13px 25px;
    background-image: url(../img/icon_arrow02.png);
    background-size: 16px auto;
    background-position: center right 15px;
    background-repeat: no-repeat;
    text-decoration: none;
  }
  #mainContents .btn_type01:hover {
    background-color: #00368F;
    color: #fff;
    background-image: url(../img/icon_arrow02_hover.png);
    border: 1px solid #00368F;
  }
  #mainContents section.s01 {
    max-width: 1280px;
    margin: 0 auto;
    padding: 15px 20px 0;
  }
  #mainContents section.s01 * {
    color: #111;
  }
  #mainContents section.s01 .wrapper .bc {
    font-size: 0;
    letter-spacing: 0;
  }
  #mainContents section.s01 .wrapper .bc li {
    display: inline-block;
    vertical-align: top;
    padding-right: 20px;
    background-image: url(../img/icon_slash.png);
    background-size: auto 16px;
    background-repeat: no-repeat;
    background-position: center right 0;
    margin: 3px 10px 3px 0;
  }
  #mainContents section.s01 .wrapper .bc li:last-child {
    padding-right: 0;
    background-image: none;
    margin-right: 0;
  }
  #mainContents section.s01 .wrapper .bc li p ,
  #mainContents section.s01 .wrapper .bc li a {
    display: block;
    text-decoration: none;
    color: #111;
    font-size: 13px;
    border-bottom: 1px solid transparent;
  }
  #mainContents section.s01 .wrapper .bc li p {
    padding-top: 0;
  }
  #mainContents section.s01 .wrapper .bc li a:hover {
    border-bottom: 1px solid #111;
    color: #074CA6;
  }
  #mainContents section.s01 .wrapper .link_list01 {
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 10px;
    margin-top: 25px;
  }
  #mainContents section.s01 .wrapper .link_list01 li {
    width: calc(50% - 5px);
    display: inline-block;
    vertical-align: top;
  }
  #mainContents section.s01 .wrapper .link_list01 li a {
    display: block;
    color: #111;
    border: 1px solid #ddd !important;
    border-radius: 50px;
    background-color: #fff !important;
    font-size: 10px;
    font-weight: 500;
    line-height: 10px;
    padding: 11px 30px 11px 20px;
    background-image: url(../img/icon_arrow02.png) !important;
    background-size: 16px auto;
    background-position: center right 10px;
    background-repeat: no-repeat;
    text-decoration: none;
    color: #00285C !important;
  }
  #mainContents section.s01 .wrapper .link_list02 {
    width: calc(100% + 40px);
    font-size: 0;
    letter-spacing: 0;
    margin: 20px -20px 20px;
    padding: 15px 25px;
    background-color: #F9F9F9;
  }
  #mainContents section.s01 .wrapper .link_list02 li {
    display: block;
    margin: 15px 0;
  }
  #mainContents section.s01 .wrapper .link_list02 li a {
    display: block;
    text-decoration: none;
    color: #111;
    line-height: 100%;
    padding-left: 30px;
    position: relative;
  }
  #mainContents section.s01 .wrapper .link_list02 li a:hover .iconbox::before {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    position: absolute;
    top: 50%;
    right: 0;
    left: 0;
    margin: 0 auto;
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
    border-radius: 20px;
    z-index: 1;
    margin-top: -10px;
    transition-duration: 0.3s;
    background-color: #074CA6;
  }
  #mainContents section.s01 .wrapper .link_list02 li a:hover .iconbox .icon {
    background-image: url(../img/icon_arrow04_hover.png);
    background-size: 12px auto;
  }
  #mainContents section.s01 .wrapper .link_list02 li a:hover p {
    color: #074CA6;
    border-bottom: 1px solid #111;
  }
  #mainContents section.s01 .wrapper .link_list02 li a .iconbox {
    width: 20px;
    height: 20px;
    position: absolute;
    top: 0;
    left: 0;
    display: inline-block;
    vertical-align: top;
    margin-right: 6px;
    margin-top: 2px;
    z-index: 2;
  }
  #mainContents section.s01 .wrapper .link_list02 li a .iconbox .icon {
    width: 20px;
    height: 20px;
    position: absolute;
    top: 0px;
    right: 0;
    left: 0;
    margin: 0 auto;
    background-image: url(../img/icon_arrow04_hover.png);
    background-size: 16px auto;
    background-position: center center;
    background-repeat: no-repeat;
    z-index: 2;
  }
  #mainContents section.s01 .wrapper .link_list02 li a .iconbox::before {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    position: absolute;
    top: 50%;
    right: 0;
    left: 0;
    margin: 0 auto;
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
    border-radius: 20px;
    z-index: 1;
    margin-top: -10px;
    transition-duration: 0.3s;
    background-color: #074CA6;
  }
  #mainContents section.s01 .wrapper .link_list02 li a p {
    display: inline;
    font-weight: 500;
    font-size: 15px;
    line-height: 20px;
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
    border-bottom: 1px solid #F9F9F9;
    padding: 3px 0;
  }
  #mainContents section.s01 .wrapper .link_list03 {
    font-size: 0;
    letter-spacing: 0;
    margin: 20px 0 20px;
  }
  #mainContents section.s01 .wrapper .link_list03 li + li {
    margin-top: 20px;
  }
  #mainContents section.s01 .wrapper .link_list03 li a {
    display: block;
    text-decoration: none;
    color: #111;
    line-height: 100%;
    padding-left: 25px;
    position: relative;
  }
  #mainContents section.s01 .wrapper .link_list03 li a:hover .iconbox::before {
    content: "";
    display: block;
    width: 16px;
    height: 16px;
    position: absolute;
    top: 50%;
    right: 0;
    left: 0;
    margin: 0 auto;
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
    border-radius: 20px;
    z-index: 1;
    margin-top: -8px;
    transition-duration: 0.3s;
    background-color: #074CA6;
  }
  #mainContents section.s01 .wrapper .link_list03 li a:hover .iconbox .icon {
    background-image: url(../img/icon_arrow03_hover.png);
    background-size: 12px auto;
  }
  #mainContents section.s01 .wrapper .link_list03 li a:hover p {
    color: #074CA6;
    border-bottom: 1px solid #111;
  }
  #mainContents section.s01 .wrapper .link_list03 li a .iconbox {
    width: 16px;
    height: 16px;
    position: absolute;
    top: 0;
    left: 0;
    display: inline-block;
    vertical-align: top;
    margin-right: 6px;
    margin-top: 2px;
    z-index: 2;
  }
  #mainContents section.s01 .wrapper .link_list03 li a .iconbox .icon {
    width: 16px;
    height: 16px;
    position: absolute;
    top: 0px;
    right: 0;
    left: 0;
    margin: 0 auto;
    background-image: url(../img/icon_arrow03_hover.png);
    background-size: 12px auto;
    background-position: center center;
    background-repeat: no-repeat;
    z-index: 2;
  }
  #mainContents section.s01 .wrapper .link_list03 li a .iconbox::before {
    content: "";
    display: block;
    width: 0;
    height: 0;
    position: absolute;
    top: 50%;
    right: 0;
    left: 0;
    margin: 0 auto;
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
    border-radius: 20px;
    z-index: 1;
    transition-duration: 0.3s;
    content: "";
    display: block;
    width: 16px;
    height: 16px;
    position: absolute;
    top: 50%;
    right: 0;
    left: 0;
    margin: 0 auto;
    transition-duration: 0.3s;
    border-radius: 20px;
    z-index: 1;
    margin-top: -8px;
    transition-duration: 0.3s;
    background-color: #074CA6;
  }
  #mainContents section.s01 .wrapper .link_list03 li a p {
    display: inline;
    font-weight: 500;
    font-size: 15px !important;
    line-height: 20px;
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
    border-bottom: 1px solid #F9F9F9;
    padding: 3px 0;
  }
  #mainContents section.s01 .wrapper .link_list03 li a p .pdf {
    display: inline-block;
    font-size: 12px;
    color: #5C5C5C;
    line-height: 16px;
    margin-left: 3px;
  }
  #mainContents section.s01 .wrapper .link_list03 li a p .pdf img {
    width: 20px;
    vertical-align: top;
    margin-right: 3px;
  }
  #mainContents section.s01 .wrapper .link_list03 li a p .link {
    display: inline-block;
    vertical-align: top;
    margin-left: 3px;
  }
  #mainContents section.s01 .wrapper .link_list03 li a p .link img {
    width: 16px;
    vertical-align: top;
  }
  #mainContents section.s01 .wrapper .link_list04 {
    font-size: 0;
    letter-spacing: 0;
    margin: 20px 0 20px;
    text-align: center;
  }
  #mainContents section.s01 .wrapper .link_list04 li {
    display: inline-block;
    vertical-align: middle;
    margin: 7px 5px !important;
  }
  #mainContents section.s01 .wrapper .link_list04 li a {
    margin: 0 !important;
  }
  #mainContents section.s01 .wrapper .txt_list01 {
    margin: 20px 0;
  }
  #mainContents section.s01 .wrapper .txt_list01 li {
    font-size: 14px;
  }
  #mainContents section.s01 .wrapper .txt_list01 > li {
    font-size: 14px;
    line-height: 150%;
    padding-left: 17px;
    background-image: url(../img/icon_dots.png);
    background-size: 10px auto;
    background-position: left 0 top 7px;
    background-repeat: no-repeat;
  }
  #mainContents section.s01 .wrapper .txt_list01 li + li,
  #mainContents section.s01 .wrapper .list li + li {
    margin-top: 13px;
  }
  #mainContents section.s01 .wrapper .txt_list01 li.is-single + li, 
  #mainContents section.s01 .wrapper .list li.is-single + li { 
    margin-top: 4px;
  }
  #mainContents section.s01 .wrapper .txt_list01.mt4 li + li {
    margin-top: 4px;
  }
  #mainContents section.s01 .wrapper .txt_list02 {
    margin: 20px 0;
  }
  #mainContents section.s01 .wrapper .txt_list02 li {
    font-size: 11px;
    line-height: 150%;
    color: #5C5C5C;
    position: relative;
/*    padding-left: 25px;*/
  }
  /*
  #mainContents section.s01 .wrapper .txt_list02 li::before {
    content: "注1";
    display: block;
    width: 30px;
    position: absolute;
    top: 0;
    left: 0;
  }
  */
  #mainContents section.s01 .wrapper .txt_list02 li + li {
    margin-top: 10px;
  }
  #mainContents section.s01 .wrapper .contents_list01 {
    margin: 20px 0;
  }
  #mainContents section.s01 .wrapper .contents_list01 .item {
    display: block;
  }
  #mainContents section.s01 .wrapper .contents_list01 .item + .item {
    margin-top: 20px;
  }
  #mainContents section.s01 .wrapper .contents_list01 .item:nth-child(even) .photobox {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  #mainContents section.s01 .wrapper .contents_list01 .item:nth-child(even) .txtbox {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  #mainContents section.s01 .wrapper .contents_list01 .item .photobox {
    margin: 0 auto;
    width: 100%;
  }
  #mainContents section.s01 .wrapper .contents_list01 .item .photobox + .photobox {
    margin-top: 20px;
  }
  #mainContents section.s01 .wrapper .contents_list01 .item .photobox img {
    width: 100%;
    display: block;
  }
  #mainContents section.s01 .wrapper .contents_list01 .item .photobox p {
    text-align: center;
    color: #5C5C5C;
    font-size: 12px;
    line-height: 150%;
    margin-top: 5px;
  }
  #mainContents section.s01 .wrapper .contents_list01 .item .txtbox {
    width: 100%;
    margin-top: 20px;
  }
  #mainContents section.s01 .wrapper .contents_list01 .item .txtbox p {
    font-size: 14px;
    line-height: 180%;
  }
  #mainContents section.s01 .wrapper .contents_list01 .item .photobox {
    width: 100%;
    margin-top: 20px;
  }
  #mainContents section.s01 .wrapper .contents_list01 .item .photobox > .contents_list01 .photobox img + img,
  #mainContents section.s01 .wrapper .contents_list01 .item .txtbox .photobox > .imglist img + img {
    margin-top: 20px;
  }

  /* contents_list02 */
  #mainContents section.s01 .wrapper .contents_list02 {
    margin: 20px 0;
  }
  #mainContents section.s01 .wrapper .contents_list02 .item {
    display: block;
  }
  #mainContents section.s01 .wrapper .contents_list02 .item + .item {
    margin-top: 20px;
  }
  #mainContents section.s01 .wrapper .contents_list02 .item.even .photobox {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  #mainContents section.s01 .wrapper .contents_list02 .item.even .txtbox {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  #mainContents section.s01 .wrapper .contents_list02 .item .photobox {
    margin: 20px auto;
    width: 100%;
  }
  #mainContents section.s01 .wrapper .contents_list02 .item .photobox img {
    width: 100%;
    display: block;
  }
  #mainContents section.s01 .wrapper .contents_list02 .item .photobox p {
    text-align: center;
    color: #5C5C5C;
    font-size: 12px;
    line-height: 150%;
    margin-top: 5px;
  }
  #mainContents section.s01 .wrapper .contents_list02 .item .txtbox {
    width: 100%;
    margin-top: 20px;
  }
  #mainContents section.s01 .wrapper .contents_list02 .item .txtbox p {
    font-size: 14px;
    line-height: 180%;
  }

  #mainContents section.s01 .wrapper .contents_list03 {
    margin: 20px 0;
    display: block; /* 1カラムにするので block でOK */
  }
  #mainContents section.s01 .wrapper .contents_list03 .item {
    width: 100%;
    margin-top: 20px;
  }
  #mainContents section.s01 .wrapper .contents_list03 .item:first-child {
    margin-top: 0;
  }
  #mainContents section.s01 .wrapper .contents_list03 .photobox {
    margin: 0 auto;
  }
  #mainContents section.s01 .wrapper .contents_list03 .photobox p {
    font-size: 12px;
    line-height: 150%;
    margin-top: 5px;
  }
  #mainContents section.s01 .wrapper .contents_list03 .txtbox p {
    font-size: 14px;
    line-height: 180%;
    margin-top: 10px;
  }
  #mainContents section.s01 .wrapper .contents_list04 {
    margin: 20px 0;
  }
  #mainContents section.s01 .wrapper .contents_list04 .item .photobox {
    float: none;
    width: 100%;
    margin: 0 0 12px 0;
  }
  #mainContents section.s01 .wrapper .contents_list04 .item .txtbox {
    display: block;
  }
  #mainContents section.s01 .wrapper .contents_list04 .item p {
    margin: 18px 0;
    font-size: 14px;
    line-height: 180%;
  }

  #mainContents section.s01 .wrapper .contents_list05 {
    margin: 20px 0;
  }
  #mainContents section.s01 .wrapper .contents_list05 .item .photobox {
    float: none;
    width: 100%;
    margin: 0 0 12px 0;
  }
  #mainContents section.s01 .wrapper .contents_list05 .item .txtbox {
    display: block;
  }
  #mainContents section.s01 .wrapper .contents_list05 .item p {
    margin: 18px 0;
    font-size: 14px;
    line-height: 180%;
  }
  #mainContents section.s01 .wrapper .contents_list06 {
    margin: 20px 0;
  }
  #mainContents section.s01 .wrapper .contents_list06 .item {
    display: block;
  }
  #mainContents section.s01 .wrapper .contents_list06 .item + .item {
    margin-top: 20px;
  }
  #mainContents section.s01 .wrapper .contents_list06 .item:nth-child(even) .photobox {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  #mainContents section.s01 .wrapper .contents_list06 .item:nth-child(even) .txtbox {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  #mainContents section.s01 .wrapper .contents_list06 .item .photobox {
    margin: 0 auto;
    width: 100%;
  }
  #mainContents section.s01 .wrapper .contents_list06 .item .photobox + .photobox {
    margin-top: 20px;
  }
  #mainContents section.s01 .wrapper .contents_list06 .item .photobox img {
    width: 100%;
    display: block;
  }
  #mainContents section.s01 .wrapper .contents_list06 .item .photobox p {
    text-align: center;
    color: #5C5C5C;
    font-size: 12px;
    line-height: 150%;
    margin-top: 5px;
  }
  #mainContents section.s01 .wrapper .contents_list06 .item .txtbox {
    width: 100%;
    margin-top: 20px;
  }
  #mainContents section.s01 .wrapper .contents_list06 .item .txtbox p {
    font-size: 14px;
    line-height: 180%;
  }
  #mainContents section.s01 .wrapper .contents_list06 .item .photobox {
    width: 100%;
    margin-top: 20px;
  }
  #mainContents section.s01 .wrapper h1 {
    font-size: 29px;
    line-height: 160%;
    margin: 50px 0 25px;
    font-weight: 500;
    color: #00285C;
  }
  #mainContents section.s01 .wrapper h2 {
    font-size: 24px;
    line-height: 160%;
    font-weight: 500;
    margin: 45px 0 25px;
    color: #00285C;
  }
  #mainContents section.s01 .wrapper h3 {
    font-size: 19px;
    line-height: 160%;
    font-weight: 500;
    margin: 45px 0 20px;
    border-bottom: 1px solid #111;
    padding-bottom: 5px;
    color: #00285C;
  }
  #mainContents section.s01 .wrapper h4 {
    font-size: 18px;
    line-height: 160%;
    color: #00285C;
    margin: 40px 0 20px;
    font-weight: 500;
    padding-left: 15px;
    position: relative;
  }
  #mainContents section.s01 .wrapper h4::before {
    content: "";
    display: block;
    width: 3px;
    height: calc(100% - 6px);
    position: absolute;
    top: 3px;
    left: 0;
    background-color: #00285C;
  }
  #mainContents section.s01 .wrapper h5 {
    font-size: 16px;
    line-height: 160%;
    font-weight: 500;
    color: #00285C;
    margin: 45px 0 20px;
  }
  #mainContents section.s01 .wrapper h1 sup ,
  #mainContents section.s01 .wrapper h2 sup ,
  #mainContents section.s01 .wrapper h3 sup ,
  #mainContents section.s01 .wrapper h4 sup ,
  #mainContents section.s01 .wrapper h5 sup ,
  #mainContents section.s01 .wrapper h1 sub ,
  #mainContents section.s01 .wrapper h2 sub ,
  #mainContents section.s01 .wrapper h3 sub ,
  #mainContents section.s01 .wrapper h4 sub ,
  #mainContents section.s01 .wrapper h5 sub {
    color: inherit !important;
  }
  #mainContents section.s01 .wrapper p.txt_left {
    text-align: left;
  }
  #mainContents section.s01 .wrapper p.txt_center {
    text-align: center;
  }
  #mainContents section.s01 .wrapper p.txt_right {
    text-align: right;
  }
  #mainContents section.s01 .wrapper p.txt01 {
    font-size: 18px;
    line-height: 175%;
    color: #074CA6;
    margin: 20px 0 20px;
  }
  #mainContents section.s01 .wrapper p.txt02 {
    font-size: 14px;
    line-height: 180%;
    margin: 20px 0 20px;
  }
  #mainContents section.s01 .wrapper .topics {
    position: relative;
    font-size: 19px;
    font-weight: 500;
    line-height: 160%;
    color: #00285C;
    background-color: #F7F9FC;
    padding: 40px 15px 15px;
    margin: 40px 0 20px;
    border: 0;
  }
  #mainContents section.s01 .wrapper .topics::before {
    display: block;
    width: 70px;
    height: 40px;
    content: "";
    position: absolute;
    top: -5px;
    left: 5px;
    background-image: url(../img/icon_topics.svg);
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
    background-color: initial;
  }
  #mainContents section.s01 .wrapper .label_txt {
    padding: 10px 0px 10px 0px;
    display: block;
    margin: 20px 0;
    font-size: 100%;
    line-height: 100%;
    font-weight: normal;
  }
  #mainContents section.s01 .wrapper .label_txt::before {
    display: none;
  }

  #mainContents section.s01 .wrapper .label_txt .label {
    font-size: 16px;
    line-height: 100%;
    color: #fff;
    font-weight: 500;
    padding: 8px 13px 10px;
    background-color: #074CA6;
    display: inline-block;
  }
  #mainContents section.s01 .wrapper .label_txt .txt {
    width: 100%;
    display: block;
    font-size: 18px;
    font-weight: 500;
    line-height: 160%;
    color: #00285C;
    text-align: left;
    margin: 5px 0 0;
  }
  #mainContents section.s01 .wrapper h3.label_txt {
    border-bottom: 0;
  }

  #mainContents section.s01 .wrapper h3.label_txt .txt {
    font-size: 19px;
  }
  #mainContents section.s01 .wrapper h4.label_txt .txt {
    font-size: 18px;
  }
  #mainContents section.s01 .wrapper h5.label_txt .txt {
    font-size: 16px;
  }
  #mainContents section.s01 .wrapper h3.label_txt .label {
    font-size: 15px;
  }
  #mainContents section.s01 .wrapper h4.label_txt .label {
    font-size: 14px;
  }
  #mainContents section.s01 .wrapper h5.label_txt .label {
    font-size: 12px;
  }



  #mainContents section.s01 .wrapper .photobox {
    margin: 40px auto 40px;
  }
  #mainContents section.s01 .wrapper .photo {
    max-width: 100%;
    margin: 0 auto;
    display: block;
    width: auto;
  }
  #mainContents section.s01 .wrapper .photobox .photo.photo02 {
    display:inline-block;
    width: 32%;
    height: auto;
  }
  #mainContents section.s01 .wrapper .photobox p {
    text-align: center;
    color: #5C5C5C;
    font-size: 12px;
    line-height: 150%;
    margin-top: 5px;
  }
  #mainContents section.s01 .wrapper .photobox p.txt02 { 
    color: #111 !important; ; 
    font-size: 14px !important; 
  } 
  #mainContents section.s01 .wrapper .btn_type01 {
    display: inline-block;
    color: #111;
    border: 1px solid #ddd;
    border-radius: 50px;
    background-color: #fff;
    font-size: 10px;
    font-weight: 500;
    line-height: 14px;
    padding: 11px 40px 11px 25px;
    background-image: url(../img/icon_arrow05.png);
    background-size: 16px auto;
    background-position: center right 12px;
    background-repeat: no-repeat;
    text-decoration: none;
    margin: 25px auto 0;
  }
  #mainContents section.s01 .wrapper .btn_type01.btn_size_l {
    padding: 22px 55px 22px 30px;
    font-size: 15px;
    line-height: 100%;
    background-size: 28px auto;
    background-position: center right 10px;
  }
  #mainContents section.s01 .wrapper .btn_type01.btn_size_l.btn_return {
    padding: 26px 40px 26px 65px;
    background-position: center left 15px;
  }
  #mainContents section.s01 .wrapper .btn_type01.btn_size_m {
    padding: 16px 45px 16px 30px;
    font-size: 14px;
    line-height: 100%;
    background-size: 16px auto;
    background-position: center right 12px;
  }
  #mainContents section.s01 .wrapper .btn_type01.btn_size_m.btn_return {
    padding: 16px 30px 16px 45px;
    background-position: center left 12px;
  }
  #mainContents section.s01 .wrapper .btn_type01.btn_return {
    padding: 11px 25px 11px 40px;
    background-image: url(../img/icon_arrow06.png);
    background-position: center left 12px;
  }
  #mainContents section.s01 .wrapper .btn_type01.btn_return:hover {
    background-image: url(../img/icon_arrow06_hover.png);
  }
  #mainContents section.s01 .wrapper .btn_type01:hover {
    background-color: #00368F;
    color: #fff;
    background-image: url(../img/icon_arrow02_hover.png);
    border: 1px solid #00368F;
  }
  #mainContents section.s01 .wrapper table {
    width: 100%;
    margin: 40px 0 20px;
    border-collapse: collapse; 
  }
  #mainContents section.s01 .wrapper table.table-scroll {
    display: block;
    overflow-x: auto;
    white-space: nowrap; 
    -webkit-overflow-scrolling: touch;
  }
  #mainContents section.s01 .wrapper table.table-scroll th,
  #mainContents section.s01 .wrapper table.table-scroll td {
  }
  #mainContents section.s01 .wrapper table.table-scroll2 {
    display: block;
    overflow-x: auto;
    white-space: normal;
    -webkit-overflow-scrolling: touch
  }
  #mainContents section.s01 .wrapper table.table-scroll2 th,
  #mainContents section.s01 .wrapper table.table-scroll2 td {
        min-width: 100px;
        white-space: normal; 
        word-break: break-word;
  }    
  #mainContents section.s01 .wrapper table tr td,
  #mainContents section.s01 .wrapper table tr th {
    border: 1px solid #D2D2D2;
    font-size: 14px;
    line-height: 170%;
  }
  #mainContents section.s01 .wrapper table tr td.txt_left,
  #mainContents section.s01 .wrapper table tr th.txt_left {
    text-align: left;
  }
  #mainContents section.s01 .wrapper table tr td.txt_center,
  #mainContents section.s01 .wrapper table tr th.txt_center {
    text-align: center;
  }
  #mainContents section.s01 .wrapper table tr td.txt_right,
  #mainContents section.s01 .wrapper table tr th.txt_right {
    text-align: right;
  }
  #mainContents section.s01 .wrapper table tr td {
    padding: 4px 12px;
  }
  #mainContents section.s01 .wrapper table tr td.checksell {
    padding: 4px 9px;
  }
  #mainContents section.s01 .wrapper table tr td.headline {
    background-color: #F9F9F9;
    color: #00285C;
    vertical-align: middle;
  }
  #mainContents section.s01 .wrapper table tr td.headline sup ,
  #mainContents section.s01 .wrapper table tr td.headline sub {
    color: #00285C;
  }
  #mainContents section.s01 .wrapper table tr th {
    background-color: #074CA6;
    color: #fff;
    text-align: center;
    vertical-align: middle;
    padding: 5px 15px;
  }
  #mainContents section.s01 .wrapper table tr th span ,
  #mainContents section.s01 .wrapper table tr th sup ,
  #mainContents section.s01 .wrapper table tr th sub {
    color: #fff;
  }
  #mainContents section.s01 .wrapper table tr td .txt_list01 {
    margin-top: 0;
  }
  #mainContents section.s01 .wrapper table tr td .txt_list02 li {
    padding-left: 0;
  }
  #mainContents section.s01 .wrapper table.noborder tr th ,
  #mainContents section.s01 .wrapper table.noborder tr td {
    border: 0px;
  }
  #mainContents section.s01 .wrapper table tr th.custom1{
      background-color: #fff;
      min-width: 123px;
  }
  #mainContents section.s01 .wrapper table tr th.custom1 img{

  }
  #mainContents section.s01 .wrapper table tr th.custom2{
      background-color: #F9F9F9;
      color: #00285C;
  }
  #mainContents section.s01 .wrapper table.table01{
  }
  #mainContents section.s01 .wrapper table.table01 tr th,
  #mainContents section.s01 .wrapper table.table01 tr td {
    font-size: 13px;
    padding: 5px 3px;
    text-align: center;
    vertical-align: middle;
  }
  #mainContents section.s01 .wrapper table.table01 tr th span,
  #mainContents section.s01 .wrapper table.table01 tr td span {
    font-size: 12px;
    display: block;
  }
  #mainContents section.s01 .wrapper table tr td.bg01,
  #mainContents section.s01 .wrapper table tr th.bg01 {
    background-color: #F9F9F9;
    color: #111;
  }
  #mainContents section.s01 .wrapper .txtbox02 {
    padding: 20px 20px;
    border: 1px solid #D2D2D2;
    margin: 40px 0 20px;
  }
  #mainContents section.s01 .wrapper .txtbox02 *:first-child {
    margin-top: 0;
  }
  #mainContents section.s01 .wrapper .txtbox02 *:last-child {
    margin-bottom: 0;
  }
  #mainContents section.s01 .wrapper .topics_link {
    margin: 20px 0;
    padding: 15px 10px;
    background-color: #F7F9FC;
    background-image: url(../img/icon_arrow08.png);
    background-size: 45px auto;
    background-position: center right 10px;
    background-repeat: no-repeat;
    text-decoration: none;
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
    transition-duration: 0.3s;
  }

  #mainContents section.s01 .wrapper .topics_link a {
    color: #00285c;
    font-size: 15px;
    font-weight: 500;
    display: block;
    width: 100%;
    height: 100%;
    padding-right: 50px;
    position: relative;
    top: 0;
    left: 0;
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
    transition-duration: 0.3s;
  }

  #mainContents section.s01 .wrapper .topics_link:hover {
    background-color: #d0dff1;
    background-image: url(../img/icon_arrow08_hover.png);
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
    transition-duration: 0.3s;
  }
  #mainContents section.s01 .wrapper .topics_link a:hover {
    color: #00368f;
    text-decoration: none;
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
    transition-duration: 0.3s;
  }

  .mt0{
    margin-top: 0 !important;
  }
  .mb0{
    margin-bottom: 0 !important;
  }
  .mb20{
    margin-bottom: 20px !important;
  }
  .nowrap{
    white-space: nowrap;
  }
  #mainContents section.s01 .wrapper table tr td.noborder-l, #mainContents section.s01 .wrapper table tr th.noborder-l{
    border-left: 0px;
  }
  #mainContents section.s01 .wrapper table tr td.noborder-r, #mainContents section.s01 .wrapper table tr th.noborder-r{
    border-right: 0px;
  }
  #mainContents section.s01 .wrapper table.noborder tr th ,
  #mainContents section.s01 .wrapper table.noborder tr td {
    border: 0px;
  }

  .mws120 { min-width: 120px !important; }
  .mws150 { min-width: 150px !important; }
  .mws200 { min-width: 200px !important; }
  .mws250 { min-width: 250px !important; }
  .mws300 { min-width: 300px !important; }
  .mws350 { min-width: 350px !important; }
  .mws400 { min-width: 400px !important; }
  .mws450 { min-width: 450px !important; }
  .mws500 { min-width: 500px !important; }

  .num{
    text-align: right;
  }
  .slash-cell {
    background: linear-gradient(
      to bottom right, 
      transparent calc(50% - 0.5px), /* 斜線の手前 */
      #000 calc(50%),                /* 斜線の色 */
      transparent calc(50% + 0.5px)  /* 斜線の後ろ */
    );
    text-align: center;
    vertical-align: middle;
  }
  .titleS{
    font-weight: bold;
    background: none;
    padding-left:0;
    color: #111 !important;
    margin: 20px 0;
  }
  .underLine {
    text-decoration: underline;
  }
  .txt_left{
    text-align: left !important;
  }
  .txt_right{
    text-align: right !important;
  }
  .txt_middle{
    vertical-align: middle;
  }
  .checkmark{
    width: 16px !important;
    height: auto !important;
    vertical-align: middle;
  }
  .photobox03 {
    margin-bottom: 15px;
  }
  .indent11 li{
  padding-left: 11em;
  line-height: 180%;
  }
  .indent11 li span{
  display: inline-block;
  width: 11em;
  margin-left: -11em;
  line-height: 180%;
  }
  #mainContents section.s01 a.link{
    color:#074CA6;
  }
  .fs18{
    font-size: 1.5rem !important;
  }
  .shasen{
    background-image: linear-gradient(to right top, transparent calc(50% - 0.5px), #fff 50%, #fff calc(50% + 0.5px), transparent calc(50% + 1px))
  }
  .txt_indent01{
    padding-left: 1em;
  }
  .contents_list01 .annotation,
  .contents_list02 .annotation,
  .contents_list03 .annotation,
  .contents_list04 .annotation,
  .contents_list05 .annotation{
    margin-top:20px;
  }
  #mainContents ul.annotation li,
  #mainContents ol.annotation li,
  #mainContents dl.annotation dt,
  #mainContents dl.annotation dd {
    font-size: 1.2rem !important;
    line-height: 1.5; 
  }
  #mainContents ul.annotation:not(.list2) li,
  #mainContents ol.annotation:not(.list2) li,
  #mainContents dl.annotation:not(.list2) dt,
  #mainContents dl.annotation:not(.list2) dd {
    text-indent: -1.2em;
    padding-left: 1.2em;
  }
  .imglist{
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
  .sp_2col .imglist{
    flex-direction: row;
  }
  .imglist p{
    text-align: center;
    color: #5C5C5C;
    font-size: 15px;
    line-height: 150%;
    margin-top: 8px;
  }
  .imglist .caption{
    text-align: center;
    color: #5C5C5C !important;
    font-size: 15px !important;
    line-height: 150%;
    margin-top: 8px;
  }
  .col2list{
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
  .col2list li iframe{
    width:100%;
    max-width: 100%;
    height: calc((327/582)*100vw);
  }
  .per6_4 > *:nth-of-type(1){
    width: 100%;
  }
  .per6_4 > *:nth-of-type(2){
    width: 100%;
  }
  p.txt01 img.photo_auto ,
  p.txt02 img.photo_auto {
    width: auto !important;
  }
  p.txt01 img.photo_auto {
    height: 24px;
  }
  p.txt01.h44 img.photo_auto {
    height: 29px;
  }
  p.txt02 img.photo_auto {
    height: 20px;
  }
  p.txt02 img.img02 {
    height: 12px;
    width: auto !important;
    vertical-align: baseline;
  }
  img.img03 {
    height: 14px;
    width: auto !important;
    vertical-align: middle;
  }
  .local_menu_bottom {
    padding-top: 20vw !important; 
  }
  #mainContents section.s01 .wrapper .imglist.imglist02 li p{
    font-size: 14px;
  }
  #mainContents section.s01 .wrapper .imglist.imglist02 li p span{
    color:#234396;
  }
  .indent1 li{
    padding-left: 1.5em;
  }
  .indent1 li span{
    display: inline-block;
    width: 1.5em;
    margin-left: -1.5em;
  }
  .indent5 > li{
    padding-left: 5em;
    line-height: 180%;
  }
  .indent5 > li > span{
    display: inline-block;
    width: 5em;
    margin-left: -5em;
    line-height: 180%;
  }
  .inline-block{
    display: inline-block;
  }
  .vtop{
    vertical-align: top;
  }
  #mainContents p {
    font-size: 1.4rem;
    padding-top: 10px;
  }
  .photobox img.border01 {
    border: 1px solid #000;
  }
  #mainContents li, #mainContents dt, #mainContents dd {
    font-size: 1.4rem;
    padding-top: 2px;
  }
  #mainContents p.h3-5{
    font-size: 19px;
    margin-top: 30px;
    color: #00285C;
    font-weight: 600;
  }
  .ml {
    margin-left: 1.5rem !important;
  }
  .w50p_sp {
    width: 30% !important;
  }
}
@media screen and (max-width: 767px) {
  .imglist.imglistsp{
    width: 100%;
  }
  .imglistsp{
    display: flex !important;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 15px 2px;
    width: 100%;
    box-sizing: border-box;
    align-items: flex-end;
  }
  .imglistsp li.long{
    width: 100% !important;
  }
  .imglistsp li{
    width: calc(50% - 1px);
  }
}
