@charset "utf-8";
/* CSS Document */

.flex_wrap01 { display: flex; flex-wrap: wrap; justify-content: space-between; }
.fb_r01 { width: 23%; }
.fb_l01 { width: 73%; }
.fb_r02 { width: 36%; }
.fb_l02 { width: 61%; }
.box_HH { width: 48%; }
.box_HH2 { width: 48%; }
.box_3P { width: 30%; }
.img_R { float: right; width: 36%; margin-left: 24px; margin-bottom: 20px; }
h3 { font-family: "Noto Sans JP", sans-serif !important; font-weight: 500 !important; }

a { -webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all  0.3s ease; }
a:hover { opacity: 0.7; }

a.nrm_link, th a, td a { color: #001e62; border-bottom: 1px dotted #001e62; }
a.nrm_link:hover, th a:hover, td a:hover { border-bottom: 1px solid #001e62; }

.breadcrumb li:first-child { font-weight: 500; color: #001e62; }

a.arrow_dw { position: relative; }
a.arrow_dw::before {
    background-image: url(/images/common2/down2.png);
    background-size: 15px 15px;
    background-repeat: no-repeat;
    margin-right: 4px;
    content: " ";
    width: 18px;
    height: 15px;
    display: inline-block;
	position: relative;
	top: 2px;
}

.mt-00 { margin-top: 0 !important; }
.mb-00 { margin-bottom: 0 !important; }
.txt_id10 { padding-left: 1em; text-indent: -1em; }
.txt_id15 { padding-left: 1.5em; text-indent: -1.5em; }
.txt_id20 { padding-left: 2em; text-indent: -2em; }
.txt_id25 { padding-left: 2.5em; text-indent: -2.5em; }

.txt_80 { font-size: 80% !important; }

th, td { line-height: 1.6; }
th { font-weight: 500 !important; }

strong, b { font-weight: 500 !important; }

ul.nrm_list, ul.sk_list { list-style: none; }
ul.nrm_list li { padding-left: 18px; position: relative; }
ul.nrm_list li::before {
    background-image: url(/images/common2/right2.png);
    background-size: 25% 50%;
    background-repeat: no-repeat;
    background-position: center center;
    content: " ";
    width: 13px;
    height: 15px;
    display: block;
	position: absolute;
	top: 2px;
	left: 0;
}
ul.nrm_list li { margin-bottom: 7px; }
ul.sk_list li { margin-bottom: 10px; }
ul.sk_list li span { width: 90px; line-height: 1; padding: 3px 6px 4px; text-align: center; background-color: #001e62; color: #fff; margin-right: 12px; display: inline-block; font-size: 80%; position: relative; top: -1px; }

.table_sp01 tbody th { white-space: nowrap !important; width: 10%; }

table.table_curriculum { width: 100%; }

table.table_curriculum thead th { background-color: #ccc !important; text-align: left !important; padding: 6px !important; width: 26%; vertical-align: middle !important; }
table.table_curriculum thead th.th_s { font-size: 80%; background-color: #e6e6e6 !important; text-align: center !important; padding: 6px !important; width: 7.33333%; }
table.table_curriculum.table_curriculum2 thead th { width: 17.5%; }
table.table_curriculum.table_curriculum2 thead th.th_s { width: 7.5%; }
table.table_curriculum thead th.c01st { background-color: #1b3c86 !important; color: #fff !important; text-align: center !important; }
table.table_curriculum thead th.c02nd { background-color: #0b2b74 !important; color: #fff !important; text-align: center !important; }
table.table_curriculum thead th.c03rd { background-color: #001e62 !important; color: #fff !important; text-align: center !important; }
table.table_curriculum tbody th { text-align: left !important; background-color: #e6e6e6 !important; padding: 6px !important; }
table.table_curriculum tbody td { text-align: center !important; background-color: #f3f3f3 !important; padding: 6px !important; }
table.table_curriculum tbody th.c_c { background-color: #ccc !important; }
table.table_curriculum tbody td.c_c { background-color: #e6e6e6 !important; }

table.table_en td { text-align: center !important; }
table.table_en { margin: 0 auto; }

.spB { display: none; }

.pcB3 { display: inherit; }
.spB3 { display: none; }

@media all and (max-width:1280px) {
.fb_r01 { width: 32%; }
.fb_l01 { width: 65%; }
.fb_r02 { width: 42%; }
.fb_l02 { width: 55%; }
.img_R { float: right; width: 44%; }
}

@media all and (max-width:1160px) {
.pcB3 { display: none; }
.spB3 { display: inherit; }
.box_HH2 { width: 100%; }
}

@media all and (max-width:768px) {
.fb_r01,
.fb_l01,
.fb_r02,
.fb_l02,
.box_HH { width: 100%; }
.box_3P { width: 48%; }
.img_R { float: none; width: 100%; margin-left: 0; }
.mg_sp01 { margin-top: 3rem !important; }
.pcB { display: none; }
.table_sp01 thead { display: none; }
.table_sp01 tbody th, .table_sp01 tbody td { white-space: normal !important; width: 100%; display: block; }
.page-layout .page-content table th, .page-layout .page-content table td { padding: 6px 10px; font-size: 90%; }
.page-layout .page-content .visual h1 { font-size: 40px !important; }

.page-layout .page-content table.table_en th,.page-layout .page-content table.table_en td { font-size: 80%; padding: 4px 6px; }
}

@media all and (max-width:480px) {
.pcB2 { display: none; }
.box_3P { width: 100%; }
.mg_sp02 { margin-top: 3rem !important; }
ul.breadcrumb { font-size: 10px; display: block; }
ul.breadcrumb li { display: inline-block; }
.page-layout .page-content .visual h1 { font-size: 32px !important; }
.page-layout .page-content h2 { font-size: 23px !important; }
.page-layout .page-content table th, .page-layout .page-content table td { padding: 6px 8px; font-size: 80%; }
.spB { display: inherit; }

ul.sk_list li span { display: block; margin-bottom: 4px; }

.page-layout .page-content table.table_curriculum thead th,
.page-layout .page-content table.table_curriculum thead th.th_s,
.page-layout .page-content table.table_curriculum tbody th,
.page-layout .page-content table.table_curriculum tbody td { padding: 4px !important; }
.page-layout .page-content table th.th_s { font-size: 60%; }
}
@media all and (max-width:540px) {
.page-layout .page-content table.table_en th,.page-layout .page-content table.table_en td { font-size: 2vw !important; padding: 4px !important; }
}

/* club */
.club-list { display: flex; justify-content: space-between; position: relative; flex-wrap: wrap; }
.club-list a { width: 31%; display: flex; align-content: center; align-items: center; justify-content: flex-start; padding: 16px; background-color: #F4F4F4; margin-bottom: 30px; }
.club-list a::before { content: ""; width: 15px; height: 15px; background-image: url(/images/common2/right.png); background-size: 15px 15px; margin-right: 8px; z-index: 5; position: relative; left: -2px; }
.club-list a p { margin: 0 !important; width: calc(100% - 20px); }
.club-list::after{
  content:"";
  display: block;
  width:31%;
}

@media screen and (max-width: 1024px) {
.club-list a { width: 48%; margin-bottom: 24px; }
.club-list::after { display: none; } }
@media screen and (max-width: 480px) {
.club-list a { width: 100%; margin-bottom: 15px; }}

.page-layout .page-content .visual .wrap {
    position: absolute;
    width: 100%;
    height: 100%;
    margin: 0 !important;
	padding: 0 32px;
    display: flex;
    place-items: center;
}

.slick-dots li button:before {
    font-size: 40px !important;
}
.slick-dots li button {
    padding: 0 !important;
}
.slick-dots li {
    margin: 0 8px !important;
}

/* foot add */
footer#footer .lower ul li:nth-child(4) { border-left: 1px solid white; }
@media screen and (max-width: 768px) {
      footer#footer .lower ul li:nth-child(1),
	  footer#footer .lower ul li:nth-child(3){
        text-align: right;
        flex-basis: 50%; }
      footer#footer .lower ul li:nth-child(2),
	  footer#footer .lower ul li:nth-child(4){
        text-align: left;
        flex-basis: 50%; } }

/* menu add */
@media screen and (min-width: 769px) {
header#header #menu footer ul li:last-child > div a {
    justify-content: flex-start;
}}

body.en_page .lang-box {
    color: #fff;
    border: 1px solid #001e62;
    background-color: #001e62;
    padding: 4px;
}
body.en_page .lang-box.active {
    color: #001e62;
    background-color: #fff;
}



/* Add 20240222 エディタテンプレ */
.ed_btn { display: flex; justify-content: space-between; position: relative; flex-wrap: wrap; }
.ed_btn a::before { content: ""; width: 15px; height: 15px; background-image: url(/images/common2/right.png); background-size: 15px 15px; margin-right: 8px; z-index: 5; position: relative; left: -2px; }
.ed_btn div { width: 31%; display: flex; align-content: center; align-items: center; justify-content: flex-start; padding: 16px; background-color: #F4F4F4; margin-bottom: 30px; }
.ed_btn div a { width: 100%; display: flex; align-content: center; align-items: center; justify-content: flex-start; }
.ed_btn div a span { margin: 0 !important; width: calc(100% - 20px); }
.ed_btn::after{
  content:"";
  display: block;
  width:31%;
}
@media screen and (max-width: 1024px) {
.ed_btn div { width: 48%; margin-bottom: 24px; }
.ed_btn::after { display: none; } }
@media screen and (max-width: 480px) {
.ed_btn div { width: 100%; margin-bottom: 15px; }}

a.ed_txt_link {
color: #001e62;
padding: 4px 0px;
display: flex;
align-items: center;
height: 36px;
}
a.ed_txt_link::before {
    background-image: url(/images/common2/right2.png);
    background-size: 25% 50%;
    background-repeat: no-repeat;
    background-position: center;
    margin-right: 2px;
    content: " ";
    width: 15px;
    height: 15px;
    display: inline-block;
}

.txt_120 { font-size: 120% !important; }


/* Uniform */
.main-img {
 width: 100%;
 max-width: 720px; margin: 0 auto;
}
.main-img img { width: 100%; height: auto; }
.sub-img {
 display: flex;
 justify-content: space-between;
 flex-wrap: wrap;
 margin: 30px auto 0;
}

.sub-img li {
 width: 23.5%;
margin-bottom: 16px;
 cursor: pointer;
 transition: all .3s;
}
.sub-img li { border: 2px solid #fff; }
.sub-img li.current { border: 2px solid #aaa; }

.sub-img li img:hover {
 opacity: 0.8;
 transition: all .3s;
}

@media screen and (min-width: 1160px) {
.sub-img li {
 width: 12%;
margin-bottom: 8px;
}}

@media screen and (max-width: 900px) {
.sub-img li { width:31%; }
.sub-img::after{
  content:"";
  display: block;
  width:31%;
} }
@media screen and (max-width: 480px) {
.sub-img li {
   width: 48.5%;
   margin: 0 auto 5px;
 }
}

/* timeline */
.timeline {
  list-style: none;
}
.timeline > li {
  margin-bottom: 60px;
}
.timeline-date { font-size: 130%; color: #001543; font-family: a-otf-ryumin-pr6n, serif; }

@media all and (min-width: 981px) {
  .timeline > li {
    overflow: hidden;
    margin: 0;
    position: relative;
  }
  .timeline-date {
    width: 132px;
    float: left;
    text-align: right;
    padding-right: 19px;
    margin: 20px 0 0 !important;
  }
  .timeline-content {
    width: 75%;
    float: left;
    border-left: 3px #fdd000 solid;
    padding-left: 30px;
  }
  .timeline-content:before {
    content: '';
    width: 11px;
    height: 11px;
    background: #5b71a5;
    position: absolute;
    left: 128px;
    top: 26px;
    border-radius: 100%;
  }
.timeline-content p { margin: 18px 0 3px !important; }
}

@media all and (max-width: 980px) {
.timeline-date { margin: 0 !important; }
.timeline li { border-left: 3px #fdd000 solid; position: relative; margin-bottom: 0; padding: 10px 0 30px 20px; }
.timeline li:last-child { padding-bottom: 14px; }
.timeline li:before { 
    content: '';
    width: 11px;
    height: 11px;
    background: #5b71a5;
    position: absolute;
    left: -7px;
    top: 17px;
    border-radius: 100%;
}
.timeline-content p { margin: 6px 0 0 !important; }}
