@charset "utf-8";
html {
  --10px: 62.5%;
  --11px: 68.8%;
  --12px: 75%;
  --13px: 81.3%;
  --14px: 87.5%;
  --15px: 93.8%;
  --16px: 100%;
  --17px: 106.3%;
  --18px: 112.5%;
  --19px: 118.8%;
  --20px: 125%;
  --21px: 131.3%;
  --22px: 131.3%;
  --24px: 137.5%;
  --26px: 162.5%;
  --28px: 175%;
  --34px: 212.5%;
}
#page_main .page .inner, #page_main .main_wrapper {
  max-width: 1200px;
  margin: auto;
}
#page_main .category_title {
  position: relative;
}
#page_main .category_title img {
  width: 100%;
}
#page_main .category_title h2 {
  position: absolute;
  top: 50%;
  left: calc(50% - 600px);
  color: #fff;
  font-size: 36px;
	font-family:"游明朝","Yu Mincho","YuMincho",'Hiragino Mincho Pro',serif !important;
  font-weight: 400;
  letter-spacing: .5rem;
  background: rgb(0 0 0 / 55%);
  padding: 1rem 1.5rem;
  margin: 0;
  border-bottom: none;
}
@media print, screen and (max-width: 1200px) {
	#page_main .category_title h2 {
		top: 50%;
		left: 50%;
    width: 100%;
    text-align: center;
		transform: translate(-50%, -50%);
		font-size: 20px;
		padding: 0.5rem 1rem;
    letter-spacing: .4rem
	}
}
#page_main .category_title h2::before {
  content: none;
}
#page_main .category_title p {
  line-height: 0;
}

#page_main .category_title2 {
  position: relative;
  background: rgba(0,0,0);
  line-height: 1;
  z-index: -1;
}
#page_main .category_title2 > div {
  display: flex;
  justify-content: center;
  align-items: center;
}
#page_main .category_title2 h2 {
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  color: #fff;
  font-size: var(--28px);
	font-family:"游明朝","Yu Mincho","YuMincho",'Hiragino Mincho Pro',serif !important;
  font-weight: 400;
  letter-spacing: .5rem;
  margin: 0;
  border-bottom: none;
}
#page_main .category_title2 h2::before {
  content: none;
}
#page_main .category_title2 p{
	line-height: 0;
}
#page_main .category_title2 img {
  width: 100%;
  opacity: 0.6;
}
@media print, screen and (max-width: 1200px) {
	#page_main .category_title2 h2 {
		font-size: var(--20px);
	}
	#page_main .category_title2 p{
		overflow-x: hidden;
	}
	#page_main .category_title2 img {
		width: auto;
	}
}
@media print, screen and (max-width: 796px) {
	#page_main .category_title2 img {
		height: 100px;
	}
}

.pankuzu {
  background: #ededed;
	font-size: var(--12px);
	text-align: left;
	padding: .5rem;
}
.pankuzu a {
	display: block;
  font-weight: 700;
  text-decoration: underline;
}
.pankuzu ol {
  max-width: 1200px;
  margin: auto !important;
}
.pankuzu li {
	display: inline-block;
	position: relative;
	padding: 0 2rem 0 0 !important;
}
.pankuzu li:not(:last-child):after {
  content: '';
  display: block;
  width: 5px;
  height: 5px;
  border: solid #000;
  border-width: 1px 1px 0 0;
  transform: rotate(45deg) translateY(-50%);
  position: absolute;
  right: 1rem;
  top: 50%;
}
@media print, screen and (max-width: 1200px) {
	.pankuzu {
		overflow-x: scroll;
	}
  .pankuzu ol {
    margin: 0 2rem;
		display: flex;
		align-items: center;
  }
	.pankuzu li {
		display: block;
		white-space: nowrap;
	}
}

.category_list h2 {
	color: #729a1b;
}
.category_list h2::before {
	background-color: #729a1b;
}

.page .content {
  line-height: 1.8;
}

/* category
============================== */

.category_list {
  left: 0;
  margin: 0 0 3rem;
  transition: all 0.2s ease;
  width: 100%;
}
.category_list .inner {
  margin: 0 auto;
}
.category_list .inner ul {
  display: flex;
  flex-wrap: wrap;
  margin: 2rem 0 !important;
  width: 100%;
  gap: 3rem 50px;
}
.category_list .inner ul li {
  width: 30.4%;
  display: block;
  background: #fff;
  padding: 0 !important;
  -webkit-filter: drop-shadow(0px 3px 10px rgba(0,0,0,.8));
	filter: drop-shadow(0px 0px 10px rgba(0,0,0,.2));
}
.category_list .inner ul li::after {
  content: none !important;
}
.category_list .inner ul li a {
  display: flex;
  align-items: center;
  position: relative;
  text-align: left;
  font-family:"游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", 'Lucida Grande', 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
  font-weight: 400;
  color: #1e2c39;
  background: #fff;
  padding: 2rem 2rem 2rem 44px;
  height: 100%;
}
.category_list .inner ul li a::before {
  content: '';
  position: absolute;
  bottom: 50%;
  transform: translateY(50%);
  left: -0;
  display: inline-block;
  width: 34px;
  height: 5px;
  background-color: #656565;
}
#page_main article.main .category_list {
	margin-top: 4rem;
}
#page_main article.main .category_list h2{
	border-bottom: 1px solid !important;
	display: inline !important;
}
#page_main article.main .category_list h2::before {
	content: '' !important;
}
#page_main article.main .category_list .inner ul {
  gap: 2rem 38px;
}

@media print, screen and (max-width: 1200px) {
  .category_list {
    margin: 0;
  }
  .category_list .inner ul li {
    width: 100%;
  }
}

.btn01 {
  display: inline-block;
}
.btn_wrap {
  margin: 1rem 0 1.5rem 0;
}

.btn01 a {
	display: flex;
  align-items: center;
  background: #729a1b;
	font-family:"游ゴシック", "Yu Gothic", 'Lucida Grande', 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
	padding: .8rem 2.4rem .8rem 3rem;
	font-size: var(--14px);
	color: #fff;
  position: relative;
  line-height: 1;
}
.btn01 a:hover {
	color: #fff;
  opacity: 1;
}
.btn01 a::before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  color: #fff;
  line-height: 1;
  width: .5rem;
  height: .5rem;
  border: 0.1rem solid currentColor;
  border-left: 0;
  border-bottom: 0;
  box-sizing: border-box;
  transform: translateX(-25%) rotate(45deg);
  margin-right: 2rem;
  position: absolute;
  left: 1.8rem;
  transition: all .3s;
}
.btn01 a:hover::before {
  left: 2rem;
  transition: all .3s;
}
ul.btn01 {
  display: block;
  margin: 1rem 0 1rem 0 !important;
}
.btn01 li {
  display: inline-block;
}
.btn01 li:first-child {
  padding: 0 0 0.5rem 0 !important;
}
.btn01 li::after {
  content: none !important;
}
/* public */
.public {
	background: url(/common/hue/images/intro1.jpg) no-repeat center;
	background-size: cover;
  min-height: 399px;
}
@media print, screen and (max-width: 1200px){
  .public {
    background: none;
  }
  .public .sp img{
    width: 100%;
  }
}
/* president */
.president {
  background: linear-gradient(to right, transparent 15%, transparent 15%, #fbf5f1 50%), url(/common/hue/images/president1.png);
  background-repeat: no-repeat;
  background-position: left;
  min-height: 399px;
  margin: 2rem 0;
}
.president .sec_box {
  display: flex;
  flex-flow: row-reverse;
}
@media print, screen and (max-width: 1200px){
  .president {
    background: none;
  }
  .president .sp img{
    width: 100%;
    height: auto;
  }
  .president .sec_box {
    display: block;
  }
}
/* student */
.student .container {
  max-width: 1000px;
  margin-left: calc((100% - 1200px) / 2);
}
.student {
	height: 400px;
  padding: 30px 0;
  background: linear-gradient(to left, transparent 15%, transparent 15%, #e7ebef 50%), url(/common/hue/images/student1.png);
  background-repeat: no-repeat;
  background-position: right;
}
@media print, screen and (max-width: 1200px){
  .student .sp img {
    width: 100%;
    margin-bottom: 1rem;
  }
  .student {
    background: none;
    height: 100%;
    padding: 0 0 30px 0;
		margin-top: 30px;
		background-color: #e7ebef;
  }
  .student .container {
    max-width: 100%;
    margin-left: auto;
  }
}
/* contact */
.contact {
  background: #ededed;
}
.contact p:first-child {
  font-weight: 700;
}
.contact p {
  color: #000;
  line-height: 1.5;
  font-size: var(--14px);
}

.cate_title1 {
	display: inline-block;
  color: #888;
  font-size: var(--18px);
	position: relative;
	border-bottom: 1px solid;
	padding: 5px 10px;
	margin-bottom: 1.5rem;
}
.cate_title1::before {
	content: '';
	position: absolute;
	bottom: -1px;
	left: -60px;
	display: inline-block;
	width: 58px;
	height: 3px;
	background-color: #888;
}
.cate_title2 {
  font:2rem/1.2 "游明朝","Yu Mincho","YuMincho",'Hiragino Mincho Pro',serif !important;
}
/* sitemap */
#sitemap_list ul li {
  padding: 0 0 0.5rem 2rem !important;
}
#sitemap_list ul li::after{
  background-color: initial !important;
  border-radius: initial !important;
}
#sitemap_list ul li.sm_category1::after,
#sitemap_list ul li.sm_category2::after,
#sitemap_list ul li.sm_category3::after,
#sitemap_list ul li.sm_category4::after,
#sitemap_list ul li.sm_category5::after,
#sitemap_list ul li.sm_category6::after,
#sitemap_list ul li.sm_category7::after,
#sitemap_list ul li.sm_category8::after {
  display: inline-block;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 25px;
  height: 25px;
  background-image: url(/common/hue/images/icon_folder.png);
  background-color: initial !important;
  border-radius: initial !important;
  background-size: contain;
  vertical-align: middle;
}
#sitemap_list ul li.sm_article::after {
  display: inline-block;
  content: '';
  background-image: url(/common/hue/images/icon_file.png);
  position: absolute;
  top: 0;
  left: 0;
  width: 25px;
  height: 25px;
  background-color: initial;
  border-radius: initial;
  background-size: contain;
  vertical-align: middle;
}
#sitemap_list input[type="button"]{
  width: 25px;
  height: 25px;
  border: 1px solid #999;
  border-radius: 5px;
  margin-left: 10px;
}
/* whatsnew and info */
.backnumber {
	margin: 2rem 0;
}
dl.whatsnew, .backnumber dl {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}
.whatsnew dt {
	width: 15%;
}
.whatsnew dd {
  width: 85%;
	margin-bottom: 10px;
}
.whatsnew dd:last-child {
  width: 85%;
	margin-bottom: 0px;
}
.backnumber dt {
	width: 20%;
}
.backnumber dd {
  width: 80%;
	margin-bottom: 10px;
}
.backnumber dd:last-child {
	margin-bottom: 0px;
}
@media print, screen and (max-width: 1200px){
	dl.whatsnew, .backnumber dl {
		display: block;
	}
	.whatsnew dt, .backnumber dt {
		width: 100%;
	}
	.whatsnew dd, .backnumber dd {
		width: 100%;
		margin-left: 36px;
	}
}
.sec_box {
  display: flex;
}
.sec_box > div {
  width: calc(100% / 2);
}
.sec_box.img_left > div:nth-of-type(2) {
  padding-left: 2.5rem;
  margin-top: 2rem;
}
.sec_box.img_right > div:nth-of-type(2) {
  padding-left: 0;
  padding-right: 2.5rem;
  margin-top: 2rem;
}
.sec_box.img_right > div:first-of-type {
  order: 2;
}
.sec_box.img_left > div:last-of-type {
  order: 1;
}
.sec_box img {
  width: 100%;
  height: auto;
  display: block;
}
.sec_box h3 {
  margin-bottom: 3rem;
}
.sec_box .btn_wrap {
  margin: 2rem 0 1rem 0;
}
.sec_box .btn_wrap + .btn_wrap {
  margin: 1rem 0 1rem 0 !important;
}

@media print, screen and (max-width: 1200px) {
  .sec_box {
    display: flex;
    flex-wrap: wrap;
  }
  .sec_box > div {
    width: 100%;
  }
  .sec_box.img_left > div:nth-of-type(2) {
    padding-left: 0;
    margin-top: 2.5rem;
    margin-bottom: 3rem;
  }
  .sec_box.img_right > div:nth-of-type(2) {
    padding-left: 0;
    padding-right: 0;
    margin-bottom: 3rem;
  }
  .sec_box.img_right > div:first-of-type {
    order: 1;
  }
  .sec_box.img_right > div:last-of-type {
    order: 2;
  }
  .sec_box.img_left > div:first-of-type {
    order: 1;
  }
  .sec_box h3 {
    margin-bottom: 2rem;
  }
}

.sec03 {
  margin-top: 2rem;
}

/* page
============================== */

#page_main .main_wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 2rem auto 8rem;
}
#page_main article {
  width: 884px;
}
#page_main .main_wrapper.main_col1 {
  display: block;
  flex-wrap: unset;
  justify-content: unset;
  margin: 2rem auto 8rem;
}
#page_main .main_col1 article {
  width: 1200px;
}
#page_main .main_wrapper h2 {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", 'Lucida Grande', 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
  display: block;
  border-bottom: none;
}
#page_main .main_wrapper h2::before {
  content: none;
}

#page_main article p {
  margin-bottom: 2rem;
}

/* #page_main article section {
  最初は非表示
  opacity: 0;
  visibility: hidden;
  transform: translateY(30px);
  transition: opacity 1s, visibility 1s, transform 1s;
}
フェードイン時に入るクラス
#page_main article section.fadein {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);
} */

#page_side {
  width: 225px;
}
#page_side h2 {
  font-size: var(--14px);
  margin: 3rem 0 0 0;
  padding: 0 0 30px;
  border-bottom: 4px solid #729a1b !important;
}
#page_side > ul {
  margin: 10px 0 4rem 0 !important;
}
#page_side > ul li {
  padding: 0 !important;
}
#page_side > ul li a, #page_side ul li.selected {
  display: block;
  color: #000;
  position: relative;
  padding: .6rem 1rem .6rem 1.5rem !important;
  font-size: var(--14px);
  font-weight: 700;
  line-height: 1.3;
}
#page_side > ul li a::before {
	content: '' !important;
	position: absolute;
	top: 18px;
	left: 0;
	display: inline-block;
	width: 13px;
	height: 3px;
	background: #729a1b;
}
#page_side > ul li a:hover {
  background: #e3ebd1;
  opacity: 1;
}
#page_side > ul li.selected {
	background: #e3ebd1;
}
#page_side > ul li.selected::before {
	content: '' !important;
	position: absolute;
	top: 18px;
	left: 0;
	display: inline-block;
	width: 13px;
	height: 3px;
	background: #729a1b;
}
#page_side > ul li::after {
	content: none !important;
}
#page_side .banner {
	margin: 00;
}
#page_side .banner ul {
	display: flex;
	flex-wrap: wrap;
  margin: 0 !important;
}
#page_side .banner ul li {
	width: 100%;
	margin: 0;
  padding: 0 !important;
}
#page_side .banner ul li::after {
  content: none !important;
}
#page_side .banner ul li img {
	width: 100%;
}

@media print, screen and (max-width: 1200px) {
  #page_main .main_wrapper {
  }
	#page_main .main_col1 article {
		width: 100%;
	}
  #page_main article {
    width: 100%;
    padding: 0 1rem;
  }
  #page_side {
    width: 100%;
    padding: 0 1rem;
  }
  #page_side .banner {
    margin: 0 -10px;
  }
  #page_side .banner ul li {
    width: 224px;
    margin: 0 10px 20px;
  }
	#page_side .banner ul li {
		width: calc((100% - 4rem) / 3);
	}
}
@media print, screen and (max-width: 796px) {
	#page_side .banner ul li {
		width: calc((100% - 2.5rem) / 2);
	}
}

.pagetitle_a1, .pagetitle_a2, .pagetitle_a3, .pagetitle_a4, .pagetitle_a5, .pagetitle_a6 {
	clear:both;
	text-align:left;
  line-height: 1.2;
  display: block;
}
.pagetitle_a2, .pagetitle_a3, .pagetitle_a4, .pagetitle_a5, .pagetitle_a6 {
  margin-top: 2rem;
}
.pagetitle_a1 {
  color: #000;
  font-size: var(--34px);
  font-weight: 400;
  margin-bottom: 2rem;
}
.pagetitle_a1 span {
  font-size: 41.2%;
  font-weight: 700;
  display: block;
  margin-bottom: 10px;
}
.pagetitle_a1 span {
  font-size: 41.2%;
  font-weight: 700;
  display: block;
  margin-bottom: 10px;
}
.pagetitle_a2 {
	font-size: var(--26px);
	font-weight: 400;
  color: #729a1b;
	border-bottom: 1px solid !important;
	padding: 6px 15px;
	margin-bottom: 2rem;
	margin-left: -14px;
	position: relative;
}
.pagetitle_a2::before {
	content: '' !important;
	position: absolute;
	bottom: -1px;
	left: -60px;
	display: inline-block;
	width: 58px;
	height: 3px;
	background-color: #729a1b;
}
.pagetitle_a3 {
	font-size: 150%;
	font-weight: 400;
  color: #729a1b;
	border-bottom: 1px dashed #b2b2b2 !important;
	padding: 8px 0;
	margin-bottom: 2rem;
	margin-left: 0;
	position: relative;
}
.pagetitle_a4 {
	font-size: 138%;
	font-weight: 400;
  color: #729a1b;
  background: #e3ebd1;
	padding: 12px 10px;
	margin-bottom: 2rem;
	margin-left: 0;
	position: relative;
}
.pagetitle_a5 {
	font-size: 138%;
	font-weight: 400;
  color: #000;
	border-bottom: 1px solid #828282 !important;
	padding: 12px 0;
	margin-bottom: 2rem;
	margin-left: 0;
	position: relative;
}
.page_outline {
	margin: 10px 0;
	padding: 10px;
	border: solid 2px #a6a6a6;
	background-color: #ffffff;
	clear: both;
}

main.page span.pdf,
main.page span.xlsx, main.page span.xlsm, main.page span.xls,
main.page span.doc, main.page span.docx,
main.page span.pptx, main.page span.ppt,
main.page span.txt {
  display: inline;
  align-items: center;
  position: relative;
  padding-left: 67px;
}
main.page span.pdf::before,
main.page span.xlsx::before, main.page span.xlsm::before, main.page span.xls::before,
main.page span.doc::before, main.page span.docx::before,
main.page span.pptx::before, main.page span.ppt::before,
main.page span.txt::before {
  font-size: var(--10px);
  letter-spacing: .5px;
  text-align: center;
  position: absolute;
  display: inline-block;
  color: #fff;
  width: 52px;
  top: 1px;
  left: 0;
  padding: 2px 0 0;
}
main.page span.pdf::before {
  content: "PDF";
  background: #9e134a;
}
main.page span.xlsx::before, main.page span.xlsm::before, main.page span.xls::before {
  content: "EXCEL";
  background: #288765;
}
main.page span.doc::before, main.page span.docx::before {
  content: "WORD";
  background: #284587;
}
main.page span.pptx::before, main.page span.ppt::before {
  content: "PowerPoint";
  background: #ce1235;
  letter-spacing: -.5px !important;
}
main.page span.txt::before {
  content: "TXT";
  background: #333333;
}

table {
  border-collapse: collapse;
  margin: 1rem 0;
}
@media only screen and (max-width: 768px) {
  table {
    white-space: nowrap;
  }
}
table th {
  font-weight: 400;
  padding: 1rem;
  border: 1px solid #b1b1b1;
  color: #ffffff;
  background: #729a1b;
}

table td {
  padding: 1rem;
  border: 1px solid #b1b1b1;
  background: #fff;
}

table.gsc-search-box td{
	padding: 0 0 0 12px;
	border: 0px;
	background: none;
}
table.gsc-above-wrapper-area-container td{
	padding: 0 0 0 12px;
	border: 0px;
	background: none;
}

.col2 img, .col3 img, .col4 img, .col5 img {
	max-width: 100%;
	height: auto;
}
.col2, .col3, .col4, .col5 {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -.5rem 2rem;
}
.col2 > div {
  width: calc((100% / 2) - 1rem);
  margin: 0 .5rem 2rem;
}
.col2 .col2_title {
  border-bottom: none;
  font-family:"游明朝","Yu Mincho","YuMincho",'Hiragino Mincho Pro',serif !important;
  color: #000000;
  font-size: 2rem;
  font-weight: 100;
  margin-bottom: 2rem
}
.col3 > div {
  width: calc((100% / 3) - 1rem);
  margin: 0 .5rem 2rem;
}
.col3 .col3_title {
  border-bottom: none;
  font-family:"游明朝","Yu Mincho","YuMincho",'Hiragino Mincho Pro',serif !important;
  color: #000000;
	display: block;
  font-size: 2rem;
  font-weight: 100;
  margin-bottom: 2rem
}
.col4 > div {
  width: calc((100% / 4) - 1rem);
  margin: 0 .5rem 2rem;
}
.col4 .col4_title {
  border-bottom: none;
  font-family:"游明朝","Yu Mincho","YuMincho",'Hiragino Mincho Pro',serif !important;
  color: #000000;
	display: block;
  font-size: 2rem;
  font-weight: 100;
  margin-bottom: 2rem
}
.col5 > div {
  width: calc((100% / 5) - 1rem);
  margin: 0 .5rem 2rem;
}
@media print, screen and (max-width: 1200px) {
  .col2 > div, .col3 > div, .col4 > div, .col5 > div {
    width: calc((100% / 2) - 1rem);
    margin: 0 .5rem 2rem;
  }
}
@media print, screen and (max-width: 796px) {
  .col2 > div, .col3 > div, .col4 > div, .col5 > div {
    width: 100%;
    margin: 0 .5rem 0rem;
  }
}
/* template 2col 3col 既存のテンプレートcss */
.box_2col,
.box_3col {
  clear: both;
  margin: 0 0 10px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
}

.box_2col div,
.box_3col div {
  padding: 5px;
  vertical-align: top;
}

.box_2col div img,
.box_3col div img {
  max-width: 100%;
  height: auto;
}

.box_2col div p.button,
.box_3col div p.button {
  margin-top: 10px;
}

.box_check {
  border: 2px solid #FFE400;
  background: #FFFBEF;
	font-family:"游明朝","Yu Mincho","YuMincho",'Hiragino Mincho Pro',serif !important;
  padding: 1.5rem 9rem 1rem 1.5rem;
  margin: 2rem 0;
  font-size: var(--16px);
  position: relative;
  min-height: 190px;
}

.box_check h3.tit {
  color: #125FA5;
  font-size: var(--16px);
}
@media print, screen and (max-width: 1200px) {
  .box_check {
    padding: 1rem 5rem 1rem 1rem;
  }
}

.btn02 {
  display: flex;
  flex-wrap: wrap;
  margin: 0 !important;
}
.btn02 li {
  display: inline-block;
  padding: 0 !important;
}
.btn02 li::after {
  content: none !important;
}
.btn02 a {
  color: #fff;
  background: #729a1b;
  display: block;
  font-family:"游ゴシック", "Yu Gothic", 'Lucida Grande', 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
  font-weight: 700;
  padding: .1rem .8rem;
  margin: 0 1rem .5rem 0;
}

.reader {
  display: flex;
  font-size: var(--12px);
  margin: 3rem 0;
}
@media print, screen and (max-width: 1200px) {
  .reader {
    flex-wrap: wrap;
	}
}
.reader > div:first-of-type {
  margin-right: 2rem;
}
.w100 {
  width: 100%;
}

/* お知らせ */
article.main .important, article.main .topics, article.main .campusinfo {
	font-size: var(--16px);
  margin-bottom: 5rem;
}
article.main .important .page, article.main .topics .page, article.main .campusinfo .page {
  border-bottom: 1px solid #828282;
  margin-bottom: 1rem;
}
article.main .important .page span.current, article.main .topics .page span.current, article.main .campusinfo .page span.current {
  padding: .5rem 1rem;
}
article.main .important .page a, article.main .topics .page a, article.main .campusinfo .page a {
  display: block;
  padding: .5rem 1rem;
}
article.main .important .page ul, article.main .topics .page ul, article.main .campusinfo .page ul {
	display: flex;
  justify-content: flex-end;
  margin: 0 !important;
}
article.main .important .page li, article.main .topics .page li, article.main .campusinfo .page li {
  display: flex;
  align-items: center;
  padding: 0 !important;
}
article.main .important .page li::after, article.main .topics .page li::after, article.main .campusinfo .page li::after {
  content: "|" !important;
  background-color: initial !important;
  height: initial !important;
  width: initial !important;
  position: initial !important;
}
article.main .important .page li:last-child:after, article.main .topics .page li:last-child:after, article.main .campusinfo .page li:last-child:after {
  content: none !important;
}
article.main .important p, article.main .topics p, article.main .campusinfo p {
  margin-bottom: 0 !important;
}
article.main .important > ul, article.main .topics > ul, article.main .campusinfo > ul  {
  border-bottom: 1px solid #828282;
  margin: 0 0 1rem 0 !important;
  padding-bottom: 1rem !important;
}
article.main .important > ul li, article.main .campusinfo > ul li {
  padding: 0 0 1rem .5rem !important;
}
article.main .topics > ul li {
  padding: 0 !important;
}
article.main .important > ul li::after, article.main .topics > ul li::after, article.main .campusinfo > ul li::after {
  content: none !important;
}
article.main .important a .date {
	color: #484848;
  text-decoration: none;
}
article.main .important .important_tit, article.main .topics .topics_tit, article.main .campusinfo .campusinfo_tit {
	display: flex;
}
article.main .important a .article, article.main .campusinfo a .article {
	text-decoration: underline;
	color: #0e467b;
}
article.main .important .important_tit .date, article.main .campusinfo .campusinfo_tit .date {
  width: 16%;
	min-width: 10rem;
}
article.main .important .important_tit .article, article.main .campusinfo .campusinfo_tit .article {
  width: 84%;
}
article.main .important .important_tit .article span, article.main .campusinfo .campusinfo_tit .article span {
	text-decoration: none;
	display: inline-block;
	color: #fff;
	border-radius: 10px;
	padding: 0 10px;
	margin-right: .3rem;
	font-size: 84.6%;
}
article.main .important .important_tit .article span.mark-zen {
	background: #1e2c39;
}
article.main .important .important_tit .article span.mark-honbu {
	background: #115fad;
}
article.main .important .important_tit .article span.mark-sapporo {
	background: #066f9a;
}
article.main .important .important_tit .article span.mark-asahikawa {
	background: #027488;
}
article.main .important .important_tit .article span.mark-kushiro {
	background: #0c7e55;
}
article.main .important .important_tit .article span.mark-hakodate {
	background: #1e2c39;
}
article.main .important .important_tit .article span.mark-iwamizawa {
	background: #1e2c39;
}
article.main .important .important_tit .article span:last-of-type {
	margin-right: 15px;
}
article.main .important .note {
	font-size: var(--12px);
	font-weight: 700;
	text-align: center;
}

article.main .topics > ul li {
	margin-bottom: 2rem;
}
article.main .topics a .article {
	color: #0e467b;
}
article.main .topics a .article p:last-child {
  text-decoration: underline;
}
article.main .topics .topics_tit .article {
  width: 84%;
}
article.main .topics .topics_tit .title {
	font-size: var(--17px);
}
article.main .topics figure {
  width: 240px;
  margin-right: 1rem;
  border-radius: 8px;
	display: flex;
	object-fit: cover;
	aspect-ratio: 600 / 402;
	align-items: center;
}
article.main .topics figure img {
  width: 100%;
	height: 100% !important;
	object-fit: cover;
	border-radius: 8px;
}
article.main .topics a .date {
	color: #484848;
  text-decoration: none;
}
article.main .topics .topics_tit .article .mark-hold {
	color: #fff;
  display: inline-block;
	border-radius: 10px;
	padding: 0 10px;
	margin-right: .3rem;
	margin-top: .5rem !important;
  margin-bottom: .5rem !important;
	font-size: 84.6%;
}
article.main .topics .topics_tit .article .mark-hold.black {
	background: #000;
}
article.main .topics .topics_tit .article .mark-hold.gray {
	background: #656565;
}
article.main .topics .topics_tit .article .mark-hold.red {
	background: #ac0000;
}
article.main .topics .topics_tit .article .mark-hold.blue {
	background: #0f477b;
}
article.main .topics .topics_tit .article .mark-hold.green {
	background: #30843e;
}
@media print, screen and (max-width: 1200px) {
	article.main .important .important_tit, article.main .topics .topics_tit, article.main .campusinfo .campusinfo_tit {
		display: block;
	}
  article.main .important .page li, article.main .topics .page li, article.main .campusinfo .page li {
    display: none;
  }
  article.main .important .page li:first-child,article.main .topics .page li:last-child,
	article.main .topics .page li:first-child, article.main .topics .page li:last-child,
	article.main .campusinfo .page li:first-child, article.main .campusinfo .page li:last-child {
    display: flex;
  }
  article.main .important .important_tit .article, article.main .topics .topics_tit .article, article.main .campusinfo .campusinfo_tit .article {
  width: 100%;
  }
	article.main .important .important_tit .date, article.main .topics .topics_tit .date, article.main .campusinfo .campusinfo_tit .date {
		width: auto;
		margin-bottom: 5px;
	}
  article.main .topics figure{
    width: 100%;
    margin-right: 0;
    margin-bottom: .5rem;
  }
}

#page_main ul {
  margin: 1rem 0 1rem .5rem;
  padding: 0;
  list-style: none;
}
#page_main ul li {
  position: relative;
  padding: 0 0 .5rem .5rem;
}
#page_main ul li ul {
  margin: .5rem 0 0 .5rem;
}
#page_main li:last-child {
  padding-bottom: 0;
}
#page_main ul li ol {
  margin: .5rem 0 0 1.5rem;
}
#page_main ul li ol li {
  padding-left: 0;
}
#page_main ul li ol li:after {
  background: none;
}

#page_main ol {
  margin: 1rem 0 1rem 1.5rem;
  padding: 0;
}
#page_main ol li {
  position: relative;
  padding: 0 0 .5rem 0;
}
#page_main ol li ul {
  margin: .5rem 0 0 0;
}
#page_main ol li ol {
  margin: .5rem 0 0 1rem;
}
#page_main ol li ul li {
  padding-left: .5rem;
}
#page_main ol li ol li {
  padding-left: 0;
}
#page_main ul li ol li:last-child {
  padding: 0;
}

#page_main ul li::after {
  display: block;
  content: '';
  position: absolute;
  top: .7em;
  left: 0;
  width: 4px;
  height: 4px;
  background-color: #729a1b;
  border-radius: 100%;
}
.round {
	float: left;
}
.round > div {
  display: inline;
}
.round .fix_left {
  float: left;
  text-align: center;
  margin: 0 10px 10px 0;
}
.round .fix_right {
  float: right;
  text-align: center;
  margin: 0 0 10px 10px;
}
@media print, screen and (max-width: 1200px) {
  .round > div {
    display: block;
  }
  .round .fix_left, .round .fix_right {
    float: none;
    clear: both;
    margin: 0 0 10px 0;
  }
}
/* footer
============================== */


.mt4 {
  margin-top: 4rem;
}
.mb10 {
  margin-bottom: 10rem;
}
.pb3 {
  padding-bottom: 3rem;
}

/* 作りこみ
============================== */
.category_title.keywordtitle .titleimg {
  position: absolute;
  transform: translateY(-50%) translateX(-50%);
  top: 50%;
  left: 50%;
}
.keyword .pagetitle_a1 span{
  font-size: 85%;
  font-weight: 400;
  color: #125fa5;
  margin-bottom: 20px;
}
.keyword .pagetitle_a1 {
  line-height: 1;
  font-family:"游明朝","Yu Mincho","YuMincho",'Hiragino Mincho Pro',serif !important;
}
.keyword .container {
  margin-bottom: 2rem;
}
.keyword .keyword_bg_gray,
.keyword .keyword_bg_beige,
.keyword .keyword_bg_green,
.keyword .keyword_bg_blue,
.keyword .keyword_bg_yellow {
  height: 400px;
  padding: 30px 0;
}
.keyword .keyword_bg_gray .container,
.keyword .keyword_bg_green .container,
.keyword .keyword_bg_yellow .container {
  max-width: 1000px;
  margin-left: calc((100% - 1200px) / 2);
}
.keyword .keyword_bg_beige .container,
.keyword .keyword_bg_blue .container {
  max-width: 1000px;
  margin-right: calc((100% - 1200px) / 2);
}
.keyword .keyword_bg_gray {
  background: linear-gradient(to left, transparent 15%, transparent 15%, #e7ebef 20%), url(/common/hue/images/keyword1.png);
  background-repeat: no-repeat;
  background-position: right;
}

.keyword .keyword_bg_beige {
  background: linear-gradient(to right, transparent 15%, transparent 15%, #f2f0e2 20%), url(/common/hue/images/keyword2.png);
  background-repeat: no-repeat;
  background-position: left;
}
.keyword .keyword_bg_green {
  background: linear-gradient(to left, transparent 15%, transparent 15%, #e2f0d9 20%), url(/common/hue/images/keyword3.png);
  background-repeat: no-repeat;
  background-position: right;
}
.keyword .keyword_bg_blue {
  background: linear-gradient(to right, transparent 15%, transparent 15%, #e8f3f4 20%), url(/common/hue/images/keyword4.png);
  background-repeat: no-repeat;
  background-position: left;
}
.keyword .keyword_bg_yellow {
  background: linear-gradient(to left, transparent 15%, transparent 15%, #f6fcea 20%), url(/common/hue/images/keyword5.png);
  background-repeat: no-repeat;
  background-position: right;
}

@media print, screen and (max-width: 1200px){
  .keyword .sp img {
    width: 100%;
    margin-bottom: 1rem;
  }
  .keyword .keyword_bg_gray,
  .keyword .keyword_bg_beige,
  .keyword .keyword_bg_green,
  .keyword .keyword_bg_blue,
  .keyword .keyword_bg_yellow {
    background: none;
    height: 100%;
    padding: 0 0 30px 0;
  }
  .keyword .keyword_bg_gray .container,
  .keyword .keyword_bg_green .container,
  .keyword .keyword_bg_yellow .container {
    max-width: 100%;
    margin-left: auto;
  }
  .keyword .keyword_bg_beige .container,
  .keyword .keyword_bg_blue .container {
    max-width: 100%;
    margin-right: auto;
  }
  .keyword .keyword_bg_gray {
    background-color: #e7ebef;
  }
  .keyword .keyword_bg_beige {
    background-color: #f2f0e2;
  }
  .keyword .keyword_bg_green {
    background-color: #e2f0d9;
  }
  .keyword .keyword_bg_blue {
    background-color: #e8f3f4;
  }
  .keyword .keyword_bg_yellow {
    background-color: #f6fcea;
  }
}

.main_wrapper article.main a:not(.btn01 a, article.main .important a, article.main .topics a),
.contents_wrapper a:not(.btn01 a, article.main .important a, article.main .topics a) {
	text-decoration: underline !important;
}
main iframe, main iframe {
	max-width: 100%;
}
@media print, screen and (max-width: 1200px){
	.main_wrapper article.main img, .contents_wrapper img {
		max-width: 100%;
		height: auto !important;
	}
}
/* only editor */
@media print, screen and (max-width: 1200px) {
  .cke_editable .col2 > div {
  	width: calc((100% / 2) - 1rem);
  	margin: 0 .5rem 2rem;
  }
  .cke_editable .col3 > div {
  	width: calc((100% / 3) - 1rem);
  	margin: 0 .5rem 2rem;
  }
  .cke_editable .col4 > div {
  	width: calc((100% / 4) - 1rem);
  	margin: 0 .5rem 2rem;
  }
  .cke_editable .col5 > div {
  	width: calc((100% / 5) - 1rem);
  	margin: 0 .5rem 2rem;
  }
  .cke_editable .sec_box {
  	display: flex;
		flex-wrap: nowrap;
  }
  .cke_editable .sec_box > div {
  	width: calc(100% / 2);
  }
  .cke_editable .sec_box.img_left > div:nth-of-type(2) {
  	padding-left: 2.5rem;
  	margin-top: 2rem;
  }
  .cke_editable .sec_box.img_right > div:nth-of-type(2) {
  	padding-left: 0;
  	padding-right: 2.5rem;
  	margin-top: 2rem;
  }
  .cke_editable .sec_box.img_right > div:first-of-type {
  	order: 2;
  }
	.cke_editable .sec_box.img_right > div:last-of-type {
		order: 1;
	}
  .cke_editable .sec_box.img_left > div:last-of-type {
  	order: 1;
  }
  .cke_editable .sec_box img {
  	width: 100%;
  	height: auto;
  	display: block;
  }
  .cke_editable .sec_box h3 {
  	margin-bottom: 3rem;
  }
	.cke_editable .round > div {
		display: inline;
	}
	.cke_editable .round .fix_left {
		float: left;
		text-align: center;
		margin: 0 10px 10px 0;
	}
	.cke_editable .round .fix_right {
		float: right;
		text-align: center;
		margin: 0 0 10px 10px;
	}
  .cke_editable .sec_box h3 {
  	margin-bottom: 3rem;
  }
}
@media print, screen and (max-width: 850px) {
  .cke_editable .col2 > div, .cke_editable .col3 > div, .cke_editable .col4 > div, .cke_editable .col5 > div {
    width: calc((100% / 2) - 1rem);
    margin: 0 .5rem 2rem;
  }
	.cke_editable .sec_box {
		display: flex;
		flex-wrap: wrap;
	}
	.cke_editable .sec_box > div {
		width: 100%;
	}
	.cke_editable .sec_box.img_left > div:nth-of-type(2) {
		padding-left: 0;
		margin-top: 2.5rem;
		margin-bottom: 3rem;
	}
	.cke_editable .sec_box.img_right > div:nth-of-type(2) {
		padding-left: 0;
		padding-right: 0;
		margin-bottom: 3rem;
	}
	.cke_editable .sec_box.img_right > div:first-of-type {
		order: 1;
	}
	.cke_editable .sec_box.img_right > div:last-of-type {
		order: 2;
	}
	.cke_editable .sec_box.img_left > div:first-of-type {
		order: 1;
	}
	.cke_editable .sec_box h3 {
		margin-bottom: 2rem;
	}
	.cke_editable .round > div {
    display: block;
  }
  .cke_editable .round .fix_left, .cke_editable .round .fix_right {
    float: none;
    clear: both;
    margin: 0 0 10px 0;
  }
}

/* date and title in incatlist */
div.incatlist_flex {
	margin: 1rem 0 1.5rem 0;
}
div.incatlist_flex > div {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	margin-bottom: .5rem;
}
div.incatlist_flex div.date {
	width: 10%;
	margin-right: 2%;
}
div.incatlist_flex div.tit {
	width: 88%;
}
@media print, screen and (max-width: 1200px){
	div.incatlist_flex > div {
		display: block;
	}
	div.incatlist_flex div.date {
		width: 100%;
		margin-right: 0;
	}
	div.incatlist_flex div.tit {
		width: 100%;
	}
}

/* only print */
@media only print {
	#page_main article section {
		opacity: 1;
		visibility: visible;
		transform: translateX(0);
	}
}