@charset "UTF-8";
/*** Break Point ***/
/*** Fonts ***/
/*** Colors ***/
/*** Spaces ***/
/*** break point ***/
/*** clearfix ***/
/*** line-height（上下の余白の削除） ***/
/* --------------------------------------
	Noto Sans JP
-------------------------------------- */
@font-face {
  font-family: "Noto Sans JP Light";
  font-style: normal;
  font-weight: 300;
  src: url("/assets/fonts/NotoSansJP/NotoSansJP-Light.ttf") format("ttf"), url("/assets/fonts/NotoSansJP/NotoSansJP-Light.woff") format("woff"), url("/assets/fonts/NotoSansJP/NotoSansJP-Light.eot") format("eot");
}
@font-face {
  font-family: "Noto Sans JP Regular";
  font-style: normal;
  font-weight: 400;
  src: url("/assets/fonts/NotoSansJP/NotoSansJP-Regular.ttf") format("ttf"), url("/assets/fonts/NotoSansJP/NotoSansJP-Regular.woff") format("woff"), url("/assets/fonts/NotoSansJP/NotoSansJP-Regular.eot") format("eot");
}
@font-face {
  font-family: "Noto Sans JP Medium";
  font-style: normal;
  font-weight: 500;
  src: url("/assets/fonts/NotoSansJP/NotoSansJP-Medium.ttf") format("ttf"), url("/assets/fonts/NotoSansJP/NotoSansJP-Medium.woff") format("woff"), url("/assets/fonts/NotoSansJP/NotoSansJP-Medium.eot") format("eot");
}
@font-face {
  font-family: "Noto Sans JP Bold";
  font-style: normal;
  font-weight: 700;
  src: url("/assets/fonts/NotoSansJP/NotoSansJP-Bold.ttf") format("ttf"), url("/assets/fonts/NotoSansJP/NotoSansJP-Bold.woff") format("woff"), url("/assets/fonts/NotoSansJP/NotoSansJP-Bold.eot") format("eot");
}
@font-face {
  font-family: "Noto Sans JP ExtraBold";
  font-style: normal;
  font-weight: 800;
  src: url("/assets/fonts/NotoSansJP/NotoSansJP-ExtraBold.ttf") format("ttf"), url("/assets/fonts/NotoSansJP/NotoSansJP-ExtraBold.woff") format("woff"), url("/assets/fonts/NotoSansJP/NotoSansJP-ExtraBold.eot") format("eot");
}
:root {
  --logoColor: #083994;
  --primaryColor: #00205B;
  --secondaryColor: #76BCE5;
  --accentColor: #FFFF8F;
  --textColorTyp1: #00205B;
  --textColorTyp2: #fff;
}

html {
  font-size: 16px;
}

/*
body {
  font-family: "Noto Sans JP Regular";
  background: #fff;
  color: #333;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
}
body a {
  text-decoration: none;
  cursor: pointer;
  transition: all 0.3s 0s ease;
}
body a:not(.move, .to_expand):hover {
  text-decoration: underline;
  opacity: 0.8;
}
*/

main,
main li,
main p {
  font-size: 16px;
}

main p {
  margin-bottom: unset;
}

main a {
  color: currentColor;
  text-decoration: none;
}
main a:is(.move, .to_expand):hover {
  text-decoration: none;
}

main :is(p) {
  line-height: 2.125;
  width: 100%;
  display: inline-block;
  letter-spacing: 0.08em;
}
main :is(p)::before, main :is(p)::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
main :is(p)::before {
  margin-top: calc((1 - 2.125) * 0.5em);
}
main :is(p)::after {
  margin-bottom: calc((1 - 2.125) * 0.5em);
}
@media (max-width: 767.89px) {
  main :is(p),
  main li {
    font-size: 0.75rem;
  }
}

main li {
  margin-bottom: 0;
}

picture {
  display: block;
  line-height: 0;
}

img {
  width: 100%;
  height: auto;
}

small {
  font-size: 80%;
}

sup {
  font-size: 70%;
  vertical-align: super;
}


/* -------------------------------
	header / footer
------------------------------- */

/* PC header mega menu */
.mega-area {
  padding-block: 26px 80px;
  width: fit-content;
}

.mega-area-wrapper {
  display: flex;
  justify-content: center;
  flex-direction: column;
  min-width: 540px;
}
.mega-area-wrapper .megadrop-title {
  width: auto;
  font-size: 1.125rem;
  margin-bottom: 2rem;
}
.mega-area-wrapper .mega-list {
  display: flex;
}
.mega-area-wrapper .mega-list .mega-area-inner {
  display: flex;
  flex-direction: column;
  width: 270px;
  border-left: 1px solid rgba(255, 255, 255, 0.3);
  padding: 0 1rem;
}
.mega-area-wrapper .mega-list .mega-area-inner:last-child {
  border-right: 1px solid rgba(255, 255, 255, 0.3);
}
.mega-area-wrapper .mega-list .mega-area-inner a {
  position: relative;
  color: #fff;
  text-decoration: none;
  padding: 1.5rem 0;
}
.mega-area-wrapper .mega-list .mega-area-inner a::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  width: 0.5rem;
  height: 0.5rem;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: translate(0, -50%) rotate(45deg);
}
.mega-area-wrapper .mega-list .mega-area-inner a:hover span {
  text-decoration: underline;
}
.mega-area-wrapper .mega-list .mega-in-list li {
  margin-bottom: 0;
  line-height: normal;
}
.mega-area-wrapper .mega-list .mega-in-list a {
  font-size: 0.875rem;
  display: block;
  padding: 0.3rem 0;
  text-indent: -1.5em;
  padding-left: 1.5em;
}
.mega-area-wrapper .mega-list .mega-in-list a::before {
  content: "ー";
  display: inline;
  margin-right: 0.5em;
}

/* SP header menu */
@media (max-width: 767.89px) {
  .nav-slider,
  .sp-footer {
    position: fixed;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    position: relative;
  }
  .nav-slider ul li,
  .sp-footer ul li {
    margin-bottom: 0;
  }
  .nav-slider .black-box,
  .sp-footer .black-box {
    height: 100%;
    background-color: #000;
    opacity: 0.7;
  }
  .nav-slider .other-link,
  .sp-footer .other-link {
    box-sizing: border-box;
    padding: 15px;
    background-color: #fff;
  }
  .nav-slider .other-link ul li,
  .sp-footer .other-link ul li {
    line-height: 2rem;
  }
  .nav-slider .other-link ul li a,
  .sp-footer .other-link ul li a {
    text-decoration: none;
    color: #333;
  }
  .nav-slider .other-link ul li a::before,
  .sp-footer .other-link ul li a::before {
    font-family: FontAwesome;
    content: "\f138";
  }
  .nav-slider ul,
  .sp-footer ul {
    margin: 0;
  }
  .nav-slider ul.add-border > li:not(.border-off, :last-child),
  .sp-footer ul.add-border > li:not(.border-off, :last-child) {
    position: relative;
  }
  .nav-slider ul.add-border > li:not(.border-off, :last-child)::after,
  .sp-footer ul.add-border > li:not(.border-off, :last-child)::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 0);
    width: calc(100% - 2rem);
    height: 1px;
    background: #cacaca;
  }
  .nav-slider ul.add-border > li.li-menu-on:has(+ li.child-menu[style*="list-item"])::after,
  .sp-footer ul.add-border > li.li-menu-on:has(+ li.child-menu[style*="list-item"])::after {
    display: none;
  }
  .nav-slider .parent-menu,
  .sp-footer .parent-menu {
    background-color: #424851;
    border-bottom: none;
    display: block;
    color: #fff;
    font-size: 0.875rem;
    text-decoration: none;
    position: relative;
    padding: 1rem;
    position: relative;
  }
  .nav-slider .parent-menu-link,
  .sp-footer .parent-menu-link {
    position: relative;
  }
  .nav-slider .parent-menu-link a,
  .sp-footer .parent-menu-link a {
    display: block;
  }
  .nav-slider .parent-menu-link::after,
  .sp-footer .parent-menu-link::after {
    content: "";
    padding-right: 0;
    position: absolute;
    top: 50%;
    right: 2rem;
    width: 0.5rem;
    height: 0.5rem;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: translate(-50%, -50%) rotate(45deg);
  }
  .nav-slider .icon-plus,
  .sp-footer .icon-plus {
    display: block;
    line-height: 1;
    width: 1em;
    height: 1px;
    position: absolute;
    background: #fff;
    top: 50%;
    right: 2rem;
    transform: translateY(-50%) rotate(-90deg);
    transition: transform 0.3s ease;
  }
  .nav-slider .icon-plus::before,
  .sp-footer .icon-plus::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: inherit;
    transform: rotate(90deg);
  }
  .nav-slider .li-menu-on .icon-plus,
  .sp-footer .li-menu-on .icon-plus {
    transform: translateY(-50%);
  }
  .nav-slider .li-menu-on .icon-plus::before,
  .sp-footer .li-menu-on .icon-plus::before {
    content: none;
  }
  .nav-slider .child-menu,
  .sp-footer .child-menu {
    padding-top: 0;
    background-color: #fff;
    display: none;
  }
  .nav-slider .child-menu::after,
  .sp-footer .child-menu::after {
    display: none;
  }
  .nav-slider .child-menu ul,
  .sp-footer .child-menu ul {
    padding: 0 1rem;
  }
  .nav-slider .child-menu ul li,
  .sp-footer .child-menu ul li {
    line-height: 1rem;
    font-size: 0.75rem;
  }
  .nav-slider .child-menu ul li a,
  .sp-footer .child-menu ul li a {
    display: block;
    box-sizing: border-box;
    padding: 1rem;
    text-decoration: none;
    color: #424851;
    position: relative;
  }
  .nav-slider .child-menu ul li a::after,
  .sp-footer .child-menu ul li a::after {
    padding-right: 0;
    content: "";
    position: absolute;
    top: 50%;
    right: 2rem;
    width: 0.5rem;
    height: 0.5rem;
    border-top: 1px solid #424851;
    border-right: 1px solid #424851;
    transform: translate(-50%, -50%) rotate(45deg);
  }
  .nav-slider .child-menu .parent-menu,
  .sp-footer .child-menu .parent-menu {
    background-color: transparent;
    color: #3c3c3c;
    font-weight: normal;
  }
  .nav-slider .child-menu .parent-menu .icon-plus,
  .sp-footer .child-menu .parent-menu .icon-plus {
    background: #3c3c3c;
  }
  .nav-slider .child-menu .child-menu a::before,
  .sp-footer .child-menu .child-menu a::before {
    content: "ー";
    display: inline;
    margin-right: 0.5em;
  }
  .nav-slider .child-menu .child-menu a::after,
  .sp-footer .child-menu .child-menu a::after {
    content: none;
  }

  .nav-slider {
    display: none;
    top: 0%;
    z-index: 90;
    overflow: auto;
    margin-top: 80px;
    position: fixed;
  }
  .nav-slider .parent-menu-link a {
    color: var(--textColorTyp2);
  }
}

/* PC footer menu */
.footer_insta {
  display: flex!important;
  align-items: center;
  justify-content: flex-start;
}
.footer_insta .insta_img {
  width: 35px;
}
.footer_insta .footer_insta_txt {
  margin-left: 10px;
  margin-bottom: 0;
  line-height: normal;
  letter-spacing: normal;
  font-size: 12px;
}
.com-footer {
  padding: 2.5rem 0.875rem;
}
.footer-box {
  height: auto;
  padding: 1.5rem 2.5rem;
}
.footer-box ul li {
  line-height: 1.3;
}
.footer-box ul li a,
.footer-box span {
  letter-spacing: normal;
}
@media (min-width: 768px) {
  .footer-box ul li {
    padding-right: 16px;
    margin-right: 16px;
    position: relative;
  }
  .footer-box ul li::after {
    content: "";
    display: inline-block;
    position: absolute;
    width: 1px;
    height: 100%;
    background-color: #333;
    right: 0;
  }
  .footer-box ul li:last-child::after {
    display: none;
  }
}

/* SP footer menu */
.sp-footer > ul > .li-menu-off:not(:last-child)::after,
.sp-footer > ul >  .li-menu-on:not(:last-child)::after {
  display: none;
}
.sp-footer .parent-menu {
  background-color: #E9EAEC;
  color: var(--textColorTyp1);
}
.sp-footer .parent-menu-link::after {
  border-color: var(--textColorTyp1);
}
.sp-footer .icon-plus {
  background-color: var(--textColorTyp1);
}
.sp-footer .parent-menu-link a {
  color: var(--textColorTyp1);
}


/* -------------------------------
	keyVisual
------------------------------- */
.keyVisual_area .keyVisual {
  position: relative;
}
.keyVisual_area .keyVisual h1 {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
@media (min-width: 768px) {
  .keyVisual_area .keyVisual h1 {
    left: 8.59%;
  }
}
@media (max-width: 767.89px) {
  .keyVisual_area .keyVisual h1 {
    left: 7.33%;
  }
}
@media (min-width: 768px) {
  .keyVisual_area .breadcrumb .container {
    padding-left: 8.59%;
  }
}
@media (max-width: 767.89px) {
  .keyVisual_area .breadcrumb .container {
    padding-left: 7.33%;
  }
}
.keyVisual_area .breadcrumb ol {
  display: flex;
}
.keyVisual_area .breadcrumb ol li {
  display: flex;
  align-items: center;
  line-height: normal;
  letter-spacing: normal;
}
@media (min-width: 768px) {
  .keyVisual_area .breadcrumb ol li {
    padding-top: 1.25rem;
    font-size: 0.75rem;
  }
}
@media (max-width: 767.89px) {
  .keyVisual_area .breadcrumb ol li {
    padding-top: 0.625rem;
    font-size: 0.562rem;
  }
}
.keyVisual_area .breadcrumb ol li:not(:last-of-type) {
  font-family: "Noto Sans JP Light";
}
.keyVisual_area .breadcrumb ol li:not(:last-of-type)::after {
  content: "";
  width: 0.375rem;
  height: 0.375rem;
  margin-right: 0.375rem;
  border-top: 1px solid;
  border-right: 1px solid;
  transform: rotate(45deg);
}
.keyVisual_area .breadcrumb ol li:last-of-type {
  font-family: "Noto Sans JP Bold";
}
.keyVisual_area .breadcrumb.colorset_b {
  background: var(--textColorTyp2);
}
.keyVisual_area .breadcrumb.colorset_b li:not(:last-of-type)::after {
  border-color: #3C3C3C;
}
.keyVisual_area .breadcrumb.colorset_b li a {
  color: #3C3C3C;
}
.keyVisual_area .breadcrumb.colorset_w {
  background: var(--textColorTyp1);
}
.keyVisual_area .breadcrumb.colorset_w li {
  color: #fff;
}
.keyVisual_area .breadcrumb.colorset_w li:not(:last-of-type)::after {
  border-color: #fff;
}

.scroll_wrap {
  position: relative;
}
.scroll_wrap .scrolldown {
  color: #fff;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  text-align: end;
  position: absolute;
}
@media (min-width: 768px) {
  .scroll_wrap .scrolldown {
    height: 10.812rem;
    font-size: 0.687rem;
    right: 2.08%;
    bottom: 2.5rem;
  }
}
@media (max-width: 767.89px) {
  .scroll_wrap .scrolldown {
    height: 5.812rem;
    font-size: clamp(0.5rem, 0.432rem + 0.34vw, 0.688rem);
    right: 2.4%;
    bottom: 1.25rem;
  }
}
.scroll_wrap .scrolldown::after {
  content: "";
  width: 1px;
  background: #fff;
  position: absolute;
  top: 0;
  right: 1.6em;
  opacity: 0;
}
@media (min-width: 768px) {
  .scroll_wrap .scrolldown::after {
    animation: scrollMovePC 1.5s ease-in-out infinite;
  }
}
@media (max-width: 767.89px) {
  .scroll_wrap .scrolldown::after {
    animation: scrollMoveSP 1.5s ease-in-out infinite;
  }
}
@keyframes scrollMovePC {
  0% {
    height: 0;
    top: 0;
    opacity: 0;
  }
  30% {
    height: 115px;
    opacity: 1;
  }
  100% {
    height: 115px;
    top: 63px;
    opacity: 0;
  }
}
@keyframes scrollMoveSP {
  0% {
    height: 0;
    top: 0;
    opacity: 0;
  }
  30% {
    height: 65px;
    opacity: 1;
  }
  100% {
    height: 65px;
    top: 33px;
    opacity: 0;
  }
}

/* -------------------------------
	Container
------------------------------- */
@media (min-width: 768px) {
  section:not(.keyVisual_area) {
    margin-bottom: 6.25rem;
  }
}
@media (max-width: 767.89px) {
  section:not(.keyVisual_area) {
    margin-bottom: 3.75rem;
  }
}
@media (min-width: 768px) {
  section:not(.keyVisual_area).mb120 {
    margin-bottom: 7.5rem;
  }
}
@media (min-width: 768px) {
  section:not(.keyVisual_area).mb150 {
    margin-bottom: 9.375rem;
  }
}

.bg_set_b {
  background: var(--primaryColor);
}
.bg_set_b section {
  margin-bottom: 0;
}

.container_def {
  max-width: min(100% - 1.874rem, 1200px);
  margin-inline: auto;
}

.container_l {
  max-width: min(100% - 1.874rem, 1100px);
  margin-inline: auto;
}

.container_m {
  max-width: min(100% - 1.874rem, 1000px);
  margin-inline: auto;
}

.container_s {
  max-width: min(100% - 1.874rem, 900px);
  margin-inline: auto;
}

.container800 {
  max-width: min(100% - 1.874rem, 800px);
  margin-inline: auto;
}

/* -------------------------------
	Title
------------------------------- */
/* カラー基本（共通タイトル、左横線、パンクズ以外） */
:not(.common_title, .sideline, .breadcrumb).colorset_b {
  color: var(--textColorTyp1);
  border-color: var(--textColorTyp1);
}
:not(.common_title, .sideline, .breadcrumb).colorset_w {
  color: var(--textColorTyp2);
  border-color: var(--textColorTyp2);
}

.common_title {
  width: fit-content;
  position: relative;
}
.common_title span {
  width: fit-content;
  display: block;
  position: relative;
}
.common_title span::before {
  content: "";
  width: 100%;
  border-left: solid 1px;
  border-right: solid 1px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media (min-width: 768px) {
  .common_title span::before {
    height: calc(100% + 1.875rem);
  }
}
@media (max-width: 767.89px) {
  .common_title span::before {
    height: calc(100% + 1.25rem);
  }
}
.common_title span::after {
  content: "";
  height: 100%;
  border-top: solid 1px;
  border-bottom: solid 1px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media (min-width: 768px) {
  .common_title span::after {
    width: calc(100% + 1.875rem);
  }
}
@media (max-width: 767.89px) {
  .common_title span::after {
    width: calc(100% + 1.25rem);
  }
}
.common_title span.no_border::before, .common_title span.no_border::after {
  border-color: transparent !important;
}
.common_title span.no_border_b::before {
  border-right-color: transparent !important;
}
.common_title span.no_border_b::after {
  border-bottom-color: transparent !important;
}
.common_title span.no_border_l::before {
  border-left-color: transparent !important;
}
.common_title span.no_border_r::before {
  border-right-color: transparent !important;
}
.common_title:has([class^=no_border])::before {
  content: "";
  width: 100%;
  height: 100%;
  border: solid 1px;
  position: absolute;
}

[class^=common_title].colorset_b::before {
  border-color: var(--textColorTyp2);
}
[class^=common_title].colorset_b span {
  background-color: var(--textColorTyp2);
  color: var(--textColorTyp1);
}
[class^=common_title].colorset_b span::before, [class^=common_title].colorset_b span::after {
  border-color: var(--textColorTyp2);
}
[class^=common_title].colorset_w::before {
  border-color: var(--textColorTyp1);
}
[class^=common_title].colorset_w span {
  background-color: var(--textColorTyp1);
  color: var(--textColorTyp2);
}
[class^=common_title].colorset_w span::before, [class^=common_title].colorset_w span::after {
  border-color: var(--textColorTyp1);
}
[class^=common_title].transparent span {
  background-color: transparent;
}

h1 span {
  margin-bottom: 1.25rem;
  font-family: "Noto Sans JP Bold";
  line-height: 1;
}
@media (min-width: 768px) {
  h1 span {
    padding: 0.312rem 0.625rem;
  }
}
@media (max-width: 767.89px) {
  h1 span {
    padding: clamp(0.188rem, 0.053rem + 0.67vw, 0.375rem) clamp(0.625rem, 0.178rem + 2.24vw, 1.25rem);
  }
}
h1 .category {
  letter-spacing: 0.1em;
}
@media (min-width: 768px) {
  h1 .category {
    font-size: 0.937rem;
  }
}
@media (max-width: 767.89px) {
  h1 .category {
    font-size: clamp(0.625rem, 0.178rem + 2.24vw, 1.25rem);
  }
}
h1 .main_title {
  letter-spacing: 0.23em;
}
@media (min-width: 768px) {
  h1 .main_title {
    padding-right: 0;
    padding-bottom: 0.624rem;
    font-size: 2.5rem;
  }
}
@media (max-width: 767.89px) {
  h1 .main_title {
    padding-right: clamp(0.313rem, 0.089rem + 1.12vw, 0.625rem);
    padding-bottom: clamp(0.375rem, 0.107rem + 1.34vw, 0.75rem);
    font-size: clamp(1.625rem, 0.462rem + 5.82vw, 3.25rem);
  }
}
h1 .sub_title {
  letter-spacing: 0.15em;
}
@media (min-width: 768px) {
  h1 .sub_title {
    font-size: 1.062rem;
  }
}
@media (max-width: 767.89px) {
  h1 .sub_title {
    font-size: clamp(0.688rem, 0.195rem + 2.46vw, 1.375rem);
  }
}

h2.common_title {
  /* 英語スタイル */
}
h2.common_title:not(.md, .large) {
  font-family: "Noto Sans JP Medium";
  letter-spacing: 0.08em;
}
@media (min-width: 768px) {
  h2.common_title:not(.md, .large) {
    margin-bottom: 2.812rem;
    font-size: 0.812rem;
  }
}
@media (max-width: 767.89px) {
  h2.common_title:not(.md, .large) {
    margin-bottom: 2.312rem;
    font-size: 0.687rem;
  }
}
h2.common_title:not(.md, .large) span {
  padding-bottom: 0.125rem;
}
@media (min-width: 768px) {
  h2.common_title:not(.md, .large) span {
    padding-inline: 0.562rem;
  }
}
@media (max-width: 767.89px) {
  h2.common_title:not(.md, .large) span {
    padding-inline: 0.437rem;
  }
}
h2.common_title.md {
  font-family: "Noto Sans JP Medium";
  letter-spacing: 0.1em;
}
@media (min-width: 768px) {
  h2.common_title.md {
    margin-bottom: 3.125rem;
    font-size: 1.75rem;
  }
}
@media (max-width: 767.89px) {
  h2.common_title.md {
    margin-bottom: 1.875rem;
    font-size: 1.125rem;
  }
}
@media (min-width: 768px) {
  h2.common_title.md span {
    padding-inline: 0.625rem 0.312rem;
    padding-bottom: 0.312rem;
  }
}
@media (max-width: 767.89px) {
  h2.common_title.md span {
    padding-inline: 0.687rem;
  }
}
h2.common_title.md span.en {
  letter-spacing: 0.01em;
}
@media (min-width: 768px) {
  h2.common_title.md span.en {
    padding-inline-end: 0.625rem;
  }
}
h2.common_title.large {
  font-family: "Noto Sans JP Medium";
  letter-spacing: 0.2em;
}
@media (min-width: 768px) {
  h2.common_title.large {
    margin-bottom: 4.375rem;
    font-size: 2.375rem;
  }
}
@media (max-width: 767.89px) {
  h2.common_title.large {
    margin-bottom: 2.937rem;
    font-size: 1.437rem;
  }
}
@media (min-width: 768px) {
  h2.common_title.large span {
    padding-inline: 0.625rem 0.312rem;
    padding-bottom: 0.312rem;
  }
}
@media (max-width: 767.89px) {
  h2.common_title.large span {
    padding-inline: 0.5rem;
    padding-bottom: 0.187rem;
  }
}
h2.common_title.large span.en {
  letter-spacing: 0.01em;
}
@media (min-width: 768px) {
  h2.common_title.large span.en {
    padding-inline-end: 0.625rem;
  }
}
h2.common_title2 {
  font-family: "Noto Sans JP Medium";
  letter-spacing: 0.2em;
  line-height: 1.2;
  text-align: center;
}
@media (min-width: 768px) {
  h2.common_title2 {
    margin-bottom: 2.5rem;
    font-size: 2.25rem;
  }
}
@media (max-width: 767.89px) {
  h2.common_title2 {
    margin-bottom: 1.875rem;
    font-size: 1.437rem;
  }
}
h2.common_title2 span {
  display: block;
}
@media (min-width: 768px) {
  h2.common_title2 span {
    padding-bottom: 0.25rem;
  }
}
@media (max-width: 767.89px) {
  h2.common_title2 span {
    padding-bottom: 0.125rem;
  }
}
h2.center {
  margin-inline: auto;
}

main h3:not(.sub, .with_border) {
  font-family: "Noto Sans JP Medium";
  line-height: 1.7;
  letter-spacing: 0.1em;
  width: 100%;
  display: inline-block;
}
main h3:not(.sub, .with_border)::before,
main h3:not(.sub, .with_border)::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
main h3:not(.sub, .with_border)::before {
  margin-top: calc((1 - 1.7) * 0.5em);
}
main h3:not(.sub, .with_border)::after {
  margin-bottom: calc((1 - 1.7) * 0.5em);
}
@media (min-width: 768px) {
  main h3:not(.sub, .with_border) {
    font-size: 2rem;
    margin-bottom: 3.125rem;
  }
}
@media (max-width: 767.89px) {
  main h3:not(.sub, .with_border) {
    font-size: 1.312rem;
    margin-bottom: 1.875rem;
  }
}
main h3.with_border {
  text-align: center;
  border-top: solid 1px;
  border-bottom: solid 1px;
  font-family: "Noto Sans JP Medium";
  line-height: 1.1;
  letter-spacing: 0.2em;
}
@media (min-width: 768px) {
  main h3.with_border {
    margin-bottom: 2.5rem;
    padding: 0.75rem;
    font-size: 1.375rem;
  }
}
@media (max-width: 767.89px) {
  main h3.with_border {
    margin-bottom: 1.875rem;
    padding: 0.437rem;
  }
}
main h3.sub {
  font-family: "Noto Sans JP Medium";
  letter-spacing: 0.2em;
  line-height: 1.2;
  width: 100%;
  display: inline-block;
}
main h3.sub::before,
main h3.sub::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
main h3.sub::before {
  margin-top: calc((1 - 1.2) * 0.5em);
}
main h3.sub::after {
  margin-bottom: calc((1 - 1.2) * 0.5em);
}
@media (min-width: 768px) {
  main h3.sub {
    margin-bottom: 1.875rem;
    font-size: 1.875rem;
  }
}
@media (max-width: 767.89px) {
  main h3.sub {
    margin-bottom: 0.937rem;
    font-size: 1.437rem;
  }
}
main h3.center {
  text-align: center;
}

/* -------------------------------
	Text
------------------------------- */
@media (min-width: 768px) {
  .head {
    margin-top: 3.75rem;
  }
}
@media (max-width: 767.89px) {
  .head {
    margin-top: 2.937rem;
  }
}

@media (min-width: 768px) {
  .heading {
    font-size: 1.25rem;
    text-align: center;
  }
}
@media (max-width: 767.89px) {
  .heading {
    font-size: 0.875rem;
    text-align: center;
  }
}

.secondary {
  color: var(--secondaryColor);
}

.emphasis {
  color: var(--accentColor);
  font-family: "Noto Sans JP Medium";
}

@media (min-width: 768px) {
  .caption {
    margin-top: 0.812rem;
    font-size: 0.812rem;
  }
}
@media (max-width: 767.89px) {
  .caption {
    margin-top: 0.687rem;
    font-size: 0.625rem;
  }
}
.caption.right {
  text-align: right;
}

.no_break {
  display: inline-block;
}

/* -------------------------------
	Icon
------------------------------- */
.arrow_n {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.arrow_n::after {
  content: "";
  border-bottom: solid 2px;
  border-right: solid 2px;
  transform: skew(45deg);
}
@media (min-width: 768px) {
  .arrow_n::after {
    width: 2.312rem;
    margin-left: 1.25rem;
    aspect-ratio: 38/7;
  }
}
@media (max-width: 767.89px) {
  .arrow_n::after {
    width: 1.687rem;
    margin-left: 0.625rem;
    aspect-ratio: 27/5;
  }
}
.arrow_n.circle {
  position: relative;
}
.arrow_n.circle::before {
  content: "";
  border-radius: 50%;
  aspect-ratio: 1/1;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
}
@media (min-width: 768px) {
  .arrow_n.circle::before {
    width: 5.6%;
    right: 3.12%;
  }
}
@media (max-width: 767.89px) {
  .arrow_n.circle::before {
    width: 10.07%;
    right: 3.88%;
  }
}
.arrow_n.circle::after {
  margin-left: 0;
  position: absolute;
  z-index: 1;
}
@media (min-width: 768px) {
  .arrow_n.circle::after {
    width: 3.04%;
    right: 4.6%;
  }
}
@media (max-width: 767.89px) {
  .arrow_n.circle::after {
    width: 5.76%;
    right: 6.4%;
  }
}
.arrow_n.circle.colorset_w::before {
  background-color: var(--textColorTyp1);
}
.arrow_n.circle.colorset_b::before {
  background-color: var(--textColorTyp2);
}

.circle_num {
  border: solid 1px var(--textColorTyp1);
  color: var(--textColorTyp1);
  border-radius: 50%;
  font-family: "Noto Sans JP Bold";
  letter-spacing: 0;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  aspect-ratio: 1/1;
  position: relative;
}
@media (min-width: 768px) {
  .circle_num {
    width: 68px;
    font-size: 1.75rem;
  }
}
@media (max-width: 767.89px) {
  .circle_num {
    width: 51px;
    font-size: 1.031rem;
  }
}
.circle_num::after {
  content: "";
  border-top: solid 3px var(--textColorTyp1);
  border-left: solid 3px var(--textColorTyp1);
  color: var(--textColorTyp1);
  border-radius: 100% 0 0 0;
  position: absolute;
  top: -2px;
  left: -2px;
}
@media (min-width: 768px) {
  .circle_num::after {
    width: 34px;
    height: 34px;
  }
}
@media (max-width: 767.89px) {
  .circle_num::after {
    width: 25.5px;
    height: 25.5px;
  }
}

/* slick */
.slider {
  display: none;
}
.slider.slick-initialized {
  display: block;
}

.prev_arrow,
.next_arrow {
  max-width: 84px;
  aspect-ratio: 1/1;
  background: var(--textColorTyp1);
  border-radius: 50%;
  position: absolute;
  z-index: 1;
  cursor: pointer;
}
@media (min-width: 768px) {
  .prev_arrow,
  .next_arrow {
    width: 7%;
  }
}
@media (max-width: 767.89px) {
  .prev_arrow,
  .next_arrow {
    width: 2.625rem;
  }
}
.prev_arrow::after,
.next_arrow::after {
  content: "";
  border-bottom: solid 1px var(--textColorTyp2);
  border-right: solid 1px var(--textColorTyp2);
  transform: skew(45deg);
  position: absolute;
  top: 45%;
  z-index: 1;
}
@media (min-width: 768px) {
  .prev_arrow::after,
  .next_arrow::after {
    width: 51.19%;
    left: 20%;
    aspect-ratio: 38/7;
  }
}
@media (max-width: 767.89px) {
  .prev_arrow::after,
  .next_arrow::after {
    width: 1.687rem;
    left: 12%;
    aspect-ratio: 27/5;
  }
}
.prev_arrow:hover,
.next_arrow:hover {
  text-decoration: underline;
  opacity: 0.8;
}

.prev_arrow {
  transform: scaleX(-1);
  bottom: 0;
}
@media (min-width: 768px) {
  .prev_arrow {
    left: 42.5%;
  }
}
@media (max-width: 767.89px) {
  .prev_arrow {
    left: calc(50% - 3.25rem);
  }
}

.next_arrow {
  bottom: 0;
}
@media (min-width: 768px) {
  .next_arrow {
    right: 42.5%;
  }
}
@media (max-width: 767.89px) {
  .next_arrow {
    right: calc(50% - 3.25rem);
  }
}

/* iZiModal */
.iziModal .close_btn {
  background-color: var(--primaryColor);
  border-radius: 50%;
  border: none;
  overflow: hidden;
  font-size: 0;
  line-height: 0;
  position: relative;
  display: block;
  transition: opacity ease 300ms;
  cursor: pointer;
}
@media (min-width: 768px) {
  .iziModal .close_btn {
    width: 2.812rem;
    height: 2.812rem;
    margin: 1.25rem 1.25rem 1.25rem auto;
  }
}
@media (max-width: 767.89px) {
  .iziModal .close_btn {
    width: 2.187rem;
    height: 2.187rem;
    margin: 0.625rem 0.625rem 0.625rem auto;
  }
}
.iziModal .close_btn:hover {
  opacity: 0.7;
}
.iziModal .close_btn::before, .iziModal .close_btn::after {
  content: "";
  width: 70%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
}
.iziModal .close_btn::after {
  transform: translate(-50%, -50%) rotate(135deg);
}

/* -------------------------------
	Layout
------------------------------- */
.sideline.colorset_b {
  border-left: solid 5px var(--textColorTyp1);
}
.sideline.colorset_w {
  border-left: solid 5px var(--textColorTyp2);
}

@media (min-width: 768px) {
  li.sideline {
    padding-left: 1.875rem;
  }
}
@media (max-width: 767.89px) {
  li.sideline {
    padding-left: 0.937rem;
    font-size: 0.75rem;
  }
}
@media (min-width: 768px) {
  li.sideline:not(:last-of-type) {
    margin-bottom: 3.125rem;
  }
}
@media (max-width: 767.89px) {
  li.sideline:not(:last-of-type) {
    margin-bottom: 1.875rem;
  }
}

:is(.article_wrap, .information_wrap) .row {
  position: relative;
}
@media (min-width: 768px) {
  :is(.article_wrap, .information_wrap) .row {
    margin-bottom: 3.125rem;
    padding-bottom: 3.125rem;
    border-bottom: solid 1px #CACACA;
  }
}
@media (max-width: 767.89px) {
  :is(.article_wrap, .information_wrap) .row {
    margin-bottom: 1.562rem;
    padding-bottom: 1.562rem;
    border-bottom: solid 1px #CACACA;
  }
}
:is(.article_wrap, .information_wrap) .content {
  display: flex;
}
@media (max-width: 767.89px) {
  :is(.article_wrap, .information_wrap) .content {
    flex-direction: column;
  }
}
@media (min-width: 768px) {
  :is(.article_wrap, .information_wrap) .content .txt_block60,
  :is(.article_wrap, .information_wrap) .content .txt_block50 {
    flex: 1;
  }
}
@media (min-width: 768px) {
  :is(.article_wrap, .information_wrap) .content .img_block40 {
    flex-basis: 35.5%;
  }
}
@media (min-width: 768px) {
  :is(.article_wrap, .information_wrap) .content .img_block50 {
    flex-basis: 50%;
  }
}
:is(.article_wrap, .information_wrap) .content .content_title {
  font-family: "Noto Sans JP Bold";
}
@media (min-width: 768px) {
  :is(.article_wrap, .information_wrap) .content .content_title {
    margin: 0.937rem 0 2.062rem;
    font-size: 1.25rem;
  }
}
@media (max-width: 767.89px) {
  :is(.article_wrap, .information_wrap) .content .content_title {
    margin: 0.5rem 0 1.062rem;
    font-size: 0.875rem;
  }
}
@media (min-width: 768px) {
  :is(.article_wrap, .information_wrap) .content .supplement {
    margin-top: 3.125rem;
    font-size: 0.875rem;
  }
}
@media (max-width: 767.89px) {
  :is(.article_wrap, .information_wrap) .content .supplement {
    margin-top: 1.562rem;
    font-size: 0.687rem;
  }
}
:is(.article_wrap, .information_wrap) iframe {
  width: 100%;
  height: auto;
}
@media (min-width: 768px) {
  :is(.article_wrap, .information_wrap) iframe {
    aspect-ratio: 500/370;
  }
}
@media (max-width: 767.89px) {
  :is(.article_wrap, .information_wrap) iframe {
    aspect-ratio: 553/370;
  }
}

@media (max-width: 767.89px) {
  .article_wrap {
    padding-inline: 0.781rem;
  }
}
@media (min-width: 768px) {
  .article_wrap .content {
    column-gap: 3.125rem;
  }
}
@media (max-width: 767.89px) {
  .article_wrap .content {
    row-gap: 1.875rem;
  }
}
.article_wrap .sideline {
  padding-left: 1.875rem;
}

@media (max-width: 767.89px) {
  .information_wrap {
    padding-inline: 1.562rem;
  }
}
@media (min-width: 768px) {
  .information_wrap .content {
    column-gap: 1.875rem;
  }
}
@media (max-width: 767.89px) {
  .information_wrap .content {
    row-gap: 1.875rem;
  }
}
@media (min-width: 768px) {
  .information_wrap .sideline {
    padding-left: 1.875rem;
  }
}
@media (max-width: 767.89px) {
  .information_wrap .sideline {
    padding-left: 0.937rem;
  }
}
@media (min-width: 768px) {
  .information_wrap .map_btn {
    position: absolute;
    right: 0;
  }
}
@media (max-width: 767.89px) {
  .information_wrap .map_btn {
    text-align: right;
  }
}
.information_wrap .map_btn a {
  padding-bottom: 0.312rem;
  border-bottom: solid 1px;
  font-family: "Noto Sans JP Bold";
}
@media (min-width: 768px) {
  .information_wrap .map_btn a {
    font-size: 0.812rem;
  }
}
@media (max-width: 767.89px) {
  .information_wrap .map_btn a {
    font-size: 0.687rem;
  }
}
.information_wrap .map_btn a:hover {
  text-decoration: none;
}

.illustration_wrap {
  border: 1px solid;
}
@media (min-width: 768px) {
  .illustration_wrap {
    margin-top: 4.375rem;
    padding: 1.875rem;
  }
}
@media (max-width: 767.89px) {
  .illustration_wrap {
    margin-top: 3.125rem;
    padding: 1.562rem 0.625rem;
  }
}
.illustration_wrap .ttl {
  width: fit-content;
  margin-inline: auto;
  text-align: center;
  line-height: 1;
  font-family: "Noto Sans JP Medium";
}
@media (min-width: 768px) {
  .illustration_wrap .ttl {
    margin-top: -2.5rem;
    margin-bottom: 1.25rem;
    padding-inline: 1.5rem;
    font-size: 1.25rem;
  }
}
@media (max-width: 767.89px) {
  .illustration_wrap .ttl {
    margin-top: -2.062rem;
    margin-bottom: 1.031rem;
    padding-inline: 1.25rem;
  }
}
.illustration_wrap.colorset_b {
  border-color: var(--textColorTyp1);
}
.illustration_wrap.colorset_b .ttl {
  color: var(--textColorTyp1);
  background-color: var(--textColorTyp2);
}
.illustration_wrap.colorset_w {
  border-color: var(--textColorTyp2);
}
.illustration_wrap.colorset_w .ttl {
  color: var(--textColorTyp2);
  background-color: var(--textColorTyp1);
}

@media (min-width: 768px) {
  .menu_card_list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    justify-content: center;
    gap: 1.875rem 1rem;
  }
}
@media (max-width: 767.89px) {
  .menu_card_list {
    display: grid;
    justify-content: center;
    row-gap: 1.562rem;
  }
}

.cat_name_wrap .cat_name {
  border-bottom: solid 1px;
  line-height: 1;
  font-family: "Noto Sans JP Medium";
}
@media (min-width: 768px) {
  .cat_name_wrap .cat_name {
    padding: 0.875rem 1.25rem 0.75rem 1.25rem;
  }
}
@media (max-width: 767.89px) {
  .cat_name_wrap .cat_name {
    padding: 0.75rem 0.625rem 0.625rem 0.625rem;
    font-size: 0.875rem;
  }
}
@media (min-width: 768px) {
  .cat_name_wrap .cat_name.pt_wide {
    padding: 0.875rem 1.25rem 0.875rem 0.625rem;
  }
}
@media (max-width: 767.89px) {
  .cat_name_wrap .cat_name.pt_wide {
    padding: 1.25rem 0.625rem 0.625rem 0.625rem;
  }
}
.cat_name_wrap .cat_name.no_border {
  border-bottom: none;
}
.cat_name_wrap .cat_name.colorset_w:not(.transparent) {
  background-color: var(--primaryColor);
  border-color: var(--primaryColor);
}
.cat_name_wrap .cat_name.center {
  text-align: center;
}
@media (min-width: 768px) {
  .cat_name_wrap .cat_name.center span {
    padding-left: 3.562rem;
  }
}
@media (max-width: 767.89px) {
  .cat_name_wrap .cat_name.center span {
    padding-left: 2.312rem;
  }
}
.cat_name_wrap .cat_name span {
  flex: 1;
}

@media (min-width: 768px) {
  .foot_menu_area:not(.recruit) .menu_card_list {
    grid-template-columns: repeat(auto-fit, minmax(49.17%, 590px));
  }
}
@media (max-width: 767.89px) {
  .foot_menu_area:not(.recruit) .menu_card_list {
    grid-template-columns: minmax(69.33%, 260px);
    row-gap: 1.875rem;
  }
}
@media (min-width: 768px) {
  .foot_menu_area.recruit .menu_card_list {
    grid-template-columns: repeat(auto-fit, minmax(49.17%, 590px));
  }
}
@media (max-width: 767.89px) {
  .foot_menu_area.recruit .menu_card_list {
    grid-template-columns: 1fr;
    row-gap: 1.875rem;
  }
}

.col_list {
  display: flex;
  gap: 0.937rem;
}
@media (min-width: 768px) {
  .col_list {
    padding-inline: 1.25rem;
    justify-content: center;
    flex-wrap: wrap;
  }
}
@media (max-width: 767.89px) {
  .col_list {
    padding-inline: 0.312rem;
    flex-direction: column;
  }
}
@media (min-width: 768px) {
  .col_list.col1 li {
    flex-basis: 100%;
  }
}
@media (min-width: 768px) {
  .col_list.col2 li {
    flex-basis: calc(50% - 0.468rem);
  }
}
@media (min-width: 768px) {
  .col_list.col3 li {
    flex-basis: calc(33.3333333333% - 0.625rem);
  }
}
.col_list li {
  border: solid 1px #CACACA;
  border-radius: 1.25rem;
  background-color: #fff;
}
@media (min-width: 768px) {
  .col_list li {
    padding: 1.875rem;
  }
}
@media (max-width: 767.89px) {
  .col_list li {
    padding: 0.937rem;
  }
}
.col_list .ttl {
  padding-bottom: 0.25rem;
  font-family: "Noto Sans JP Medium";
  color: #fff;
  background-color: #848484;
  text-align: center;
  line-height: normal;
  letter-spacing: normal;
}
@media (min-width: 768px) {
  .col_list .ttl {
    width: calc(100% + 3.75rem);
    margin-inline-start: -1.875rem;
    margin-bottom: 1.875rem;
    font-size: 1.562rem;
  }
}
@media (max-width: 767.89px) {
  .col_list .ttl {
    width: calc(100% + 1.874rem);
    margin-inline-start: -0.937rem;
    margin-bottom: 0.937rem;
    font-size: 1.125rem;
  }
}
.col_list p {
  line-height: 2;
  width: 100%;
  display: inline-block;
}
.col_list p::before, .col_list p::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.col_list p::before {
  margin-top: calc((1 - 2) * 0.5em);
}
.col_list p::after {
  margin-bottom: calc((1 - 2) * 0.5em);
}

/* -------------------------------
	Animation
------------------------------- */
.to_expand picture {
  overflow: hidden;
}
.to_expand picture img {
  width: 100%;
  transition: all 0.3s 0s ease;
  -webkit-backface-visibility: hidden;
}
.to_expand:hover img {
  transform: scale(1.05);
}

.move:hover .arrow_n::after {
  animation-name: fadeLeftAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes fadeLeftAnime {
  from {
    opacity: 0;
    transform: skew(45deg) translateX(-20px);
  }
  to {
    opacity: 1;
    transform: skew(45deg) translateX(0);
  }
}
/* -------------------------------
	Helper class
------------------------------- */
/* Break */
@media (max-width: 767.89px) {
  .pc_only {
    display: none;
  }
}

@media (min-width: 768px) {
  .sp_only {
    display: none;
  }
}/*# sourceMappingURL=style.css.map */


