@charset "utf-8";
/* CSS Document */
@import url("./older-style.css");
button:focus {
    outline: none;
}
#dbg {
    display: block;
    width: auto;
    background: rgba(5, 5, 5, 0.8);
    color: #FFF;
    position: fixed;
    left: 0;
    bottom: 0;
    padding: 5px;
    font-size: 11px;
    z-index: 9999;
}
/********************************************************  游ゴシック **/
@font-face {
    font-family: "Yu Gothic";
    src: local("Yu Gothic Medium");
    font-weight: 100;
}
@font-face {
    font-family: "Yu Gothic";
    src: local("Yu Gothic Medium");
    font-weight: 200;
}
@font-face {
    font-family: "Yu Gothic";
    src: local("Yu Gothic Medium");
    font-weight: 300;
}
@font-face {
    font-family: "Yu Gothic";
    src: local("Yu Gothic Medium");
    font-weight: 400;
}
@font-face {
    font-family: "Yu Gothic";
    src: local("Yu Gothic Bold");
    font-weight: bold;
}
@font-face {
    font-family: "Yu Mincho";
    src: local("Yu Mincho Regular");
    font-weight: 500;
}
body {
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
  font-weight: 500;
  scroll-behavior: smooth;
}
.mincho {
    /*  font-family: "Yu Mincho", "YuMincho", serif;*/
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    /* 追加 */
    transform: rotate(.03deg);
}
html.Android .mincho {
    font-family: "Sawarabi Mincho", serif;
}
a {
    color: #009FE9;
}
td a {
    word-break: break-all;
}
.btn-category {
    color: #fff;
    background-color: #8E93AF;
    border-color: #8E93AF;
}
.btn-category:hover {
    color: #fff;
    background-color: #1E265F;
    border-color: #1E265F;
    text-decoration: none;
}
.btn-entry {
    color: #fff;
    background-color: #D9A629;
    border-color: #D9A629;
}
.btn-entry:hover {
    color: #fff;
    background-color: #A17B1C;
    border-color: #A17B1C;
    text-decoration: none;
}
/* End Hack */
img.circle {
    border: 1px #EEE solid;
    border-radius: 50%;
}
/********************************************************  .youtube **/
.youtube16-9 {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}
.youtube16-9 iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
}
td > *:last-child {
    margin-bottom: 0;
}
/******************************************** header */
header {
    border-top: 2px solid #1E2760;
}
.top header {
    /*    background-color: #5798A6;*/
    background-color: #A5ACE2;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}
header.container-fluid {
    padding-left: 0px;
    padding-right: 0px;
}
.top header .inner {
    position: relative;
    min-height: 640px;
}
@media screen and (max-width: 768px) {
    .top header .inner {
        min-height: 415px;
    }
}
@media screen and (max-width: 600px) {
    .top header .inner {
        min-height: 324px;
    }
}
@media screen and (max-width: 375px) {
    .top header .inner {
        min-height: 202px;
    }
}
@media screen and (max-width: 320px) {
    .top header .inner {
        min-height: 173px;
    }
}
header .navbar {
    padding-top: 10px;
    padding-bottom: 10px;
    z-index: 101;
}
.jamt-brand {
    display: inline-block;
    padding-top: 0;
    padding-bottom: 0;
    color: #333;
    white-space: normal;
    vertical-align: top;
}
.top .jamt-brand {
    color: #FFF;
}
.navbar-toggler {
    display: inline-block;
}
.jamt-brand .head-logo {
    display: inline-block;
    vertical-align: top;
    text-indent: -9999px;
    width: 94px;
    height: 32px;
    float: left;
    border-right: 1px solid #333;
    margin-right: 14px;
    background: url(/assets/images/header_logo_inner.png) left top no-repeat;
    background-size: auto 32px;
}
.top .jamt-brand .head-logo {
    border-right-color: #FFF;
    background-image: url(/assets/images/header_logo.png);
}
.jamt-brand .head-title {
    display: block;
    padding-left: 108px;
  margin: 0;
}
.jamt-brand .head-title-text {
    display: block;
    line-height: 1;
    vertical-align: top;
    font-size: 18px;
    font-weight: bold;
}
.top .jamt-brand .head-title-text {}
.jamt-brand .head-title-text-e {
    color: #333;
    margin-top: 3px;
    display: block;
    font-size: 12px;
    height: 12px;
    line-height: 1;
    vertical-align: top;
    white-space: nowrap;
}
.top .jamt-brand .head-title-text-e {
    color: #fff;
}
@media screen and (max-width: 1128px) {
    .jamt-brand .head-logo {
        width: 72px;
        height: 24px;
        background-size: auto 100% !important;
        margin-right: 7px;
    }
    .jamt-brand .head-title {
        display: block;
        padding-left: 84px;
    }
    .jamt-brand .head-title-text {
        font-size: 14px;
    }
    .jamt-brand .head-title-text-e {
        font-size: 6px;
    }
}
@media screen and (max-width: 600px) {
    header .navbar {
        padding-left: 10px;
        padding-right: 10px;
    }
    .jamt-brand .head-logo {
        width: 60px;
        height: 20px;
        background-size: auto 100% !important;
        margin-right: 5px;
    }
    .jamt-brand .head-title {
        padding-left: 70px;
    }
    .jamt-brand .head-title-text {
        font-size: 12px;
    }
}
@media screen and (max-width: 374px) {
    .jamt-brand {
        height: auto;
    }
    .jamt-brand .head-logo {
        width: 45px;
        height: 16px;
    }
    .jamt-brand .head-title {
        padding-left: 50px;
    }
    .jamt-brand .head-title-text {
        font-size: 9px;
    }
    .jamt-brand .head-title-text-e {
        font-size: 6px;
    }
}
header nav li {
    max-height: 37px;
}
header .nav-item {
    font-size: 13px;
}
.top header .nav-item {
    text-shadow: 0px 1px 5px rgba(0, 0, 0, 0.4);
}
header .nav-item a {
    color: #333;
}
header .nav-item a:hover {
    text-decoration: underline;
}
.top header .nav-item a {
    color: #FFF;
}
.top header .nav-item {
    color: #FFF;
}
header .nav-item:before {
    content: "/";
}
header .nav-item:first-child:before {
    content: "";
}
header .nav-link {
    display: inline-block;
    padding-left: 0.5em;
    padding-right: 0.5em;
    vertical-align: middle;
}
header .search {
    margin-left: 8px;
}
header .search label {
    position: relative;
    font-size: 13px;
}
header .search label:before {
    position: absolute;
    top: 50%;
    right: 15px;
    display: block;
    margin-top: -10px;
    width: 10px;
    height: 10px;
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f002';
    color: #FFF;
}
header .search label.focus:before {
    color: #1E2760;
}
header input.form-control-search {
    width: 130px;
    background-color: rgba(206, 206, 206, 0.80);
    color: #FFF;
    font-size: 13px;
    padding: 8px 2.25rem 8px 10px;

    caret-color: #1E2760;
}
header input.form-control-search:placeholder-shown {
    color: #FFF;
}
header input.form-control-search::-webkit-input-placeholder {
    color: #FFF;
}
/* Google Chrome, Safari, Opera 15+, Android, iOS */
header input.form-control-search:-moz-placeholder {
    color: #FFF;
    opacity: 1;
}
/* Firefox 18- */
header input.form-control-search::-moz-placeholder {
    color: #FFF;
    opacity: 1;
}
/* Firefox 19+ */
header input.form-control-search:-ms-input-placeholder {
    color: #FFF;
}
/* IE 10+ */
header .members {
    margin-left: 10px;
}
header .members button {
    background-color: #1E2760;
    color: #FFF;
    font-size: 13px;
    padding: 8px;
    transition: .3s;
}
header .members button:hover {
    cursor: pointer;
    background-color: #000;
}
header .members button i.fas {
    margin-left: 0.5em;
}
@media screen and (max-width: 1180px) {
    /* 1128->1180 */
    header .nav-item,
    header .search label,
    header .members button {
        font-size: 11px;
    }
    header input.form-control-search:placeholder-shown {
        font-size: 11px;
    }
    header input.form-control-search::-webkit-input-placeholder {
        font-size: 11px;
    }
    /* Google Chrome, Safari, Opera 15+, Android, iOS */
    header input.form-control-search:-moz-placeholder {
        font-size: 11px;
    }
    /* Firefox 18- */
    header input.form-control-search::-moz-placeholder {
        font-size: 11px;
    }
    /* Firefox 19+ */
    header input.form-control-search:-ms-input-placeholder {
        font-size: 11px;
    }
    /* IE 10+ */
    .search-gs .gsc-input input[name=search] {
        font-size: 11px !important;
    }
    .search-gs .gsc-input input[name=search]:placeholder-shown {
        font-size: 11px;
    }
    .search-gs .gsc-input input[name=search]::-webkit-input-placeholder {
        font-size: 11px;
    }
    /* Google Chrome, Safari, Opera 15+, Android, iOS */
    .search-gs .gsc-input input[name=search]:-moz-placeholder {
        font-size: 11px;
    }
    /* Firefox 18- */
    .search-gs .gsc-input input[name=search]::-moz-placeholder {
        font-size: 11px;
    }
    /* Firefox 19+ */
    .search-gs .gsc-input input[name=search]:-ms-input-placeholder {
        font-size: 11px;
    }
    /* IE 10+ */
}
@media screen and (max-width: 767px) {
    .navbar-toggler {
        padding: 0;
    }
}
header .search-gs {
    margin-left: 10px;
}
/******************************************** Google Search Custom */
.search-gs #___gcse_0 {
    display: inline-block;
    width: auto;
    max-width: 150px
}
.search-gs .gsc-input-box-focus {
    box-shadow: none !important;
}
.search-gs form.gsc-search-box {
    margin: 0;
}
.search-gs .gsc-search-box-tools .gsc-search-box .gsc-input {
    padding-right: 0;
}
.search-gs .gsc-search-box-tools .gsc-search-box .gsc-search-button {
    display: none;
}
.search-gs .gsc-control-cse {
    background-color: transparent;
    border: none;
    padding: 0;
}
.search-gs .cse .gsc-control-cse,
.gsc-control-cse {
    padding: 0;
    border: none;
    width: auto;
}
.search-gs input.gsc-input,
.search-gs .gsc-input-box,
.search-gs .gsc-input-box-hover,
.search-gs .gsc-input-box-focus {
    border: none;
}
.search-gs table.gsc-search-box {
    margin-bottom: 0;
    border: 0;
}
.search-gs .gsib_a {
    padding: 0;
    position: relative;
}
.search-gs .gsib_a:before {
    position: absolute;
    top: 50%;
    right: 15px;
    display: block;
    margin-top: -10px;
    width: 10px;
    height: 10px;
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f002';
    color: #FFF;
    z-index: 10;
}
.search-gs .gsc-input-box-focus .gsib_a:before {
    color: #333;
}
.search-gs #___gcse_0 {
    max-width: 100%;
}
.search-gs .gsc-search-box-tools .gsc-input-box {
    background-color: transparent !important;
    height: auto;
}
.search-gs .gsc-input input[name=search] {
    background-image: url(../lib/google/googlelogo_white_46x16dp.png) !important;
    background-repeat: no-repeat !important;
    position: relative;
    transition: .3s;
    width: 180px !important;
    background-color: rgba(206, 206, 206, 0.80) !important;
    color: #FFF !important;
    font-size: 13px;
    padding: 8px 2.25rem 8px 10px !important;
    caret-color: #1E2760;
    border: 1px solid #ced4da !important;
    border-radius: .2rem;
    background-clip: padding-box;
    background-position: 10px center !important;
    text-indent: 48px !important;
}
.search-gs .gsc-input input[name=search]:placeholder-shown {
    font-size: 13px;
    color: #FFF;
}
.search-gs .gsc-input input[name=search]::-webkit-input-placeholder {
    font-size: 13px;
    color: #FFF;
}
/* Google Chrome, Safari, Opera 15+, Android, iOS */
.search-gs .gsc-input input[name=search]:-moz-placeholder {
    font-size: 13px;
    color: #FFF;
    opacity: 1;
}
/* Firefox 18- */
.search-gs .gsc-input input[name=search]::-moz-placeholder {
    font-size: 13px;
    color: #FFF;
    opacity: 1;
}
/* Firefox 19+ */
.search-gs .gsc-input input[name=search]:-ms-input-placeholder {
    font-size: 13px;
    color: #FFF;
}
/* IE 10+ */
.search-gs .gsc-input input[name=search]:focus {
    color: #333 !important;
    background-color: #FFF !important;
    border-color: #80bdff;
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, .25);
    text-indent: 0 !important;
}
@supports (-ms-ime-align:auto) {
    .search-gs .gsc-input input[name=search] {
        text-indent: 24px !important;
    }
    .search-gs .gsc-input input[name=search]:focus {
        text-indent: 0 !important;
    }
}
/******************************************** head-copy */
header .head-copy {
    width: 1080px;
    text-align: left;
    margin-left: auto;
    margin-right: auto;

    margin-top: 160px;
}
@media screen and (max-width: 1110px) {
    header .head-copy {
        width: auto;
        padding-left: 15px;
        padding-right: 15px;
    }
}
header .head-copy p {
    font-size: 50px;
    line-height: 1.2;
    /*  font-family: "Yu Mincho", "YuMincho", serif;*/
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-weight: bold;

    color: #FFF;
    text-shadow: 0px 1px 2px rgba(0, 0, 0, 0.4);
}
@media screen and (max-width: 767px) {
    header .head-copy {
        margin-top: 0;
        position: absolute;
        left: 0;
        bottom: 20px;
    }
    header .head-copy p {
        font-size: 26px;
        font-weight: 700;
        text-shadow: 0px 4px 6px rgba(0, 0, 0, 0.8);
    }
}
.navbar-toggler {
    color: #1E2760;
    padding-bottom: 5px;
}
.top .navbar-toggler {
    color: #FFF;
    text-shadow: 0px 1px 5px rgba(0, 0, 0, 0.7);
}
header .navbar-collapse .search label,
header .navbar-collapse .members button {
    margin-bottom: 0;
}
@media screen and (max-width: 991px) {
    header .navbar-collapse ul {
        margin-top: 5px;
        margin-bottom: 5px;
    }
    header .navbar-collapse {
        background-color: #F4F4F7;
        margin-left: -16px;
        margin-right: -16px;
        padding: 10px;
    }
    .top header .navbar-collapse {
        background-color: rgba(0, 0, 0, 0.7);
    }
    header .navbar-collapse .nav {
        -webkit-justify-content: center;
        justify-content: center;
    }
    header .navbar-collapse .search-gs,
    header .navbar-collapse .search,
    header .navbar-collapse .members {
        display: block;
        /*    width: 48%;*/
        width: 100%;
        margin-left: auto;
    }
    .search-gs #___gcse_0,
    .search-gs .gsc-control-cse,
    .search-gs .gsc-search-box .search-gs .gsc-input,
    .search-gs .gsc-input input[name=search] {
        width: 100% !important;
    }
    header .navbar-collapse .search label,
    header .navbar-collapse .search label input,
    header .navbar-collapse .members button {
        width: 100%;
    }
}
@media screen and (max-width: 600px) {
    header .navbar-collapse {
        margin-left: -10px;
        margin-right: -10px;
    }
}
@media screen and (max-width: 480px) {
    header .navbar-collapse .search,
    header .navbar-collapse .search-gs,
    header .navbar-collapse .members {
        width: 100%;
    }
    header .navbar-collapse .members {
        margin-top: 10px;
    }
}
/******************************************** #navbarNav */
#navbarNav {}
#navbarNav ul#navCat {
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    margin: 0;
}
@media screen and (min-width: 768px) {
    #navbarNav ul#navCat {
        display: none;
    }
}
#navbarNav ul#navCat li {
    display: block;
    width: 50%;
}
header nav #navbarNav ul#navCat li {
    max-height: none;
}
#navbarNav ul#navCat li a {
    display: block;
    background-color: #1E265F;
    border-radius: 2px;
    font-size: 13px;
    line-height: 1.2;
    color: #FFF;
    text-align: center;
    padding-top: 1.1em;
    padding-bottom: 1.1em;
    margin-left: 1px;
    margin-right: 1px;
    margin-bottom: 2px;
    transition: background-color .3s;
}
#navbarNav ul#navCat li a:hover {
    background-color: #8E93AF;
    text-decoration: none;
}
#navbarNav ul#navCat li a span {}
#navbarNav ul#globalMega {
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    margin: 0;
}
@media screen and (min-width: 768px) {
    #navbarNav ul#globalMega {
        display: none;
    }
}
#navbarNav ul#globalMega li {
    display: block;
    width: 50%;
}
header nav #navbarNav ul#globalMega li {
    max-height: none;
}
#navbarNav ul#globalMega li.home {
    width: 100%;
    order: 4;
}
#navbarNav ul#globalMega li a {
    display: block;
    background-color: #949494;
    border-radius: 2px;
    font-size: 13px;
    line-height: 1.2;
    color: #FFF;
    text-align: center;
    padding-top: 1.1em;
    padding-bottom: 1.1em;
    margin-left: 1px;
    margin-right: 1px;
    margin-bottom: 2px;
    transition: background-color .3s;
}
#navbarNav ul#globalMega li a:hover {
    background-color: #333;
    text-decoration: none;
}
#navbarNav ul#globalMega li a span {}
#navbarNav ul#globalMega li ul {
    display: none;
}
@media screen and (max-width:767px) {
    #navbarNav ul#globalMega li a {
        background-color: #03A0E9;
    }
    #navbarNav ul#globalMega li a:hover {
        background-color: #0274A9;
    }
}
@media screen and (max-width: 420px) {
    #navbarNav ul#navCat li a {
        font-size: 12px;
    }
    #navbarNav ul#globalMega li a {
        font-size: 12px;
    }
}
@media screen and (max-width: 360px) {
    #navbarNav ul#navCat li a {
        font-size: 10px;
    }
    #navbarNav ul#globalMega li a {
        font-size: 10px;
    }
}
/******************************************** global nav */
.nav-global {
    border-bottom: 2px solid #E5E5E5;
}
.top .nav-global {
    border-bottom: none;
}
nav.nav-global .inner {
    padding-top: 18px;
    padding-bottom: 18px;
}
.top nav.nav-global .inner {
    padding-top: 21px;
    padding-bottom: 21px;
}
.nav-global ul {
    list-style: none;
    padding-left: 0;
    display: flex;
    -webkit-justify-content: space-between;
    /* Safari */
    justify-content: space-between;
}
.nav-global ul li {
    display: block;
    background: url(../images/glnav-border.png) right top no-repeat;
    padding-right: 1px;
}
.nav-global ul li {
    width: 28%;
}
.nav-global ul li:first-child {
    width: 16%;
}
.nav-global ul li a {
    display: block;
    text-align: center;
    /*  font-family: "Yu Mincho", "YuMincho", serif;*/
    font-size: 15px;
    color: #333;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    /* 追加 */
    transform: rotate(.03deg);
}
html.Android .nav-global ul li a {
    font-family: "Sawarabi Mincho", serif;
}
.nav-global ul li a .sub {
    display: block;
    font-size: 8px;
    min-height: 8px;
    line-height: 1;
    color: #666666;
    width: 83%;
    margin-left: auto;
    margin-right: auto;
    position: relative;
}
@media screen and (max-width: 480px) {
    .nav-global ul li a {
        font-size: 12px;
    }
    .nav-global ul li a .sub {
        font-size: 6px;
    }
}
.top .nav-global ul li a .sub {
    min-height: 25px;
    padding-bottom: 8px;
    border-bottom: 2px solid #E8E9EF;
}
.nav-global ul li.home a .sub {
    width: 74px;
}
.top .nav-global ul li.active a .sub:after,
.top .nav-global ul li a:hover .sub:after {
    content: "";
    display: block;
    border: 8px solid transparent;
    border-top-color: #E8E9EF;
    border-bottom-width: 0;
    width: 0;
    position: absolute;
    bottom: -10px;
    margin-left: -8px;
    left: 50%;
}
.nav-global ul li.about a .sub {
    border-color: #A5ACE2;
}
.nav-global ul li.about.active a .sub:after,
.nav-global ul li.about a:hover .sub:after {
    border-top-color: #A5ACE2;
}
.nav-global ul li.general a .sub {
    border-color: #4355C5;
}
.nav-global ul li.general.active a .sub:after,
.nav-global ul li.general a:hover .sub:after {
    border-top-color: #4355C5;
}
.nav-global ul li.member a .sub {
    border-color: #1E2760;
}
.nav-global ul li.member.active a .sub:after,
.nav-global ul li.member a:hover .sub:after {
    border-top-color: #1E2760;
}
@media screen and (max-width: 767px) {
    .nav-global {
        padding-left: 0;
        padding-right: 0;
    }
    .nav-global .inner {}
    .nav-global ul {}
    .nav-global ul li {
        /*    width: 33.3%;*/
        width: 27%;
    }
    .nav-global ul li:first-child {}
    .nav-global ul li:last-child {
        background-image: none;
    }
    .nav-global ul li.home {
        /*    display: none;*/
        width: 19%;
    }
    .nav-global ul li.home a .sub,
    .nav-global ul li a .sub {
        width: 100%;
    }
}
/******************************************** breadcrumb */
.section.breadcrumb {
    padding-top: 0;
    padding-bottom: 0;
    background-color: transparent;
    margin-bottom: 0;
}
@media screen and (max-width: 767px) {
    .section.breadcrumb {
        display: none;
    }
}
.section.breadcrumb .inner {
    padding-top: 0;
    padding-bottom: 0;
}
.section.breadcrumb .breadcrumb {
    background-color: transparent;
    padding-top: 6px;
    padding-bottom: 6px;
    padding-left: 0;
}
.breadcrumb-item,
.breadcrumb-item a {
    color: #7F7F7F;
    font-size: 12px;
}
.breadcrumb-item + .breadcrumb-item:before {
    content: ">";
    padding-left: 1.2em;
    padding-right: 1.2em;
}
/******************************************** cat-nav */
.cat-nav {
    /*  background-color: aqua;*/
}
.section.cat-nav .inner {
    padding-top: 1px;
    /* IEにて上部に食い込む事象が発生したため、1px余白を指定 */
    padding-bottom: 0;
    padding-left: 0;
    padding-right: 0;
    width: 1080;
}
@media screen and (max-width: 1180px) {
    .section.cat-nav .inner {
        padding-top: 0;
        padding-bottom: 0;
        width: auto;
    }
}
@media screen and (max-width: 910px) {
    .section.cat-nav {
        padding-left: 0;
        padding-right: 0;
    }
}
.cat-nav ul.cat-nav-list {
    background-color: #FFF;
    list-style: none;
    padding-left: 0;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: start;
    /* Safari */
    justify-content: start;
    -webkit-align-content: space-between;
    /* Safari */
    align-content: space-between;
    margin-left: auto;
    margin-right: auto;
}
@media screen and (max-width: 1180px) {
    .cat-nav ul.cat-nav-list {
        width: 804px;
    }
}
@media screen and (max-width: 910px) {
    .cat-nav ul.cat-nav-list {
        width: auto;
    }
}
@media screen and (max-width: 767px) {
    .cat-nav ul.cat-nav-list {
        width: 90%;
    }
}
.cat-nav ul.cat-nav-list li {
    display: block;
    width: 268px;
    margin-bottom: 2px;
}
@media screen and (max-width: 910px) {
    .cat-nav ul.cat-nav-list li {
        width: 33.3%;
    }
}
@media screen and (max-width: 600px) {
    .cat-nav ul.cat-nav-list li {
        width: 50%;
    }
}
ul.cat-nav-list .cat-panel .nolink,
ul.cat-nav-list .cat-panel a {
    display: block;
    text-align: center;
    font-size: 20px;
    color: #333;
    min-height: 268px;
    border: 1px solid #D6D6D6;
    /*  font-family: "Yu Mincho", "YuMincho", serif;*/
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    /* 追加 */
    transform: rotate(.03deg);
    position: relative;
    transition: .3s;

    margin-left: 1px;
    margin-right: 1px;
}
ul.cat-nav-list .cat-panel a:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 3px;
}
ul.cat-nav-list .cat-panel[data-cat=about] a:before {
    background-color: #A5ACE2;
}
ul.cat-nav-list .cat-panel[data-cat=general] a:before {
    background-color: #4355C5;
}
ul.cat-nav-list .cat-panel[data-cat=member] a:before {
    background-color: #1E2760;
}
html.Android ul.cat-nav-list .cat-panel .nolink,
html.Android ul.cat-nav-list .cat-panel a {
    font-family: "Sawarabi Mincho", serif;
}
ul.cat-nav-list .cat-panel a:hover {
    background-color: rgba(0, 0, 0, 0.06);
}
ul.cat-nav-list .cat-panel a span {
    display: block;
    margin-left: auto;
    margin-right: auto;
}
ul.cat-nav-list .cat-panel .ico {
    margin-top: 70px;
    width: 90px;
    height: 90px;
    border-radius: 50%;
    background-color: #EEE;
    background-position: center center;
    background-repeat: no-repeat;
    margin-bottom: 46px;
}
ul.cat-nav-list .cat-panel .ico img {
    width: 90px;
    height: 90px;
}
@media screen and (max-width: 910px) {
    ul.cat-nav-list .cat-panel .nolink,
    ul.cat-nav-list .cat-panel a {
        min-height: 200px;
    }
    ul.cat-nav-list .cat-panel .ico {
        margin-top: 40px;
        width: 70px;
        height: 70px;
        background-size: auto 70px;
    }
    ul.cat-nav-list .cat-panel .ico img {
        width: 70px;
        height: 70px;
    }
}
@media screen and (max-width: 600px) {
    ul.cat-nav-list .cat-panel .nolink,
    ul.cat-nav-list .cat-panel a {
        min-height: 140px;
    }
    ul.cat-nav-list .cat-panel .ico {
        margin-top: 25px;
        width: 45px;
        height: 45px;
        background-size: auto 45px;
    }
    ul.cat-nav-list .cat-panel .ico img {
        width: 45px;
        height: 45px;
    }
}
ul.cat-nav-list .cat-panel[data-cat=about] .ico {
    background-color: #A5ACE2;
}
ul.cat-nav-list .cat-panel[data-cat=general] .ico {
    background-color: #4355C5;
}
ul.cat-nav-list .cat-panel[data-cat=member] .ico {
    background-color: #1E2760;
}
ul.cat-nav-list .cat-panel a span i {
    font-style: normal;
    display: inline-block;
    /*  width: 0.5em;*/
}
ul.cat-nav-list .cat-panel span i.gl {
    margin-left: -0.4em;
}
ul.cat-nav-list .cat-panel span i.gr {
    margin-right: -0.4em;
}
ul.cat-nav-list .cat-panel .ttext {
    position: absolute;
    width: 100%;
    left: 0;
    /*  bottom: 10px;*/
    bottom: 40px;
    line-height: 1.2;
}
ul.cat-nav-list .cat-panel .title {}
ul.cat-nav-list .cat-panel .sub {
    display: block;
    font-size: 8px;
    color: #666;
    margin-top: 4px;
}
ul.cat-nav-list .cat-panel {}
@media screen and (max-width: 910px) {
    ul.cat-nav-list .cat-panel .ttext {
        bottom: 20px;
    }
    ul.cat-nav-list .cat-panel .title {
        font-size: 16px;
    }
    ul.cat-nav-list .cat-panel .sub {
        font-size: 6px;
    }
}
@media screen and (max-width: 420px) {
    ul.cat-nav-list .cat-panel .ttext {
        bottom: 10px;
    }
    ul.cat-nav-list .cat-panel .title {
        font-size: 14px;
    }
}
@media screen and (max-width: 360px) {
    ul.cat-nav-list .cat-panel .sub {
        font-size: 5px;
    }
}
/******************************************** emergency */
section.emergency {
    background-color: #F4F4F7;
}
section.emergency .inner {
    padding-top: 25px;
    padding-bottom: 25px;
}
section.emergency .list-box {}
section.emergency ul.list-topics {
    margin-top: 0;
    margin-bottom: 0;
}
section.emergency ul.list-topics li {}
section.emergency ul.list-topics li a,
section.emergency ul.list-topics li > span {
    position: relative;
    padding-left: 24px;
}
section.emergency ul.list-topics li a span,
section.emergency ul.list-topics li > span span {
    font-size: 115%;
}
section.emergency ul.list-topics li a .ico-info,
section.emergency ul.list-topics li > span .ico-info {
    position: absolute;
    left: 0;
    top: .7em;
    color: #000;
}
section.top-sp-nav + section.emergency {
    margin-top: -26px;
}
section.top-sp-nav + section.emergency .inner {
    padding-top: 0;
    padding-bottom: 25px;
}
/******************************************** topics */
.list-box {}
.list-box-header {
    display: flex;
    -webkit-justify-content: space-between;
    /* Safari */
    justify-content: space-between;
    padding-bottom: 12px;
    border-bottom: 1px solid #E5E5E5;
}
@media screen and (max-width: 767px) {
    .list-box-header {
        padding-bottom: 6px;
    }
}
.list-box-header h3 {
    font-size: 20px;
    /*  font-family: "Yu Mincho", "YuMincho", serif;*/
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    /* 追加 */
    transform: rotate(.03deg);
    margin-bottom: 0;
}
html.Android .list-box-header h3 {
    font-family: "Sawarabi Mincho", serif;
}
@media screen and (max-width: 767px) {
    .list-box-header h3 {
        font-size: 16px;
    }
}
.list-box-header a {
    color: #7F7F7F;
    font-size: 13px;
}
.list-box-header a:hover {
    background-color: #EEE;
}
.list-box-header a.btn-sm {
    padding-bottom: 1px;
    border-color: #7F7F7F;
}
.list-box-header a.btn-sm .fas {
    margin-left: 0.5em;
}
.list-topics {
    margin-top: 6px;
    padding-left: 0;
    list-style: none;
}
.list-topics li {
    display: block;
}
.list-topics li .fa,
.list-topics li .fas,
.list-topics li .far,
.list-topics li .fal,
.list-topics li .fab {
    margin-left: .2em;
    font-size: 15px;
}
.list-topics li a,
.list-topics li > span {
    display: block;
    font-size: 13px;
    line-height: 1.7;
    padding-top: 6px;
    padding-bottom: 6px;
}
.list-topics li .badge-new {
    display: none;
}
@media screen and (max-width: 767px) {
    .list-topics li {
        font-size: 12px;
    }
    .list-topics li .date {
        font-size: 9px;
    }
}
.list-topics li a .badge {
    vertical-align: middle;
    margin-left: .2em;
    font-size: 10px;
    padding-top: .2em;
    padding-bottom: .2em;
}
.list-topics li a span.date {
    display: block;
    color: #333333;
}
/**/
.cat-news .list-topics {/* ul */
  margin-top: 0;
  padding: 10px 15px;
  max-height: 300px;
  overflow-y: auto;
  margin-bottom: 2.6em !important;
  border: solid 1px #E5E5E5;
  border-top: none;
}
.cat-news .list-topics li {
  border-bottom: 1px solid #efefef;
}
.cat-news .list-topics li:last-child {
  border-bottom: none;
}
@media screen and (max-width: 600px) {
  .cat-news .list-topics {/* ul */
    padding: 10px 15px;
  }
}
/******************************************** footer */
footer {
    background-color: #7F7F7F;
    color: #FFF;
    font-size: 13px;
}
@media screen and (max-width: 600px) {
    footer {
        font-size: 9px;
    }
}
footer .inner {
    padding-top: 24px;
    padding-bottom: 60px;
}
footer a {
    color: #FFF;
}
footer ul {
    list-style: none;
    padding-left: 0;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: center;
    /* Safari */
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 0px;
}
footer ul li {
    display: inline-block;
}
@media screen and (max-width: 600px) {
    footer ul li {
        margin-bottom: 15px;
    }
}
footer ul li:after {
    content: "/";
}
footer ul li:last-child:after {
    content: "";
}
footer ul li a {
    padding-right: 0.4em;
    padding-left: 0.4em;
    line-height: 1.2;
}
.copyright {
    margin-top: 1em;
}
@media screen and (max-width: 600px) {
    .copyright {
        font-size: 8px;
    }
}
/******************************************** backToTop  */
#backToTop {
    display: none;
    width: 50px;
    height: 40px;
    position: fixed;
    bottom: 0px;
    right: 0;
    margin: 0;
    padding: 0;
    z-index: 999;
}
#backToTop a {
    display: block;
    width: 50px;
    height: 40px;
    color: #FFF;
    background-color: #7F7F7F;
    margin: 0;
    padding: 0;
    text-decoration: none;
    text-align: center;
}
#backToTop a:hover {
    text-decoration: none;
}
#backToTop a span {
    display: none;
}
#backToTop a:after {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: "\f077";
    color: #FFF;
    line-height: 40px;
    margin: 0;
}
/******************************************** banner section  */
.section.banner {
    border-top: 1px solid #D2D2DF;
    overflow: hidden;
}
.section.banner .inner {
    padding-bottom: 30px;
}
ul.banner-list {
    margin-left: -15px;
    margin-right: -15px;
	margin: 0 auto;
	max-width: 830px;
    padding-left: 0;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: center;
    /* Safari */
    justify-content: center;
    -webkit-align-content: flex-start;
    /* Safari */
    align-content: flex-start;
    -webkit-align-content: space-between;
    /* Safari */
    align-content: space-between;
}
ul.banner-list li {
    display: inline-block;
    width: 253px;
    margin-bottom: 20px;
    margin-left: 10px;
    margin-right: 10px;
}
ul.banner-list li a {
    display: inline-block;
    box-shadow: 0px 1px 2px rgba(0, 0, 0, 0.2);
    transition: opacity .3s;
}
ul.banner-list li a:hover {
    opacity: 0.7;
}
ul.banner-list li a img {}
@media screen and (max-width: 1200px) {
    ul.banner-list li {
        display: inline-block;
        width: 30%;
        margin-bottom: 20px;
    }
    ul.banner-list li a {
        width: 100%;
    }
    ul.banner-list li a img {
        width: 100%;
        height: auto;
    }
}
@media screen and (max-width: 767px) {
    ul.banner-list li {
        width: 30%;
        margin-bottom: 10px;
        margin-left: 5px;
        margin-right: 5px;
    }
}
@media screen and (max-width: 600px) {
    ul.banner-list li {
        width: 42%;
    }
}
/****************************************************************************** .bnr-carousel */
.bnr-carousel .flickity-viewport {}
.bnr-carousel .carousel-cell .inner {
    padding-bottom: 0;
}
.bnr-carousel .flickity-prev-next-button {
    background-color: transparent;
}
.bnr-carousel .flickity-prev-next-button:hover {
    background-color: rgba(0, 0, 0, 0.30);
}
.bnr-carousel .flickity-prev-next-button .arrow {
    fill: #7F7F7F;
}
.bnr-carousel .flickity-prev-next-button.previous {
    left: -50px;
}
.bnr-carousel .flickity-prev-next-button.next {
    right: -50px;
}
@media screen and (max-width: 767px) {
    .bnr-carousel .flickity-prev-next-button.previous {
        left: -19px;
    }
    .bnr-carousel .flickity-prev-next-button.next {
        right: -19px;
    }
}
.bnr-carousel .flickity-page-dots {
    bottom: -15px;
}
/******************************************** section  */
.section.migration-950,
.section {
    text-align: center;
    z-index: 10;
}
.section > .inner {
    width: 1072px;
    margin-left: auto;
    margin-right: auto;
    text-align: left;
    padding-top: 50px;
    padding-bottom: 50px;
}
.section.migration-950 > .inner {
    width: 950px;
    padding-top: 0;
    padding-bottom: 0;
}
.section .inner > *:last-child {
    margin-bottom: 0;
}
@media screen and (max-width: 1110px) {
    .section .inner {
        /*    width: auto;*/
        width: 100%;
    }
}
@media screen and (max-width: 920px) {
    .section.migration-950 > .inner {
        width: auto;
    }
}
@media screen and (max-width: 767px) {
    .section > .inner {
        padding-top: 30px;
    }
}
.bg-gray {
    background-color: #F4F4F7;
}
/******************************************** page-header  */
section.page-header {
    background-color: #F4F4F7;
}
body.cat-menu section.page-header {
    background-color: #E5F5FD;
}
body.cat-menu.bulletin section.page-header,
body.cat-menu.blog section.page-header {
    background-color: #ECECEC;
}
section.page-header .inner {
    padding-top: 24px;
    padding-bottom: 24px;
}
section.page-header h1,
section.page-header .h1 {
    font-size: 34px;
    line-height: 1.2;
    /*  font-family: "Yu Mincho", "YuMincho", serif;*/
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    /* 追加 */
    transform: rotate(.03deg);
    color: #212529;
}
body.cat-menu section.page-header h1,
body.cat-menu section.page-header .h1 {
    color: #1E265F;
}
html.Android section.page-header h1,
html.Android section.page-header .h1 {
    font-family: "Sawarabi Mincho", serif;
    margin-bottom: 0;
}
section.page-header h1 span.eng,
section.page-header .h1 span.eng {
    display: block;
    font-size: 10px;
    color: #666;
}
/******************************************** .local-list */
.local-list {
    padding-left: 0;
    list-style: none;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: start;
    justify-content: start;
    -webkit-align-content: flex-start;
    align-content: flex-start;
    -webkit-align-content: space-between;
    align-content: space-between;
}
.local-list li {
    display: block;
    width: 30%;
    margin-right: 5%;
    margin-bottom: 30px;
}
.local-list li:nth-child(3n) {
    margin-right: 0;
}
@media screen and (max-width: 767px) {
    .local-list li {
        width: 48%;
        margin-right: 2%;
    }
    .local-list li:nth-child(3n) {
        margin-right: 2%;
    }
    .local-list li:nth-child(2n) {
        margin-right: 0;
    }
}
.local-list li a {
    display: block;
    /*  padding: 35px 10px 35px 18px; */
    padding: 35px 10px 35px 30px;
    border: 1px solid #E5E5E5;
    color: #333;
    position: relative;
    box-sizing: content-box;
}
.local-list li .fa,
.local-list li .fal,
.local-list li .far,
.local-list li .fab,
.local-list li .fas {
    margin-left: .25em;
}
.local-list li a:hover {
    text-decoration: none;
    background-color: rgba(0, 0, 0, 0.06);
}
.local-list li a:after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 2px;
    background-color: #1E2760;
}
.local-list li a:before {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f105';
    color: #1E2760;
    padding-right: 0.5em;
    position: absolute;
    left: 15px;
    top: 35px;
}
@media screen and (max-width: 767px) {
    .local-list li {
        margin-bottom: 15px;
    }
    .local-list li a {
        padding: 20px 10px 20px 20px;
    }
    .local-list li a:before {
        top: 18px;
        left: 8px;
    }
}
/**************************************************** article content */
h2,
h3,
h4 {
    margin-bottom: 0.8em;
}
h5,
h6 {
    margin-bottom: 0.4em;
}
article h2 {
    font-size: 26px;
    border-left: 4px solid #1E2760;
    padding: 7px 0 8px 10px;
    margin-bottom: 30px;
}
article h3 {
    font-size: 20px;
    color: #1E265F;
    font-weight: bold;
}
article * + h2,
article * + h3 {
    margin-top: 1em;
}
article h4 {
    font-size: 18px;
    color: #333;
    font-weight: bold;
}
article h5 {
    font-size: 16px;
    color: #333;
    font-weight: bold;
}
article h6 {
    font-size: 16px;
    color: #333;
}
article p {
    font-size: 16px;
    line-height: 1.6;
    margin-bottom: 1.6em;
}
article figure {
    color: #7F7F7F;
    font-size: 12px;
    line-height: 1.6;
    width: auto;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}
article figure img {
    margin-left: auto;
    margin-right: auto;
    width: 100%;
}
article figcaption {
    display: block;
    text-align: left;
    margin-left: auto;
    margin-right: auto;
    margin-top: 6px;
}
article ul,
article ol {
    padding-left: 1.4em;
    margin-bottom: 1.6em;
}
article ul li ul,
article ul li ol,
article ol li ul,
article ol li ol {
    padding-left: 1.2em;
    margin-bottom: 0;
}
article dl ul,
article dl ol {
    margin-bottom: 0;
}
article thead th {
    background-color: #1E2760;
    color: #FFF;
}
.text-attention {
    font-size: 87.5%;
    color: #7F7F7F;
}
th {
    background-color: #F4F4F7;
    font-weight: normal;
}
.list-UnOrderedLink,
.list-UnOrderedLink ul {
    padding-left: 0;
    list-style: none;
}
.list-UnOrderedLink li,
.list-UnOrderedLink td,
.iconLink.list-UnOrderedLink,
table tr .icon,
.list-UnOrderedLink.mgT0 {
    position: relative;
    padding-left: 1.4em;
}
.list-UnOrderedLink li:before,
.list-UnOrderedLink td:before,
.iconLink.list-UnOrderedLink:before,
table tr .icon:before,
.list-UnOrderedLink.mgT0:before {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f138';
    font-size: 90%;
    color: #1E2760;
    position: absolute;
    top: 0;
    left: 0;
}
.list-UnOrderedLink li li {
    padding-left: 1em;
}
.list-UnOrderedLink li li:before {
    content: '\f105';
}
.list-UnOrderedLink li a {}
.list-UnOrderedLink li a:before {}
.box.border.ma {
    margin-top: 1.6em;
}
.table-StyleLight tr th {
    border: 1px solid #dee2e6 !important;
    text-align: center;
    padding: .75rem;
}
.table-StyleLight tr td {
    border: 1px solid #dee2e6 !important;
    padding: .75rem;
}
.table-StyleLight {
    margin-bottom: 1.6em;
}
.col-md-9 article table {
    margin-bottom: 1.6em;
}
dl.list-DefinitionMiddle {}
.list-DefinitionMiddle dd {
    border-left: 1px solid #ccc;
    margin-left: 0.5em;
    padding-left: 0.5em;
}
dl.faq {
    margin-bottom: 10px;
}
dl.faq dt {
    position: relative;
    padding: 0;
    color: #FFF;
    background-color: #1E2760;
}
dl.faq dt:before {
    content: 'Q';
    line-height: 1;
    color: #FFF;
    font-size: 30px;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    transform: rotate(.03deg);
    display: inline-block;
    position: absolute;
    left: 18px;
    top: 10px;
}
dl.faq dt a,
dl.faq dt span {
    position: relative;
    color: #FFF;
    display: inline-block;
    padding: 8px 52px 8px 60px;
    min-height: 3em;
}
dl.faq dt a:after {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f077';
    position: absolute;
    top: 10px;
    right: 18px;
    font-size: 16px;
}
dl.faq dt a.collapsed:after {
    content: '\f078';
}
dl.faq dd {
    position: relative;
    padding: 18px 25px 18px 60px;
    border: #E5E5E5 1px solid;
    background-color: #F4F4F7;
    margin-bottom: 0;
}
dl.faq dd:before {
    content: 'A';
    line-height: 1;
    font-size: 30px;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    transform: rotate(.03deg);
    color: #1E2760;
    display: inline-block;
    position: absolute;
    left: 18px;
    top: 18px;
}
ul.attention {
    padding-left: 0;
    list-style: none;
}
ul.attention li {
    padding-left: 1.2em;
    position: relative;
}
ul.attention li:before {
    content: "※";
    display: inline-block;
    position: absolute;
    left: 0;
    top: 0;
}
.box {
    box-sizing: content-box;
    padding: 30px 40px;
    margin-bottom: 1.6em;
}
.box > *:last-child {
    margin-bottom: 0;
}
.box.box-bg01 {
    background-color: #FEF6E8;
}
.box.box-bg02 {
    background-color: #F4F4F7;
}
.box.box-border {
    border: 1px solid #E5E5E5;
}
/**************************************************** mynumber*/
#navPickup_2 .left .image {
    margin-bottom: 1.6em;
}
/**************************************************** e-learning*/
.buttonArea {
    margin: 25px 0;
    overflow: hidden;
}
.button_L {
    float: left;
    margin-right: 45px;
    width: 202px;
}
.button_R {
    float: right;
    margin-left: 45px;
    width: 202px;
}
.column2 {
    width: 500px;
    margin: 0 auto;
    text-align: center;
}
.tCenter {
    text-align: center !important;
}
.mgB30 {
    margin-bottom: 30px;
}
.mgT30 {
    margin-top: 30px;
}
.buttonArea p span {
    width: 150px;
    display: inline-block;
    text-align: center;
}
.column2 .buttonArea p {
    text-align: left;
}
.fa-file-pdf:before,
.fa-clone:before,
.fa-file-pdf:before,
.fa-file-word:before,
.fa-file-excel:before,
.fa-file-powerpoint:before,
.fa-file-archive:before {
    padding-left: 5px;
}
.naviInlineMenu ul li {
    display: inline;
}
@media screen and (max-width: 767px) {
    .box {
        padding: 15px 20px;
    }
}
@media screen and (max-width: 420px) {
    .box {
        padding: 15px 10px;
    }
}
/******************************************** aside */
aside {
    text-align: right;
}
aside > .inner {
    max-width: 200px;
    margin-right: 0;
    margin-left: auto;
    text-align: left;
}
@media screen and (max-width: 767px) {
    aside > .inner {
        max-width: 100%;
        margin-right: auto;
        margin-left: auto;
    }
}
aside .aside-header {
    border-top: 2px solid #1E2760;
    color: #333;
}
aside .aside-header a {
    color: #333;
}
aside .aside-header a:hover {
    text-decoration: none;
}
aside .aside-header .title {
    padding-top: 30px;
    padding-bottom: 30px;
    display: block;
    font-size: 20px;
}
aside .aside-header .title:before {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f22d';
    color: #1E2760;
    padding-right: 0.2em;
}
aside .aside-header .title span {}
aside .aside-list {
    list-style: none;
    padding-left: 0;
    border-bottom: #E5E5E5 1px solid;
}
aside .aside-list li {
    display: block;
    width: 100%;
    border-top: #E5E5E5 1px solid;
    line-height: 1.2;
}
aside .aside-list li.subtitle {
    display: block;
}
aside .aside-list li.subtitle span {
    display: block;
    padding-top: 15px;
    padding-bottom: 15px;
    padding-left: 1em;
    background-color: rgba(0, 0, 0, 0.06);
}
aside .aside-list li a {
    display: block;
    color: #333;
    padding-top: 15px;
    padding-bottom: 15px;
    padding-left: 1em;
    padding-right: 10px;
    position: relative;
}
aside .aside-list li a:before {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f105';
    color: #1E2760;
    position: absolute;
    left: 0;
    top: 15px;
}
aside .aside-list li a:hover {
    text-decoration: none;
    background-color: rgba(0, 0, 0, 0.06);
}
aside .aside-list li .fa,
aside .aside-list li .fal,
aside .aside-list li .far,
aside .aside-list li .fab,
aside .aside-list li .fas {
    margin-left: .5em;
    color: #CCC;
}
aside .aside-list li a span {}
aside .aside-list > li > ul {
    display: none;

    list-style: none;
}
aside .aside-list > li > ul.active {
    display: block;
}
aside .aside-list > li > ul li {}
aside .aside-list > li > ul li a {
    padding-left: 2em;
    padding-top: 10px;
    padding-bottom: 10px;
    padding-right: 10px;
    background-color: #F4F4F7;
}
aside .aside-list > li > ul li a:before {
    left: 1em;
    top: 10px;
    content: '\f0da';
}
/********************************************************  local-menu open **/
body.books.conventional aside .aside-list > li.conventional > ul,
body.books.newbook aside .aside-list > li.newbook > ul,
body.studysession.jamt aside .aside-list > li.jamt > ul,
body.studysession.center aside .aside-list > li.center > ul,
body.studysession.area aside .aside-list > li.area > ul,
body.studysession.branch aside .aside-list > li.branch > ul {
    display: block;
}

/********************************************************/
.main-carousel {
    margin-left: 0;
    margin-right: 0;
}
.carousel-cell {
    width: 100%;
    margin-left: 1px;
    margin-right: 1px;
}
.carousel-cell > .inner {}
.flickity-prev-next-button {
    width: 49px;
    height: 100%;
    border-radius: 0;
    background: #E8E9EF;
}
.flickity-prev-next-button:hover {
    background: rgba(0, 0, 0, 0.01);
}
.flickity-prev-next-button.previous {
    left: -50px;
}
.flickity-prev-next-button.next {
    right: -50px;
}
.flickity-prev-next-button .arrow {
    fill: #FFF;
}
.flickity-prev-next-button:hover .arrow {
    fill: #333;
}
.cat-nav .carousel-cell ul.cat-nav-list {
    width: 100%;
}
.cat-nav .carousel-cell ul.cat-nav-list li {
    width: 25%;
}
@media screen and (max-width: 1180px) {
    .main-carousel {
        margin-left: 50px;
        margin-right: 50px;
    }
}
@media screen and (max-width: 767px) {
    .main-carousel {
        margin-left: 30px;
        margin-right: 30px;
    }
    .flickity-prev-next-button {
        width: 29px;
    }
    .flickity-prev-next-button.previous {
        left: -30px;
    }
    .flickity-prev-next-button.next {
        right: -30px;
    }

    .cat-nav .carousel-cell ul.cat-nav-list li {
        width: 33.3333%;
    }
}
@media screen and (max-width: 600px) {
    .cat-nav .carousel-cell ul.cat-nav-list li {
        width: 50%;
    }
}
.fas.fa-file-pdf,
.far.fa-file-pdf {
    color: #D60F0F;
}
/* http://masafumishoji.com/blog/colorcode-apps-office365/ */
.fas.fa-file-powerpoint,
.far.fa-file-powerpoint {
    color: #d04525;
}
.fas.fa-file-word,
.far.fa-file-word {
    color: #2c589c;
}
.fas.fa-file-excel,
.far.fa-file-excel {
    color: #206f44;
}
.fas.fa-file-archive,
.far.fa-file-archive {
    /* color: #000; */
    color: #206f44;
}
.naviInlineMenu {}
.naviInlineMenu ul {
    list-style: none;
    padding-left: 0;
}
.naviInlineMenu ul li a {
    display: block;
    padding-left: 15px;
    position: relative;
}
.naviInlineMenu.menu ul li a {
    display: inline-block;
}
.naviInlineMenu ul li a:before {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f107';
    color: #1E2760;
    position: absolute;
    left: 0;
    top: 0;
}
.naviInlineMenu ul.nav li a:before {
    padding-top: .5rem;
}
/****************************************************************************** .top-sp-nav */
.top-sp-nav {
    background-color: #F4F4F7;
}
.top-sp-nav .inner {}
.section.top-sp-nav > .inner {
    padding-top: 40px;
    padding-bottom: 25px;
}
/****************************************************************************** .top-nav */
.top-nav {
    display: flex;
    justify-content: space-between;
}
/*.top-nav .top-nav-item {
    display: block;
    width: 24%;
    background-color: #1E2760;
    border-radius: 5px;
    text-align: center;
    transition: background-color .3s;
    margin-bottom: 20px;
}*/
/* 20251020 */
.top-nav .top-nav-item {
    display: block;
    width: 19.5%;
    background-color: #1E2760;
    border-radius: 5px;
    text-align: center;
    transition: background-color .3s;
    margin-bottom: 20px;
}
@media screen and (max-width: 1020px) {
    .top-nav .top-nav-item {
        margin-bottom: 15px;
    }
}
@media screen and (max-width: 767px) {
    .top-nav {
        flex-wrap: wrap;
    }
/*    .top-nav .top-nav-item {
        width: 49%;
    }*/
	/* 20251020 */
    .top-nav .top-nav-item {
        width: 48%;
    }
}
.top-nav .top-nav-item.mem01 {
    background-color: #03A0E9;
}
.top-nav .top-nav-item.mem02 {
    background-color: #D9A629;
}
.top-nav .top-nav-item.mem03 {
    background-color: #E97132;
}
.top-nav .top-nav-item span {
    color: #FFF;
    font-size: 22px;
}
@media screen and (max-width: 1020px) {
    .top-nav .top-nav-item span {
        font-size: 16px;
    }
}
.top-nav a.top-nav-item {
    display: block;
    position: relative;
    min-height: 90px;
}
.top-nav a.top-nav-item:hover {
    text-decoration: none;
    background-color: #12173A;
}
.top-nav a.top-nav-item.mem01:hover {
    background-color: #0274A9;
}
.top-nav a.top-nav-item.mem02:hover {
    background-color: #A17B1C;
}
.top-nav a.top-nav-item.mem03:hover {
    background-color: #D25917;
}
.top-nav a.top-nav-item:after {
    display: inline-block;
    width: 6px;
    height: 10px;

    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f105';
    color: #FFF;
    font-size: 12px;

    position: absolute;
    right: 20px;
    top: 45%;
}
@media screen and (max-width: 1020px) {
    .top-nav a.top-nav-item:after {
        right: 10px;
    }
}
@media screen and (max-width: 400px) {
    .top-nav .top-nav-item span {
        font-size: 14px;
    }
    .top-nav a.top-nav-item span i {
        padding-left: 10px;
    }
    .top-nav a.top-nav-item:after {}
}
@media screen and (max-width: 360px) {
    .top-nav a.top-nav-item:after {
        top: 34%;
        bottom: auto;
    }
}
.top-nav a.top-nav-item span {
    position: absolute;
    left: 0;
    top: 36%;
    display: block;
    width: 100%;
    height: auto;
    text-align: left;
}
.top-nav a.top-nav-item span i {
    font-style: normal;
    display: inline-block;
    margin-top: -1.2em;
    padding-left: 1em;
}
.top-nav a.top-nav-item span ins {
    display: inline-block;
    font-size: 65%;
    vertical-align: top;
    text-decoration: none;
}
.top-nav a.top-nav-item span i.nkg {
    padding-left: 0;
    margin-left: -.2em;
    margin-right: -.2em;
}
.top-nav ul.top-nav-item {
    display: block;
    padding: 10px;
}
.top-nav ul.top-nav-item.mod--col {
  padding: 0;
  background-color: transparent;
}
.top-nav .top-nav-item li {
    display: block;
    margin-top: 10px;
}
.top-nav .top-nav-item li:first-child {
    margin-top: 0;
}
.top-nav .top-nav-item li a {
    display: block;
    background-color: #FFF;
    border-radius: 5px;
    padding: 9px;
    transition: background-color .3s;
}
.top-nav .top-nav-item.mod--col li a {
  background-color: #1E265F;
  padding: 14px 9px;
}
.top-nav .top-nav-item.mod--col li a::after {
  color: #FFF;
}
.top-nav .top-nav-item.mod--col li a span {
  color: #FFF;
}
.top-nav .top-nav-item.mod--col li a i {
  font-style: normal;
}
.top-nav .top-nav-item.mod--col li a.mod--member {
  background-color: #1E265F;
}
.top-nav .top-nav-item.mod--col li a.mod--member:hover {
  background-color: #12173A;
}
.top-nav .top-nav-item.mod--col li a.mod--admin {
  background-color: #016E35;
}
.top-nav .top-nav-item.mod--col li a.mod--admin:hover {
  background-color: #014320;
}
.top-nav .top-nav-item li a:hover {
  text-decoration: none;
  background-color: #DCDCDC;
}
.top-nav .top-nav-item li a:after {
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: '\f105';
  color: #1E265F;
  font-size: 12px;
  margin-left: 20px;
}
@media screen and (max-width: 1020px) {
  .top-nav .top-nav-item li a {
    padding: 3px 9px;
  }
  .top-nav .top-nav-item li a:after {
    margin-left: 8px;
  }
}
.top-nav .top-nav-item li a span {
    font-size: 16px;
    line-height: 20px;
    color: #1E265F;
}
@media screen and (max-width: 1020px) {
    .top-nav .top-nav-item li a span {
        font-size: 12px;
        line-height: 24px;
    }
}
@media screen and (max-width: 360px) {
    .top-nav {
        display: block;
    }
    .top-nav .top-nav-item {
        width: 100%;
        margin-bottom: 5px;
    }
    .top-nav a.top-nav-item {
        min-height: inherit;
        padding: 9px;
    }
    .top-nav a.top-nav-item span {
        position: relative;
        left: 0;
        top: 0;
    }
    .top-nav a.top-nav-item span i {
        position: relative;
        left: 0;
        top: 0;
        margin-top: 0;
    }
    .top-nav a.top-nav-item span br {
        display: none;
    }

    .top-nav ul.top-nav-item {
        margin-bottom: 5px;
    }
}
/****************************************************************************** .top-headline */
.top-headline {
    border-radius: 5px;
    background-color: #FFF;
    position: relative;
    overflow: hidden;
    margin-bottom: 15px !important;
}
.top-headline dl {
    margin: 0;
    min-height: 40px;
    padding-left: 77px;
}
.top-headline dt {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    background-color: #FFBF00;
    color: #FFF;
    font-size: 22px;
    min-width: 77px;
    text-align: center;
    line-height: 1.2;
    padding-top: 6.8px;
    vertical-align: middle;
}
.top-headline .topics dt {
    font-size: 16px;
    padding-top: 10px;
}
@media screen and (max-width: 1020px) {
    .top-headline dt {
        font-size: 16px;
        line-height: inherit;
    }
}
.top-headline dd {
    margin: 0;
}
.top-headline dd a {
    display: block;
    width: auto;
    vertical-align: baseline;
    font-size: 18px;
    color: #009FE9;
    line-height: 22px;
    padding: 9px 20px 9px 137px;
    position: relative;
}
.top-headline dd a .date {
    font-size: 16px;
    color: #333333;
    position: absolute;
    left: 20px;
    top: 10px;
}
@media screen and (max-width: 1020px) {
    .top-headline dd a {
        font-size: 16px;
        line-height: inherit;
    }
    .top-headline dd a .date {
        font-size: 12px;
    }
}
@media screen and (max-width: 767px) {
    .top-headline dd a {
        padding: 9px 15px;
    }
    .top-headline dd a .date {
        display: block;
        position: relative;
        left: 0;
        top: 0;
    }
}
@media screen and (max-width: 420px) {
    .top-headline dt {
        min-width: auto;
        font-size: 12px;
        padding-left: 5px;
        padding-right: 5px;
    }
    .top-headline .topics dt {
        font-size: 12px;
    }
    .top-headline dl {
        padding-left: 34px;
    }
    .top-headline .topics {
        padding-left: 60px;
    }
    .top-headline .topics dt {}
    .top-headline dd a {
        font-size: 12px;
        padding: 6px 9px;
    }
}
/****************************************************************************** .cat-ico-nav */
.cat-ico-nav {}
.cat-ico-nav .inner {}
.cat-ico-nav ul {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    padding: 0;
}
.cat-ico-nav ul li {
    width: 16.6666%;
    display: block;
}
@media screen and (max-width: 1020px) {
    .cat-ico-nav ul li {
        width: 20%;
    }
}
@media screen and (max-width: 920px) {
    .cat-ico-nav ul li {
        width: 25%;
    }
}
@media screen and (max-width: 580px) {
    .cat-ico-nav ul li {
        width: 33.333333%;
    }
}
@media screen and (max-width: 460px) {
    .cat-ico-nav ul li {
        width: 50%;
    }
}
.cat-ico-nav ul li a {
    display: block;
    border: #cfcfcf 1px solid;
    margin: 1px;
    text-align: center;
    padding-top: 18px;
    padding-bottom: 18px;
    transition: background-color .3s;
}
.cat-ico-nav ul li a:hover {
    background-color: #EBEBEB;
}
.cat-ico-nav ul li a span {
    display: inline-block;
    color: #1E265F;
    font-size: 16px;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}
.cat-ico-nav ul li a i {
    color: #1E265F;
}
.cat-ico-nav ul li.menu02 a span,
.cat-ico-nav ul li.menu02 a i {
    color: #FFBF00;
}
li a span .nkg,
.cat-ico-nav ul li a span .nkg {
    display: inline-block;
    margin-left: -0.25em;
    margin-right: -0.25em;
}
.cat-ico-nav ul li a span.ico {
    display: block;
    width: 110px;
    height: 110px;
    padding: 10px;
    background-color: #1E265F;
    border-radius: 50%;
    margin-bottom: 15px;
}
.cat-ico-nav ul li.menu02 a span.ico {
    background-color: #FFBF00;
}
.cat-ico-nav ul li a span.ico img {
    width: 90px;
    height: 90px;
}
@media screen and (max-width: 767px) {
    .cat-ico-nav ul li a span {
        font-size: 12px;
    }
    .cat-ico-nav ul li a span.ico {
        width: 60px;
        height: 60px;
        padding: 0;
    }
    .cat-ico-nav ul li a span.ico img {
        width: 60px;
        height: 60px;
    }
}
/****************************************************************************** .global-mega-menu */
.global-mega-menu {
    height: 51px;
    border-bottom: 6px #E5E5E5 solid;
    position: relative;

    background-color: transparent;
    height: 55px;
}
body.top-index .global-mega-menu {
    height: 79px;
}
body.cat-menu .global-mega-menu {
    display: none;
}
@media screen and (max-width: 767px) {
    body.top-index .global-mega-menu,
    .global-mega-menu {
        display: none;
        /* ←トップページ以外はメニュー非表示 */
        padding-left: 0;
        padding-right: 0;
        border: none;
        border-bottom: none;
    }
    body.top-index .global-mega-menu {
        display: block;
        height: auto;
    }
}
.global-mega-menu > .inner {}
.global-mega-menu.open {
    overflow: visible;
}
.global-mega-menu .mask {
    display: none;

    position: absolute;
    background-color: #FFF;
    top: 56px;
    left: 0;
    border-bottom: 1px #D6D6D6 solid;
    border-top: 1px #FFF solid;
    width: 100%;
    padding: 10px;
    z-index: 99;
}
.global-mega-menu.open .mask {
    display: block;
    top: 50px;
}
body.top-index .global-mega-menu .mask {
    top: 78px;
}
.global-mega-menu .inner > ul {
    display: flex;
    justify-content: space-between;
    padding-left: 0;
}
@media screen and (max-width: 767px) {
    .global-mega-menu .inner > ul {
        flex-wrap: wrap;
    }
}
.global-mega-menu.section {}
.global-mega-menu.section .inner {
    padding: 0;
}
.global-mega-menu .inner > ul li {
    width: 22%;
    position: relative;
    list-style: none;
}
@media screen and (max-width: 767px) {
    .global-mega-menu .inner > ul > li {
        margin-bottom: 0;
        border-left: none;
    }
    .global-mega-menu .inner > ul > li:last-child {
        border-left: none;
        border-right: none;
        margin-bottom: 0;
    }
}
.global-mega-menu .inner > ul > li.home {
    width: 12%;
}
body.top-index .global-mega-menu .inner > ul > li,
body.top-index .global-mega-menu .inner > ul > li:last-child {
    width: 25%;
}
@media screen and (max-width: 1020px) {
    body.top-index .global-mega-menu .inner > ul > li {
        width: 23%;
    }
    body.top-index .global-mega-menu .inner > ul > li:last-child {
        width: 31%;
    }
}
@media screen and (max-width: 767px) {
    body.top-index .global-mega-menu .inner > ul > li,
    body.top-index .global-mega-menu .inner > ul > li:last-child {
        width: 50%;
    }
}
.global-mega-menu .inner > ul > li > a {
    display: block;
    min-height: 49px;
    height: 49px;
    border-right: 1px solid #E5E5E5;
    border-color: #E5E5E5 !important;
    border-bottom: none;
    text-align: center;
    padding-top: 14px;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 16px;
    font-weight: 900;
    color: #EEE;
    transition: background-color .3s;
    position: relative;
    background-color: #03A0E9;
}
.global-mega-menu .inner > ul > li > a:after {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f107';
    color: #EEE;
    font-size: 18px;
    line-height: 19px;
    margin-left: 20px;
    text-decoration: none;
    position: absolute;
    top: 16px;
    right: 23%;
}
.global-mega-menu .inner > ul > li.home > a:after {
    content: '\f015';
    right: 14%;
    font-size: 12px;
}
body.top-index .global-mega-menu .inner > ul > li > a {
    border-bottom: 6px #E5E5E5 solid;
    min-height: 79px;
    height: 79px;
    padding-top: 28px;
}
body.top-index .global-mega-menu .inner > ul > li > a:after {
    font-size: 22px;
    color: #EEE;
}
.global-mega-menu .inner > ul > li:first-child > a {
    border-left: 1px solid #D6D6D6;
}
.global-mega-menu .inner > ul > li:last-child > a {
    padding-top: 7px;
}
.global-mega-menu .inner > ul > li > a span {
    display: inline-block;
    line-height: 1.1875;
    padding-right: 18%;
}
.global-mega-menu .inner > ul > li > a:hover {
    background-color: #0274A9;
    color: #FFF;
}
.global-mega-menu .inner > ul > li > a:hover:after {
    text-decoration: none;
    color: #FFF;
}
body.top-index .global-mega-menu .inner > ul > li:last-child > a {
    padding-top: 20px;
}
body.top-index .global-mega-menu .inner > ul > li > a:after {
    top: 25px;
    line-height: 28px;
}
.global-mega-menu .inner > ul > li > a span i {
    display: block;
}
@media screen and (max-width:980px) {
    .global-mega-menu .inner > ul > li > a span {
        padding-right: 12%;
        font-size: 14px;
    }
    .global-mega-menu .inner > ul > li > a:after {
        right: 10%;
    }
    .global-mega-menu .inner > ul > li.home > a:after {
        right: 5%;
    }
    .global-mega-menu .inner > ul > li:last-child > a {
        padding-top: 10px;
    }
    body.top-index .global-mega-menu .inner > ul > li:last-child > a {
        padding-top: 19px;
    }
}
/* 内部メニュー */
.global-mega-menu .inner > ul > li > ul {
    display: none;

    position: absolute;
    left: 0;
    top: 50px;
    padding-left: 0;
    background-color: #FFF;
    width: 100%;
    padding-top: 10px;
    padding-bottom: 10px;
    z-index: 999;
    border-right: 1px #D6D6D6 solid;
}
.global-mega-menu .inner > ul > li:first-child > ul {
    border-left: 1px #D6D6D6 solid;
}
body.top-index .global-mega-menu .inner > ul > li > ul {
    top: 78px;
    border-top: none;
}
.global-mega-menu.open .inner > ul > li > ul {
    display: block;
}
.global-mega-menu .inner > ul > li > ul li {
    width: 100%;
}
.global-mega-menu .inner > ul > li > ul li a {
    display: block;
    background-color: #FFF;
    color: #333;
    font-size: 13px;
    /* 24.8 15.6 */
    line-height: 1.2;
    padding: 4.6px 15px;
    transition: background-color .3s;
}
.global-mega-menu .inner > ul > li > ul li a:hover {
    background-color: #EBEBEB;
}
.global-mega-menu .inner ul li .fa,
.global-mega-menu .inner ul li .fal,
.global-mega-menu .inner ul li .far,
.global-mega-menu .inner ul li .fab,
.global-mega-menu .inner ul li .fas {
    margin-left: .25em;
    color: #CCC;
}
@media screen and (max-width: 767px) {
    .global-mega-menu .inner > ul > li > a {
        font-size: 12px;
    }
    .global-mega-menu .inner > ul > li:first-child > a {
        border-left: none;
    }
    .global-mega-menu.open .inner > ul > li > ul {
        display: none;
    }
}
@media screen and (max-width: 575px) {
    body.top-index .global-mega-menu .inner > ul > li,
    body.top-index .global-mega-menu .inner > ul > li:last-child {
        width: 50%;
    }
    body.top-index .global-mega-menu .inner > ul > li:nth-child(2n) {
        border-left: none;
        border-right: none;
    }
    body.top-index .global-mega-menu .inner > ul > li:nth-child(2n + 2) {
        border-right: none;
    }
    body.top-index .global-mega-menu .inner > ul > li:nth-child(n + 3) {
        border-top: none;
    }
    body.top-index .global-mega-menu .inner > ul > li > a {
        min-height: 70px;
    }
    .global-mega-menu .inner > ul > li > a:after {
        font-size: 16px;
        line-height: 20px;
    }
}
@media screen and (max-width: 460px) {
    .global-mega-menu .inner > ul > li > a {
        font-size: 10px;
    }
    .global-mega-menu.open .inner > ul > li > ul {
        display: none !important;
    }
}
/****************************************************************************** .top-carousel */
.top-carousel {}
.top-carousel .inner {}
.top-carousel .inner .carousel-cell {
    background-position: center center;
    background-size: cover;
    width: 100%;
    max-height: 480px;
}
.top-carousel .inner .carousel-cell > .inner {
    position: relative;
    text-align: center;
}
.top-carousel .inner .carousel-cell > .inner.inner-row {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  max-width: 1070px;
  margin: auto;
}
@media all and (-ms-high-contrast:none){
  *::-ms-backdrop, .top-carousel .inner .carousel-cell > .inner.inner-row {
    max-width: 1070.4px;
  }
}
.top-carousel .inner .carousel-cell > a.inner {
    display: block;
}
.top-carousel .inner .carousel-cell > .inner a {
    display: block;
}
.top-carousel .inner .carousel-cell > .inner .col-half {
  display: inline-block;
  vertical-align: bottom;
  max-width: 50%;
}
/* 2021.12.06 */
.top-carousel .inner .carousel-cell > .inner .col-quarter {
  display: inline-block;
  vertical-align: bottom;
  max-width: 50%;
}
.top-carousel .inner .carousel-cell img {
    width: auto;
    height: 480px;
    max-height: 480px;
    margin-left: auto;
    margin-right: auto;
}
.top-carousel .inner .carousel-cell .col-quarter img {
  height: 240px;
  max-height: 240px;
}
/*
2018.10.01.
*/
@media screen and (max-width: 1072px) {
    .top-carousel .inner .carousel-cell img {
        width: 100%;
        height: auto;
        max-height: inherit;
    }
    .top-carousel .inner .carousel-cell .col-quarter img {
      height: auto;
    }
}
.top-carousel .flickity-prev-next-button {
    background-color: transparent;
}
.top-carousel .flickity-prev-next-button.previous {
    left: 10px;
}
.top-carousel .flickity-prev-next-button.next {
    right: 10px;
}
.top-carousel .head-copy {
    position: absolute;
    text-align: left;
    margin-left: auto;
    margin-right: auto;
    left: 50px;
    top: 15%;
}
@media screen and (max-width: 1110px) {
    .top-carousel .head-copy {
        width: auto;
        padding-left: 15px;
        padding-right: 15px;
    }
}
.top-carousel .head-copy p {
    font-size: 50px;
    line-height: 1.2;
    /*  font-family: "Yu Mincho", "YuMincho", serif;*/
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-weight: bold;

    color: #FFF;
    text-shadow: 0px 1px 2px rgba(0, 0, 0, 0.4);
    margin-bottom: 0;
}
@media screen and (max-width: 767px) {
    .top-carousel .head-copy {
        margin-top: 0;
        position: absolute;
        left: 0;
        bottom: 20px;
    }
    .top-carousel .head-copy p {
        font-size: 26px;
        font-weight: 700;
        text-shadow: 0px 4px 6px rgba(0, 0, 0, 0.8);
    }
}
/****************************************************************************** .nav-cat-global */
.nav-cat-global {
    display: none;

    border-bottom: 2px #E5E5E5 solid;
}
body.cat-menu .nav-cat-global {
    display: block;
}
@media screen and (max-width: 767px) {
    body.cat-menu .nav-cat-global,
    .nav-cat-global {
        display: none;
    }
}
.nav-cat-global .inner {
    position: relative;
    padding: 20px 0;
}
.nav-cat-global a.home {
    display: block;
    background-color: #1E265F;
    border-radius: 2px;
    height: 100%;
    font-size: 13px;
    line-height: 1.2;
    color: #FFF;
    text-align: center;
    padding-left: 5px;
    padding-right: 5px;
    float: left;
    margin-right: 2px;
    transition: background-color .3s;
}
.nav-cat-global a.home span {
    display: inline-block;
    top: 40%;
}
.nav-cat-global ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    padding-left: 0;
}
.nav-cat-global ul li {
    width: 14.2857%;
    list-style: none;
    margin-bottom: 4px;
}
.nav-cat-global ul li a {
    display: block;
    background-color: #1E265F;
    border-radius: 2px;
    font-size: 13px;
    /* 15.6 -- 32 */
    line-height: 1.2;
    color: #FFF;
    text-align: center;
    padding-top: 7.2px;
    padding-bottom: 7.2px;
    margin-left: 2px;
    margin-right: 2px;
    transition: background-color .3s;
}
@media screen and (max-width: 1060px) {
    .nav-cat-global ul li a {
        min-height: 45px;
        padding-left: 5px;
        padding-right: 5px;
    }
}
.nav-cat-global a.home:hover,
.nav-cat-global ul li a:hover {
    background-color: #8E93AF;
    text-decoration: none;
}
/********************************************************** body.blog */
body.blog {}
body.blog section.page-header {
    background-color: #ECECEC;
    background-image: -webkit-gradient(linear, 0 0, 100% 100%, color-stop(.25, #F9F9F9), color-stop(.25, transparent), color-stop(.5, transparent), color-stop(.5, #F9F9F9), color-stop(.75, #F9F9F9), color-stop(.75, transparent), to(transparent));
    -webkit-background-size: 14px 14px;
    gradient(linear,
      0 0,
      100% 100%,
      color-stop(.25, #F9F9F9),
      color-stop(.25, transparent),
      color-stop(.5, transparent),
      color-stop(.5, #F9F9F9),
      color-stop(.75, #F9F9F9),
      color-stop(.75, transparent),
      to(transparent)
    );
    background-size: 14px 14px;
}
body.blog section.page-header h1,
body.blog section.page-header .h1 {
    display: block;
    margin-bottom: .5rem;
}
body.blog section.page-header a:hover {
    text-decoration: none;
}
body.blog section.page-header .subtitle {
    color: #1D4FA8;
    font-weight: bold;
}
body.blog section.content h1,
body.blog section.content .h1 {
    padding-bottom: 30px;
    border-bottom: 1px solid #ccc;
    margin-bottom: 20px;
}
/********************************************************** body.bulletin */
body.bulletin {}
body.bulletin section.page-header {
    background-color: #ECECEC;
    background-image: url('/information/kaiho/prompt_report/asset/images/bulletin.jamt.bg.png'),
    -webkit-gradient(linear, 0 0, 100% 100%, color-stop(.25, #F9F9F9), color-stop(.25, transparent), color-stop(.5, transparent), color-stop(.5, #F9F9F9), color-stop(.75, #F9F9F9), color-stop(.75, transparent), to(transparent));
    background-size: contain, 14px 14px;
    -webkit-background-size: contain, 14px 14px;
    background-repeat: no-repeat, repeat;
    background-position: center bottom, left top;
}
body.bulletin section.page-header a:hover {
    text-decoration: none;
}
body.bulletin section.page-header h1,
body.bulletin section.page-header .h1 {
    text-shadow: 0px 4px 6px rgba(255, 255, 255, 0.8);
}
body.bulletin section.page-header h1 i,
body.bulletin section.page-header .h1 i {
    color: #D2912B;
    text-shadow: 0 1px 0 #FFF;
    font-weight: bold;
}
body.bulletin section.page-header h1 i:after,
body.bulletin section.page-header .h1 i:after {
    color: #fff;
    mask-image: linear-gradient(top, rgba(0, 0, 0, 1), rgba(0, 0, 0, 0.4) 50%, rgba(0, 0, 0, 0.2) 51%, rgba(0, 0, 0, 0));
    -webkit-mask-image: -webkit-linear-gradient(top, rgba(0, 0, 0, 1), rgba(0, 0, 0, 0.4) 50%, rgba(0, 0, 0, 0.2) 51%, rgba(0, 0, 0, 0));
}
@media screen and (max-width: 1000px) {
    body.bulletin section.page-header {
        background-size: auto 100%, 14px 14px;
        -webkit-background-size: auto 100%, 14px 14px;
        background-position: right bottom, left top;
    }
}
body.bulletin section.content h1,
body.bulletin section.content .h1 {
    padding-bottom: 30px;
    border-bottom: 1px solid #ccc;
    margin-bottom: 20px;
}
/********************************************************** body.tuuchi */
body.tuuchi {}
body.tuuchi td span.date {
    display: none;
}
/********************************************************** table.topics-list, table.table-link */
table.topics-list,
table.table-link {}
table.topics-list tr,
table.table-link tr {}
table.topics-list tr.link:hover,
table.table-link tr.link:hover {
    cursor: pointer;
}
table.topics-list td {
    width: 15%;
}
table.topics-list td:last-child {
    width: 85%;
}
@media screen and (max-width: 420px) {
    table.topics-list,
    table.topics-list tbody,
    table.topics-list tr,
    table.topics-list td,
    table.topics-list td:last-child {
        display: block;
        width: auto;
        padding-bottom: 0;
    }
    table.topics-list {
        width: 100%;
    }
    table.topics-list td:last-child {
        border-top: none;
        padding-top: 0;
        padding-bottom: .75rem;
    }
}
section.content table.topics-list {
    border-bottom: 1px solid #dee2e6;
}
section.content h1 + table.topics-list tr:first-child td {
    border-top: none;
}
/********************************************************** body.studysession */
body.studysession section.content h1,
body.studysession section.content .h1 {
    padding-bottom: 30px;
    border-bottom: 1px solid #ccc;
    margin-bottom: 20px;
}
@media screen and (max-width: 420px) {
    body.studysession section.content h1 img,
    body.studysession section.content .h1 img {
        width: 24px;
        height: auto;
    }
}
/********************************************************** body.notification */
body.notification section.content h1,
body.notification section.content .h1 {
    padding-bottom: 30px;
    border-bottom: 1px solid #ccc;
    margin-bottom: 20px;
}
body.studysession article h3 {
    position: relative;
}
body.studysession article a.anchor {
    display: block;
    position: absolute;
    height: 0px;
    left: 0;
    top: -30px;
}
/*20191107*/
@media screen and (max-width:985px) {
    .nav_pickup .float-left {
        float: none !important;
    }
    .nav_pickup .float-right {
        float: none !important;
    }
}
@media screen and (max-width:572px) {
    .pickup18_button a:nth-child(2) img {
        margin-top: 5px;
    }
}
