@import url('https://fonts.googleapis.com/css2?family=Albert+Sans:ital,wght@0,100..900;1,100..900&family=Noto+Sans+JP:wght@100..900&display=swap');
@charset "UTF-8";
/* Contents Menu
-------------------------------------------------------------------------------------
【PC/SP】
	**:normalize
	**:icon
	**:reset
	**:base contents
		header/gnav/mv/contents/footer/newslist/
	**:indent
	**:size
	**:wide
	**:section
	**:compo parts
		btn/box/list/head/table/float/column/topcontrol/roBtn/
	**:pager
	**:form
-------------------------------------------------------------------------------------*/
/* normalize
-------------------*/
/*! normalize.css v2.0.1 | MIT License | git.io/normalize */ article, aside, details, figcaption, figure, footer, header, hgroup, nav, section, summary {
  display: block
}
audio, canvas, video {
  display: inline-block
}
audio:not([controls]) {
  display: none;
  height: 0
}
[hidden] {
  display: none
}
html {
  font-family: sans-serif;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%
}
body {
  margin: 0
}
h1 {
  font-size: 2em
}
abbr[title] {
  border-bottom: 1px dotted
}
b, strong {
  font-weight: 700
}
dfn {
  font-style: italic
}
mark {
  background: #ff0;
  color: #000
}
code, kbd, pre, samp {
  font-family: monospace, serif;
  font-size: 1em
}
pre {
  white-space: pre;
  white-space: pre-wrap;
  word-wrap: break-word
}
q {
  quotes: "\201C""\201D""\2018""\2019"
}
small {
  font-size: 80%
}
sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline
}
sup {
  top: -.5em
}
sub {
  bottom: -.25em
}
img {
  border: 0
}
svg:not(:root) {
  overflow: hidden
}
figure {
  margin: 0;
  line-height: 0;
}
fieldset {
  border: 1px solid silver;
  margin: 0 2px;
  padding: .35em .625em .75em
}
legend {
  border: 0;
  padding: 0
}
button, input, select, textarea {
  font-family: inherit;
  font-size: 100%;
  margin: 0
}
button, input {
  line-height: normal
}
button, html input[type="button"], input[type=reset], input[type=submit] {
  -webkit-appearance: button;
  cursor: pointer
}
button[disabled], input[disabled] {
  cursor: default
}
input[type=checkbox], input[type=radio] {
  box-sizing: border-box;
  padding: 0
}
input[type=search] {
  -webkit-appearance: textfield;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  box-sizing: content-box
}
input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none
}
button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0
}
textarea {
  overflow: auto;
  vertical-align: top
}
table {
  border-collapse: collapse;
  border-spacing: 0
}
/* reset
-------------------*/
html {
  /*  scroll-behavior: smooth;*/
  background-color: #F1F3EE;
  font-size: 62.5%; /* sets the base font to 10px for easier math */
}
body, h1, h2, h3, h4, h5, h6, pre, ul, ol, li, dl, dt, dd, p, img {
  margin: 0;
  padding: 0;
}
body {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #291753;
  font-size: 14px;
  font-size: 1.4rem;
  font-feature-settings: "palt";
  line-height: 1.8;
  letter-spacing: 0.05rem;
  overflow-x: hidden;
}
body * {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
a, a:link, a:hover, a:focus {
  color: #000;
  text-decoration: none;
  cursor: pointer;
  outline: none;
  -webkit-transition: all .5s ease-in-out;
  transition: all .5s ease-in-out;
}
a:hover {
  text-decoration: none;
}
ul, ol {
  list-style-type: none;
}
::selection {
  background-color: #888;
  color: #FFF; /* Safari */
}
::-moz-selection {
  background-color: #888;
  color: #FFF; /* Firefox */
}
img {
  width: 100%;
  height: auto;
}
@font-face {
  font-family: 'icomoon';
  src: url('fonts/icomoon.eot?3wtgd6');
  src: url('fonts/icomoon.eot?3wtgd6#iefix') format('embedded-opentype'), url('fonts/icomoon.ttf?3wtgd6') format('truetype'), url('fonts/icomoon.woff?3wtgd6') format('woff'), url('fonts/icomoon.svg?3wtgd6#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.icon-arrow-left:before {
  content: "\e930";
}
.icon-arrow-right:before {
  content: "\e931";
}
.icon-search:before {
  content: "\f002";
}
/**/
.flex {
  display: flex;
  flex-wrap: wrap;
}
.center {
  text-align: center;
}
.left {
  text-align: left;
}
.right {
  text-align: right;
}
.bold {
  font-weight: 600;
}
.en {
  font-family: "Albert Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
}
/*-------------------*/
.wrap {
  overflow: hidden;
}
.item01 {
  order: 1;
}
.item02 {
  order: 2;
}
.sp {
  display: block;
}
.pc {
  display: none;
}
.mgb10 {
  margin-bottom: 10px;
}
.mgb30 {
  margin-bottom: 30px;
}
.mgb50 {
  margin-bottom: 5rem;
}
.mgb60 {
  margin-bottom: 30px;
}
.mgb80 {
  margin-bottom: 40px;
}
.indent > li {
  padding-left: 10px;
  text-indent: -10px;
}
@media only screen and (min-width: 820px) {
  .sp {
    display: none;
  }
  .pc {
    display: block;
  }
  .item01 {
    order: 2;
  }
  .item02 {
    order: 1;
  }
  .mgb60 {
    margin-bottom: 60px;
  }
  .mgb80 {
    margin-bottom: 80px;
  }
}
/*header*/
.header_wrap {
  z-index: 1000;
  position: fixed;
  background-color: #F1F3EE;
  width: 100%;
  height: 58px;
  border-bottom: 1px solid #291753;
  padding: 10px;
}
.header_wrap .logo {
  position: fixed;
  top: 13px;
  left: 15px;
}
.header_wrap .logo a {
  display: flex;
  align-items: baseline;
}
.header_wrap .logo-1 {
  width: 80px;
  margin-right: 7px;
}
.header_wrap .logo-2 {
  width: 163px;
}
.header_wrap.active::after {
  top: 0;
}
.header_wrap .gnav_list li a {
  font-size: 17px;
  color: #000000;
  font-weight: 400;
  display: block;
}
@media only screen and (min-width: 820px) {
  .header_wrap {
    height: 90px;
    padding: 23px 25px 20px 25px;
    display: flex;
    justify-content: space-between;
  }
  .header_wrap .logo {
    display: flex;
    top: 23px;
    left: 25px;
  }
  .header_wrap .logo-1 {
    width: 93px;
    margin-right: 7px;
  }
  .header_wrap .logo-2 {
    width: 183px;
  }
  .header_wrap #spNav {
    width: 60%;
    height: 90px;
    position: fixed;
    top: 0;
    right: 0;
  }
  .header_wrap .gnav_list {
    display: flex;
    width: 100%;
    height: 100%;
  }
  .header_wrap .gnav_list li {
    width: calc(100% - 150px / 4);
    max-width: 90px;
    border-left: 1px solid #291753;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 10px;
  }
  .header_wrap .gnav_list li:first-child {
    display: none;
  }
  .header_wrap .gnav_list li:last-child {
    width: calc(100% - 360px);
    max-width: inherit;
  }
  .header_wrap .gnav_list li a {
    font-size: 15px;
    text-align: center;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .header_wrap .searchform_box {
    border: 1px solid #000000;
    background-color: #F1F3EE;
    border-radius: 40px;
    display: flex;
    width: 100%;
    margin: auto;
    position: relative;
  }
  .header_wrap .searchform_box input {
    border: none;
    background-color: #F1F3EE;
    border-radius: 0 40px 40px 0;
    height: 30px;
  }
  .header_wrap .searchform_box button {
    width: 30px;
    border: none;
    height: 30px;
    background: transparent;
  }
}
@media only screen and (min-width: 1100px) {
  .header_wrap .gnav_list li {
    max-width: 110px;
  }
  .header_wrap #spNav {
    width: 55%;
  }
}
@media only screen and (min-width: 1360px) {
  .header_wrap #spNav {
    width: 50%;
  }
  .header_wrap .gnav_list li a {
    font-size: 17px;
  }
  .header_wrap .gnav_list li {
    width: calc(100% / 5);
    max-width: 122px;
  }
  .header_wrap .gnav_list li:last-child {
    width: calc(100% - 488px);
    max-width: inherit;
  }
}
@media only screen and (min-width: 1440px) {
  .header_wrap .gnav_list li {
    max-width: inherit;
    width: calc(100% / 5);
  }
  .header_wrap .gnav_list li:last-child {
    width: calc(100% / 5 + 100px);
  }
}
@media only screen and (max-width: 819px) {
  .header_wrap .sp_menu {
    cursor: pointer;
    display: block;
    position: fixed;
    padding: 10px;
    width: 58px;
    height: 58px;
    right: 0;
    top: 0;
    z-index: 10100;
  }
  .header_wrap .sp_menu span {
    background-color: #291753;
    height: 2.5px;
    width: 20px;
    position: absolute;
    border-radius: 100vh;
    -webkit-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);
    transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);
    right: 20px;
  }
  .header_wrap .sp_menu span:nth-of-type(1) {
    top: 23px;
  }
  .header_wrap .sp_menu span:nth-of-type(2) {
    top: 31px;
    transform: translateX(0);
  }
  .header_wrap .sp_menu span:nth-of-type(3) {
    top: 39px;
    transform: translateX(0);
  }
  .header_wrap .sp_menu.active span {
    background-color: #fff;
  }
  .header_wrap .sp_menu.active span:nth-of-type(1) {
    -webkit-transform: translateX(0) translateY(5px) rotate(-45deg);
    transform: translateX(0) translateY(5px) rotate(-45deg);
    width: 3rem;
  }
  .header_wrap .sp_menu.active span:nth-of-type(2) {
    -webkit-transform: translateX(0) translateY(-3px) rotate(45deg);
    transform: translateX(0) translateY(-3px) rotate(45deg);
    width: 3rem;
  }
  .header_wrap .sp_menu.active span:nth-of-type(3) {
    background-color: transparent;
  }
  .header_wrap #spNav {
    height: 100%;
    transition: all 550ms ease 0.25s;
    visibility: hidden;
    padding: 8rem 4rem;
    width: 100%;
    position: fixed;
    right: -100%;
    top: 0;
    z-index: 990;
    background: #5B5072;
    overflow-y: scroll;
    text-align: center;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
  }
  .header_wrap #spNav a {
    color: #fff;
    padding: 15px 0;
  }
  .header_wrap #spNav::after {
    height: 100%;
    z-index: -1;
  }
  .header_wrap #spNav.active {
    visibility: visible;
    right: 0;
  }
  .header_wrap #spNav .gnav_list {
    width: 100%;
  }
  .header_wrap #spNav .gnav_list li {
    color: #fff;
    text-align: left;
  }
  .header_wrap #spNav .gnav_list li:last-child {
    margin-top: 30px;
  }
  .header_wrap {
    border-bottom: none;
  }
  .header_wrap .searchform_box {
    border: 1px solid #fff;
    background-color: #5B5072;
    border-radius: 40px;
    display: flex;
    width: 100%;
    margin: auto;
    position: relative;
  }
  .header_wrap .searchform_box input {
    border: none;
    background-color: #5B5072;
    border-radius: 0 40px 40px 0;
    height: 35px;
    width: 100%;
  }
  .header_wrap .searchform_box button {
    width: 30px;
    border: none;
    height: 30px;
    background: transparent;
    color: #fff;
  }
}
/*footer*/
footer .cont_inr, footer .footer_link, footer .right_cont {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
}
footer .footer_link {
  padding: 10px;
}
footer .footer_link li {
  margin-right: 47px;
}
footer .footer_link a {
  text-decoration: underline;
  font-size: 11px;
}
footer .copyright {
  font-size: 9px;
  color: #000;
  margin-bottom: 5px;
}
footer .footer_logo {
  width: 56px;
  line-height: 0;
}
@media only screen and (min-width: 820px) {
  footer .cont_inr {
    justify-content: space-between;
  }
  footer .footer_link li {
    margin-right: 20px;
  }
}
@media only screen and (min-width: 1440px) {
  footer .footer_link li {
    margin-right: 47px;
  }
}
@media only screen and (max-width: 819px) {
  footer {
    padding: 0 15px 50px;
  }
  footer .cont_inr {
    border-top: 1px solid #1F0064;
    padding-top: 26px
  }
  footer .footer_link {
    width: 100%;
  }
  footer .footer_link li {
    margin-right: 20px;
  }
  footer .right_cont {
    width: 100%;
  }
  footer .right_cont .footer_logo {
    width: 62px;
  }
  footer .right_cont .copyright {
    width: calc(100% - 68px);
    text-align: left;
  }
}
/**/
.common_mv, .common_top {
  margin-top: 60px;
}
.contents {
  padding: 40px 25px 100px;
}
.border_btm {
  border-bottom: 1px solid #837A38
}
.border_btm-2 {
  border-bottom: 1px solid #0F8C28
}
.border_btm-3 {
  border-bottom: 1px solid #1D7BFF
}
.border_btm-4 {
  border-bottom: 1px solid #291753
}
.cont_inr {
  max-width: 136rem;
  margin: auto;
  position: relative;
}
.txt {
  font-size: 14px;
}
h1, h2, h3, h4 {
  font-weight: 400;
}
.sec-ttl {
  font-size: 17px;
}
.sec-box_ttl {
  font-size: 24px;
  width: 100%;
  text-align: center;
  line-height: 1;
  border: 1px solid #291753;
  padding: 20px;
}
.inr_txt {
  font-size: 15px;
  color: #000;
  width: 100%;
  margin-top: 60px;
}
.l-r-contents {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
}
.l-r-contents .sec-ttl {
  width: 100%;
}
.l-r-contents .right_cont {
  width: 100%;
}
.article-list {
  max-width: 1100px;
  display: flex;
  flex-wrap: wrap;
  margin-top: 10px;
}
.article-list .article-inr {
  margin-bottom: 35px;
}
.article-list .thum {
  border-radius: 15px;
  line-height: 1;
  overflow: hidden;
  height: 100px;
}
.article-list .thum img {
  object-fit: cover;
  height: 100px;
  transition: all 1s;
  -webkit-transition: all 1s;
  width: 100%;
}
.article-list time {
  color: #676767;
  font-size: 12px;
  margin-top: 15px;
  display: block;
}
.article-list .ttl {
  color: #291753;
  font-size: 22px;
  margin-top: 5px;
  line-height: 1.4;
}
.cat {
  margin-top: 15px;
}
.cat > span {
  margin-right: 10px;
  position: relative;
  padding: 5px 12px;
  border-radius: 30px;
  border: 1px solid #291753;
  color: #291753;
  font-size: 11px;
  line-height: 1;
  display: inline-block;
  margin-bottom: 0.5rem;
}
.archive_wrap {
  padding: 80px 20px;
}
.archive_wrap .txt {
  margin-top: 40px;
}
.archive_wrap .common_inr {
  display: flex;
  flex-wrap: wrap;
  max-width: 1360px;
  margin: auto;
}
.archive_wrap .common_inr .leftside, .archive_wrap .common_inr .leftside .sec-box_ttl {
  width: 100%;
}
.archive_wrap .common_inr .rightside {
  width: 100%;
}
.archive_wrap .common_inr .rightside .inr_txt {
  margin: 0;
}
.archive_wrap .article-list .article-inr {
  width: calc(100% / 2);
  padding: 0 5px;
}
.archive_wrap .leftside_btm .under_ttl span {
  border-bottom: 3px solid #291753;
}
.archive_wrap .leftside_btm .link_list {
  margin-top: 5px;
}
.archive_wrap .leftside_btm .link_list li a {
  color: #291753;
}
.archive_wrap .leftside_btm .pagination_wrap {
  margin-top: 24px;
}
@media only screen and (min-width: 600px) {
  .archive_wrap .common_inr {
    justify-content: space-between;
  }
  .article-list {
    justify-content: flex-start;
  }
  .article-list .article-inr {
    width: calc(100% / 2);
    padding: 0 10px;
    margin-bottom: 60px;
  }
  .article-list .thum {
    border-radius: 30px;
    height: 190px;
  }
  .article-list .thum img {
    object-fit: cover;
    height: 190px;
    transition: all 1s;
    -webkit-transition: all 1s;
    width: 100%;
  }
  .article-list a:hover .thum img {
    transform: scale(1.05);
  }
}
@media only screen and (min-width: 820px) {
  .common_mv, .common_top {
    margin-top: 90px;
  }
  .contents {
    padding: 40px 40px 100px;
  }
  .sec-ttl {
    font-size: 24px;
  }
  .sec-box_ttl {
    font-size: 24px;
    width: 200px;
    padding: 10px;
  }
  .inr_txt {
    font-size: 18px;
    color: #000;
  }
  .l-r-contents .sec-ttl {
    width: 50%;
  }
  .l-r-contents .right_cont {
    width: 45%;
  }
  .txt {
    font-size: 18px;
  }
  /**/
  .article-list .article-inr {
    width: calc(100% / 3);
    padding: 0 10px;
  }
  /**/
  .archive_wrap {
    padding: 80px 40px;
  }
  .archive_wrap .txt {
    font-size: 16px;
    margin-top: 27px;
  }
  .archive_wrap .common_inr .leftside {
    width: 280px;
    margin-bottom: 240px;
  }
  .archive_wrap .common_inr .rightside {
    width: calc(100% - 330px);
  }
  .archive_wrap .leftside_btm {
    margin-top: -190px;
  }
}
@media only screen and (min-width: 1360px) {
  .cont_inr {
    max-width: 136rem;
  }
  .sec-ttl {
    font-size: 30px;
  }
  .sec-box_ttl {
    font-size: 30px;
    width: 280px;
  }
  .txt {
    font-size: 22px;
  }
  .archive_wrap {
    padding: 80px 40px;
  }
  .archive_wrap .article-list .article-inr {
    width: calc(100% / 3);
    padding: 0 10px;
  }
  .article-list .article-inr {
    width: calc(100% / 3);
    padding: 0 17.5px;
  }
}
@media only screen and (max-width: 819px) {
  .archive_wrap .common_inr .rightside {
    margin-top: 130px;
  }
  .archive_wrap .article-list {
    justify-content: space-between;
  }
  .archive_wrap .article-list .ttl {
    font-size: 16px;
  }
  .archive_wrap .leftside_btm {
    margin: auto;
  }
  .archive_wrap .tag_list_wrap {
    margin: 10px 0 30px;
  }
  .archive_wrap .tag_list {
    display: flex;
    flex-wrap: wrap;
  }
  .archive_wrap .tag_list li {
    margin: 10px 10px 5px 0;
  }
  .archive_wrap .tag_list li.active a {
    background-color: #291753;
    color: #fff;
  }
  .archive_wrap .tag_list li a {
    font-size: 10px;
    border: 1px solid #291753;
    padding: 5px 12px;
    color: #291753;
    border-radius: 20px;
    line-height: 1;
  }
}
/*breadcrumbs_wrap*/
.breadcrumbs_wrap {
  text-align: left;
  margin-top: 4rem;
  color: #fff;
}
.breadcrumbs_wrap a {
  border-bottom: 1px solid #fff;
  color: #fff;
}
@media only screen and (min-width: 820px) {
  .breadcrumbs_wrap {
    margin-top: 8rem;
  }
}
.cl2, .cl3, .cl4 {
  display: flex;
  flex-wrap: wrap;
}
.cl2 li, .cl3 li, .cl4 li {
  width: 100%;
}
@media only screen and (min-width: 820px) {
  .cl2, .cl3, .cl4 {
    justify-content: space-between;
  }
  .cl2 li {
    width: calc(100% / 2 - 1rem);
  }
  .cl3 li {
    width: calc(100% / 3 - 4rem);
  }
  .cl4 li {
    width: calc(100% / 4 - 1rem);
  }
}
@media only screen and (min-width: 1360px) {
  .cl3 li {
    width: calc(100% / 3 - 4rem);
  }
}
/**/
.page-numbers, .page-numbers.current {
  width: 3.6rem;
  font-size: 1.8rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  transition: all 1s;
  -webkit-transition: all 1s;
  opacity: 0.6;
  color: #291753;
}
.page-numbers.current {
  opacity: 1;
}
.next.page-numbers, .prev.page-numbers {
  font-size: 2.4rem;
  color: #291753;
  border-radius: 100vh;
}
.nav-links {
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
.wp-pagenavi {
  display: flex;
  justify-content: center;
  font-family: "Albert Sans", sans-serif;
}
@media only screen and (min-width: 820px) {
  .wp-pagenavi {
    justify-content: flex-start;
  }
  .next.page-numbers:hover, .prev.page-numbers:hover, .page-numbers:hover {
    background-color: #000;
  }
  .page-numbers.current:hover {
    background-color: #000;
  }
}
/**/
.cvsbtn {
  margin-top: 40px;
  width: 100%;
}
.cvsbtn a {
  text-align: center;
  display: block;
  padding: 10px 10px;
  font-size: 14px;
  line-height: 1;
  position: relative;
  width: 100%;
  border-radius: 30px;
  border: 1px solid #291753;
  color: #291753;
}
@media only screen and (min-width: 820px) {
  .cvsbtn {
    margin-top: 60px;
  }
  .cvsbtn a {
    font-size: 16px;
  }
  .cvsbtn a:hover {
    background-color: #291753;
    color: #fff;
  }
}
@media only screen and (max-width: 819px) {
  .cvsbtn a {
    background-color: #291753;
    color: #fff;
  }
}
.blur {
  animation-name: blurAnime;
  animation-duration: 2s;
  animation-fill-mode: forwards;
}
@keyframes blurAnime {
  from {
    filter: blur(10px);
    transform: scale(1.02);
    opacity: 0;
  }
  to {
    filter: blur(0);
    transform: scale(1);
    opacity: 1;
  }
}
.blurTrigger {
  opacity: 0;
}
.fade {
  opacity: 0;
  visibility: hidden;
  transform: translateY(50px);
  transition: all 1s;
}
.fade.is-show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0px);
}
.fadein {
  animation: fadein 0.8s cubic-bezier(0.33, 1, 0.68, 1) forwards;
}
@keyframes fadein {
  0% {
    opacity: 0;
    transform: translateY(20px);
    filter: blur(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}