@charset "UTF-8";
/* ==========================================================================
   reset
========================================================================== */
/*! minireset.css v0.0.2 | MIT License | github.com/jgthms/minireset.css */
html, body, p, ol, ul, li, dl, dt, dd, blockquote, figure, fieldset, legend, textarea, pre, iframe, hr, h1, h2, h3, h4, h5, h6 {
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
  line-height: 1;
}

ul {
  list-style: none;
}

button, input, select, textarea {
  margin: 0;
  line-height: 1;
}

html {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  font-size: 62.5%;
}

* {
  -webkit-box-sizing: inherit;
          box-sizing: inherit;
}
*:before, *:after {
  -webkit-box-sizing: inherit;
          box-sizing: inherit;
}

img, embed, object, audio, video {
  height: auto;
  max-width: 100%;
}

iframe {
  border: 0;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

td, th {
  padding: 0;
  text-align: left;
  line-height: 1;
}

::-moz-selection {
  background: #F8CAC3;
}

::-moz-selection, ::selection {
  background: #F8CAC3;
}

/*webfont smooth fix with cssua.js
©https://gist.github.com/dalethedeveloper/1846552
*/
.ua-firefox.ua-desktop p, .ua-edge.ua-desktop p, .ua-ie.ua-desktop p, .ua-firefox.ua-desktop [class*=text], .ua-edge.ua-desktop [class*=text], .ua-ie.ua-desktop [class*=text], .ua-firefox.ua-desktop [class*=title], .ua-edge.ua-desktop [class*=title], .ua-ie.ua-desktop [class*=title] {
  -webkit-transform: rotate(0.001deg);
          transform: rotate(0.001deg);
}

/* © https://gist.github.com/larrybotha/7881691 */
.lt-ie10 img.img-responsive[src*=".svg"] {
  width: 100%;
}

/*IE9 svg fix*/
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  img.img-responsive[src*=".svg"] {
    width: 100%;
  }
  /*IE10+ svg fix*/
}
body {
  font-family: YakuHanJP_Noto, "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 16px;
  line-height: 1.75;
  color: #212121;
  background-color: #F3EDEB;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
   -ms-text-size-adjust: 100%;
       text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
body.active {
  height: 100%;
  overflow: hidden;
}

#wrapper {
  position: relative;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
}
#wrapper.wrapper-off {
  overflow: inherit !important;
}

img {
  vertical-align: bottom;
}

a {
  outline: none;
  color: #212121;
  text-decoration: none;
}
a:visited, a:hover, a:active {
  outline: none;
  text-decoration: none;
}
a:hover, a:active, a.active .active a {
  text-decoration: none;
}

@media only screen and (max-width: 768px) {
  /* Small Devices, Tablets */
  body {
    min-width: inherit;
  }
}
/* ==========================================================================
  LAYOUT
========================================================================== */
/*-------------
	header
---------------*/
.header {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 999;
  width: 100%;
  height: 90px;
}
.header.filter::before {
  position: absolute;
  content: "";
  top: 0;
  left: 5px;
  width: calc(100% - 5px);
  height: 90px;
  background: transparent;
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  -webkit-transition: 0.3s cubic-bezier(0.7, 0, 0.3, 1);
  transition: 0.3s cubic-bezier(0.7, 0, 0.3, 1);
}
.header::after {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 5px;
  height: 100vh;
  background-color: #BC0312;
}

.header-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin: 0 auto;
  width: calc(100% - 120px);
  min-height: 90px;
  position: relative;
  z-index: 1;
}

.header-logo {
  width: 100%;
  max-width: 318px;
}
.header-logo .header-logo-wh {
  display: none;
}
.header-logo a {
  display: block;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.header-logo a:hover {
  opacity: 0.7;
  text-decoration: none;
}

.header-menu {
  position: fixed;
  top: 0;
  right: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 999;
}

.header-btn {
  -webkit-transition: 0.35s ease-in-out;
  transition: 0.35s ease-in-out;
}
.header-btn a {
  position: relative;
  width: 100px;
  height: 90px;
  padding-top: 32px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  line-height: 1;
  font-weight: 500;
}
.header-btn a .icon {
  position: absolute;
  top: 0;
  padding: 14px 0;
}
.header-btn a:hover {
  opacity: 0.7;
}
.header-btn.-btn01 a {
  color: #fff;
  background-color: #BC0312;
}
.header-btn.-btn01 a .icon-01-wh {
  display: block;
}
.header-btn.-btn01 a .icon-01-r {
  display: none;
}
.header-btn.-btn02 a {
  background-color: #E70012;
  color: #fff;
}
.header-btn.-btn03 a {
  background-color: #E83928;
  color: #fff;
}

.icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  fill: currentColor;
  overflow: hidden;
}

/* nav-toggle */
#nav-toggle {
  position: fixed;
  top: 0;
  right: 0;
  display: block;
  width: 60px;
  height: 90px;
  cursor: pointer;
  z-index: 101;
  padding: 10px 15px;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  background-color: #212121;
}

#nav-toggle div {
  position: relative;
}

#nav-toggle span {
  display: block;
  position: absolute;
  height: 2px;
  width: 100%;
  background: #fff;
  left: 0;
  -webkit-transition: 0.35s ease-in-out;
  transition: 0.35s ease-in-out;
}

#nav-toggle span:nth-child(1) {
  top: 24px;
}

#nav-toggle span:nth-child(2) {
  top: 31px;
}

#nav-toggle span:nth-child(3) {
  top: 38px;
}

/* #nav-toggle 切り替えアニメーション */
#nav-toggle.on span:nth-child(1) {
  top: 31px;
  -webkit-transform: rotate(30deg);
  transform: rotate(30deg);
}

#nav-toggle.on span:nth-child(2) {
  width: 0;
  left: 50%;
}

#nav-toggle.on span:nth-child(3) {
  top: 31px;
  -webkit-transform: rotate(-30deg);
  transform: rotate(-30deg);
}

/* drawer */
.drawer-container {
  visibility: hidden;
  position: relative;
  top: 0;
  right: 0;
  opacity: 0;
  -webkit-transition: 0.5s ease-in-out;
  transition: 0.5s ease-in-out;
}
.drawer-container::before {
  position: absolute;
  content: "";
  top: -90px;
  left: 0;
  width: 100%;
  height: calc(100% + 90px);
  background-color: #BC0312;
}
.drawer-container .col-wrap {
  padding-top: 60px;
}
.drawer-container .a-loop {
  z-index: 0;
  opacity: 0.5;
}

/* drawer open */
#wrapper.open .header {
  background-color: #BC0312;
  height: 100%;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
#wrapper.open .header::-webkit-scrollbar {
  display: none;
}
#wrapper.open .header-logo {
  position: relative;
}
#wrapper.open .header-logo .header-logo-r {
  display: none;
}
#wrapper.open .header-logo .header-logo-wh {
  display: block;
}
#wrapper.open .header-menu .header-btn.-btn01 a {
  background-color: #fff;
  color: #BC0312;
  /*.icon {
  fill: $color-r3;
  }*/
}
#wrapper.open .header-menu .header-btn.-btn01 a .icon-01-wh {
  display: none;
}
#wrapper.open .header-menu .header-btn.-btn01 a .icon-01-r {
  display: block;
}
#wrapper.open .drawer-container {
  visibility: visible;
  opacity: 1;
  min-height: 678px;
  -webkit-transition: 0.5s ease-in-out;
  transition: 0.5s ease-in-out;
}
#wrapper.open .drawer-inner {
  margin: 30px auto 30px;
}

/* tab */
.tab-wrap {
  width: 100%;
  height: 428px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin: 20px auto 60px;
  position: relative;
}
.tab-wrap-title {
  font-size: 2rem;
  font-weight: bold;
  color: #fff;
}

.tab-label {
  margin-bottom: 25px;
  padding: 1em 0;
  width: clamp(200px, 21vw, 260px);
  font-size: min(2vw, 2rem);
  font-weight: bold;
  line-height: 1.1;
  text-align: center;
  background-color: #E2CECF;
  color: #7D7575;
  -webkit-box-ordinal-group: 0;
      -ms-flex-order: -1;
          order: -1;
  position: relative;
  z-index: 1;
  cursor: pointer;
}

.tab-content {
  display: none;
}

.tab-content .footer-only {
  display: none;
}

/* アクティブなタブ */
.tab-switch:checked + .tab-label {
  background-color: #FFD83D;
  color: #212121;
}

.tab-switch:checked + .tab-label + .tab-content {
  display: block;
  position: absolute;
  top: -50px;
  right: 0;
  height: 100%;
  width: calc(100% - clamp(220px, 24vw, 320px));
}

/* ラジオボタン非表示 */
.tab-switch {
  display: none;
}

.drawer-nav02 {
  position: absolute;
  right: 0;
  bottom: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.drawer-nav02 li {
  position: relative;
  font-size: clamp(1.2rem, 1.4vw, 1.4rem);
  line-height: 1.35;
}
.drawer-nav02 li a {
  padding: 0 1em;
  color: #fff;
}
.drawer-nav02 li::after {
  position: absolute;
  content: "|";
  top: 0;
  left: 0;
  color: #fff;
}
.drawer-nav02 li:first-child a {
  padding-left: 0;
}
.drawer-nav02 li:first-child::after {
  content: "";
}

/* === topic-path  ======================== */
.topic-path {
  position: relative;
  top: min(15vw, 200px);
  display: block;
  width: 100%;
  margin: 0 auto;
  padding: 15px 0;
  text-align: right;
  font-size: 1.4rem;
  z-index: 1;
}
.topic-path ul {
  width: 100%;
  margin: 0 auto;
  padding-right: 60px;
}
.topic-path ul li {
  display: inline;
  list-style: none;
}
.topic-path ul li:after {
  display: inline-block;
  content: ">";
  margin-right: 0.5em;
  margin-left: 0.5em;
}
.topic-path ul li:last-child:after {
  display: none;
}
.topic-path ul li a {
  color: #E70012;
  text-decoration: underline;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.topic-path ul li a:hover {
  text-decoration: none;
}

/* === g-nav ======================== */
.g-nav01 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr clamp(20px, 3vw, 56px) 1fr clamp(20px, 3vw, 56px) 1fr clamp(20px, 3vw, 56px) 1fr;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(20px, 3vw, 56px);
}

.g-nav02 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr clamp(20px, 4vw, 80px) 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 4vw, 80px);
  margin-left: clamp(20px, 10vw, 210px);
}

.g-nav03 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr clamp(20px, 4vw, 80px) 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 4vw, 80px);
  margin-left: clamp(20px, 10vw, 210px);
}

/* nav-list */
.nav-list li dt {
  position: relative;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.28;
  color: #FFD83D;
  padding-bottom: 10px;
  height: min(4vw, 35px);
  border-bottom: solid 1px #fff;
}
.nav-list li dt.nav01-head {
  font-size: clamp(1.3rem, 1.3vw, 1.6rem);
}
.nav-list li dt.nav02-head {
  font-size: clamp(1.7rem, 1.74vw, 2.4rem);
}
.nav-list li dt.nav03-head {
  font-size: clamp(1.7rem, 1.74vw, 2.4rem);
}
.nav-list li dt a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  color: #FFD83D;
  line-height: 1.1;
  z-index: 1;
}
.nav-list li dt a .icon-next {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 18px;
}
.nav-list li dt a .icon-next::before {
  position: absolute;
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background-color: #fff;
}
.nav-list li dt a .icon-next::after {
  position: absolute;
  content: "";
  width: 6px;
  height: 8px;
  background: URL("../images/base/ico_mark_red.svg");
  background-size: contain;
}
.nav-list li dd {
  margin-top: 20px;
  font-size: clamp(1.2rem, 1.2vw, 1.4rem);
  line-height: 1.28;
}
.nav-list li dd ul li {
  margin-bottom: 10px;
}
.nav-list li dd ul li a {
  color: #fff;
}
.nav-list li dd ul li .icon-blank {
  position: relative;
}
.nav-list li dd ul li .icon-blank::before {
  position: absolute;
  content: "";
  top: 50%;
  left: 5px;
  width: 13px;
  height: 13px;
  background: url(../images/base/ico_blank_wh.svg) no-repeat;
  background-size: contain;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

/*-------------
	footer
---------------*/
.footer {
  margin-top: 0;
  position: relative;
  background-color: #BC0312;
}
.footer .col-wrap {
  padding-top: 65px;
  padding-bottom: 20px;
}
.footer a {
  display: block;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.footer a:hover {
  opacity: 0.7;
  text-decoration: none;
}

.footer-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.footer-logo {
  width: min(30vw, 478px);
}

.footer-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.footer-info-text {
  margin-left: min(4vw, 50px);
  font-size: clamp(1.2rem, 1.1vw, 1.6rem);
  line-height: 1.5625;
  letter-spacing: 0.1px;
  color: #fff;
}
.footer-info a {
  display: inline-block;
  color: #fff;
}

.footer-sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: min(1vw, 10px);
     -moz-column-gap: min(1vw, 10px);
          column-gap: min(1vw, 10px);
}
.footer-sns-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: clamp(1.2rem, 1.19vw, 1.6rem);
  color: #fff;
}
.footer-sns-title::after {
  position: relative;
  content: "";
  display: inline-block;
  left: 10px;
  width: min(3vw, 59px);
  height: 1px;
  background-color: #fff;
}
.footer-sns-list {
  margin-left: min(1vw, 15px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
}

.footer-body {
  margin: 50px auto 40px;
  padding: 30px min(4vw, 60px);
}

.footer-body .g-nav01 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr min(3vw, 50px) 1fr min(3vw, 50px) 1fr min(3vw, 50px) 1fr min(3vw, 50px) 1fr;
  grid-template-columns: repeat(5, 1fr);
  gap: 70px min(3vw, 50px);
}

.footer-bottom {
  position: relative;
  padding-bottom: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.footer-nav02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-right: clamp(10px, 1.5vw, 20px);
}
.footer-nav02 li {
  position: relative;
  font-size: clamp(1.2rem, 1.05vw, 1.4rem);
  line-height: 1.35;
}
.footer-nav02 li a {
  padding: 0 clamp(10px, 1.5vw, 20px);
  color: #E6E6E6;
}
.footer-nav02 li:first-child a {
  padding-left: 0;
}
.footer-nav02 li::before {
  position: absolute;
  content: "|";
  top: 0;
  right: 0;
  color: #E6E6E6;
}

.footer-mark {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: absolute;
  right: 60px;
  bottom: 90px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 15px;
     -moz-column-gap: 15px;
          column-gap: 15px;
}
.footer-mark img {
  width: 95px;
  height: 35px;
}
.footer-mark p {
  font-size: clamp(1.2rem, 1.05vw, 1.4rem);
  color: #E6E6E6;
}

.footer-copy {
  padding-top: 20px;
  font-size: 1.4rem;
  text-align: center;
  color: #E6E6E6;
  border-top: solid 1px #fff;
}

/* pagetop */
.to-pagetop {
  position: absolute;
  bottom: 190px;
  right: 60px;
  z-index: 10;
  /* a:hover{
  -webkit-transition: .2s;
  transition: .2s;  
   opacity: 0.7;
   }*/
}
.to-pagetop .-circle {
  width: 160px;
  height: 160px;
}
.to-pagetop .-arrow {
  position: absolute;
  z-index: 2;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 22px;
  height: 28px;
}

.footer-link {
  background-color: #A4000D;
}
.footer-link .col-wrap {
  padding: 0 60px;
}
.footer-link-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 20px min(4vw, 60px);
}
.footer-link-title {
  margin-right: 28px;
  margin-top: 5px;
  font-size: clamp(1.2rem, 1.05vw, 1.4rem);
  color: #fff;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.footer-link-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: clamp(9px, 1.49vw, 19px);
}
.footer-link-list li {
  display: block;
  _width: clamp(79px, 10vw, 106px);
  width: clamp(79px, 5vw, 100px);
}
.footer-link-list li img {
  width: 100%;
}

/* ==========================================================================
   parts
========================================================================== */
/*section*/
/*.section {
	clear:both;
	position:relative;
	z-index:10;
	overflow:hidden;
	padding: 80px 0;
}*/
.col-wrap {
  max-width: 1366px;
  height: 100%;
  margin: 0 auto;
  padding: 0 63px;
  position: relative;
}
@media (min-width: 769px) and (max-width: 1060px) {
  .col-wrap {
    max-width: 1060px;
    padding: 0 30px;
  }
}

.col-inner {
  display: block;
  width: 100%;
  max-width: 1126px;
  margin: 0 auto;
  padding: 0 63px;
}
@media (min-width: 769px) and (max-width: 1060px) {
  .col-inner {
    max-width: 1000px;
    padding: 0 30px;
  }
}

.post-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.main {
  width: 100%;
}

.side {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 220px;
          flex: 0 0 220px;
  margin-left: 70px;
}

.side-item-title {
  position: relative;
  padding: 10px 10px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 2rem;
  border-bottom: solid 1px #212121;
}
.side-item-list {
  margin-top: 15px;
}
.side-item-list li a {
  display: block;
  padding: 10px 10px;
}

/*list*/
/*
.notice-list {
  li{
	margin-left: 1em;
	margin-bottom: 5px;
	text-indent: -1em;
  text-align: left!important;
  font-size: 1.4rem;
  color: #5C5C5C;  
  }
}
*/
.m-indent-list {
  margin-top: 10px;
  line-height: 1.85;
}
.m-indent-list li {
  position: relative;
  margin-left: 1em;
  text-indent: -1em;
  text-align: left;
}

.indent-list li {
  margin-top: 5px;
  margin-left: 2.5em;
  margin-bottom: 5px;
  text-indent: -2.5em;
  text-align: left !important;
}

.normal-list {
  margin-top: 5px;
}
.normal-list li {
  position: relative;
  margin-top: 2px;
  margin-bottom: 2px;
  margin-left: 1em;
  text-indent: -1em;
  text-align: left;
}
.normal-list li::before {
  position: relative;
  content: "・";
  margin-right: 0.5em;
}

/*
.m-caption{
	font-size: 1.5rem;
}
.m-caution{
	margin-top: 5px;
	font-size: 1.2rem;
}
*/
/* icon付きボタンスタイル（リスト） ======================== */
.m-icon-link-list {
  display: -ms-grid;
  display: grid;
  justify-items: center;
  -ms-grid-columns: 1fr min(6vw, 80px) 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 25px min(6vw, 80px);
  margin: 30px auto 100px;
}
.m-icon-link-list.-list3 {
  -ms-grid-columns: 1fr min(3vw, 35px) 1fr min(3vw, 35px) 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 25px min(3vw, 35px);
}
.m-icon-link-list.-list3 .m-icon-link {
  max-width: 310px;
}
.m-icon-link-list.-list3 .m-icon-link a {
  padding: 21px 35px;
  font-size: min(1.6rem, 3vw, 1.6rem);
}

.m-icon-link {
  position: relative;
  width: 100%;
  max-width: 460px;
}
.m-icon-link a {
  display: block;
  padding: 18px 35px;
  font-size: clamp(1.5rem, 1.8vw, 2rem);
  font-weight: bold;
  color: #fff !important;
  background-color: #BC0312;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.m-icon-link a::before {
  position: absolute;
  content: "";
  top: 50%;
  right: clamp(10px, 4vw, 35px);
  width: 25px;
  height: 26px;
  background: url(../images/base/ico_arrow-l_wh.svg) no-repeat;
  background-size: contain;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.m-icon-link a:hover {
  opacity: 0.7;
}

.m-icon-link.icon-blank a::before {
  width: 22px;
  height: 22px;
  background: url(../images/base/ico_blank_wh.svg) no-repeat;
  background-size: contain;
}
.m-icon-link.icon-pdf a::before {
  width: 27px;
  height: 29px;
  background: url(../images/base/ico_pdf_wh.svg) no-repeat;
  background-size: contain;
}
.m-icon-link.icon-xls a::before {
  width: 27px;
  height: 29px;
  background: url(../images/base/ico_xls_wh.svg) no-repeat;
  background-size: contain;
}

.icon-down::before {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}
/* icon付きスタイル ======================== */
.btn-icon-link {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 156px;
  height: 31px;
  line-height: 1.35;
  font-weight: bold;
  color: #212121;
  border-bottom: solid 1px #212121;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.btn-icon-link:hover {
  opacity: 0.7;
}

.icon-arrow {
  position: relative;
  width: 25px;
  height: 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.icon-arrow::before {
  position: absolute;
  content: "";
  width: 25px;
  height: 25px;
  background-color: #E70012;
  border-radius: 50%;
}
.icon-arrow::after {
  position: absolute;
  content: "";
  width: 8px;
  height: 7px;
  background: URL("../images/base/ico_arrow_wh.svg");
  background-size: cover;
}

.icon-arrow.-y::before {
  background-color: #FFD83D;
}
.icon-arrow.-y::after {
  background: URL("../images/base/ico_arrow_bk.svg");
  background-size: cover;
}

/* button ======================== */
.icon-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: absolute;
  width: 35px;
  height: 35px;
}
.icon-nav::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  border: solid 1px #212121;
  border-radius: 50%;
}
.icon-nav::after {
  position: absolute;
  content: "";
  width: 8px;
  height: 7px;
  background: URL("../images/base/ico_arrow_bk.svg");
  background-size: cover;
}
.icon-nav.-prev::after {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}
.btn-more,#gform_next_button_1_10  {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 260px;
  height: 65px;
  padding: 0 28px;
  z-index: 1;
  background: URL("../images/base/bg_btn.png") 0 0;
  background-size: cover;
  overflow: hidden;
  -webkit-transition: color ease 0.3s;
  transition: color ease 0.3s;
  border: solid 2px transparent;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.btn-more::after {
  position: absolute;
  content: "";
  width: 25px;
  height: 25px;
  top: 50%;
  right: 28px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: URL("../images/base/ico_arrow-l_wh.svg");
  background-size: cover;
}
.btn-more span, .btn-more .__next {
  position: relative;
  color: #fff;
  z-index: 3;
}
.btn-more:hover {
  border: 2px solid #BC0312;
}
.btn-more:hover::after {
  background: URL("../images/base/ico_arrow-l_red.svg");
  background-size: cover;
}
.btn-more:hover span, .btn-more:hover .__next {
  color: #BC0312;
}
.btn-more::before {
  position: absolute;
  content: "";
  width: 120%;
  height: 200%;
  top: 0;
  right: 0;
  z-index: -1;
  background: #fff;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  -webkit-transition: -webkit-transform ease 0.3s;
  transition: -webkit-transform ease 0.3s;
  transition: transform ease 0.3s;
  transition: transform ease 0.3s, -webkit-transform ease 0.3s;
}
.btn-more:hover::before {
  -webkit-transform: translateX(10%);
          transform: translateX(10%);
}

.btn-more-ico {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 260px;
  height: 65px;
  padding: 0 28px;
  z-index: 1;
  background: URL("../images/base/bg_btn.png") 0 0;
  background-size: cover;
  overflow: hidden;
  -webkit-transition: color ease 0.3s;
  transition: color ease 0.3s;
  border: solid 2px transparent;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.btn-more-ico span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.btn-more-ico.-btn01 {
  height: 55px;
}
.btn-more-ico.-btn01::after {
  display: none;
}
.btn-more-ico.-btn01 .icon {
  margin-right: 10px;
  width: 34px;
  height: 29px;
  background: URL("../images/base/ico_menu_01.svg") 0 0;
  background-size: cover;
}
.btn-more-ico.-btn01:hover .icon {
  background: URL("../images/base/ico_menu_01_r.svg") 0 0;
}
.btn-more-ico.-btn02 {
  height: 55px;
}
.btn-more-ico.-btn02::after {
  display: none;
}
.btn-more-ico.-btn02 .icon {
  margin-right: 10px;
  width: 21px;
  height: 26px;
  background: URL("../images/base/ico_menu_02.svg") 0 0;
  background-size: cover;
}
.btn-more-ico.-btn02:hover .icon {
  background: URL("../images/base/ico_menu_02_r.svg") 0 0;
}
.btn-more-ico::after {
  position: absolute;
  content: "";
  width: 25px;
  height: 25px;
  top: 50%;
  right: 28px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: URL("../images/base/ico_arrow-l_wh.svg");
  background-size: cover;
}
.btn-more-ico span {
  position: relative;
  color: #fff;
  z-index: 3;
}
.btn-more-ico:hover {
  border: 2px solid #BC0312;
  /*   &::after{
     background: URL("../images/base/ico_arrow-l_red.svg");
     background-size: cover;
     }*/
}
.btn-more-ico:hover span, .btn-more-ico:hover .__next {
  color: #BC0312;
}
.btn-more-ico::before {
  position: absolute;
  content: "";
  width: 120%;
  height: 200%;
  top: 0;
  right: 0;
  z-index: -1;
  background: #fff;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  -webkit-transition: -webkit-transform ease 0.3s;
  transition: -webkit-transform ease 0.3s;
  transition: transform ease 0.3s;
  transition: transform ease 0.3s, -webkit-transform ease 0.3s;
}
.btn-more-ico:hover::before {
  -webkit-transform: translateX(10%);
          transform: translateX(10%);
}

.btn-prev {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  width: 260px;
  height: 65px;
  padding: 0 28px;
  z-index: 1;
  color: #BC0312;
  background-color: #fff;
  overflow: hidden;
  -webkit-transition: color ease 0.3s;
  transition: color ease 0.3s;
  border: solid 2px #BC0312;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.btn-prev::after {
  position: absolute;
  content: "";
  width: 26px;
  height: 26px;
  top: 50%;
  left: 28px;
  background: URL("../../common/images/base/ico_arrow-l_red.svg");
  background-size: cover;
  -webkit-transform: translateY(-50%) scale(-1, 1);
          transform: translateY(-50%) scale(-1, 1);
}
.btn-prev span, .btn-prev .__prev {
  position: relative;
  color: #BC0312;
  font-weight: bold;
  z-index: 3;
}
.btn-prev:hover {
  border: 2px solid #E70012;
}
.btn-prev:hover::after {
  background: URL("../images/base/ico_arrow-l_wh.svg");
  background-size: cover;
}
.btn-prev:hover span, .btn-prev:hover .__prev {
  color: #fff;
}
.btn-prev::before {
  position: absolute;
  content: "";
  width: 120%;
  height: 200%;
  top: 0;
  right: 0;
  z-index: -1;
  background: URL("../images/base/bg_btn.png") 0 0;
  background-size: contain;
  -webkit-transform: translateX(200%);
          transform: translateX(200%);
  -webkit-transition: -webkit-transform ease 0.3s;
  transition: -webkit-transform ease 0.3s;
  transition: transform ease 0.3s;
  transition: transform ease 0.3s, -webkit-transform ease 0.3s;
}
.btn-prev:hover::before {
  -webkit-transform: translateX(10%);
          transform: translateX(10%);
}

.btn-wh {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 55px 0 25px;
  font-size: 1.6rem;
  font-weight: bold;
  background-color: #fff;
  color: #BC0312;
  max-width: 310px;
  height: 70px;
}
.btn-wh::after {
  position: absolute;
  content: "";
  width: 25px;
  height: 25px;
  top: 50%;
  right: 20px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../images/base/ico_arrow-l_red.svg) no-repeat;
  background-size: contain;
}

.btn-bk {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-line-pack: center;
      align-content: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: bold;
  color: #fff;
  background-color: #212121;
  max-width: 260px;
  height: 65px;
}
.btn-bk span {
  position: relative;
  padding-left: 25px;
}
.btn-bk span::before {
  position: absolute;
  content: "";
  top: 50%;
  left: 0;
  width: 18px;
  height: 21px;
  background: URL("../images/base/ico_pdf_cl.svg") repeat-x 0 0;
  background-size: cover;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

/* === page ======================== */
.container {
  position: relative;
}
.container p a {
  position: relative;
  color: #E83928;
  border-bottom: solid 1px #E83928;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  /* &::after{
    position: absolute;
    content: "";
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    background-color: $color-r1;  
    -webkit-transition: .2s;
    transition: .2s;
    }*/
}
.container p a:hover {
  border-bottom: none;
  /*   border-bottom: solid 1px rgba(255,255,255, 0.5);
       &::after {
         width: 100%;
       } */
}

/*.page-header === */
.page-header {
  position: relative;
  margin-top: 90px;
  height: min(40vw, 500px);
}
.page-header::before {
  position: absolute;
  content: "";
  bottom: 0;
  width: 100%;
  height: clamp(58px, 8vw, 123px);
  background: URL("../images/base/bg_loop_logo.svg") repeat-x 0 0;
  background-size: auto 100%;
  -webkit-animation: bg-loop 15s linear infinite;
          animation: bg-loop 15s linear infinite;
  margin: 10px 0;
  padding: 0;
  z-index: -3;
}
.page-header .header-line-wrap {
  position: absolute;
  bottom: -30px;
  left: 0;
  width: 100%;
  height: auto;
  padding-top: 28.1112737921%;
}
.page-header .header-line-wrap .a-line-wrap {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  bottom: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.page-header .header-line-wrap .a-svg-line {
  width: 0;
  height: 0;
  fill: none;
  stroke-width: 0;
  opacity: 0;
}
.page-header .header-line-wrap.svgAnime .a-svg-line {
  stroke-dasharray: 200%;
  stroke-width: 1;
  opacity: 1;
  -webkit-transition-duration: 3s;
          transition-duration: 3s;
  width: 100%;
  height: auto;
}

/* ページタイトル === */
.page-header-title {
  position: relative;
  top: 20%;
  display: block;
}
.page-header-title .en {
  position: absolute;
  top: 0;
  left: 0;
  font-family: "din-2014", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(4.5rem, 10vw, 14.4rem);
  color: #fff;
  text-transform: uppercase; /* 大文字 */
}
.page-header-title .ja {
  position: relative;
  top: 40px;
  left: 60px;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-size: clamp(2rem, 4vw, 5.6rem);
  color: #333;
}

/* セクションタイトル === */
.section-title {
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-size: clamp(3.8rem, 3.8vw, 5.2rem);
  line-height: 1.28;
  margin-top: -1.28rem;
}

.section-en {
  position: absolute;
  font-family: "din-2014", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: min(5.8vw, 8rem);
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  line-height: 1;
  color: #fff;
  z-index: -3;
}

.section-en.-cr {
  height: 100%;
  text-align: center;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.section-en.-r {
  right: min(1%, 50px);
  margin-right: -1rem;
}

.section-en.-l {
  left: min(1%, 50px);
  margin-left: -1rem;
}

.section-lead {
  margin: 50px auto 30px;
  text-align: center;
}

/* indexタイトル === */
.m-index-title {
  position: relative;
  padding: 10px 0;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-size: clamp(2.4rem, 3.75vw, 4rem);
  line-height: 1.375;
}
.m-index-title::before {
  position: absolute;
  content: "";
  display: block;
  top: 0;
  left: 0;
  width: 10px;
  height: 10px;
  background-color: #E70012;
}
.m-index-title.-center {
  margin-right: auto;
  margin-left: auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.m-index-title.-sp-center {
  margin-right: inherit;
  margin-left: 0;
  width: inherit;
}
.m-index-title.-no::before {
  display: none;
}

/* post-item, card-item? === */
.post-item {
  position: relative;
  width: 400px;
  width: 29.4117647059vw;
  max-width: 400px;
  height: 416px;
  border-bottom: dotted 1px #212121;
}
.post-item a::after {
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  pointer-events: auto;
  background-color: transparent;
}
.post-item-thumb {
  aspect-ratio: 400/235;
}
.post-item-thumb img {
  aspect-ratio: 400/235;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.post-item-meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 20px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  row-gap: 5px;
}
.post-item-date {
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  margin-right: 15px;
  line-height: 1;
}
.post-item-cat {
  font-size: min(1vw, 1.2rem);
  line-height: 1;
  font-weight: bold;
  margin-right: min(2vw, 10px);
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.post-item-cat a, .post-item-cat span {
  position: relative;
  padding: 4px min(2vw, 10px);
  background-color: #E70012;
  color: #fff;
  z-index: 2;
  display: inline-block;
}
.post-item-title {
  font-size: 2rem;
  font-weight: bold;
  margin-top: 10px;
}
.post-item-text {
  margin-top: 20px;
  padding-bottom: 20px;
  font-size: 1.4rem;
  line-height: 2.14;
}

/* m- */
.m-lead-title {
  padding: 10px 0;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-size: 4rem;
  line-height: 1.375;
}

.m-lead-text {
  margin-top: 20px;
  line-height: 2.1875;
}

.m-content {
  margin-top: 100px;
}
.m-content-title {
  margin-top: 40px;
  font-size: clamp(2rem, 2.4vw, 3.2rem);
  font-weight: bold;
  line-height: 1.5;
}
.m-content h3 {
  margin-top: 40px;
  font-size: clamp(2rem, 2.4vw, 3.2rem);
  font-weight: bold;
  line-height: 1.5;
}
.m-content h3 .-small {
  margin-left: 10px;
  font-size: clamp(1.6rem, 2vw, 2.4rem);
}
.m-content h4 {
  margin-top: 20px;
  font-weight: bold;
  font-size: clamp(1.6rem, 2vw, 2.4rem);
  line-height: 2.1875;
}
.m-content p {
  line-height: 2.1875;
}

/* css animation === */
.a-loop {
  width: 100%;
  height: clamp(58px, 8vw, 123px);
  position: relative;
  background: URL("../images/base/bg_loop_logo.svg") repeat-x 0 0;
  background-size: auto 100%;
  -webkit-animation: bg-loop 15s linear infinite;
          animation: bg-loop 15s linear infinite;
  margin: 10px 0;
  padding: 0;
  z-index: -2;
}

.a-rotate1 {
  -webkit-animation: rotation 12s infinite linear 0.5s both;
          animation: rotation 12s infinite linear 0.5s both;
}

/* ==========================================================================
  コンテンツページ共通
========================================================================== */
/* === menu-contents ======================== */
.section-related-menu {
  margin-top: 100px;
  padding-bottom: 20px;
  overflow: hidden;
}
.section-related-menu .col-inner {
  padding-top: 45px;
  padding-bottom: 15px;
  position: relative;
}
.section-related-menu .col-inner::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
  z-index: -3;
}

.related-menu-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr min(3vw, 35px) 1fr min(3vw, 35px) 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 25px min(3vw, 35px);
  margin: 30px auto 35px;
}

.related-menu {
  position: relative;
  width: 100%;
}
.related-menu a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 15px;
  height: 70px;
  font-size: min(1.3vw, 1.6rem);
  font-weight: bold;
  line-height: 1.285;
  color: #fff;
  background-color: #BC0312;
  border: solid 2px #BC0312;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.related-menu a::before {
  position: absolute;
  content: "";
  top: 50%;
  right: min(1.4vw, 20px);
  width: min(1.8vw, 25px);
  height: min(1.8vw, 25px);
  background: url(../images/base/ico_arrow-l_wh.svg) no-repeat;
  background-size: contain;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.related-menu a:hover {
  opacity: 0.7;
}
.related-menu.is-current a {
  color: #BC0312;
  background-color: #fff;
}
.related-menu.is-current a::before {
  background: url(../images/base/ico_arrow-l_red.svg) no-repeat;
  background-size: contain;
}

.contact-menu {
  margin-top: clamp(58px, 8vw, 123px);
  margin-bottom: 30px;
}

.contact-menu-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: min(3vw, 40px);
     -moz-column-gap: min(3vw, 40px);
          column-gap: min(3vw, 40px);
}

.contact-menu-btn {
  width: 33.33%;
  -webkit-transition: 0.35s ease-in-out;
  transition: 0.35s ease-in-out;
}
.contact-menu-btn a {
  outline: 2px solid #fff;
  outline-offset: -15px;
  position: relative;
  width: 100%;
  max-width: 388px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.contact-menu-btn a::before {
  content: "";
  padding-top: 68.2989690722%;
}
.contact-menu-btn a p {
  margin-top: 50px;
  padding-right: 40px;
  position: absolute;
  font-size: min(2vw, 2.8rem);
  line-height: 1;
  font-weight: 500;
  color: #fff;
}
.contact-menu-btn a p::after {
  position: absolute;
  content: "";
  width: 25px;
  height: 25px;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: URL("../images/base/ico_arrow-l_wh.svg");
  background-size: cover;
}
.contact-menu-btn a .icon {
  position: absolute;
  top: 25%;
}
.contact-menu-btn a:hover {
  opacity: 0.7;
}
.contact-menu-btn.-btn01 {
  background: URL("../images/base/bg_contact_01.webp") 0 0;
  background-size: cover;
}
.contact-menu-btn.-btn01 .icon {
  width: 70px;
  height: 59px;
  background: URL("../images/base/ico_menu_01.svg") 0 0;
  background-size: cover;
}
.contact-menu-btn.-btn02 {
  background: URL("../images/base/bg_contact_02.webp") 0 0;
  background-size: cover;
}
.contact-menu-btn.-btn02 .icon {
  width: 41px;
  height: 52px;
  background: URL("../images/base/ico_menu_02.svg") 0 0;
  background-size: cover;
}
.contact-menu-btn.-btn03 a {
  background: URL("../images/base/bg_contact_03.webp") 0 0;
  background-size: cover;
}
.contact-menu-btn.-btn03 a .icon {
  width: 54px;
  height: 52px;
  background: URL("../images/base/ico_menu_03.svg") 0 0;
  background-size: cover;
}

/* === formのスタイル select ======================== */
.m-select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 12px 40px 10px 20px;
  min-width: 220px;
  height: 40px;
  font-size: 1.6rem;
  font-weight: bold;
  color: #212121;
  background-color: #fff;
  background-image: url(../images/base/ico_select.svg);
  background-repeat: no-repeat;
  background-size: 14px 9px;
  background-position: center right 20px;
  border: solid 1px #BCBCBC;
}

/* === ボタンリスト ======================== */
.btn-wrap {
  margin-top: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 20px;
}

.btn-wrap-c a {
  margin: 40px auto;
}

/* ==========================================================================
   Helper classes
========================================================================== */
/* clearfix */
.clearfix:after {
  clear: both;
  display: table;
  content: " ";
}
.clearfix:before {
  display: table;
  content: " ";
}

/* clear */
.clear {
  clear: both !important;
}

/* ol */
ol li {
  margin-left: 1em;
  line-height: 1.6875;
}

.fz-20 {
  font-size: clamp(1.6rem, 2vw, 2rem);
}

.fz-12 {
  font-size: clamp(1.1rem, 0.9vw, 1.2rem);
}

.fw-b {
  font-weight: bold;
}

.clr-red {
  color: #E70012;
}

em {
  font-weight: bold;
  font-style: normal;
}

.en {
  font-family: "Roboto", sans-serif;
  /*font-weight: 500;*/
}

.min {
  font-family: "Noto Serif JP", serif;
}

/* text-align */
.txt-l {
  text-align: left !important;
}

.txt-c {
  text-align: center !important;
}
.txt-c.sp-no {
  text-align: left !important;
}

.txt-r {
  text-align: right !important;
}

.txt-j {
  text-align: justify;
  text-justify: inter-ideograph !important;
}

.m-notice {
  font-size: 1.4rem;
  color: #5C5C5C;
}

/* pc/sp , br */
.m-pc-only,
.br-pc {
  display: block !important;
}

.m-sp-only,
.br-sp {
  display: none !important;
}

/* object-fit 
.object-fit-img {
  object-fit: contain;
  font-family: 'object-fit: contain;'
}
*/
/* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
テーブル
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
tbody {
  overflow-x: auto;
  /* white-space: nowrap;*/
  width: auto;
}

.table {
  margin-top: 10px;
  margin-bottom: 20px;
  width: 100%;
  display: table;
  top: 0;
  border-collapse: collapse;
  z-index: 100;
}

/*
.data-tbl {
	margin-top: 0 ;
	margin-bottom: 1px;
	position: relative;
	width: 100%;
	table-layout: fixed;
}


.data-tbl thead th {
}
.data-tbl tbody th {
	width: 250px;
	padding: 14px 10px 14px 20px;
	vertical-align: top;
	border: solid 1px #e0e0e0;
	line-height: 1.75;
	font-weight: 500;
	background-color: #f5f5f5;

}
.data-tbl td {
	padding: 14px 10px 14px 20px;
	border: solid 1px #e0e0e0;
	line-height: 1.75;
}
.noborder{
	margin-top: 10px;
 th,td{
	padding: 5px 10px 5px 20px!important;
	border: none!important;
	background-color: #fff!important;
}
}
*/
.m-data-table {
  margin-top: 50px;
  padding: 50px 50px 10px 50px;
  background-color: #fff;
}
.m-data-table > dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 40px;
  padding-bottom: 35px;
  border-bottom: dashed 1px #212121;
}
.m-data-table > dl.-last {
  border-bottom: none;
  padding-bottom: 0;
}
.m-data-table > dl > dt {
  width: min(15vw, 200px);
  text-align: left;
  font-size: clamp(1.2rem, 1.4vw, 2rem);
  line-height: 1.3;
  font-weight: bold;
  color: #BC0312;
}
.m-data-table > dl > dd {
  margin-left: 50px;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.m-data-table .icon-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 15px;
}
.m-data-table .icon-item .icon {
  background-color: #E83928;
  width: 35px;
  height: 35px;
}
.m-data-table .icon-item-text {
  margin-left: 10px;
  font-weight: bold;
}

.m-sub-table {
  margin-top: 15px;
  padding: 10px 70px 5px 0;
}
.m-sub-table > dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: clamp(20px, 3.4vw, 50px);
     -moz-column-gap: clamp(20px, 3.4vw, 50px);
          column-gap: clamp(20px, 3.4vw, 50px);
  margin-bottom: 15px;
  padding-bottom: 15px;
  padding-left: 5px;
  padding-right: 5px;
  font-size: clamp(1.3rem, 1.2vw, 1.6rem);
  border-bottom: solid 1px #212121;
}
.m-sub-table > dl.-head {
  font-weight: bold;
}
.m-sub-table > dl > dt {
  line-height: 1.5;
  width: 70px;
}
.m-sub-table > dl > dd {
  text-align: left;
  width: 100%;
  line-height: 1.5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: clamp(20px, 2.5vw, 50px);
     -moz-column-gap: clamp(20px, 2.5vw, 50px);
          column-gap: clamp(20px, 2.5vw, 50px);
}
.m-sub-table > dl > dd .-cell1 {
  width: 70%;
}
.m-sub-table > dl > dd .-cell2 {
  width: 30%;
}
/* 
.m-item-l {
	float: left;
	width: 60%;
}
.m-item-r {
	margin-left: 40%;
}
 */
i {
  font-style: normal;
}

/* helper */
.m-mt-30 {
  margin-top: 30px;
}

.m-mt-40 {
  margin-top: 40px;
}

.m-mt-50 {
  margin-top: 50px;
}

.m-mt-80 {
  margin-top: 80px;
}

/* ==========
  1 トップページ
========================================================================== */
/*body.home .container {
    position: relative;
    margin-top: 0;
    margin-bottom: 0;
}*/
/* MainVisual */
.section-home-mv {
  width: 100%;
  height: 100%;
  display: block;
  margin-bottom: 20px;
}

.home-mv {
  position: relative;
  height: calc(100vh - 60px);
  max-height: 833px;
}
.home-mv-line {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  margin-top: -90px;
  padding-top: 38.0673499268%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.home-mv-line .a-line-wrap {
  position: absolute;
  content: "";
  width: 100%;
  height: auto;
  bottom: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.home-mv-line .a-svg-line {
  width: 0;
  height: 0;
  fill: none;
  stroke-width: 0;
  opacity: 0;
}
.home-mv-line.svgAnime .a-svg-line {
  stroke-dasharray: 200%;
  stroke-width: 1;
  opacity: 1;
  -webkit-transition-duration: 3s;
          transition-duration: 3s;
  width: 100%;
  height: auto;
}
.home-mv-content {
  position: absolute;
  text-align: center;
  top: 50%;
  left: 50%;
  margin-top: 20px;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.home-mv-items {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  text-align: center;
  z-index: 1;
  opacity: 0;
}
.home-mv-image {
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: 60px;
  text-align: center;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 1;
  opacity: 0;
}
.home-mv-text {
  position: absolute;
  top: 110px;
  left: 7%;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  width: 3.5em;
  height: auto;
  font-size: clamp(4rem, 3vw, 4.4rem);
  line-height: 1.8;
  z-index: 1;
}
.home-mv-circle {
  position: absolute;
  right: 60px;
  bottom: 60px;
}

/* home-pickup */
.home-pickup {
  position: absolute;
  bottom: -10%;
  left: 0;
  padding: 30px 60px 20px;
  width: 360px;
  height: 145px;
  z-index: 10;
}
.home-pickup::before {
  position: absolute;
  content: "";
  width: 100vw;
  height: 100%;
  right: 0;
  top: 0;
  background: #fff;
}
.home-pickup-title {
  position: absolute;
  top: -20px;
  left: 60px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 2.4rem;
}
.home-pickup-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.home-pickup-body .post-item-meta {
  margin-top: 0;
}
.home-pickup-body .post-item-text {
  margin-top: 5px;
}
.home-pickup-nav {
  position: absolute;
  right: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 10px;
}
.home-pickup-nav .icon-nav {
  left: 0;
}

/* section-home-news */
.home-news {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.home-news-wrap {
  position: relative;
  padding-top: 30px;
  padding-bottom: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.home-news-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
  z-index: -1;
}
.home-news-head {
  width: 240px;
}
.home-news-title {
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-size: 3.2rem;
  margin-bottom: 30px;
}
.home-news-list {
  margin-top: -10px;
  width: calc(100% - 240px);
}
.home-news-list li {
  padding: 12px 10px;
  border-bottom: 1px dashed #A1A1A1;
  min-height: 54px;
}
.home-news-list li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.home-news-list li a:hover {
  opacity: 0.7;
}
.home-news-list li a::after {
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  bottom: 0;
  width: 7px;
  height: 7px;
  margin: auto 0;
  border-top: 1px solid #212121;
  border-right: 1px solid #212121;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.home-news-list-date {
  width: 84px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 1.6rem;
}
.home-news-list-text {
  width: calc(100% - 104px);
}

/* section-home-features */
.section-home-features {
  position: relative;
  padding: 120px 0 80px;
}
.section-home-features .col-inner {
  position: relative;
  padding: 0 clamp(20px, 3vw, 60px);
}

.home-features-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
/* p-card  vanilla-tilt.js使用 */
.p-card {
  position: relative;
  display: block;
  width: 100%;
  max-width: 310px;
  margin: clamp(10px, 1vw, 20px);
  cursor: -webkit-grab;
  cursor: grab;
}
.p-card::after {
  position: absolute;
  content: "";
  top: 15px;
  left: 5px;
}
.p-card-image {
  position: relative;
  margin: 0 auto;
  text-align: center;
}
.p-card-body {
  margin-top: -130px;
  padding: 150px 25px 25px;
  background-color: #fff;
  height: 423px;
}
.p-card-title {
  font-size: clamp(1.7rem, 1.6vw, 2rem);
  font-weight: bold;
  line-height: 1.5;
}
.p-card-text {
  margin-top: 15px;
  font-size: clamp(1.4rem, 1.4vw, 1.6rem);
  line-height: 1.875;
}
.p-card:nth-child(1) {
  margin-top: 80px;
}
.p-card:nth-child(1)::after {
  width: 80px;
  height: 62px;
  background-image: url(../images/home/num_01.svg);
  background-size: cover;
}
.p-card:nth-child(2) {
  margin-top: 30px;
}
.p-card:nth-child(2)::after {
  width: 88px;
  height: 62px;
  background-image: url(../images/home/num_02.svg);
  background-size: cover;
}
.p-card:nth-child(3) {
  margin-top: -20px;
}
.p-card:nth-child(3)::after {
  width: 88px;
  height: 62px;
  background-image: url(../images/home/num_03.svg);
  background-size: cover;
}

/*
.is-active .p-card:nth-child(1){transition-delay: .2s;}
.is-active .p-card:nth-child(2){transition-delay: .6s;}
.is-active .p-card:nth-child(3){transition-delay: 1.0s;}
*/
/* section-home-department */
.section-home-department {
  position: relative;
}
.section-home-department .col-wrap {
  padding: 100px 10px 120px;
}
.section-home-department .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  right: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #F2DBD7;
  z-index: -3;
}
.section-home-department .section-en {
  top: 140px;
}

.home-department-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-column-gap: 47px;
     -moz-column-gap: 47px;
          column-gap: 47px;
}
@media (min-width: 769px) and (max-width: 1359px) {
  .home-department-wrap {
    -webkit-column-gap: 25px;
       -moz-column-gap: 25px;
            column-gap: 25px;
  }
}
.home-department-wrap.-r {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-column-gap: 33px;
     -moz-column-gap: 33px;
          column-gap: 33px;
  margin-top: 10px;
  margin-right: min(-1vw, -60px);
}
@media (min-width: 769px) and (max-width: 1260px) {
  .home-department-wrap.-r {
    margin-right: 0;
  }
}
.home-department-wrap.-r .home-department-image {
  margin-right: 0;
  width: 58.37%;
  max-width: 586px;
}
.home-department-wrap.-r .home-department-lead {
  position: absolute;
  top: 110px;
  right: -10px;
}
.home-department-wrap.-r .home-department-content {
  margin-top: 10px;
}
.home-department-wrap.-l {
  margin-top: 50px;
  margin-left: min(-1vw, -60px);
}
@media (min-width: 769px) and (max-width: 1260px) {
  .home-department-wrap.-l {
    margin-left: 0;
  }
}
.home-department-image {
  position: relative;
  width: 58.37%;
  max-width: 592px;
}
.home-department-image .-student01 {
  position: absolute;
  bottom: -23px;
  left: 40px;
  width: clamp(80px, 14vw, 157px);
  height: auto;
}
.home-department-image .-student02 {
  position: absolute;
  bottom: 10px;
  right: 29px;
  width: clamp(70px, 12vw, 129px);
  height: auto;
}
.home-department-lead {
  position: absolute;
  top: 65px;
  left: -10px;
  font-size: clamp(1.4rem, 1.3vw, 2rem);
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 3;
  text-indent: -1em;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}
.home-department-lead span {
  padding: 10px 5px;
  background-color: #fff;
}
.home-department-content {
  margin-top: -30px;
  width: 43vw;
  max-width: 438px;
}
.home-department-content-title {
  font-size: clamp(2.8rem, 2.7vw, 4rem);
  font-weight: bold;
}
.home-department-content-text {
  margin-top: 40px;
  line-height: 1.875;
}
.home-department-tag-box {
  margin: 30px 0 30px;
  padding: 12px 12px;
  background-color: #FCF4F2;
}
.home-department-tag-title {
  font-weight: bold;
}
.home-department-tag-list {
  margin-top: 1em;
  font-size: 1.4rem;
}
.home-department-tag-list li {
  display: inline-block;
  margin-right: 0.5em;
}
.home-department-tag-list li a, .home-department-tag-list li span {
  position: relative;
  color: #E70012;
}
.home-department-tag-list li a::before, .home-department-tag-list li span::before {
  content: "#";
  color: #212121;
}

.home-course {
  position: relative;
  margin: 40px auto 0;
  width: 100%;
  padding: 20px 50px;
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 50px;
     -moz-column-gap: 50px;
          column-gap: 50px;
}
.home-course .txt-wrap01 {
  position: absolute;
  top: -25px;
  right: 39px;
}
.home-course-image {
  width: 210px;
  height: 210px;
}
.home-course-title {
  margin-top: 10px;
  font-weight: bold;
  font-size: 2.8rem;
  line-height: 1.5;
}
.home-course-title .lead {
  display: block;
  font-size: 2rem;
}
.home-course-text {
  line-height: 1.875;
  margin-top: 10px;
  margin-bottom: 20px;
}
.home-course .btn-more {
  width: 250px;
  height: 55px;
}

/* section-home-opencampus */
.section-home-opencampus {
  position: relative;
  padding: 147px 0 0;
}
.section-home-opencampus .section-en.-l {
  top: -60px;
}
.section-home-opencampus .col-wrap {
  padding: 0;
}

.home-opencampus-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-left: 180px;
  padding-right: 60px;
}
.home-opencampus-head .btn-icon-link {
  margin-top: 10px;
}

.home-opencampus-slider {
  position: relative;
  padding-left: 120px;
  margin: 40px 0 45px 60px;
  width: calc(100vw - 60px);
}

.slide-no {
  width: 100%;
  max-width: 1000px;
}

.txt-no-slide {
  min-height: 350px;
  padding: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.home-opencampus-foot {
  display: none;
}

/* section-home-events */
.section-home-events {
  padding: 50px 0;
}
.section-home-events .section-en.-l {
  top: -50px;
}
.section-home-events .col-wrap {
  padding: 0;
}

.home-events-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-left: 180px;
  padding-right: 60px;
}
.home-events-head .btn-icon-link {
  margin-top: 10px;
}

/* swiper設定 */
.card01 .swiper-button-prev {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin: 0;
  width: 35px;
  height: 35px;
  right: inherit;
  left: inherit;
}
.card01 .swiper-button-prev:after {
  content: none;
}
.card01 .swiper-button-next {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin: 0;
  width: 35px;
  height: 35px;
  right: inherit;
  left: inherit;
}
.card01 .swiper-button-next:after {
  content: none;
}

.card03-1, .card03-2, .opencampus-slider {
  /*.card00-1,.card00-2,.card00-3,.card00-4,.card00-5,.card00-6, { //opencampus-slider*/
  overflow: visible;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  /*
   .swiper-controller {
     display: flex;
     gap: 1.6rem;
     align-items: center;
     justify-content: flex-end;
     margin-top: 3.2rem;
   }
   .swiper-pagination {
     display: flex;
     flex-wrap: wrap;
     gap: 1.2rem 0.8rem;
     justify-content: flex-start;
     margin: 0 auto 0 0;
     text-align: center;
   }
   .swiper-pagination-bullet {
     width: 1.6rem;
     height: 3px;
     cursor: pointer;
     -webkit-transition: var(--transition);
     transition: var(--transition);
     vertical-align: top;
     background-color: var(--color-gray);
   }
   .swiper-pagination-bullet-active {
     width: 4rem;
     background-color: var(--color-theme);
   }
  */
  /*
   .swiper-button-disabled {
     pointer-events: none;
     opacity: 0.5;
   }
   .swiper-button-disabled::before {
    box-shadow: var(--box-shadow-inset);
   }
  */
}
.card03-1 .swiper, .card03-2 .swiper, .opencampus-slider .swiper {
  overflow: hidden;
}
.card03-1 .swiper-button-prev, .card03-2 .swiper-button-prev, .opencampus-slider .swiper-button-prev {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin: 0;
  width: 60px;
  height: 60px;
  right: inherit;
  left: inherit;
}
.card03-1 .swiper-button-prev:after, .card03-2 .swiper-button-prev:after, .opencampus-slider .swiper-button-prev:after {
  content: none;
}
.card03-1 .swiper-button-next, .card03-2 .swiper-button-next, .opencampus-slider .swiper-button-next {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin: 0;
  width: 60px;
  height: 60px;
  right: inherit;
  left: inherit;
}
.card03-1 .swiper-button-next:after, .card03-2 .swiper-button-next:after, .opencampus-slider .swiper-button-next:after {
  content: none;
}
.card03-1 .swiper-slide, .card03-2 .swiper-slide, .opencampus-slider .swiper-slide {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}

.card04 {
  overflow: visible;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.card04 .swiper {
  overflow: hidden;
}
.card04 .swiper-slide {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}

/*
.swiper-wrapper{
 display: flex;
 column-gap: 75px;
 border:solid 2px $color-r3;
 width: 100%;
 height: 416px;
}*/
.swiper-nav01 {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 25px;
}

/* section-home-campuslife */
.section-home-campuslife {
  margin-top: 50px;
  position: relative;
}
.section-home-campuslife .section-en.-r {
  z-index: 1;
}

/* section-home-addmissions */
.section-home-admissions {
  margin-top: 100px;
}
.section-home-admissions .section-en.-l {
  z-index: 1;
}

/* home-menu */
.home-menu-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.home-menu-image {
  position: relative;
  margin-right: 60px;
  margin-left: -60px;
}
.home-menu-image .photo {
  width: 460px;
  height: 500px;
  -o-object-fit: cover;
     object-fit: cover;
}
.home-menu-image .wavy-wrap01 {
  position: absolute;
  left: -60px;
  bottom: 16px;
}
.home-menu-image .wavy-wrap02 {
  position: absolute;
  right: -30px;
  bottom: -30px;
}
.home-menu-content {
  position: relative;
  margin-left: 80px;
  width: 51.6%;
  max-width: 460px;
  min-height: 570px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.home-menu-content::before {
  position: absolute;
  content: "";
  top: 0;
  left: -60px;
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
  z-index: -3;
}
.home-menu-textarea {
  position: relative;
  width: 100%;
}
.home-menu-title {
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-size: 4rem;
}

.home-menu-wrap.-r {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
.home-menu-wrap.-r .home-menu-image {
  margin-left: inherit;
  margin-right: -60px;
  margin-left: 60px;
}
.home-menu-wrap.-r .home-menu-content {
  margin-left: inherit;
  margin-right: 80px;
}
.home-menu-wrap.-r .home-menu-content::before {
  top: 0;
  right: -60px;
  left: inherit;
}

/* home-nav-list */
.home-nav-list {
  margin-top: 30px;
  max-width: 463px;
  font-size: clamp(2rem, 1.7vw, 2.4rem);
  font-weight: bold;
  line-height: 1.45;
}
.home-nav-list li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-line-pack: center;
      align-content: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  padding: 1em 0 0.5em 0.5em;
  border-bottom: 1px solid #212121;
}
.home-nav-list li a:hover {
  opacity: 0.7;
}

/*
.home-nav-list.-list02{
 li a{
 &::before{
  background-color:$color-y;  
  }
 &::after{
    background: URL("../images/base/ico_arrow_bk.svg");
    background-size: cover;
   }
 }
}
*/
/*section-home-ogob */
.section-home-ogob {
  position: relative;
  margin-top: clamp(58px, 8vw, 123px);
}

.home-ogob {
  padding-top: 40px;
  padding-bottom: 40px;
}
.home-ogob-wrap {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 50px;
     -moz-column-gap: 50px;
          column-gap: 50px;
}
.home-ogob-content {
  width: 42%;
  max-width: 370px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.home-ogob-content-text {
  margin: 30px 0 50px;
  line-height: 2.1875;
}
.home-ogob-slider {
  position: relative;
  padding-left: min(11vw, 150px);
}
.home-ogob .card04 {
  width: 760px;
  overflow: hidden;
}
.home-ogob .card04 .swiper {
  overflow: visible;
}
.home-ogob .card04_sub {
  position: relative;
  margin-top: -150px;
  margin-left: max(-11vw, -150px);
  width: 325px;
  height: 230px;
  z-index: 1;
}
.home-ogob .swiper-wrapper {
  width: 100%;
}

.home-ogob-item {
  position: relative;
  width: 430px;
  height: auto;
}
.home-ogob-item a {
  display: block;
}
.home-ogob-item-thumb {
  width: 430px;
  height: 430px;
}
.home-ogob-item-thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.home-ogob-item-content {
  position: relative;
  display: block;
  padding: 20px;
  left: 0;
  bottom: 0;
  background-color: #fff;
}
.home-ogob-item-content__title {
  font-size: 1.4rem;
  line-height: 1.4;
}
.home-ogob-item-content__title .-txt01 {
  color: #E70012;
}
.home-ogob-item-content__title .-txt02 {
  font-size: 2.4rem;
  font-weight: bold;
}
.home-ogob-item-content__title .-txt03 {
  font-weight: bold;
}
.home-ogob-item-content__text {
  margin-top: 1em;
  font-size: 1.4rem;
  line-height: 2.14;
}

/*section-home-instagram */
.section-home-instagram {
  padding: 100px 0 10px;
  position: relative;
}

.home-instagram-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.home-instagram-body {
  margin: 60px -20px 30px;
  text-align: center;
}

/* instagram プラグイン用 */
.sb_instagram_header {
  display: none;
}

#sbi_load {
  display: none;
}

/* css animation === */
.home-mv-image.is-active {
  -webkit-transition: 0.8s;
  transition: 0.8s;
  -webkit-transition-delay: 2s;
          transition-delay: 2s;
  opacity: 1;
}

.home-mv-circle.is-active {
  -webkit-animation: rotation 8s infinite linear 0.5s both;
          animation: rotation 8s infinite linear 0.5s both;
}

.home-mv-items.is-active {
  -webkit-transition: 0.6s;
  transition: 0.6s;
  -webkit-transition-delay: 1.5s;
          transition-delay: 1.5s;
  opacity: 1;
  -webkit-animation: fuwafuwa 5s linear infinite;
          animation: fuwafuwa 5s linear infinite;
  -webkit-transform-origin: 50% 50%;
          transform-origin: 50% 50%;
  -webkit-animation-delay: 2.8s;
          animation-delay: 2.8s;
}

.action-text span {
  opacity: 0;
}

.a-line-wrap {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  z-index: -1;
}

.a-line-wrap2 {
  position: absolute;
  content: "";
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.line01-wrap {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.line02-wrap {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: -90px;
}

.line03-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-top: 140px;
}

.line04-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-top: -17.5%;
}

.line05-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-top: -21%;
}

.line06-wrap {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: -30px;
}

.line07-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-top: 120px;
}

.a-article {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-animation: fuwafuwa 3s linear infinite;
          animation: fuwafuwa 3s linear infinite;
  -webkit-transform-origin: 50% 50%;
          transform-origin: 50% 50%;
}
.a-article.item-01 {
  top: 40px;
  left: 3%;
  width: 90%;
}
.a-article.item-02 {
  right: 7%;
  top: -20px;
  width: 116px;
}
.a-article.item-03 {
  left: 8%;
  bottom: -50px;
  width: 90px;
}
.a-article.item-04 {
  right: 11%;
  top: -35%;
  width: 90px;
}
.a-article.item-05 {
  left: 7%;
  top: -21%;
  width: 130px;
}
.a-article.item-06 {
  left: 38%;
  top: -100px;
  width: 75px;
}
.a-article.item-07 {
  bottom: -40px;
  left: 12%;
  width: 63px;
}
.a-article.item-08 {
  left: 0;
  top: 75%;
  width: 93px;
}
.a-article.item-09 {
  bottom: -35%;
  right: 6%;
  width: 94px;
}

/* ==========
  02 about //
========================================================================== */
.about-lead {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  gap: 50px;
}
.about-lead-image {
  max-width: 442px;
  max-height: 390px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.about-lead-text {
  margin-top: 35px;
  line-height: 2.1875;
}

.about-style {
  position: relative;
}
.about-style .col-wrap {
  position: relative;
}
.about-style .col-wrap::before {
  position: absolute;
  content: "";
  top: 48px;
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
  z-index: -3;
}
.about-style .col-wrap.-r::before {
  right: min(3vw, 60px);
}
.about-style .col-wrap.-l::before {
  left: min(3vw, 60px);
}
.about-style-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: min(7vw, 100px);
     -moz-column-gap: min(7vw, 100px);
          column-gap: min(7vw, 100px);
  margin-top: 150px;
}
.about-style-wrap.-r {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
.about-style-wrap.-r .about-style-image {
  margin-right: -63px;
}
.about-style-wrap.-l {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
.about-style-wrap.-l .about-style-image {
  margin-left: -63px;
}
.about-style-content {
  margin-top: -35px;
  margin-bottom: 10px;
}
.about-style-num {
  font-family: "din-2014", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 8.8rem;
  letter-spacing: 0.25rem;
  color: transparent;
  -webkit-text-stroke: 2px #BC0312;
}
.about-style-title {
  font-size: min(3.2vw, 3.2rem);
  font-weight: bold;
  line-height: 1.5625;
  color: #BC0312;
}
.about-style-text {
  margin-top: 30px;
  line-height: 2.1875;
}
.about-style-image {
  max-width: 460px;
  max-height: 355px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.about-style-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.about-greeting {
  position: relative;
  margin-top: 150px;
}
.about-greeting .col-inner {
  position: relative;
  padding-top: 100px;
}
.about-greeting-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 70px;
     -moz-column-gap: 70px;
          column-gap: 70px;
  margin-top: 50px;
}
.about-greeting-image {
  max-width: 430px;
  max-height: 550px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.about-greeting-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.about-greeting-name {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.about-greeting-name .-en {
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: min(5.6vw, 7.1rem);
  line-height: 1.16;
  color: #fff;
}
.about-greeting-name .-ja {
  position: absolute;
  font-size: 3.2rem;
  font-weight: bold;
}
.about-greeting-name .-ja .-txt01 {
  margin-right: 10px;
  font-size: 2rem;
}
.about-greeting-title {
  margin-top: 20px;
  font-size: 2.4rem;
  font-weight: bold;
  color: #E70012;
}
.about-greeting-text {
  margin-top: 30px;
  line-height: 2.1875;
}

.about-rinen-section {
  position: relative;
}

.about-rinen {
  position: relative;
  margin-top: 120px;
  padding: 10px 60px 60px 60px;
  background-color: #fff;
  z-index: -2;
}
.about-rinen .m-index-title {
  margin-top: 60px;
  font-size: 3.2rem;
}
.about-rinen-lead {
  margin-top: 20px;
  padding-bottom: 20px;
  font-size: 2rem;
  line-height: 1.875;
}
.about-rinen-list {
  margin-top: 30px;
  font-size: 2rem;
  counter-reset: list-count;
  list-style: none;
}
.about-rinen-list li {
  margin-left: 2em;
  margin-bottom: 6px;
  text-indent: -2em;
  line-height: 1.875;
  /* &::marker{
   color:$color-r1;
   }*/
}
.about-rinen-list li::before {
  content: counter(list-count) ".";
  counter-increment: list-count;
  margin-right: 1em;
  color: #E70012;
}

.line01-about-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  top: -50px;
  z-index: 0;
}

.line02-about-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  top: -30%;
  z-index: 0;
}

.line03-about-wrap {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  bottom: -20%;
}

.a-article.item-about-01 {
  bottom: -90px;
  left: 80px;
  width: 40px;
}
.a-article.item-about-02 {
  top: 0px;
  right: 20px;
  width: 63px;
}

/* ==========
  18 guide //
========================================================================== */
.section-guide-tab {
  position: relative;
  margin-top: 100px;
  margin-bottom: 120px;
  padding: 0 0 100px;
}
.section-guide-tab::before {
  position: absolute;
  content: "";
  top: 50px;
  left: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
}

.guide-menu-wrap {
  position: relative;
  margin-top: 50px;
  padding: 25px min(6vw, 90px);
  background-color: #fff;
}

.guide-menu-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 35px 1fr 35px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 25px 35px;
}

.tab_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: auto;
  max-width: 250px;
  font-size: 2rem;
  font-weight: bold;
  text-decoration: none;
  background-color: #AFAFAF;
  color: #fff;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  cursor: pointer;
  text-align: center;
  line-height: 1.4em;
  padding: 0.3em 0;
}
.tab_list:hover {
  opacity: 0.7;
}

.guide-menu-select {
  display: block;
  border: dotted;
}

.tab-content {
  display: none; /*初期状態を非表示に*/
}

/*ラジオボタンを全て消す*/
input[name=tab_item] {
  display: none;
}

/*選択されているタブのスタイルを変える*/
#sougou:checked ~ .guide-menu-wrap .guide-menu-list #sougou_list,
#suisen:checked ~ .guide-menu-wrap .guide-menu-list #suisen_list,
#ippan:checked ~ .guide-menu-wrap .guide-menu-list #ippan_list {
  background-color: #E70012;
  color: #fff;
}

/*選択されているタブのコンテンツのみを表示*/
#sougou:checked ~ #sougou_content,
#suisen:checked ~ #suisen_content,
#ippan:checked ~ #ippan_content {
  display: block;
}

.guide-flow {
  position: relative;
  margin-top: 100px;
  margin-bottom: 120px;
  padding: 95px 0 100px;
}
.guide-flow-items {
  margin-top: 40px;
}
.guide-flow-item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 95px;
}
.guide-flow-item::before {
  position: absolute;
  content: "";
  bottom: -55px;
  left: 50%;
  display: inline-block;
  width: 40px;
  height: 40px;
  border-bottom: 5px solid #BC0312;
  border-right: 5px solid #BC0312;
  -webkit-transform: translateX(-50%) rotate(45deg);
          transform: translateX(-50%) rotate(45deg);
}
.guide-flow-item.-last {
  margin-bottom: 0;
}
.guide-flow-item.-last::before {
  display: none;
}
.guide-flow-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  padding: 10px 0;
  width: clamp(36px, 3.74vw, 50px);
  font-size: clamp(1.6rem, 1.5vw, 2rem);
  line-height: 1.1;
  text-align: center;
  color: #fff;
  background-color: #BC0312;
  font-family: "din-2014", sans-serif;
  font-weight: 400;
  font-style: normal;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  text-orientation: sideways;
}
.guide-flow-body {
  padding: 5px 40px 30px;
  width: 100%;
  background-color: #fff;
}
.guide-flow-title {
  margin-top: 25px;
  font-size: clamp(1.6rem, 2.4vw, 2.8rem);
  font-weight: bold;
  line-height: 1.875;
  color: #E70012;
}
.guide-flow-text {
  margin-top: 10px;
  line-height: 1.875;
}
.guide-flow p a {
  position: relative;
  color: #E70012;
  border-bottom: solid 1px #E70012;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

/* ==========
  19 guidelines //
========================================================================== */
.guidelines-lead {
  margin-bottom: -40px;
}
.guidelines-content-info {
  margin-top: 20px;
}
.guidelines-content-info h4 {
  font-size: 1.6rem;
}

.guidelines-table-title {
  margin-top: 50px;
  font-size: clamp(2rem, 2vw, 2.4rem);
  font-weight: bold;
}

.guidelines-table {
  margin-top: 25px;
  width: 100%;
  white-space: nowrap;
}
.guidelines-table.-table01 th {
  width: 20%;
  min-height: 110px;
}
.guidelines-table.-table01 th.cell-1 {
  width: 130px;
}
.guidelines-table.-table01 th.cell-2 {
  width: 226px;
}
.guidelines-table.-table01 th.cell-3 {
  padding-top: 10px;
  min-width: 13%;
}
.guidelines-table.-table01 th.cell-4 {
  padding-top: 10px;
  min-width: 13%;
}
.guidelines-table.-table01 th.cell-5 {
  padding-top: 10px;
  min-width: 13%;
}
.guidelines-table.-table01 th.cell-6 {
  padding-top: 10px;
  min-width: 13%;
}
.guidelines-table.-table01 th.cell-7 {
  min-width: 13%;
}
.guidelines-table.-table02 th {
  min-height: 110px;
}
.guidelines-table.-table02 th.cell-1 {
  width: 130px;
}
.guidelines-table.-table02 th.cell-2 {
  width: 226px;
}
.guidelines-table.-table02 th.cell-3 {
  padding-top: 10px;
  min-width: 16%;
}
.guidelines-table.-table02 th.cell-4 {
  padding-top: 10px;
  min-width: 16%;
}
.guidelines-table.-table02 th.cell-5 {
  min-width: 16%;
}
.guidelines-table.-table02 th.cell-6 {
  min-width: 16%;
}
.guidelines-table.-table02 .note {
  bottom: 20px;
}
.guidelines-table.-table03 {
  margin-top: 40px;
}
.guidelines-table.-table03 th {
  width: 20%;
  font-size: clamp(1.6rem, 1.8vw, 2rem);
}
.guidelines-table.-table03 th.cell-1 {
  min-width: 260px;
}
.guidelines-table.-table03 th.cell-2 {
  min-width: 260px;
}
.guidelines-table th {
  position: relative;
  padding: 2px 0 0;
  height: 55px;
  font-size: clamp(1.3rem, 1.2vw, 1.6rem);
  line-height: 1.25;
  text-align: center;
  color: #fff;
  background-color: #E70012;
  border-left: 1px solid #F3EDEB;
}
.guidelines-table th .cell-1 {
  position: sticky;
  width: 130px;
}
.guidelines-table th .cell-2 {
  width: 226px;
}
.guidelines-table th.-no {
  border-left: none;
}
.guidelines-table th .note {
  position: absolute;
  right: 0;
  bottom: 10px;
  left: 0;
  margin: 0 auto;
  width: calc(100% - 6px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 2px 5px;
  min-height: 35px;
  font-weight: normal;
  text-align: center;
  font-size: 1.2rem;
  color: #212121;
  background-color: #F3EDEB;
}
.guidelines-table td {
  margin: auto auto;
  padding: 0 10px;
  height: 60px;
  font-size: clamp(1.3rem, 1.2vw, 1.6rem);
  line-height: 1.5625;
  background: #F8F8F8;
  border: 1px solid #F3EDEB;
}
.guidelines-table td.td-title {
  line-height: 1.25;
}
.guidelines-table tr:nth-child(odd) td {
  background: #fff;
}

.scroll-wrap {
  padding-bottom: 30px;
  margin-bottom: 20px;
}

.simplebar-track.simplebar-horizontal {
  height: 6px;
  background-color: #A8A8A8;
  border-radius: 0;
  max-width: calc(100% - 15px);
  margin: 0 0;
}

.simplebar-scrollbar {
  height: 6px;
  background-color: #BC0312;
  border-radius: 0;
  top: 0;
  width: 140px;
}

/* ==========
 21 qualification_contest-results
========================================================================== */
.contest-results {
  margin-top: 80px;
  padding-bottom: 20px;
}
.contest-results-wrap {
  margin-top: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
.contest-results-wrap-2 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 35px 1fr 35px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 25px 35px;
  margin-top: 50px;
}
.contest-results-data {
  margin-top: 66px;
  background-color: #fff;
}
.contest-results-data-title {
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-size: clamp(2rem, 3.2vw, 3.2rem);
}
.contest-results-data-text {
  margin-top: 20px;
  line-height: 2.1875;
}
.contest-results-data-text strong {
  color: #BC0312;
  font-weight: normal;
}
.contest-results-data-content {
  padding: 40px 40px 30px;
}
.contest-results-data-tag {
  padding: 20px 40px;
  background-color: #E70012;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-height: 90px;
}
.contest-results-data-tag-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-left: solid 1px #fff;
}
.contest-results-data-tag-content + .contest-results-data-tag-content {
  border-top: solid 1px #fff;
}
.contest-results-data-tag-content.-no-border {
  border-left: none;
}
.contest-results-data-tag-title {
  padding: 15px 0px 15px 10px;
  color: #fff;
  font-weight: bold;
  font-size: clamp(1.4rem, 1.15vw, 1.6rem);
  min-width: min(11.98vw, 160px);
}
.contest-results-data-tag-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 5px 15px;
  font-weight: bold;
  margin-bottom: 5px;
}
.contest-results-data-tag-list li {
  padding: 4px 10px;
  display: inline-block;
  font-size: clamp(1.2rem, 1vw, 1.4rem);
  color: #E70012;
  background-color: #fff;
}

.contest-results-image {
  position: relative;
}
.contest-results-image img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.contest-results-image.item-01 {
  width: 37%;
  height: 100%;
  max-height: 370px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.contest-results-image.item-01 .contest-results-image-title {
  top: 30px;
  font-size: 2.4rem;
  color: #fff;
}
.contest-results-image.item-01 .contest-results-image-title .-txt01 {
  padding-top: 5px;
}
.contest-results-image.item-01 .contest-results-image-name {
  position: absolute;
  bottom: 40px;
  right: 25px;
  color: #fff;
}
.contest-results-image.item-02 {
  width: 100%;
  max-width: 310px;
}
.contest-results-image.item-02 img {
  aspect-ratio: 310/250;
  height: auto;
}
.contest-results-image-icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  text-align: center;
  position: absolute;
  content: "";
  width: 100px;
  height: 100px;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  color: #fff;
}
.contest-results-image-icon .icon-text-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
.contest-results-image-icon.-icon01 {
  bottom: 15px;
  left: 15px;
  width: clamp(100px, 11.23vw, 150px);
  height: clamp(80px, 8.98vw, 120px);
  background: URL("../images/contest-results/ico_01.png") no-repeat;
  background-size: cover;
}
.contest-results-image-icon.-icon01 .-txt01 {
  font-size: clamp(1.3rem, 1.2vw, 1.6rem);
}
.contest-results-image-icon.-icon01 .-txt02 {
  font-size: clamp(3rem, 3.29vw, 4.4rem);
  line-height: 1;
}
.contest-results-image-icon.-icon01 .-txt03 {
  font-size: clamp(2rem, 1.8vw, 2.4rem);
  line-height: 1.2;
}
.contest-results-image-icon.-icon02 {
  top: 15px;
  left: 20px;
  width: clamp(57px, 7.49vw, 100px);
  height: clamp(57px, 7.49vw, 100px);
  background: URL("../images/contest-results/ico_02.png") no-repeat;
  background-size: cover;
}
.contest-results-image-icon.-icon02 .-txt01 {
  font-size: clamp(1.4rem, 1.5vw, 2rem);
}
.contest-results-image-title {
  position: absolute;
  top: 20px;
  right: 15px;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-weight: bold;
  font-size: 2rem;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  color: #fff;
}
.contest-results-image-title .-txt01 {
  font-size: 1.2rem;
}
.contest-results-image-name {
  margin-top: 20px;
  line-height: 1.2;
}
.contest-results-image-name .-txt01 {
  display: block;
  padding-bottom: 7px;
  font-size: 1.2rem;
}
.contest-results-image-name .-txt02 {
  font-size: 2rem;
  font-weight: bold;
}
.contest-results-image-name .-txt03 {
  font-size: 1.2rem;
  font-weight: bold;
}
.contest-results-image-label {
  position: absolute;
  bottom: 20px;
  font-weight: bold;
}
.contest-results-image-label .-txt01 {
  display: inline-block;
  padding: 1px 10px;
  font-size: clamp(1.6rem, 1.5vw, 2rem);
  line-height: 1.7;
  color: #BC0312;
  background-color: #fff;
}
.contest-results-image-label .-txt02 {
  display: inline-block;
  padding: 1px 10px;
  font-size: clamp(2rem, 1.8vw, 2.4rem);
  line-height: 1.35;
  color: #BC0312;
  background-color: #fff;
}
.contest-results-image-label .-txt03 {
  display: inline-block;
  padding: 3px 10px;
  font-size: clamp(1.3rem, 1.4vw, 1.6rem);
  color: #212121;
  background-color: #fff;
}

/* ==========
 20 qualification_exam
========================================================================== */
.exam-lead-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 50px;
}
.exam-lead-content {
  width: 48%;
}
.exam-lead-title {
  margin-top: 50px;
  font-size: 2.4rem;
  font-weight: bold;
  color: #E70012;
}
.exam-lead-text {
  margin-top: 25px;
  line-height: 2.1875;
}

.exam-card-item {
  margin-top: -60px;
  width: 47%;
  height: 100%;
  max-height: 329px;
  padding: 22px 20px;
  border-top: solid 10px #E70012;
  background-color: #fff;
}
.exam-card-title {
  margin: 10px auto;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-weight: bold;
  font-size: clamp(2.9rem, 3.59vw, 4.8rem);
  text-align: center;
}
.exam-card-icon {
  position: absolute;
  margin-top: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-weight: bold;
  font-size: clamp(2rem, 2.1vw, 2.8rem);
  line-height: 1.25;
  text-align: center;
  color: #fff;
  background-color: #212121;
  width: clamp(92px, 9.36vw, 125px);
  height: clamp(92px, 9.36vw, 125px);
  border-radius: 100%;
}
.exam-card-num {
  margin-top: 45px;
  margin-right: 10px;
  margin-left: 80px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-style: italic;
  font-size: clamp(9.3rem, 9.58vw, 12.8rem);
  letter-spacing: 0.55rem;
  line-height: 1;
  text-align: right;
  color: #E70012;
}
.exam-card-num .-small {
  font-size: clamp(6.4rem, 6.59vw, 8.8rem);
}
.exam-card-lead {
  margin-top: 10px;
  font-weight: bold;
  text-align: center;
  background-color: #FFD83D;
}
.exam-card-lead .-txt01 {
  font-size: 2rem;
  color: #E70012;
}

.exam-greeting {
  margin-top: 100px;
}
.exam-greeting .col-wrap {
  position: relative;
  padding-top: 95px;
  padding-bottom: 100px;
}
.exam-greeting .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  right: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #F2DBD7;
  z-index: -1;
}
.exam-greeting-wrap {
  margin-top: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 50px;
     -moz-column-gap: 50px;
          column-gap: 50px;
}
.exam-greeting-content {
  position: relative;
  width: 67%;
}
.exam-greeting-text {
  line-height: 2.1875;
  padding-bottom: 60px;
}
.exam-greeting-image {
  width: 100%;
  height: auto;
  max-width: 287px;
  max-height: 280px;
  aspect-ratio: 287/280;
}
.exam-greeting-image img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.exam-greeting-name {
  position: absolute;
  right: 0;
  bottom: 0;
  font-size: 1.4rem;
  line-height: 1.4;
}
.exam-greeting-name .-txt01 {
  display: block;
  margin-bottom: 5px;
  color: #E70012;
}
.exam-greeting-name .-txt02 {
  font-size: 2.4rem;
  font-weight: bold;
}

.exam-data {
  margin-top: 95px;
}
.exam-data-index {
  margin-top: 50px;
  font-size: 2.4rem;
  font-weight: bold;
  color: #BC0312;
}
.exam-data-items {
  margin-top: 30px;
  padding-bottom: 50px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 35px 1fr 35px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 25px 35px;
}
.exam-data-head {
  padding: 10px;
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  color: #fff;
}
.exam-data-head.-item01 {
  background-color: #E83928;
}
.exam-data-head.-item02 {
  -ms-grid-column: 2;
  -ms-grid-column-span: 2;
  grid-column: 2/span 2;
  background-color: #BC0312;
}
.exam-data-image {
  aspect-ratio: 310/240;
}
.exam-data-image img {
  height: 100%;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.exam-data-title {
  margin-top: 20px;
  font-size: 2rem;
  font-weight: bold;
}
.exam-data-text {
  margin-top: 15px;
  line-height: 2.1875;
}

.exam-data2 {
  margin-top: 30px;
}
.exam-data2 dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 17px;
  min-height: 50px;
  background-color: #fff;
}
.exam-data2 dt {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 157px;
  padding: 12px 15px;
  font-size: clamp(1.6rem, 1.5vw, 2rem);
  font-weight: bold;
  color: #fff;
  background-color: #BC0312;
}
.exam-data2 dd {
  padding: 0 20px;
  font-size: clamp(1.4rem, 1.4vw, 1.6rem);
}

.exam-flow {
  position: relative;
  margin-top: 100px;
  margin-bottom: 120px;
  padding: 95px 0 100px;
}
.exam-flow::before {
  position: absolute;
  content: "";
  top: 0;
  left: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
}
.exam-flow-items {
  margin-top: 40px;
}
.exam-flow-item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 95px;
}
.exam-flow-item::before {
  position: absolute;
  content: "";
  bottom: -55px;
  left: 50%;
  display: inline-block;
  width: 40px;
  height: 40px;
  border-bottom: 5px solid #BC0312;
  border-right: 5px solid #BC0312;
  -webkit-transform: translateX(-50%) rotate(45deg);
          transform: translateX(-50%) rotate(45deg);
}
.exam-flow-item.-last {
  margin-bottom: 0;
}
.exam-flow-item.-last::before {
  display: none;
}
.exam-flow-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  padding: 10px 0;
  width: clamp(36px, 3.74vw, 50px);
  font-size: clamp(1.6rem, 1.5vw, 2rem);
  line-height: 1.1;
  text-align: center;
  color: #fff;
}
.exam-flow-head.-season01 {
  background-color: #E83928;
}
.exam-flow-head.-season02 {
  background-color: #E70012;
}
.exam-flow-head.-season03 {
  background-color: #BC0312;
}
.exam-flow-body {
  padding: 5px 40px 30px;
  width: 100%;
  background-color: #fff;
}
.exam-flow-title {
  margin-top: 25px;
  font-size: clamp(1.6rem, 2.4vw, 2.8rem);
  font-weight: bold;
  line-height: 1.875;
  color: #E70012;
}
.exam-flow-text {
  margin-top: 10px;
  line-height: 1.875;
}

/* ==========
  22 qualification_data 
========================================================================== */
.data-card-items {
  margin-top: 30px;
}
.data-card-items.hair-items-01 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: clamp(15px, 3.74vw, 50px);
     -moz-column-gap: clamp(15px, 3.74vw, 50px);
          column-gap: clamp(15px, 3.74vw, 50px);
}
.data-card-items.hair-items-02 {
  margin-top: 40px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr clamp(10px, 3.29vw, 44px) 1fr clamp(10px, 3.29vw, 44px) 1fr clamp(10px, 3.29vw, 44px) 1fr;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  -webkit-column-gap: clamp(10px, 3.29vw, 44px);
     -moz-column-gap: clamp(10px, 3.29vw, 44px);
          column-gap: clamp(10px, 3.29vw, 44px);
}
.data-card-items.total-items-01 {
  margin-top: 30px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr clamp(10px, 2.99vw, 40px) 1fr clamp(10px, 2.99vw, 40px) 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px clamp(10px, 2.99vw, 40px);
}
.data-card-items.total-items-02 {
  margin-top: 40px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr clamp(10px, 3.29vw, 44px) 1fr clamp(10px, 3.29vw, 44px) 1fr clamp(10px, 3.29vw, 44px) 1fr;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  -webkit-column-gap: clamp(10px, 3.29vw, 44px);
     -moz-column-gap: clamp(10px, 3.29vw, 44px);
          column-gap: clamp(10px, 3.29vw, 44px);
}
.data-card-item {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 15px 15px;
  border-top: solid 6px #008EAA;
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.data-card-item .small{
  font-size:0.8em;
}
.data-card-item.item-hair-01 {
  max-width: 670px;
  min-height: 314px;
  padding: 35px 15px 20px;
}
.data-card-item.item-hair-01 .data-card-body {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-column-gap: 40px;
     -moz-column-gap: 40px;
          column-gap: 40px;
  margin-top: 40px;
}
.data-card-item.item-hair-01 .data-card-en {
  top: 15px;
  font-size: 4rem;
}
.data-card-item.item-hair-01 .data-card-title {
  text-align: center;
  font-size: clamp(2.4rem, 2.99vw, 4rem);
}
.data-card-item.item-hair-01 .data-card-wrap {
  margin-top: 20px;
  margin-bottom: 10px;
  -webkit-column-gap: 30px;
     -moz-column-gap: 30px;
          column-gap: 30px;
}
.data-card-item.item-hair-01 .data-card-num-title {
  margin-top: 5px;
  font-size: 2.8rem;
}
.data-card-item.item-hair-01 .data-card-num .-txt01 {
  font-size: clamp(5.6rem, 7.11vw, 9.5rem);
}
.data-card-item.item-hair-01 .data-card-num .-txt02 {
  font-size: clamp(4.4rem, 5.16vw, 6.9rem);
}
.data-card-item.item-hair-01 .data-card-num .-txt03 {
  font-size: clamp(2.8rem, 3.82vw, 5.1rem);
}
.data-card-item.item-hair-01 .data-card-num.-sub .data-card-num-title {
  font-size: 1.5rem;
}
.data-card-item.item-hair-01 .data-card-num.-sub .-txt01 {
  font-size: clamp(2.8rem, 5.1vw, 5.1rem);
}
.data-card-item.item-hair-01 .data-card-num.-sub .-txt02 {
  font-size: clamp(2rem, 3.8vw, 3.8rem);
}
.data-card-item.item-hair-01 .data-card-num.-sub .-txt03 {
  font-size: clamp(1.6rem, 3vw, 3rem);
}
.data-card-item.item-hair-02 {
  max-width: 280px;
  min-height: 314px;
  padding: 30px 15px;
}
.data-card-item.item-hair-02 .data-card-en {
  top: 15px;
  font-size: 4rem;
}
.data-card-item.item-hair-02 .data-card-title {
  font-size: 2.4rem;
  text-align: center;
}
.data-card-item.item-hair-02 .data-card-body {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 40px;
}
.data-card-item.item-hair-02 .data-card-icon {
  width: 70px;
  height: 70px;
  font-size: 1.4rem;
}
.data-card-item.item-hair-02 .data-card-icon .data-card-num-title {
  font-size: 2rem;
}
.data-card-item.item-hair-02 .data-card-num-title {
  font-size: 2rem;
}
.data-card-item.item-hair-02 .data-card-num .-txt01 {
  font-size: clamp(4.8rem, 7.2vw, 7.2rem);
}
.data-card-item.item-hair-02 .data-card-num .-txt02 {
  font-size: clamp(3.4rem, 6vw, 6rem);
}
.data-card-item.item-hair-02 .data-card-num .-txt03 {
  font-size: clamp(2.8rem, 4.2vw, 4.2rem);
}
.data-card-item.item-hair-02 .data-card-text {
  font-size: clamp(1.2rem, 1.4vw, 1.4rem);
  text-align: center;
}
.data-card-item.item-hair-03 {
  max-width: 217px;
  min-height: 205px;
}
.data-card-item.item-total-01 {
  max-width: 306px;
  min-height: 290px;
  padding: 20px 20px 20px;
  border-top-color: #A51890;
}
.data-card-item.item-total-01 .data-card-en {
  top: 5px;
  font-size: 4rem;
  -webkit-text-stroke: 1px #A51890;
}
.data-card-item.item-total-01 .data-card-title {
  font-size: clamp(1.6rem, 2.8vw, 2.8rem);
}
.data-card-item.item-total-01 .data-card-title .-txt01 {
  font-size: 1.4rem;
  padding-bottom: 5px;
}
.data-card-item.item-total-01 .data-card-body {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-top: 20px;
}
.data-card-item.item-total-01 .data-card-icon {
  width: clamp(76px, 8.2vw, 82px);
  height: clamp(76px, 8.2vw, 82px);
  font-size: 1.2rem;
  background-color: #A51890;
}
.data-card-item.item-total-01 .data-card-icon .data-card-num-title {
  font-size: 2rem;
}
.data-card-item.item-total-01 .data-card-num {
  /* .-txt02{
   font-size: clamp(3.0rem,5.0vw,5.0rem);
   }*/
}
.data-card-item.item-total-01 .data-card-num-title {
  font-size: clamp(1.4rem, 2vw, 2rem);
}
.data-card-item.item-total-01 .data-card-num .-txt01 {
  font-size: clamp(4.8rem, 5.6vw, 5.6rem);
}
.data-card-item.item-total-01 .data-card-num .-txt03 {
  font-size: clamp(2.8rem, 3.6vw, 3.6rem);
}
.data-card-item.item-total-01 .data-card-text {
  font-size: clamp(1.2rem, 1.6vw, 1.6rem);
}
.data-card-item.item-total-02 {
  max-width: 306px;
  min-height: 290px;
  padding: 15px 20px 20px;
  border-top-color: #A51890;
}
.data-card-item.item-total-02 .data-card-en {
  top: 5px;
  font-size: clamp(2rem, 4vw, 4rem);
  -webkit-text-stroke: 1px #A51890;
}
.data-card-item.item-total-02 .data-card-title {
  margin-top: 10px;
  font-size: clamp(1.6rem, 2.8vw, 2.8rem);
}
.data-card-item.item-total-02 .data-card-title .-txt01 {
  font-size: 1.4rem;
  padding-bottom: 5px;
}
.data-card-item.item-total-02 .data-card-body {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-top: 20px;
}
.data-card-item.item-total-02 .data-card-icon {
  width: 82px;
  height: 82px;
  font-size: 1.2rem;
  background-color: #A51890;
}
.data-card-item.item-total-02 .data-card-icon .data-card-num-title {
  font-size: 2rem;
}
.data-card-item.item-total-02 .data-card-num-title {
  font-size: clamp(1.2rem, 2vw, 2rem);
}
.data-card-item.item-total-02 .data-card-num .-txt01 {
  font-size: clamp(3.6rem, 5.6vw, 5.6rem);
}
.data-card-item.item-total-02 .data-card-num .-txt02 {
  font-size: clamp(3rem, 5vw, 5rem);
}
.data-card-item.item-total-02 .data-card-num .-txt03 {
  font-size: clamp(2rem, 3.6vw, 3.6rem);
}
.data-card-item.item-total-02 .data-card-text {
  font-size: clamp(1.2rem, 1.6vw, 1.6rem);
}
.data-card-item.item-total-03 {
  max-width: 217px;
  min-height: 205px;
  border-top-color: #A51890;
}
.data-card-item.item-total-03 .data-card-en {
  -webkit-text-stroke: 1px #A51890;
}
.data-card-item.item-total-03 .data-card-icon {
  width: 57px;
  height: 57px;
  font-size: 0.9rem;
  background-color: #A51890;
}
.data-card-en {
  position: absolute;
  top: 0px;
  right: 5px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  letter-spacing: 0.25rem;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  text-orientation: sideways;
  color: transparent;
  -webkit-text-stroke: 1px #008EAA;
  font-size: 2.8rem;
  line-height: 1;
  opacity: 0.2;
}
.data-card-title {
  margin: 0 auto;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-weight: bold;
  font-size: clamp(1.6rem, 2vw, 2rem);
  line-height: 1.2;
}
.data-card-title .-txt01 {
  display: block;
  font-size: 1.2rem;
  line-height: 1.5;
  padding-bottom: 5px;
}
.data-card-title .-txt01.-small {
  font-size: 1rem;
}
.data-card-title .-txt01.-small-sp {
  font-size: 1rem;
}
.data-card-title .-label {
  display: inline-block;
  padding: 1px 2px;
  margin-left: 5px;
  font-size: 1rem;
  background-color: #212121;
  color: #fff;
}
.data-card-title-lead {
  font-size: clamp(1.2rem, 1.4vw, 1.4rem);
  font-weight: bold;
  text-align: center;
}
.data-card-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 5px;
     -moz-column-gap: 5px;
          column-gap: 5px;
  margin-top: 25px;
}
.data-card-wrap {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-column-gap: 5px;
     -moz-column-gap: 5px;
          column-gap: 5px;
}
.data-card-icon {
  position: relative;
  top: -5px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-weight: bold;
  font-size: 1.2rem;
  line-height: 1.25;
  text-align: center;
  color: #fff;
  background-color: #008EAA;
  width: clamp(50px, 4.27vw, 57px);
  height: clamp(50px, 4.27vw, 57px);
  border-radius: 100%;
}
.data-card-num {
  font-family: "din-2014", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-weight: bold;
  font-style: italic;
  letter-spacing: 0.25rem;
  line-height: 1;
  color: #E70012;
}
.data-card-num-title {
  margin-left: 5px;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-style: normal;
  font-weight: bold;
  font-size: 1.6rem;
  color: #212121;
}
.data-card-num .-txt01 {
  font-size: clamp(3.6rem, 4vw, 4rem);
}
.data-card-num .-txt02 {
  font-size: clamp(2.4rem, 3vw, 3rem);
}
.data-card-num .-txt03 {
  font-size: clamp(2rem, 2.4vw, 2.4rem);
}
.data-card-lead {
  position: relative;
  margin-top: 10px;
  margin-bottom: 10px;
  padding: 5px;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-weight: bold;
  font-size: clamp(1.2rem, 1.6vw, 1.6rem);
  text-align: center;
  background-color: #FFD83D;
}
.data-card-lead .-txt01 {
  font-size: clamp(1.6rem, 2vw, 2rem);
  color: #E70012;
}
.data-card-text {
  font-size: 1.2rem;
}

.data-total-content {
  margin-top: 100px;
  padding-bottom: 25px;
}

/* ==========
  15 campus-life 
========================================================================== */
.section-campuslife-item {
  margin-bottom: 200px;
}

.campuslife-items {
  position: relative;
  margin-top: -140px;
}
.campuslife-items .col-wrap {
  position: relative;
}
.campuslife-items .col-wrap::before {
  position: absolute;
  content: "";
  top: 48px;
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
  z-index: -1;
}
.campuslife-items .col-wrap.-r::before {
  right: min(30vw, 420px);
}
.campuslife-items .col-wrap.-l::before {
  left: min(30vw, 420px);
}

.campuslife-item-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 190px;
  -webkit-column-gap: 100px;
     -moz-column-gap: 100px;
          column-gap: 100px;
}
.campuslife-item-wrap.item01 {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
.campuslife-item-wrap.item01 .campuslife-item-image {
  margin-right: -63px;
}
.campuslife-item-wrap.item01 .campuslife-item-image .img01 {
  position: absolute;
  top: -10px;
  right: 0;
  width: clamp(226px, 30vw, 400px);
}
.campuslife-item-wrap.item01 .campuslife-item-image .img02 {
  position: absolute;
  top: min(19vw, 255px);
  left: max(-5vw, -63px);
  width: clamp(149px, 18vw, 249px);
}
.campuslife-item-wrap.item01 .campuslife-item-image .img03 {
  position: absolute;
  top: min(14vw, 180px);
  right: min(5vw, 63px);
  width: clamp(108px, 15vw, 196px);
}
.campuslife-item-wrap.item01 .campuslife-item-text {
  max-width: 400px;
}
.campuslife-item-wrap.item02 {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
.campuslife-item-wrap.item02 .campuslife-item-image {
  margin-left: -63px;
}
.campuslife-item-wrap.item02 .campuslife-item-image .img01 {
  position: absolute;
  top: 90px;
  left: 0;
  width: clamp(217px, 28vw, 385px);
}
.campuslife-item-wrap.item02 .campuslife-item-image .img02 {
  position: absolute;
  top: -30px;
  right: 0;
  width: clamp(180px, 18vw, 249px);
}
.campuslife-item-wrap.item02 .campuslife-item-image .img03 {
  position: absolute;
  top: min(14vw, 190px);
  right: min(-3vw, -50px);
  width: clamp(117px, 15vw, 195px);
}
.campuslife-item-wrap.item02 .campuslife-item-title::before {
  right: 0;
  left: inherit;
}
.campuslife-item-wrap.item03 {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
.campuslife-item-wrap.item03 .campuslife-item-image {
  margin-right: -63px;
}
.campuslife-item-wrap.item03 .campuslife-item-image .img01 {
  position: absolute;
  top: -10px;
  right: min(5vw, 63px);
  width: clamp(225px, 33vw, 440px);
}
.campuslife-item-wrap.item03 .campuslife-item-image .img02 {
  position: absolute;
  top: min(19vw, 250px);
  right: 0;
  width: clamp(149px, 19vw, 264px);
}
.campuslife-item-wrap.item03 .campuslife-item-image .img03 {
  position: absolute;
  top: min(14vw, 180px);
  left: max(-4vw, -45px);
  width: clamp(126px, 18vw, 219px);
}
.campuslife-item-wrap.item03 .campuslife-item-text {
  max-width: 400px;
}
.campuslife-item-content {
  margin-top: -35px;
  margin-bottom: 10px;
  max-width: 480px;
}
.campuslife-item-num {
  font-family: "din-2014", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 8.8rem;
  letter-spacing: 0.25rem;
  color: transparent;
  -webkit-text-stroke: 2px #BC0312;
}
.campuslife-item-title {
  position: relative;
  font-size: min(3.2vw, 3.2rem);
  font-weight: bold;
  line-height: 1.5625;
  color: #BC0312;
  margin-top: 10px;
  padding-bottom: 12px;
}
.campuslife-item-title::before {
  position: absolute;
  content: "";
  left: 0;
  bottom: 0;
  width: min(52vw, 718px);
  height: 1px;
  background-color: #212121;
}
.campuslife-item-text {
  max-width: 480px;
  margin-top: 20px;
  margin-bottom: 20px;
  line-height: 2.1875;
}
.campuslife-item-image {
  position: relative;
  max-height: 453px;
  width: 48%;
}
.campuslife-item-image img {
  width: 100%;
  height: auto;
}

.campuslife-gallery {
  margin-top: 100px;
}
.campuslife-gallery-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100vw;
  overflow: hidden;
}
.campuslife-gallery-wrap-sp {
  display: none;
}
.campuslife-gallery-images {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.campuslife-gallery-image {
  height: clamp(130px, 21.96vw, 300px);
  margin-right: clamp(20px, 2.93vw, 40px);
  aspect-ratio: 400/300;
}
.campuslife-gallery-image img {
  height: 100%;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

/* campuslife-cta */
.campuslife-cta {
  margin-top: 100px;
  margin-bottom: 100px;
  padding: 60px 40px 50px;
  text-align: center;
  outline: solid 2px #fff;
  outline-offset: -17px;
  color: #fff;
  background: #BC0312 URL("../images/campus-life/bg_cta.webp") 0 0;
  background-size: cover;
}
.campuslife-cta-title {
  font-size: clamp(2rem, 3vw, 3.2rem);
  font-weight: bold;
  line-height: 1.458;
}
.campuslife-cta .btn-wh {
  margin: 40px auto 0;
}

.section-campuslife-menu {
  position: relative;
}
.section-campuslife-menu .col-wrap {
  position: relative;
  padding: 100px 0 100px;
}
.section-campuslife-menu .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  right: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #F2DBD7;
  z-index: -3;
}

.campuslife-menu {
  position: relative;
  width: 100%;
  max-width: 475px;
}
.campuslife-menu-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 50px;
     -moz-column-gap: 50px;
          column-gap: 50px;
}
.campuslife-menu-image {
  display: block;
  max-width: 475px;
  max-height: 320px;
}
.campuslife-menu-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.campuslife-menu .btn-icon-link {
  position: relative;
  padding-top: 25px;
  padding-bottom: 15px;
  width: 100%;
  height: inherit;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 2.8rem;
}

.line01-campuslife-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  top: -190px;
  z-index: 1;
}

.a-article.item-c-01 {
  bottom: -120px;
  left: 100px;
  width: 113px;
}
.a-article.item-c-02 {
  bottom: -120px;
  right: 110px;
  width: 132px;
}
.a-article.item-c-03 {
  bottom: -130px;
  left: 110px;
  width: 130px;
}
.a-article.item-c-04 {
  bottom: -70px;
  left: 290px;
  width: 53px;
}
.a-article.item-c-05 {
  top: -70px;
  left: 90px;
  width: 66px;
}
.a-article.item-c-06 {
  top: 80px;
  right: 80px;
  width: 59px;
}
.a-article.item-c-07 {
  bottom: -60px;
  right: 100px;
  width: 74px;
}

/* ==========
  16 campus-life/school-event/
========================================================================== */
.school-event-lead-title {
  margin-top: 30px;
  font-size: clamp(1.6rem, 1.8vw, 2.4rem);
  font-weight: bold;
  color: #BC0312;
}
.school-event-lead-text {
  margin-top: 30px;
  line-height: 2.1875;
}

.school-event-items {
  margin-top: 45px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 50px 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 70px 50px;
}
.school-event-image {
  position: relative;
  width: 100%;
  height: auto;
  aspect-ratio: 475/220;
}
.school-event-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.school-event-month {
  position: absolute;
  bottom: -30px;
  right: 5px;
  line-height: 1;
  color: #BC0312;
}
.school-event-month .-txt01 {
  font-family: "din-2014", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(5.6rem, 6.59vw, 8.8rem);
}
.school-event-month .-txt02 {
  margin-left: 5px;
  font-size: clamp(3.2rem, 3.59vw, 4.8rem);
  font-weight: bold;
}
.school-event-title {
  margin-top: 25px;
  font-size: clamp(2rem, 1.8vw, 2.4rem);
  line-height: 1.666;
  font-weight: bold;
}
.school-event-list {
  margin-top: 10px;
  line-height: 1.85;
}
.school-event-list li {
  position: relative;
  margin-left: 1em;
  text-indent: -1em;
  text-align: left;
}
.school-event-list li::before {
  position: relative;
  content: "";
  display: inline-block;
  margin-right: 0.5em;
  width: 10px;
  height: 10px;
  background-color: #E70012;
}

/* ==========
  17 campus-life/beauty-contest/
========================================================================== */
.beauty-contest-lead-text {
  margin-top: 40px;
  line-height: 2.1875;
}

.beauty-contest-gallery {
  margin-top: 90px;
}
.beauty-contest-gallery-title {
  margin-top: 10px;
  font-size: 3.2rem;
  font-weight: bold;
  color: #BC0312;
}
.beauty-contest-gallery-text {
  margin-top: 40px;
  line-height: 2.1875;
}
.beauty-contest-gallery-list {
  margin-top: 30px;
  padding-bottom: 10px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 7px 1fr 7px 1fr 7px 1fr;
  grid-template-columns: repeat(4, 1fr);
  gap: 7px 7px;
}
.beauty-contest-gallery-list li {
  width: 100%;
  height: auto;
  aspect-ratio: 245/162;
}
.beauty-contest-gallery-list li img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/* ==========
  12 career support //
========================================================================== */
.support-lead-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 50px;
}
.support-lead-content {
  width: 48%;
}
.support-lead-title {
  margin-top: 40px;
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.666;
  color: #E70012;
}
.support-lead-text {
  margin-top: 20px;
  line-height: 2.1875;
}

.support-card-item {
  margin-top: -70px;
  width: 47%;
  height: 100%;
  max-height: 329px;
  padding: 22px 20px;
  border-top: solid 10px #E70012;
  background-color: #fff;
}
.support-card-nai_image {
  padding:0;
  border: none;
}
.support-card-title {
  margin: 20px auto 0;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-weight: bold;
  font-size: clamp(2.9rem, 3.59vw, 4rem);
  text-align: center;
}
.support-card-icon {
  position: absolute;
  margin-top: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-weight: bold;
  font-size: clamp(2rem, 2.1vw, 2.8rem);
  line-height: 1.25;
  text-align: center;
  color: #fff;
  background-color: #212121;
  width: clamp(92px, 9.36vw, 125px);
  height: clamp(92px, 9.36vw, 125px);
  border-radius: 100%;
}
.support-card-num {
  margin-top: 45px;
  margin-right: 10px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-style: italic;
  font-size: clamp(9.3rem, 9.58vw, 12.8rem);
  letter-spacing: 0.55rem;
  line-height: 1;
  text-align: right;
  color: #E70012;
}
.support-card-num .-small {
  font-size: clamp(6.4rem, 6.59vw, 8.8rem);
}
.support-card-lead {
  margin-top: 10px;
  font-weight: bold;
  text-align: center;
  background-color: #FFD83D;
}
.support-card-lead .-txt01 {
  font-size: 2rem;
  color: #E70012;
}

.section-support-item .col-wrap {
  position: relative;
  margin-top: 100px;
  padding: 90px 0 100px;
}
.section-support-item .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  left: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
  z-index: -1;
}

.support-items {
  margin-top: 30px;
}
.support-items-title {
  margin-top: 40px;
  font-size: clamp(1.6rem, 2vw, 2.4rem);
  font-weight: bold;
  line-height: 1.875;
}
.support-items-lead {
  margin-top: 60px;
  font-size: clamp(1.6rem, 2vw, 2.4rem);
  font-weight: bold;
  line-height: 1.666;
}

.support-item {
  margin-top: 100px;
  padding: 0 45px 45px 30px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 35px;
     -moz-column-gap: 35px;
          column-gap: 35px;
  counter-increment: number;
  background-color: #fff;
}
.support-item-image {
  position: relative;
  margin-top: -40px;
  left: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: clamp(144px, 20vw, 250px);
  height: clamp(144px, 20vw, 250px);
  z-index: 0;
}
.support-item-image img {
  overflow: hidden;
  width: 100%;
  height: 100%;
  border-radius: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.support-item-image::before {
  position: absolute;
  content: "";
  bottom: -8px;
  left: 0;
  width: clamp(144px, 20vw, 250px);
  height: clamp(144px, 20vw, 250px);
  border-radius: 100%;
  background-color: #BC0312;
  z-index: -1;
}
.support-item-num {
  font-family: "din-2014", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 8.8rem;
  letter-spacing: 0.25rem;
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 2px #BC0312;
  margin-top: -50px;
}
.support-item-title {
  margin-top: 15px;
  font-size: clamp(2rem, 2.4vw, 3.2rem);
  line-height: 1.45;
  font-weight: bold;
  color: #BC0312;
}
.support-item-text {
  margin-top: 20px;
  line-height: 2.1875;
}

.section-support-career {
  margin-top: 95px;
  padding-bottom: 20px;
}

.support-career {
  position: relative;
  background-color: #fff;
  margin-top: 40px;
  /* &-group{
    margin-bottom: 100px;
    .m-index-title{
     margin-bottom: 20px;
    }
   }*/
}

.support-career-title {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 100px;
  margin: 0;
  padding: 30px 70px 30px 35px;
  font-size: 2.4rem;
  font-weight: bold;
  color: #BC0312;
  cursor: pointer;
}
.support-career-title::after {
  position: absolute;
  content: "";
  top: 50%;
  right: 35px;
  width: 16px;
  height: 16px;
  border-right: none;
  border-bottom: none;
  border-right: 3px solid #212121;
  border-bottom: 3px solid #212121;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}
.support-career-title.is-active {
  position: relative;
}
.support-career-title.is-active::after {
  position: absolute;
  content: "";
  top: 50%;
  right: 30px;
  bottom: 0;
  width: 15px;
  height: 15px;
  border-right: none;
  border-bottom: none;
  border-left: 3px solid #212121;
  border-top: 3px solid #212121;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}

.support-career-text {
  display: none;
  position: relative;
  padding: 0 35px 30px 35px;
  line-height: 2.1875;
}

.support-career-list {
  margin-top: 10px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr clamp(10px, 2.25vw, 30px) 1fr clamp(10px, 2.25vw, 30px) 1fr clamp(10px, 2.25vw, 30px) 1fr;
  grid-template-columns: repeat(4, 1fr);
  -webkit-column-gap: clamp(10px, 2.25vw, 30px);
     -moz-column-gap: clamp(10px, 2.25vw, 30px);
          column-gap: clamp(10px, 2.25vw, 30px);
  line-height: 1.35;
}
.support-career-list li {
  position: relative;
  margin-bottom: 1em;
  margin-left: 1em;
  text-indent: -1em;
  text-align: left;
}
.support-career-list li::before {
  position: relative;
  content: "";
  display: inline-block;
  margin-right: 0.5em;
  width: 10px;
  height: 10px;
  background-color: #E70012;
}
.support-career-list li .-txt01 {
  font-size: 1.2rem;
}

/* ==========
  13 career system //
========================================================================== */
.system-lead-title {
  margin-top: 50px;
  font-size: 2.4rem;
  font-weight: bold;
  color: #BC0312;
}
.system-lead-text {
  margin-top: 25px;
  line-height: 1.875;
}

.section-system-item {
  position: relative;
  margin-top: 100px;
}
.section-system-item .col-wrap {
  position: relative;
  padding-top: 95px;
  padding-bottom: 100px;
}
.section-system-item .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
  z-index: -3;
}

.system-items {
  position: relative;
}

.system-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 95px;
  -webkit-column-gap: 55px;
     -moz-column-gap: 55px;
          column-gap: 55px;
}
.system-item.item01 {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  padding-bottom: 90px;
}
.system-item.item01 .system-item-image {
  margin-top: -50px;
}
.system-item.item01 .system-item-image .img01 {
  position: absolute;
  top: 0;
  right: 0;
  width: clamp(287px, 30vw, 397px);
}
.system-item.item01 .system-item-image .img02 {
  position: absolute;
  bottom: 0;
  left: 0;
  width: clamp(188px, 18vw, 249px);
}
.system-item.item02 {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
.system-item.item02 .system-item-image {
  margin-top: -70px;
}
.system-item.item02 .system-item-image .img01 {
  position: absolute;
  top: 0;
  right: 0;
  width: clamp(198px, 20vw, 273px);
}
.system-item.item02 .system-item-image .img02 {
  position: absolute;
  bottom: 0;
  left: 0;
  width: clamp(225px, 22.84vw, 312px);
}
.system-item-content {
  width: 46.8%;
}
.system-item-title {
  margin-top: 10px;
  font-size: 3.2rem;
  font-weight: bold;
  color: #BC0312;
}
.system-item-text {
  margin-top: 30px;
  line-height: 2.1875;
}
.system-item-image {
  position: relative;
  width: 47.7%;
  height: clamp(300px, 30.38vw, 415px);
}

.system-interview-items {
  margin-top: -10px;
}

.system-interview {
  margin-top: 95px;
  margin-bottom: 125px;
}
.system-interview-item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 50px;
  background-color: #fff;
}
.system-interview-item::after {
  position: absolute;
  content: "";
  bottom: 0;
  height: 5px;
  width: 100%;
  background-color: #E70012;
}
.system-interview-content {
  position: relative;
  padding: 55px 40px 75px;
  width: 84.3%;
}
.system-interview-title {
  font-size: 2.4rem;
  font-weight: bold;
  color: #BC0312;
}
.system-interview-text {
  margin-top: 25px;
  padding-bottom: 25px;
  line-height: 2.1875;
}
.system-interview-name {
  position: absolute;
  right: 30px;
  bottom: 35px;
  margin-top: 15px;
  font-size: min(1.4vw, 1.4rem);
  line-height: 1.4;
}
.system-interview-name .-txt01 {
  display: block;
  margin-bottom: 5px;
  color: #E70012;
}
.system-interview-name .-txt02 {
  font-size: min(2.4vw, 2.4rem);
  font-weight: bold;
}
.system-interview-name .-txt03 {
  margin-left: 5px;
  font-weight: bold;
}
.system-interview-image {
  position: relative;
}
.system-interview-image .-en {
  position: relative;
  top: 15px;
  right: 15px;
}
.system-interview-image .-image {
  position: absolute;
  content: "";
  width: min(10.93vw, 146px);
  bottom: 0;
  right: 30px;
}

.line01-system-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  top: 52%;
}

.a-article.item-system-01 {
  top: 54%;
  left: -60px;
  width: 40px;
  z-index: 1;
}

/* ==========
  03 about_teachers
========================================================================== */
.line03-t-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  top: -120px;
  z-index: 1;
}

.line04-t-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-top: -16.5%;
  z-index: 1;
}
.line04-t-wrap .svg-elem-2 {
  display: none;
}

.a-article.item-t-01 {
  top: -160px;
  right: 80px;
  width: 110px;
}
.a-article.item-t-02 {
  bottom: 20%;
  right: 70px;
  width: 91px;
}
.a-article.item-t-03 {
  top: -10px;
  left: 90px;
  width: 38px;
}
.a-article.item-t-04 {
  top: -50px;
  right: 130px;
  width: 63px;
}

.teachers-lead {
  margin-bottom: 100px;
}
.teachers-lead-title {
  margin-top: 30px;
  font-size: 2.4rem;
  font-weight: bold;
}
.teachers-lead-text {
  margin-top: 30px;
  line-height: 1.875;
}

.section-teachers-01 .col-wrap {
  position: relative;
  padding: 100px 0 100px;
}
.section-teachers-01 .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  right: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #F2DBD7;
  z-index: -3;
}
.section-teachers-01 .col-inner {
  position: relative;
}

.section-teachers-02 {
  position: relative;
}
.section-teachers-02 .col-wrap {
  position: relative;
  padding: 100px 0 100px;
}

.section-teachers-03 .col-wrap {
  position: relative;
  padding: 100px 0 100px;
}
.section-teachers-03 .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  left: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
  z-index: -3;
}

.teacher-items {
  margin-top: 50px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 58px 1fr 58px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 50px 58px;
}

.teacher-item {
  position: relative;
}
.teacher-item-image {
  max-width: 295px;
  height: auto;
  -webkit-mask-image: url(../images/teachers/mask_teacher.png);
          mask-image: url(../images/teachers/mask_teacher.png);
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
}
.teacher-item-image img {
  /*width: 295px;
  height: 295px;*/
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 0 0;
     object-position: 0 0;
}
.teacher-item-name {
  margin-top: 30px;
  font-size: 2.4rem;
  font-weight: bold;
}
.teacher-item-en {
  margin-top: 10px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 1.6rem;
  color: #E70012;
}

/* ==========
  04 about_facility 
========================================================================== */
.facility-lead-text {
  margin-top: 30px;
  line-height: 2.1875;
}

.facility-items {
  margin-top: 80px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 50px 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 70px 50px;
}

.facility-item {
  position: relative;
  padding-bottom: 20px;
  border-bottom: solid 1px #212121;
}
.facility-item-image {
  position: relative;
  max-width: 475px;
  height: 220px;
}
.facility-item-image img {
  /*height: 295px;*/
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 0 0;
     object-position: 0 0;
}
.facility-item-tag {
  position: absolute;
  top: 15px;
  right: 15px;
  padding: 3px 15px;
  display: inline-block;
  font-weight: bold;
  color: #fff;
  background-color: #E70012;
}
.facility-item-title {
  position: relative;
  margin-top: 40px;
  padding-left: 25px;
  font-size: 2.4rem;
  font-weight: bold;
}
.facility-item-title::before {
  position: absolute;
  content: "";
  display: block;
  top: 50%;
  left: 0;
  width: 15px;
  height: 15px;
  background-color: #E70012;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.facility-item-text {
  margin-top: 20px;
  line-height: 1.875;
}

/* ==========
  05 about_faq 
========================================================================== */
.faq {
  position: relative;
  border-bottom: dashed 1px #212121;
}
.faq-group {
  margin-bottom: 100px;
}
.faq-group .m-index-title {
  margin-bottom: 20px;
}

.faq-title {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 100px;
  margin: 0;
  padding: 30px 70px 30px 75px;
  font-size: 2rem;
  font-weight: bold;
  cursor: pointer;
}
.faq-title::before {
  position: absolute;
  content: "Q";
  top: 25px;
  left: 0;
  width: 50px;
  height: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 3.2rem;
  color: #fff;
  background-color: #E83928;
}
.faq-title::after {
  position: absolute;
  content: "";
  top: 50%;
  right: 30px;
  width: 15px;
  height: 15px;
  border-right: none;
  border-bottom: none;
  border-right: 3px solid #212121;
  border-bottom: 3px solid #212121;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}
.faq-title.is-active {
  position: relative;
}
.faq-title.is-active::after {
  position: absolute;
  content: "";
  top: 50%;
  right: 30px;
  bottom: 0;
  width: 15px;
  height: 15px;
  border-right: none;
  border-bottom: none;
  border-left: 3px solid #212121;
  border-top: 3px solid #212121;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}

.faq-text {
  display: none;
  position: relative;
  padding: 30px 85px 30px 90px;
  line-height: 2.1875;
}
.faq-text::before {
  position: absolute;
  content: "A";
  top: 35px;
  left: 30px;
  width: 35px;
  height: 35px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 3.2rem;
  color: #fff;
  background-color: #212121;
}

/* ==========
  06 hair-beauty
========================================================================== */
.hair-beauty-area .m-index-title,
.total-beauty-area .m-index-title {
  line-height: 1.375;
}
.hair-beauty-area .m-index-title::before,
.total-beauty-area .m-index-title::before {
  top: 5px;
}

.hair-beauty-mv,
.total-beauty-mv {
  position: relative;
  margin-bottom: 40px;
}
.hair-beauty-mv-content,
.total-beauty-mv-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 71%;
  height: 120px;
}
.hair-beauty-mv-content .-en,
.total-beauty-mv-content .-en {
  margin: 0 auto;
  max-width: 100%;
  mix-blend-mode: exclusion;
}
.hair-beauty-mv-content .-txt,
.total-beauty-mv-content .-txt {
  margin-top: 30px;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-size: clamp(16px, 2vw, 24px);
  line-height: 1.5625;
  font-weight: bold;
  text-align: center;
  color: #fff;
}
.hair-beauty-lead-text,
.total-beauty-lead-text {
  margin-top: 20px;
  line-height: 2.1875;
}

.course-data {
  margin-top: 50px;
  padding: 35px 30px;
  background-color: #EFE3DF;
}
.course-data-title {
  padding-left: 30px;
  position: relative;
  font-size: clamp(1.4rem, 1.5vw, 2rem);
  font-weight: bold;
}
.course-data-title::before {
  position: absolute;
  content: "";
  top: 3px;
  left: 0;
  width: 15px;
  height: 15px;
  background-color: #212121;
}
.course-data-tag {
  display: inline-block;
  margin-top: 30px;
  padding: 5px 25px;
  font-weight: bold;
  background-color: #FFD83D;
}
.course-data-text {
  margin-top: 10px;
  padding-bottom: 10px;
  font-size: 1.4rem;
}
.course-data-item-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 22px;
}
.course-data-item-title {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin-right: 35px;
  font-size: clamp(1.6rem, 1.5vw, 2rem);
  font-weight: bold;
}
.course-data-item-list li {
  margin-right: 12px;
  margin-bottom: 5px;
  padding: 3px 10px;
  display: inline-block;
  font-weight: bold;
  background-color: #fff;
  color: #E70012;
}
.course-data-item-list li.-no-style {
  background-color: inherit;
  color: #212121;
}

.anchor-link-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 50px 1fr 50px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 15px 50px;
  margin: 90px auto 110px;
}

.anchor-link a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 60px;
  font-size: clamp(1.4rem, 2.2vw, 2rem);
  line-height: 1.35;
  font-weight: bold;
  color: #212121;
  border-bottom: solid 1px #212121;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.anchor-link a::after {
  position: absolute;
  content: "";
  top: 50%;
  right: 0;
  width: 25px;
  height: 26px;
  background: url("../images/hair-beauty/ico_down.svg") no-repeat;
  background-size: contain;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.anchor-link a:hover {
  opacity: 0.7;
}
.anchor-link a:hover::after {
  -webkit-transform: translateY(-45%);
          transform: translateY(-45%);
}

.course-point-item {
  margin-top: 40px;
  margin-bottom: 60px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 50px;
     -moz-column-gap: 50px;
          column-gap: 50px;
  counter-increment: number;
}
.course-point-item-wrap {
  margin-top: -30px;
}
.course-point-item-image {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  max-width: 300px;
  max-height: 230px;
}
.course-point-item-image img {
  aspect-ratio: 300/230;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.course-point-item-image::before {
  position: absolute;
  counter-increment: number 0;
  content: "0" counter(number);
  top: -25px;
  left: 2px;
  font-family: "din-2014", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.025em;
  font-size: 7.2rem;
  line-height: 1;
  color: #E70012;
}
.course-point-item-title {
  margin-top: -5px;
  font-size: clamp(2.4rem, 2.4vw, 2.8rem);
  line-height: 1.4285;
  font-weight: bold;
}
.course-point-item-text {
  margin-top: 25px;
  line-height: 2.1875;
}

.section-schedule {
  position: relative;
  margin-top: 120px;
}
.section-schedule .col-wrap {
  position: relative;
  padding-top: 40px;
  padding-bottom: 95px;
}
.section-schedule .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  left: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
  z-index: -3;
}
.section-schedule .col-wrap .m-index-title {
  margin-top: 60px;
  margin-bottom: 40px;
}
.section-schedule .line01-b-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  top: -220px;
  z-index: 0;
}

.schedule-table {
  margin-top: 25px;
  position: relative;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 120px 25px 1fr;
  grid-template-columns: 120px 1fr;
  -webkit-column-gap: 25px;
     -moz-column-gap: 25px;
          column-gap: 25px;
  z-index: 2;
}
.schedule-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  padding: 30px 40px;
  font-size: clamp(2rem, 2.4vw, 3.2rem);
  font-weight: bold;
  line-height: 1.25;
  background-color: #E83928;
  color: #fff;
}
.schedule-head.-grade2 {
  background-color: #BC0312;
}
.schedule-body {
  display: -ms-grid;
  display: grid;
  gap: 25px;
}
.schedule-body-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 40px;
     -moz-column-gap: 40px;
          column-gap: 40px;
  padding: 5px 40px 20px;
  background-color: #fff;
}
.schedule-month {
  font-size: clamp(1.6rem, 2.1vw, 2.8rem);
  font-weight: bold;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  min-width: 3em;
  margin-top: 10px;
}

.schedule-detail + .schedule-detail {
  margin-top: 50px;
}
.schedule-detail-title {
  margin-top: 30px;
  font-size: clamp(1.6rem, 1.8vw, 2.4rem);
  font-weight: bold;
}
.schedule-detail-text {
  margin-top: 20px;
  margin-bottom: 10px;
  line-height: 1.875;
}

.schedule-tags {
  margin-top: 10px;
  margin-bottom: 10px;
}

.schedule-tag {
  position: relative;
  display: inline-block;
  margin-right: 25px;
  padding-left: 20px;
}
.schedule-tag::before {
  position: absolute;
  content: "";
  left: 0;
  top: 10px;
  width: 10px;
  height: 10px;
  border-radius: 100%;
  background-color: #FFD83D;
}

.section-course-select {
  margin-top: 95px;
}
.section-course-select .col-inner {
  position: relative;
}

.course-select {
  margin-top: -10px;
}

.course-select-item {
  margin-top: 50px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: #fff;
}
.course-select-item-image {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  max-width: 370px;
}
.course-select-item-image .-image {
  aspect-ratio: 370/378;
  width: auto;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.course-select-item-image .-en {
  position: absolute;
  min-height: 37px;
  top: 20px;
  left: 60px;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  -webkit-transform-origin: 0 0;
          transform-origin: 0 0;
}
.course-select-item-content {
  padding: 15px 40px 35px;
}
.course-select-item-title {
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-size: clamp(2rem, 2.4vw, 3.2rem);
  line-height: 2.343;
  font-weight: bold;
}
.course-select-item-text {
  line-height: 2.1875;
}

.course-select-tags {
  margin-top: 10px;
}
.course-select-tags-title {
  margin-top: 35px;
  font-size: clamp(1.6rem, 1.5vw, 2rem);
  font-weight: bold;
}

.course-select-tag {
  margin-right: 12px;
  margin-top: 10px;
  padding: 2px 8px;
  display: inline-block;
  font-size: 1.4rem;
  font-weight: bold;
  background-color: #fff;
  color: #E70012;
  border: solid 2px #E70012;
}
.course-select-tag.-last {
  margin-right: 0;
}

.section-course-unique {
  position: relative;
  margin-top: 115px;
}

.course-unique {
  margin-top: -20px;
}

.course-unique-item {
  margin-top: 60px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.course-unique-item-image {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  max-width: 400px;
  max-height: 250px;
}
.course-unique-item-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.course-unique-item-content {
  margin-left: 50px;
}
.course-unique-item-title {
  font-size: clamp(2rem, 2.5vw, 2.8rem);
  line-height: 1.4285;
  font-weight: bold;
}
.course-unique-item-text {
  margin-top: 15px;
  line-height: 2.1875;
}

.section-course-menu {
  position: relative;
  margin-top: 100px;
  margin-bottom: 120px;
}
.section-course-menu .col-wrap {
  position: relative;
  padding-top: 50px;
  padding-bottom: 30px;
}
.section-course-menu .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  right: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
  z-index: -3;
}
.section-course-menu .m-index-title {
  margin-top: 40px;
}

.course-menus {
  margin-top: 10px;
  padding-bottom: 70px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 40px 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 40px;
}

.course-menu {
  padding: 30px 0 22px;
  border-bottom: solid 1px #212121;
}
.course-menu.-no-border {
  border-bottom: none;
}
.course-menu-title {
  position: relative;
  padding-left: 23px;
  font-size: clamp(1.4rem, 1.5vw, 2rem);
  font-weight: bold;
  line-height: 1.3;
}
.course-menu-title.-no-mark {
  padding-left: 0;
}
.course-menu-title.-no-mark::before {
  display: none;
}
.course-menu-title::before {
  position: absolute;
  content: "";
  left: 0;
  top: 7px;
  width: 13px;
  height: 13px;
  border-radius: 100%;
  background-color: #E70012;
}
.course-menu-title .-txt01 {
  margin-left: 10px;
  font-size: 1.6rem;
  font-weight: normal;
}
.course-menu-title .-txt02 {
  font-size: 1.4rem;
  font-weight: normal;
}
.course-menu-text {
  margin-top: 20px;
  line-height: 2.0875;
}

#section01, #section02, #section03, #section04, #section05, #section06 {
  margin-top: -90px;
  padding-top: 90px;
}

.line02-b-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  top: -500px;
  z-index: 0;
}

.a-article.item-b-01 {
  top: -80px;
  right: 120px;
  width: clamp(65px, 9.73vw, 130px);
}
.a-article.item-b-02 {
  top: -40px;
  left: 0px;
  width: clamp(51px, 6.21vw, 83px);
}
.a-article.item-b-03 {
  top: -70px;
  right: 120px;
  width: clamp(40px, 6.74vw, 90px);
}
.a-article.item-b-04 {
  top: -50px;
  left: 0px;
  width: clamp(50px, 4.49vw, 60px);
}
.a-article.item-b-05 {
  top: -150px;
  left: 90px;
  width: clamp(35px, 3.82vw, 51px);
}

/* ==========
  07 total-beauty
========================================================================== */
/* ==========
  08 hair-beauty-tsushin
========================================================================== */
.tsushin-lead {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 50px;
}
.tsushin-lead-image {
  max-width: 390px;
  max-height: 390px;
  border-radius: 100%;
  overflow: hidden;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.tsushin-lead-content .m-index-title {
  line-height: 1.15;
}
.tsushin-lead-text {
  max-width: 472px;
  margin-top: 30px;
  line-height: 2.1875;
}

.section-tsushin-item {
  margin-top: 100px;
}
.section-tsushin-item .col-wrap {
  position: relative;
  padding-top: 90px;
  padding-bottom: 100px;
}
.section-tsushin-item .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  left: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
  z-index: -1;
}

.tsushin-items {
  position: relative;
  margin-top: -70px;
}

.tsushin-item-lead {
  margin-top: 25px;
  font-size: clamp(1.6rem, 2.4vw, 2.4rem);
  font-weight: bold;
  line-height: 1.666;
}
.tsushin-item-wrap {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 120px;
  -webkit-column-gap: 30px;
     -moz-column-gap: 30px;
          column-gap: 30px;
  padding: 0 30px 30px 50px;
}
.tsushin-item-wrap.item01 {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
.tsushin-item-wrap.item01 .tsushin-item-image {
  margin-right: min(-6vw, -63px);
}
.tsushin-item-wrap.item01 .tsushin-item-image .img01 {
  position: absolute;
  top: 0px;
  right: -10px;
  width: clamp(286px, 39vw, 397px);
}
.tsushin-item-wrap.item01 .tsushin-item-image .img02 {
  position: absolute;
  top: min(23vw, 263px);
  left: -30px;
  width: clamp(179px, 24vw, 249px);
}
.tsushin-item-wrap.item02 {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  margin-left: min(-6vw, -63px);
}
.tsushin-item-wrap.item02 .tsushin-item-content::before {
  left: inherit;
  right: -30px;
}
.tsushin-item-wrap.item02 .tsushin-item-num {
  left: inherit;
  right: 0;
}
.tsushin-item-wrap.item02 .tsushin-item-image {
  margin-left: min(-5vw, -63px);
}
.tsushin-item-wrap.item02 .tsushin-item-image .img01 {
  position: absolute;
  top: 140px;
  left: -10px;
  width: clamp(274px, 39vw, 397px);
}
.tsushin-item-wrap.item02 .tsushin-item-image .img02 {
  position: absolute;
  top: 10px;
  right: 0;
  width: clamp(180px, 24vw, 249px);
}
.tsushin-item-wrap.item03 {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
.tsushin-item-wrap.item03 .tsushin-item-image {
  margin-right: min(-5vw, -63px);
}
.tsushin-item-wrap.item03 .tsushin-item-image .img01 {
  position: absolute;
  top: 0px;
  right: -30px;
  width: clamp(188px, 26vw, 260px);
}
.tsushin-item-wrap.item03 .tsushin-item-image .img02 {
  position: absolute;
  top: 170px;
  left: 0;
  width: clamp(203px, 28vw, 280px);
}
.tsushin-item-content {
  position: relative;
  max-width: 810px;
  padding-top: 90px;
}
.tsushin-item-content::before {
  position: absolute;
  content: "";
  top: 50px;
  left: -50px;
  width: 160%;
  max-width: 810px;
  height: 100%;
  background-color: #fff;
  z-index: -1;
}
.tsushin-item-num {
  position: absolute;
  top: 0;
  left: -20px;
  font-family: "din-2014", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(6.4rem, 8.8vw, 8.8rem);
  letter-spacing: 0.25rem;
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 2px #BC0312;
}
.tsushin-item-title {
  position: relative;
  font-size: min(3.2vw, 3.2rem);
  font-weight: bold;
  line-height: 1.5625;
  color: #BC0312;
  margin-top: 10px;
  padding-bottom: 12px;
}
.tsushin-item-text {
  max-width: 500px;
  margin-top: 10px;
  line-height: 2.1875;
}
.tsushin-item-image {
  position: relative;
  top: 0px;
  max-height: 451px;
  width: 48%;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.tsushin-item-image img {
  width: 100%;
  height: auto;
}
.tsushin-item-tag {
  margin-top: 140px;
  padding: 50px 50px 30px 50px;
  background-color: #F3EDEB;
}
.tsushin-item-tag-title {
  margin-top: -60px;
  font-size: 2.4rem;
  font-weight: bold;
  color: #BC0312;
}
.tsushin-item-tag-list {
  margin-top: 30px;
  line-height: 1.85;
  -webkit-column-count: 3;
     -moz-column-count: 3;
          column-count: 3;
}
.tsushin-item-tag-list li {
  position: relative;
  margin-left: 1em;
  text-indent: -1em;
  padding-bottom: 5px;
  text-align: left;
}
.tsushin-item-tag-list li::before {
  position: relative;
  content: "";
  display: inline-block;
  margin-right: 0.5em;
  width: 10px;
  height: 10px;
  background-color: #E70012;
}
.tsushin-item-tag-list li .-small {
  font-size: 1.2rem;
  line-height: 1.2;
}
.tsushin-item-tag .course-menus {
  padding-bottom: 20px;
}

.section-tsushin-flow {
  margin-top: 100px;
}

.tsushin-flow-menu {
  padding: 20px 20px;
  background-color: #fff;
  border-top: solid 6px #BC0312;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.tsushin-flow-menu-wrap {
  position: relative;
  margin-top: 45px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
}
.tsushin-flow-menu-title {
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  font-size: 2.4rem;
  text-align: center;
}
.tsushin-flow-menu-text {
  margin-top: 15px;
  min-height: 56px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
}

.tsushin-flow-items {
  margin-top: 100px;
  margin-bottom: 120px;
}
.tsushin-flow-item {
  position: relative;
  margin-bottom: 85px;
}
.tsushin-flow-item::before {
  position: absolute;
  content: "";
  bottom: -55px;
  left: 50%;
  display: inline-block;
  width: 40px;
  height: 40px;
  border-bottom: 5px solid #BC0312;
  border-right: 5px solid #BC0312;
  -webkit-transform: translateX(-50%) rotate(45deg);
          transform: translateX(-50%) rotate(45deg);
}
.tsushin-flow-item.-last {
  margin-bottom: 0;
}
.tsushin-flow-item.-last::before {
  display: none;
}
.tsushin-flow-head {
  padding: 5px 0;
  min-height: 50px;
  font-size: clamp(2.4rem, 3vw, 3.2rem);
  font-weight: bold;
  line-height: 1.1;
  text-align: center;
  color: #fff;
}
.tsushin-flow-head.-season01 {
  background-color: #E83928;
}
.tsushin-flow-head.-season02 {
  background-color: #BC0312;
}
.tsushin-flow-head.-season03 {
  background-color: #80000A;
}
.tsushin-flow-body {
  padding: 30px 30px;
  width: 100%;
  background-color: #fff;
}
.tsushin-flow-title {
  margin-top: 25px;
  font-size: clamp(1.6rem, 2.4vw, 2.8rem);
  font-weight: bold;
  line-height: 1.875;
  color: #E70012;
}
.tsushin-flow-text {
  margin-top: 10px;
  line-height: 1.875;
}

.tsushin-flow-table {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.tsushin-flow-table.-table01 .tsushin-flow-table-head {
  background-color: #FFD83D;
}
.tsushin-flow-table.-table01 .tsushin-flow-table-item {
  background-color: rgba(255, 216, 61, 0.4);
}
.tsushin-flow-table.-table02 .tsushin-flow-table-head {
  position: relative;
  background-color: #EBAD98;
}
.tsushin-flow-table.-table02 .tsushin-flow-table-head::before {
  position: absolute;
  content: "";
  top: 0;
  bottom: 0;
  left: -42px;
  margin: auto;
  width: 52px;
  height: 52px;
  border-radius: 100%;
  background-color: #fff;
}
.tsushin-flow-table.-table02 .tsushin-flow-table-head::after {
  position: absolute;
  content: "";
  top: 0;
  bottom: 0;
  left: -35px;
  margin: auto;
  width: 38px;
  height: 38px;
  background-image: url("../../common/images/hair-beauty-tsushin/ico_plus.svg");
  background-size: cover;
}
.tsushin-flow-table.-table02 .tsushin-flow-table-item {
  background-color: rgba(235, 173, 152, 0.4);
}
.tsushin-flow-table-wrap {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 35px 1fr;
  grid-template-columns: 1fr 1fr;
  gap: 10px 35px;
}
.tsushin-flow-table-head {
  padding: 10px 10px;
  font-size: clamp(1.4rem, 2vw, 2rem);
  font-weight: bold;
  text-align: center;
  background-color: #F2DBD7;
}
.tsushin-flow-table-body {
  margin-top: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  min-height: 130px;
}
.tsushin-flow-table-body.-col01 {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 15px;
}
.tsushin-flow-table-body-text {
  font-size: 2rem;
  font-weight: bold;
}
.tsushin-flow-table-item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 100%;
  height: 100%;
  min-height: 50px;
  padding: 10px;
  background-color: #F2DBD7;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.tsushin-flow-table-item-wrap {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
  grid-template-columns: 1fr;
  gap: 10px;
}
.tsushin-flow-table-item-wrap.-col02 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 35px 1fr;
  grid-template-columns: 1fr 1fr;
  -webkit-column-gap: 35px;
     -moz-column-gap: 35px;
          column-gap: 35px;
}
.tsushin-flow-table-item-text {
  text-align: center;
  line-height: 1.25;
}
.tsushin-flow-table-item-text .-txt01 {
  font-weight: bold;
  line-height: 1.5;
}
.tsushin-flow-table-item-text .-label01 {
  position: absolute;
  left: 0;
  display: inline-block;
  padding: 5px 10px;
  background-color: #212121;
  color: #fff;
}
.tsushin-flow-table-item-text .-label02 {
  position: absolute;
  left: 0;
  display: block;
  padding: 0 10px;
  background-color: #fff;
  color: #212121;
}
.tsushin-flow-table-item-tag-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 5px;
  margin-left: 5px;
}
.tsushin-flow-table-item-tag-list li {
  padding: 5px 10px;
  font-size: 1.2rem;
  background-color: #fff;
}
.tsushin-flow-table-item.-labelcell {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding-left: 60px;
}
.tsushin-flow-table-item.-labelcell .tsushin-flow-table-item-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  text-align: left;
}
.tsushin-flow-table-item.-cell01 {
  background-color: #BC0312;
  color: #fff;
}
.tsushin-flow-table-item.-cell02 {
  background-color: #212121;
  color: #fff;
}
.tsushin-flow-table-bottom {
  padding: 0 20px 0;
  margin-bottom: -10px;
  font-weight: bold;
  text-align: center;
}
.tsushin-flow-table-bottom.-col02 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr;
  grid-template-columns: 1fr 1fr;
}
.tsushin-flow-table-bottom .-txt01 {
  font-size: clamp(1.6rem, 2vw, 2rem);
  color: #BC0312;
}
.tsushin-flow-table-bottom .-txt02 {
  display: block;
  margin-top: 10px;
  font-size: clamp(1.6rem, 3.2vw, 3.2rem);
  color: #BC0312;
}

.tsushin-data {
  position: relative;
  margin-top: 100px;
  margin-bottom: 100px;
  padding: 95px 0 100px;
}
.tsushin-data::before {
  position: absolute;
  content: "";
  top: 0;
  left: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
}

.section-tsushin-guide .guidelines-table {
  padding-bottom: 20px;
}

.tsushin-guide {
  position: relative;
  padding-top: 40px;
  padding-bottom: 90px;
}
.tsushin-guide::before {
  position: absolute;
  content: "";
  left: -60px;
  width: calc(100% + 120px);
  height: 100%;
  background-color: #EFE3DF;
  z-index: -1;
}
.tsushin-guide-title {
  margin-top: 50px;
  font-size: clamp(1.6rem, 2.4vw, 2.4rem);
  font-weight: bold;
  color: #BC0312;
}
.tsushin-guide-lead {
  margin-top: 30px;
  font-weight: bold;
}
.tsushin-guide-note {
  font-size: 1.2rem;
  line-height: 1.666;
}

.tsushin-guide-table {
  margin-top: 30px;
  width: 100%;
  white-space: nowrap;
}
.tsushin-guide-table.-table01 {
  -webkit-writing-mode: vertical-lr;
      -ms-writing-mode: tb-lr;
          writing-mode: vertical-lr;
  max-width: 1000px;
}
.tsushin-guide-table.-table01 th {
  width: 13%;
  max-width: 164px;
  -webkit-writing-mode: horizontal-tb;
      -ms-writing-mode: lr-tb;
          writing-mode: horizontal-tb;
}
.tsushin-guide-table.-table01 th.cell-1 {
  width: 20%;
  max-width: 345px;
}
.tsushin-guide-table.-table01 td {
  -webkit-writing-mode: horizontal-tb;
      -ms-writing-mode: lr-tb;
          writing-mode: horizontal-tb;
  text-align: center;
}
.tsushin-guide-table.-table02 th {
  width: 157px;
  min-height: 59px;
  font-size: 2rem;
  text-align: left;
  padding: 15px 15px;
  vertical-align: text-top;
}
.tsushin-guide-table.-table02 td {
  padding: 15px 15px;
  border: none;
}
.tsushin-guide-table.-table02 td .-txt01 {
  font-size: 1.2rem;
}
.tsushin-guide-table.-table03 {
  margin-top: 40px;
}
.tsushin-guide-table.-table03 th {
  width: 10%;
  height: 42px;
  font-size: clamp(1.4rem, 1.5vw, 1.5rem);
  border-bottom: solid 2px #EFE3DF;
  border-left: solid 2px #EFE3DF;
}
.tsushin-guide-table.-table03 th.cell-1 {
  min-width: 202px;
}
.tsushin-guide-table.-table03 th.cell-2 {
  min-width: 225px;
}
.tsushin-guide-table.-table03 th.cell-5 {
  min-width: 114px;
}
.tsushin-guide-table.-table03 td {
  text-align: center;
  padding: 0 10px;
  border: solid 2px #EFE3DF;
}
.tsushin-guide-table.-table04 {
  margin-top: 40px;
}
.tsushin-guide-table.-table04 th {
  width: 10%;
  height: 42px;
  font-size: clamp(1.4rem, 1.5vw, 1.5rem);
  border-bottom: solid 2px #EFE3DF;
  border-left: solid 2px #EFE3DF;
}
.tsushin-guide-table.-table04 th.cell-1 {
  min-width: 202px;
}
.tsushin-guide-table.-table04 th.cell-2 {
  min-width: 109px;
}
.tsushin-guide-table.-table04 th.cell-2-1 {
  height: 60px;
}
.tsushin-guide-table.-table04 th.cell-3 {
  min-width: 79px;
}
.tsushin-guide-table.-table04 th.cell-4 {
  min-width: 160px;
}
.tsushin-guide-table.-table04 th.cell-5 {
  min-width: 114px;
}
.tsushin-guide-table.-table04 td {
  text-align: center;
  padding: 0 5px;
  border: solid 2px #EFE3DF;
}
.tsushin-guide-table th {
  position: relative;
  padding: 2px 0 0;
  height: 55px;
  font-size: clamp(1.3rem, 1.2vw, 1.6rem);
  line-height: 1.25;
  text-align: center;
  color: #fff;
  background-color: #E70012;
  border-left: 1px solid #F3EDEB;
}
.tsushin-guide-table th .cell-1 {
  position: sticky;
  width: 130px;
}
.tsushin-guide-table th .cell-2 {
  width: 226px;
}
.tsushin-guide-table th.-no {
  border-left: none;
}
.tsushin-guide-table th .note {
  position: absolute;
  right: 0;
  bottom: 10px;
  left: 0;
  margin: 0 auto;
  width: calc(100% - 6px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 2px 5px;
  min-height: 35px;
  font-weight: normal;
  text-align: center;
  font-size: 1.2rem;
  color: #212121;
  background-color: #F3EDEB;
}
.tsushin-guide-table td {
  margin: auto auto;
  padding: 0 15px;
  height: 60px;
  font-size: clamp(1.3rem, 1.2vw, 1.6rem);
  line-height: 1.5625;
  background: #F8F8F8;
  border: 1px solid #F3EDEB;
}
.tsushin-guide-table td.td-title {
  line-height: 1.25;
}
.tsushin-guide-table tr:nth-child(odd) td {
  background: #fff;
}

.tsushin-arrow {
  margin-top: 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 109px;
  background-color: #E70012;
  color: #fff;
}
.tsushin-arrow-item {
  padding-left: 10px;
  position: relative;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
  /*
  &::before{
   position: absolute;
   content:"";
   top:0;
   right: -34px;
   width: 0;
   height: 0;
   border-style:solid;
   border-width: 54.5px 0 54.5px 34px;
   border-color: transparent transparent transparent #EFE3DE;
  }
  &::after{
   position: absolute;
   content:"";
   top:0;
   right: -32px;
   width: 0;
   height: 0;
   border-style:solid;
   border-width: 54.5px 0 54.5px 34px;
   border-color: transparent transparent transparent $color-r1;
  }
  */
}
.tsushin-arrow-item::after {
  position: absolute;
  content: "";
  top: 0;
  right: -30px;
  width: 36px;
  height: 110px;
  background-image: url("../../common/images/hair-beauty-tsushin/img_arrow.svg");
  background-size: cover;
}
.tsushin-arrow-item.-last::beore {
  display: none;
}
.tsushin-arrow-item.-last::after {
  display: none;
}
.tsushin-arrow-item-text .-txt01 {
  font-weight: bold;
  line-height: 1.5;
}
.tsushin-arrow-item-text .-txt02 {
  display: inline-block;
  font-size: 1.2rem;
  line-height: 1.5;
  font-weight: normal;
}

/* ==========
  09 opencampus
========================================================================== */
/* opencampus archive */
.opencampus-cat-menu {
  /*  padding: 25px 30px;
    background-color: #fff;
   &-wrap{// news
     margin: 0 auto;
    }
   &-list{
   	text-align: center;
    li{
     display: inline-flex;
     margin: 10px 10px;
     font-size: 2.0rem;
     font-weight: bold;
      width: 215px;
     &:first-child{
    //  width: 185px;
     } 
    &.current-cat a{
      background-color: $color-r1;
      color:#fff;
      }
    a {
      display: block;
      padding: 7px 3px;
      width: 100%;
      text-decoration: none;
      text-align: center;
      background-color: #AFAFAF;
      color: #fff;
      transition: 0.3s;
     &:hover{
      opacity: .7;
     }
    }
   }
  }*/
}

.section-opencampus {
  position: relative;
  padding-top: 95px;
  /*.section-en.-l{
    top: -60px;
   }
  .col-wrap{
    padding: 0;
   }*/
}
.section-opencampus .opencampus-slider {
  margin-bottom: 95px;
}

.opencampus-slider {
  position: relative;
  padding-left: min(8vw, 120px);
  margin: 30px 0 45px 0;
  width: calc(100vw - 60px);
}

.opencampus-cat-menu-wrap {
  margin-top: 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.opencampus-cat-menu-wrap .m-select {
  min-width: 230px;
}
.opencampus-cat-menu-title {
  margin-right: 15px;
  font-size: 2rem;
  font-weight: bold;
}

.opencampus-calendar {
  margin-top: 175px;
}
.opencampus-calendar .col-wrap {
  position: relative;
  padding-top: 70px;
  padding-bottom: 75px;
}
.opencampus-calendar .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  right: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #F2DBD7;
  z-index: -1;
}

.open-campus-calendar {
  margin-top: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.open-campus-calendar .calendar-left {
  width: 44.5%;
  max-width: 445px;
  overflow: hidden;
  margin-right: min(5vw, 70px);
  margin-left: 0;
}
.open-campus-calendar .calendar-right {
  width: 48.5%;
  margin-top: -25px;
}

.js-calendar-slider .swiper-navi {
  position: absolute;
  z-index: 2;
  width: 100%;
  top: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.js-calendar-slider .swiper-button-prev,
.js-calendar-slider .swiper-button-next {
  width: 10px;
  height: 15px;
  background-image: url(../../common/images/base/ico_mark_bk.svg);
  position: absolute;
  left: 0;
  top: 35px;
  right: auto;
  background-size: contain;
  background-repeat: no-repeat;
  cursor: pointer;
  scale: -1;
}
.js-calendar-slider .swiper-button-prev::after,
.js-calendar-slider .swiper-button-next::after {
  display: none;
}
.js-calendar-slider .swiper-button-next {
  right: 0;
  left: auto;
  scale: 1;
}

.calendar {
  position: relative;
  padding-bottom: 75px;
  text-align: center;
  font-weight: 400;
  max-width: 455px;
  /*
  &-memo {
    text-align: right;
    margin-top: 1.6rem;
    font-weight: 500;
    }
   */
}
.calendar-title {
  font-size: 3.2rem;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-style: normal;
  letter-spacing: 0.025em;
  margin-bottom: 20px;
}
.calendar-head {
  border-bottom: solid 2px #212121;
  margin-bottom: 16px;
  padding-bottom: 10px;
}
.calendar-head-cells {
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-style: normal;
  letter-spacing: 0.025em;
  display: -ms-grid;
  display: grid;
  gap: 16px 20px;
  justify-items: center;
  -ms-grid-columns: 1fr 20px 1fr 20px 1fr 20px 1fr 20px 1fr 20px 1fr 20px 1fr;
  grid-template-columns: repeat(7, 1fr);
  white-space: nowrap;
}
.calendar-head-cell {
  width: clamp(23px, 3vw, 38px);
}
.calendar-head .is-holiday {
  color: #E83928;
}
.calendar-head .is-sun {
  color: #E83928;
}
.calendar-cells {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 20px 1fr 20px 1fr 20px 1fr 20px 1fr 20px 1fr 20px 1fr;
  grid-template-columns: repeat(7, 1fr);
  gap: 16px 20px;
  justify-items: center;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-style: normal;
  letter-spacing: 0.025em;
}
.calendar-cell {
  width: clamp(23px, 2vw, 30px);
  height: clamp(23px, 2vw, 30px);
  line-height: clamp(23px, 2vw, 30px);
  border-radius: 100%;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.calendar-cell.is-holiday {
  color: #E83928;
}
.calendar-cell.is-sun {
  color: #E83928;
}
.calendar-cell.is-open_campus {
  background-color: #fff;
  cursor: pointer;
}
.calendar-cell.is-current {
  background-color: #E83928;
  color: #fff;
}
/* calendar-list === */
.calendar-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  padding: 25px 0;
  min-height: 104px;
  border-bottom: dotted 1px #212121;
}
.calendar-list a::after {
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  pointer-events: auto;
  background-color: transparent;
}
.calendar-list-thumb {
  aspect-ratio: 160/104;
  margin-right: min(2vw, 30px);
  max-width: 160px;
}
.calendar-list-thumb img {
  aspect-ratio: 160/104;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.calendar-list-content {
  width: 60%;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.calendar-list-meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 0;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.calendar-list-date {
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 2rem;
  line-height: 1;
  margin-right: 20px;
}
.calendar-list-cat {
  font-size: min(1vw, 1.2rem);
  /* line-height: 1;
   font-weight: bold;
   margin-right: 10px;
   flex-shrink: 0;
   a, span{
    position: relative;
    padding: 2px 10px;
    background-color: $color-r1;
    color: #fff;
    z-index: 2;
   }*/
}
.calendar-list-cat .post-item-cat {
  display: inline-block;
}
.calendar-list-title {
  margin-top: 10px;
  font-weight: bold;
  line-height: 1.875;
}
.calendar-list-text {
  margin-top: 20px;
  padding-bottom: 20px;
  font-size: 1.4rem;
  line-height: 2.14;
}

@media only screen and (max-width: 1000px) and (min-width: 769px) {
  .calendar-list-meta {
    display: block;
  }
  .calendar-list-cat {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 10px;
  }
}
.opencampus-faq {
  margin-top: 125px;
}
.opencampus-faq .col-wrap {
  position: relative;
  padding-top: 100px;
  padding-bottom: 60px;
}
.opencampus-faq .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  left: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
}
.opencampus-faq .btn-wrap-c {
  margin-top: 70px;
}

.opencampus-tokuten {
  margin: 100px auto 120px;
}
.opencampus-tokuten .tokuten-items {
  margin-top: -30px;
}
.opencampus-tokuten .tokuten-item {
  margin-top: 70px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 50px;
     -moz-column-gap: 50px;
          column-gap: 50px;
  counter-increment: number;
}
.opencampus-tokuten .tokuten-item-image {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  aspect-ratio: 300/220;
  max-width: 300px;
  max-height: 220px;
}
.opencampus-tokuten .tokuten-item-image img {
  aspect-ratio: 300/220;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.opencampus-tokuten .tokuten-item-image::before {
  position: absolute;
  counter-increment: number 0;
  content: "0" counter(number);
  right: 15px;
  bottom: 5px;
  font-family: "din-2014", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.025em;
  font-size: 7.2rem;
  line-height: 1;
  color: #fff;
}
.opencampus-tokuten .tokuten-item-title {
  font-size: min(2vw, 2.8rem);
  line-height: 1.66;
  font-weight: bold;
}
.opencampus-tokuten .tokuten-item-text {
  margin-top: 20px;
  padding-bottom: 20px;
  line-height: 2.1875;
}

/* ==========
  09_ opencampus_details
========================================================================== */
.oc-detail-wrap {
  margin-top: -40px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.oc-detail-thumb {
  max-width: 424px;
  height: auto;
}
.oc-detail-thumb img {
  position: sticky;
  top: 100px;
}
.oc-detail-content {
  width: 516px;
  margin-left: 60px;
}
.oc-detail-meta {
  margin-top: -5px;
}
.oc-detail-title {
  margin-top: 15px;
  font-size: 3.2rem;
  font-weight: bold;
  line-height: 1.5625;
}
.oc-detail-text {
  margin: 30px 0;
  line-height: 1.875;
}

.oc-detail-data {
  margin-bottom: 50px;
}
.oc-detail-data dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 15px;
  padding-bottom: 15px;
  border-bottom: dotted 1px #707070;
}
.oc-detail-data dl.oc-detail-support {
  padding-bottom: 0;
}
.oc-detail-data dt {
  width: 110px;
  font-weight: bold;
}
.oc-detail-data dd {
  margin-left: 30px;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.oc-detail-data .icon-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 15px;
}
.oc-detail-data .icon-item .icon {
  background-color: #E83928;
  width: 35px;
  height: 35px;
}
.oc-detail-data .icon-item-text {
  margin-left: 10px;
  font-weight: bold;
}

/* oc-summary */
.oc-summary {
  margin: 90px auto 80px;
}
.oc-summary-text {
  margin-top: 30px;
}

.m-card {
  position: relative;
  max-width: 475px;
}
.m-card-wrap {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 50px 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 50px;
}
.m-card-image {
  margin-top: 50px;
  aspect-ratio: 475/320;
}
.m-card-image img {
  aspect-ratio: 475/320;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.m-card-title {
  margin-top: 20px;
  font-size: 2.4rem;
  line-height: 1.66;
  font-weight: bold;
}
.m-card-text {
  margin-top: 20px;
  padding-bottom: 30px;
  line-height: 2.1875;
  border-bottom: solid 1px #212121;
}

/* oc-point */
.oc-point {
  margin: 100px auto;
}

.m-number-card {
  margin-top: 45px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 50px;
     -moz-column-gap: 50px;
          column-gap: 50px;
  counter-increment: number;
}
.m-number-card-image {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  aspect-ratio: 380/220;
  max-width: 380px;
}
.m-number-card-image img {
  aspect-ratio: 380/220;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.m-number-card-image::before {
  position: absolute;
  counter-increment: number 0;
  content: "0" counter(number);
  right: 15px;
  bottom: 10px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  letter-spacing: 0.025em;
  font-size: 6.4rem;
  font-style: italic;
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 2px #fff;
  text-stroke: 2px #fff;
}
.m-number-card-title {
  font-size: min(2vw, 2.4rem);
  line-height: 1.66;
  font-weight: bold;
}
.m-number-card-text {
  margin-top: 20px;
  line-height: 2.1875;
}

/* oc-form */
.oc-form {
  margin-top: 80px;
  padding: 95px 0 100px;
  position: relative;
}
.oc-form::before {
  position: absolute;
  content: "";
  top: 0;
  _right: min(3vw, 60px);
  right:0;
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
}
.oc-form .col-inner {
  position: relative;
  padding-right: 30px;
}
.oc-form .col-inner h2 {
  margin-bottom: 2em;
}
.oc-form .contact-head {
  margin-top: 40px;
  margin-bottom: 75px;
}
.oc-form .form-steps-list li {
  background-color: #EFE3DF;
}
.oc-form .form-area {
  max-width: 550px;
}
.oc-form-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 20px;
  background-color: #fff;
}
.oc-form-thumb {
  width: 110px;
  height: 90px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.oc-form-thumb img {
  aspect-ratio: 110/90;
  width: auto;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.oc-form-content {
  margin-left: 25px;
}
.oc-form-cat {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height: 1;
}
.oc-form-date {
  font-size: 1.4rem;
  font-weight: bold;
  margin-top: 5px;
}
.oc-form-title {
  margin-top: 10px;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.875;
}
.oc-form .form-items {
  margin-top: 50px;
}
.oc-form .form-item input, .oc-form .form-item textarea {
  background-color: #EFE3DF;
}
.oc-form .form-item input[type=radio], .oc-form .form-item input[type=checkbox] {
  background-color: #fff;
}
.oc-form .form-item-input {
  padding: 10px 0;
}
.oc-form .form-button {
  margin-top: 50px;
  display: block;
  text-align: center;
}
.oc-form .wpcf7-response-output {
  border: none !important;
}
/* oc-detail-cta */
.oc-detail-cta {
  margin-bottom: 12rem;
  background-color: #EFE3DF;
  padding: 40px;
  text-align: center;
  outline: solid 3px #BC0312;
  outline-offset: -13px;
}
.oc-detail-cta-title {
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.458;
}
.oc-detail-cta .btn-more {
  margin: 30px auto 0;
}

/* oc-osusume */
.oc-osusume {
  margin-bottom: 50px;
  padding-top: 100px;
  overflow: hidden;
}

/* ==========
  11 opencampus/ocguide（oc-guide）
========================================================================== */
.ocguide-mv {
  position: relative;
}
.ocguide-mv-content {
  padding: 80px 60px;
  position: absolute;
  top: 0;
  left: 0;
  width: 52%;
  height: 100%;
  color: #fff;
}
.ocguide-mv-title {
  font-size: 2.8rem;
  font-weight: bold;
}
.ocguide-mv-title .-en {
  display: block;
  margin-top: 20px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: min(6.3vw, 8rem);
  letter-spacing: 0.25rem;
  color: #FFD83D;
}
.ocguide-mv-text {
  margin-top: 45px;
  font-size: min(1.8vw, 2rem);
  line-height: 2;
  font-weight: bold;
}

.ocguide-lead {
  position: relative;
  margin-top: 60px;
}
.ocguide-lead-wrap {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  padding: 30px 35px;
}
.ocguide-lead-wrap::before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  height: 183px;
  width: calc(100% - 50px);
  background-color: #fff;
  z-index: -1;
}
.ocguide-lead-content {
  width: 51%;
}
.ocguide-lead-content .m-index-title {
  margin-left: -30px;
}
.ocguide-lead-title {
  font-weight: bold;
  font-size: min(3.2vw, 3.2rem);
}
.ocguide-lead-title .-txt01 {
  font-size: min(4.8vw, 4.8rem);
}
.ocguide-lead-title .-txt02 {
  margin-left: 20px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-style: italic;
  font-size: min(10vw, 11.2rem);
  color: #E70012;
}
.ocguide-lead-title .-txt03 {
  margin-left: 10px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-style: italic;
  font-size: 5.6rem;
  color: #E70012;
}
.ocguide-lead-text {
  margin-top: 10px;
  font-size: min(2.1vw, 2.4rem);
  font-weight: bold;
  line-height: 1.666;
}
.ocguide-lead-caption {
  margin-top: 10px;
  font-size: 1.2rem;
}
.ocguide-lead-image {
  width: 37%;
}
.ocguide-lead-image .img01 {
  position: relative;
  top: 20px;
  width: 350px;
}
.ocguide-lead-image .img02 {
  position: absolute;
  right: 0;
  width: min(12vw, 148px);
}

.ocguide-faq {
  position: relative;
}
.ocguide-faq .col-wrap {
  position: relative;
  margin-top: 150px;
  padding-top: 95px;
  padding-bottom: 100px;
}
.ocguide-faq .col-wrap::before {
  position: absolute;
  content: "";
  top: 0;
  left: min(3vw, 60px);
  width: 100vw;
  height: 100%;
  background-color: #EFE3DF;
  z-index: -3;
}
.ocguide-faq-lead {
  margin-top: 40px;
  text-align: center;
}
.ocguide-faq .faq-text {
  background-color: #F3EDEB;
}
.ocguide-faq .faq-body {
  margin-top: 20px;
}

.section-ocguide-menu {
  position: relative;
  margin-top: 95px;
  padding-bottom: 30px;
}
.section-ocguide-menu .col-inner {
  position: relative;
}

.ocguide-menus {
  margin-top: -40px;
}

.ocguide-menu {
  position: relative;
  margin-top: 80px;
}
.ocguide-menu::before {
  position: absolute;
  content: "";
  top: 46px;
  width: 100vw;
  height: calc(100% - 46px);
  background-color: #E70012;
  background-repeat: no-repeat;
  background-position: center;
  background-size: auto 100%;
  z-index: -3;
}
.ocguide-menu.-year1 {
  padding-right: min(14vw, 210px);
}
.ocguide-menu.-year1::before {
  left: min(-3vw, -60px);
  background-color: #E70012;
  background-image: URL("../images/ocguide/bg_menu_01.jpg");
}
.ocguide-menu.-year2 {
  padding-left: min(16vw, 210px);
}
.ocguide-menu.-year2::before {
  right: min(-3vw, -60px);
  background-color: #E83928;
  background-image: URL("../images/ocguide/bg_menu_02.jpg");
}
.ocguide-menu.-year2 .ocguide-menu-title {
  border: solid 3px #E83928;
}
.ocguide-menu.-year3 {
  padding-right: min(16vw, 210px);
}
.ocguide-menu.-year3::before {
  left: min(-3vw, -60px);
  background-color: #FFB13A;
  background-image: URL("../images/ocguide/bg_menu_03.jpg");
}
.ocguide-menu.-year3 .ocguide-menu-title {
  border: solid 3px #FFB13A;
}
.ocguide-menu-title {
  padding: 10px 75px 18px;
  display: inline-block;
  background-color: #fff;
  border: solid 3px #E70012;
  font-size: min(3.1vw, 4rem);
  font-weight: bold;
}
.ocguide-menu-title .-txt01 {
  font-size: min(4.5vw, 5.6rem);
}
.ocguide-menu-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 50%;
  max-width: 380px;
}
.ocguide-menu-item-wrap {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 30px;
     -moz-column-gap: 30px;
          column-gap: 30px;
  padding-bottom: 50px;
}
.ocguide-menu-lead {
  margin-top: 40px;
  font-size: min(1.8vw, 2.4rem);
  font-weight: bold;
  line-height: 1.5;
  color: #fff;
}
.ocguide-menu-text {
  margin-top: 35px;
  font-weight: bold;
  line-height: 2.1875;
  color: #fff;
}
.ocguide-menu-image {
  position: absolute;
}
.ocguide-menu-image.-student01 {
  top: 0px;
  right: 0px;
  width: min(14vw, 160px);
  height: auto;
}
.ocguide-menu-image.-student02 {
  top: 0px;
  left: 0;
  width: min(13vw, 134px);
  height: auto;
}
.ocguide-menu-image.-student03 {
  top: 0px;
  right: 0;
  width: min(14vw, 170px);
  height: auto;
}

.ocguide-menu-btn {
  margin-top: 30px;
  width: 100%;
  -webkit-transition: 0.35s ease-in-out;
  transition: 0.35s ease-in-out;
}
.ocguide-menu-btn a {
  outline: 2px solid #fff;
  position: relative;
  width: 100%;
  max-width: 380px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.ocguide-menu-btn a::before {
  content: "";
  padding-top: 38.4210526316%;
}
.ocguide-menu-btn a p {
  margin-top: 70px;
  padding-right: 40px;
  position: absolute;
  font-size: min(2vw, 2.8rem);
  line-height: 1;
  font-weight: 500;
  color: #fff;
}
.ocguide-menu-btn a p::after {
  position: absolute;
  content: "";
  width: 25px;
  height: 25px;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: URL("../images/base/ico_arrow-l_wh.svg");
  background-size: cover;
}
.ocguide-menu-btn a .icon {
  position: absolute;
  top: 14%;
}
.ocguide-menu-btn a:hover {
  opacity: 0.7;
}
.ocguide-menu-btn.-btn01 {
  /*  background: URL("../images/base/bg_contact_01.webp") 0 0;
    background-size: cover;*/
}
.ocguide-menu-btn.-btn01 .icon {
  width: 70px;
  height: 59px;
  background: URL("../images/base/ico_menu_01.svg") 0 0;
  background-size: cover;
}
.ocguide-menu-btn.-btn02 {
  /* background: URL("../images/base/bg_contact_02.webp") 0 0;
   background-size: cover; */
}
.ocguide-menu-btn.-btn02 .icon {
  width: 41px;
  height: 52px;
  background: URL("../images/base/ico_menu_02.svg") 0 0;
  background-size: cover;
}

.line01-ocguide-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  top: -90px;
  z-index: 0;
}

.line02-ocguide-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-top: -14%;
  z-index: -1;
}

.a-article.item-ocguide-01 {
  top: -50px;
  left: 120px;
  width: 90px;
}
.a-article.item-ocguide-02 {
  top: -120px;
  right: 5px;
  width: 74px;
}

/* ==========
  14 ogob
========================================================================== */
.ogob-list {
  margin-bottom: 55px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 35px 1fr 35px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 35px 35px;
}

.ogob-item {
  position: relative;
  width: 100%;
}
.ogob-item a::after {
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  pointer-events: auto;
  background-color: transparent;
}
.ogob-item-thumb {
  aspect-ratio: 310/240;
}
.ogob-item-thumb img {
  aspect-ratio: 310/240;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.ogob-item-name {
  margin-top: 15px;
  font-size: 1.4rem;
  line-height: 1.45;
}
.ogob-item-name .-txt01 {
  color: #E70012;
}
.ogob-item-name .-txt02 {
  font-size: 2.4rem;
  font-weight: bold;
}
.ogob-item-name .-txt03 {
  margin-left: 5px;
  font-weight: bold;
}
.ogob-item-lead {
  margin-top: 10px;
  padding-bottom: 20px;
  font-size: 1.4rem;
  line-height: 2.14;
}

/* ==========
  14_ ogob_details
========================================================================== */
.ogob-detail-wrap {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 45px;
}
.ogob-detail-thumb {
  aspect-ratio: 450/363;
  max-width: 450px;
  height: auto;
}
.ogob-detail-thumb img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.ogob-detail-content {
  width: 500px;
  margin-left: 50px;
}
.ogob-detail-title {
  font-size: min(3.2vw, 3.2rem);
  font-weight: bold;
  line-height: 1.7187;
  min-height: 5em;
}
.ogob-detail-name {
  margin-top: 50px;
  font-size: min(2vw, 2rem);
  line-height: 1.4;
}
.ogob-detail-name .-txt01 {
  display: block;
  margin-bottom: 10px;
  color: #E70012;
}
.ogob-detail-name .-txt02 {
  font-size: min(2.8vw, 2.8rem);
  font-weight: bold;
}
.ogob-detail-name .-txt03 {
  margin-left: 15px;
  font-weight: bold;
}
.ogob-detail-lead {
  margin: 30px 0;
  line-height: 2.1875;
}

.ogob-sonota {
  margin-top: 115px;
}
.ogob-sonota .ogob-list {
  margin-top: 40px;
}

/* ==========
  23 お知らせ /news/
========================================================================== */
/* news */
.cat-menu-wrap {
  clear: both;
  position: relative;
  margin: -12px auto 50px;
}

.cat-menu-list {
  text-align: center;
}
.cat-menu-list li {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  margin: 12px 10px;
  font-size: 2rem;
  font-weight: bold;
  /*a &-list {
  margin-top: -10px;
  width: calc( 100% - 240px );*/
}
.cat-menu-list li.current-cat a {
  background-color: #E70012;
  color: #fff;
}
.cat-menu-list li a {
  display: block;
  padding: 7px 3px;
  width: 200px;
  text-decoration: none;
  text-align: center;
  background-color: #AFAFAF;
  color: #fff;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.cat-menu-list li a:hover {
  opacity: 0.7;
}

.cat-menu-select {
  display: none;
}

.news-list {
  margin: 60px auto 80px;
}
.news-list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 28px 10px;
  border-bottom: 1px dashed #A1A1A1;
  min-height: 54px;
}
.news-list li > a {
  position: relative;
  width: calc(100% - 160px);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.news-list li > a:hover {
  opacity: 0.7;
}
.news-list li > a::after {
  position: absolute;
  content: "";
  top: 0;
  right: 10px;
  bottom: 0;
  width: 7px;
  height: 7px;
  margin: auto 0;
  border-top: 1px solid #212121;
  border-right: 1px solid #212121;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.news-list-meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.news-list-date {
  margin-right: 5px;
  width: 80px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 1.6rem;
}
.news-list-cat {
  font-size: 1.2rem;
  line-height: 1.3;
  font-weight: bold;
  margin-right: 5px;
}
.news-list-cat-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 80px;
}
.news-list-cat > a {
  position: relative;
  display: block;
  margin-top: 4px;
  padding: 3px 3px;
  width: 75px;
  text-align: center;
  color: #fff;
  background-color: #212121;
  z-index: 2;
  /*  &.cat-01{
     background-color: $color-bk;}
    &.cat-02{
     background-color: $color-r2;}*/
}
.news-list-text {
  display: block;
  padding-right: 20px;
  margin-left: 30px;
}

/* pagenavi */
.wp-pagenavi {
  margin: 40px auto 80px;
  font-size: 0;
}

.wp-pagenavi a, .wp-pagenavi span {
  width: 60px;
  height: 60px;
  margin-top: 20px;
  margin-right: 10px;
  margin-left: 10px;
  line-height: 58px;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 2.4rem;
  text-align: center;
  background-color: transparent;
  color: #E70012;
  border: solid 1px #E70012;
}

.page-numbers {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.page-numbers a:hover, .page-numbers .current {
  -webkit-transition: 0.3s;
  transition: 0.3s;
  color: #fff;
  background-color: #E70012;
}

.page-numbers li {
  display: inline-block;
}

.prev {
  border: none !important;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.prev::before {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  border-bottom: 2px solid #000;
  border-left: 2px solid #000;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.prev:hover::before {
  border-bottom: 2px solid #fff;
  border-left: 2px solid #fff;
}

.next {
  border: none !important;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.next::before {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.next:hover::before {
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}

/* post */
.post-area {
  min-height: 200px;
  overflow: hidden;
  text-align: left;
}

.post-title {
  margin-top: 30px;
  font-size: 2.8rem;
  font-weight: bold;
  line-height: 2;
}

.post-body {
  margin: 30px 0;
  /* p a, table a, li a,
   .wp-block-file a{ //link設定共通
    position: relative;
    color: #283593;
    border-bottom: solid 1px #283593;
    &:hover{
      border-bottom: solid 1px rgba(255,255,255, 0.5);
      }
    }
   */
}
.post-body img {
  margin-bottom: 70px;
}
.post-body p {
  margin-bottom: 2em;
  line-height: 2;
}
.post-body p.clear {
  clear: both;
  margin-bottom: 0;
}
.post-body h2 {
  margin: 1em 0;
  padding: 1em 0;
  font-size: 2rem;
  line-height: 1.75;
  font-weight: bold;
}
.post-body h2::first-letter {
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
}
.post-body h3 {
  position: relative;
  margin: 2em 0;
  padding: 0 1em;
  font-size: 2rem;
  line-height: 1.75;
  font-weight: bold;
}
.post-body h3::before {
  position: absolute;
  content: "";
  width: 5px;
  height: 85%;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: #E70012;
}
.post-body .alignleft {
  float: left;
  margin-right: 45px;
  margin-bottom: 45px;
}
.post-body .alignright {
  float: right;
  margin-left: 45px;
  margin-bottom: 45px;
}
.post-body .aligncenter {
  margin: 40px auto;
  text-align: center;
}
.post-body .wp-block-file a.wp-block-file__button {
  color: #fff !important;
}
.post-body em {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(65%, transparent), color-stop(65%, #FFF33F));
  background: linear-gradient(transparent 65%, #FFF33F 65%);
  font-style: normal;
  font-weight: normal;
}
.post-body pre {
  padding: 1em 1.5em;
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
  background-color: #F3F3F3;
  border: solid 1px #707070;
}
.post-body table {
  margin: 40px 0;
}
.post-body table th {
  background-color: #f5f5f5;
  padding: 20px 20px;
  color: #333;
  border: solid 1px #e0e0e0;
  font-weight: bold;
  width: 250px;
  line-height: 2;
}
.post-body table td {
  padding: 20px 20px;
  border: solid 1px #e0e0e0;
  color: #333;
  line-height: 2;
  word-break: break-word;
}
.post-body ul {
  margin: 20px 0;
}
.post-body ul li {
  margin-bottom: 0.5em;
  margin-left: 1.5em;
  line-height: 1.35;
  list-style-type: disc;
}
.post-body ul li ul {
  margin: 0.5em 0;
}
.post-body ol {
  margin: 40px auto;
  padding: 22px 26px;
  counter-reset: list-count;
  list-style: none;
  background-color: #fff;
}
.post-body ol li {
  margin-left: 2em;
  text-indent: -2em;
}
.post-body ol li::before {
  content: counter(list-count) ".";
  counter-increment: list-count;
  margin-right: 0.5em;
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 2.4rem;
}

/*  pager  */
.post-pager {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 60px;
}
.post-pager li {
  position: relative;
  margin: 0 5px;
}
.post-pager li .btn_wh {
  width: 160px;
}
.post-pager li.btn-prev a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  width: 60px;
  height: 60px;
}
.post-pager li.btn-prev a::before {
  position: absolute;
  content: "";
  width: 15px;
  height: 14px;
  background: url(../images/base/ico_arrow.svg) no-repeat;
  background-size: contain;
}
.post-pager li.btn-prev a:hover {
  opacity: 0.7;
}
.post-pager li.btn-next a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  width: 60px;
  height: 60px;
}
.post-pager li.btn-next a::before {
  position: absolute;
  content: "";
  width: 15px;
  height: 14px;
  background: url(../images/base/ico_arrow.svg) no-repeat;
  background-size: contain;
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}
.post-pager li.btn-next a:hover {
  opacity: 0.7;
}

/* ==========
  27 プライバシーポリシー /privacy/
========================================================================== */
/* privacy */
.privacy-area {
  padding: 65px 70px;
  background-color: #fff;
}

.privacy-body h2 {
  font-size: 2.4rem;
  font-weight: bold;
}
.privacy-body h3 {
  margin-top: 50px;
  font-size: 2.4rem;
  font-weight: bold;
}
.privacy-body p {
  margin-top: 30px;
  line-height: 1.875;
}
/* ==========
  26 アクセス /access/
========================================================================== */
.access-info {
  margin: 50px auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 60px;
     -moz-column-gap: 60px;
          column-gap: 60px;
}
.access-info-map {
  width: 480px;
}
.access-info-content {
  width: 460px;
}
.access-info-logo {
  padding-bottom: 30px;
  border-bottom: solid 1px #212121;
}
.access-info-logo img {
  width: 358px;
}
.access-info-data {
  margin-top: 35px;
}
.access-info-data dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 10px;
  padding-bottom: 10px;
}
.access-info-data dt {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 90px;
  font-size: min(1.7vw, 1.6rem);
  font-weight: bold;
}
.access-info-data dd {
  font-size: min(1.7vw, 1.6rem);
  line-height: 1.5625;
}

.access-map {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 75%;
}
.access-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.access-spot {
  margin-top: 125px;
}
.access-spot-items {
  margin-top: 40px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 35px 1fr 35px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 35px;
}
.access-spot-item-title {
  margin-top: 30px;
  font-size: 2rem;
  font-weight: bold;
}
.access-spot-item-text {
  margin-top: 20px;
  font-size: 1.4rem;
  line-height: 2.14;
}

/* ==========
  25  情報公開　/information/
========================================================================== */
/* ==========
  31  企業の方へ　/company/
========================================================================== */
.company-content {
  margin-top: 90px;
}
.company-text {
  margin-top: 30px;
  line-height: 1.875;
}

/* ==========
  28  保護者の方へ　/parent/
========================================================================== */
.parent-content {
  margin-top: 100px;
}
.parent-title {
  font-size: 2.8rem;
  font-weight: bold;
  line-height: 1.5;
  padding-bottom: 10px;
  border-bottom: solid 1.5px #212121;
}
.parent-text {
  margin-top: 35px;
  margin-bottom: 35px;
  line-height: 2.1875;
}

/* ==========
  10 交通費補助　/opencampus/support/
========================================================================== */
.oc-support-content {
  width: 100%;
}
.oc-support-text {
  margin-top: 20px;
  line-height: 1.875;
}

/* .m-data-table */
/*.oc-support-data{
 margin-top: 50px;
 padding: 50px 50px 10px 50px;
 background-color: #fff;
 dl{
 display: flex;
 margin-bottom: 40px;
 padding-bottom: 35px; 
 border-bottom: dashed 1px $color-bk;
 &.-last{
   border-bottom:none;
   padding-bottom: 0;
  }
 }
 dt{
 width: 200px;
 text-align: right;
 font-size: 2.4rem;
 line-height: 1.3;
 font-weight: bold;
 color: $color-r3;
 }
 dd{
 margin-left: 50px;
 flex: 1;
 }
 .icon-item{
  display: flex;
  margin-bottom: 15px;
  .icon{
    background-color:$color-r2;
    width: 35px;
    height: 35px;
   }
   &-text{
    margin-left: 10px;
    font-weight: bold;
   }
  }
 } */
/* ==========
  29_ 既卒生の方へ /alumnus/
  30_ 県外から進学を目指す方へ　/outside/
========================================================================== */
.section-voice-item {
  margin-top: 120px;
  padding-bottom: 20px;
}

.voice-items {
  margin-top: 25px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 40px 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 35px 40px;
}

.voice-item {
  padding: 30px 24px 25px;
  background-color: #fff;
}
.voice-item-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.voice-item-head-image {
  margin-right: 20px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 114px;
  height: 136px;
}
.voice-item-head-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.voice-item-head-title {
  margin-top: 5px;
  font-size: 2rem;
  font-weight: bold;
  line-height: 1.65;
  color: #E70012;
}
.voice-item-head-text {
  margin-top: 5px;
}
.voice-item-head-name {
  margin-top: 15px;
  text-align: right;
  line-height: 1.25;
}
.voice-item-head-name .-small {
  font-size: 1.2rem;
}
.voice-item-body {
  margin-top: 15px;
  background-image: linear-gradient(90deg, transparent 0%, transparent 50%, #fff 50%, #fff 100%), linear-gradient(180deg, #DBDBDB 1px, transparent 1px);
  background-size: 4px 100%, 100% 2.4em;
  line-height: 2.4em; /* 文字の高さ */
  padding-bottom: 5px;
}

/* ==========
  24 お問い合わせ /contact/
========================================================================== */
.contact-head {
  margin: 10px auto 70px;
  max-width: 836px;
}

.form-steps-list {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.form-steps-list::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 1px;
  left: 0;
  top: 50%;
  border-bottom: 1px solid #D3D3D3;
}
.form-steps-list li {
  position: relative;
  padding: 0 24px;
  text-align: center;
  font-size: 2rem;
  font-weight: bold;
  background-color: #F3EDEB;
}
.form-steps-list li .num {
  font-family: "din-2014-narrow", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 2.8rem;
  vertical-align: middle;
}
.form-steps-list li.is-active {
  color: #BC0312;
}

.form-lead {
  margin: 0 auto;
  text-align: center;
}
.form-lead-image {
  margin: 0 auto 20px;
}
.form-lead-title {
  margin: 20px auto 30px;
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.2;
  text-align: center;
}
.form-lead-text {
  margin: 20px auto;
}
.form-lead-text p {
  margin-bottom: 1em;
  line-height: 1.875;
}
.form-lead .btn-more {
  margin: 80px auto;
}

.contact-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.contact-aside {
  margin-right: min(6vw, 80px);
  width: min(37vw, 370px);
  line-height: 2.1875;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.confirm-area .contact-aside {
  display: none;
}
.confirm-area .form-area {
  margin-top: 0;
}
.confirm-area .form-items {
  padding: 0 20px;
  border-top: solid 1px #212121;
}
.confirm-area .form-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 0;
  padding: 30px 0;
  border-bottom: dashed 1px #212121;
}
.confirm-area .form-item-name {
  width: min(28vw, 300px);
  margin-right: min(8vw, 90px);
  text-align: right;
  font-size: 1.6rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.confirm-area .form-item-name::before {
  display: none;
}
.confirm-area .form-item-input {
  padding: 0;
  max-width: 450px;
}

/*
#wpcf7cpcnf{
 table{
  padding: 0 20px;
  border-top: solid 1px $color-bk;
  width: 100%;
 }
 tr{
  display: flex;
  margin-top: 0;
  padding: 30px 0;
  border-bottom: dashed 1px $color-bk;
 }
 th{
  width: min(28vw, 280px);
  margin-right: min(8vw, 90px);
  text-align: right;
  font-size: 1.6rem;
  flex-shrink: 0;
 &::before{
  display: none;
  }
 }
 td{
   padding: 0;
   max-width: 450px;
 }


}
.wpcf7cp-btns{
 position: relative;
 display: flex;
 justify-content: center;
 margin-top: 80px;
 column-gap: 40px;
 button{
  padding: 0;
  cursor: pointer;
  overflow: hidden;
 } 
}
.wpcf7cp-cfm-submit-btn{ //btn-prev
 position: relative;
 display: flex;
 align-items: center;
 justify-content: center;
 width: 260px;
 height: 65px;
 padding: 0 28px;
 z-index: 1;
 background: URL("../images/base/bg_btn.png") 0 0; 
 background-size: cover;
 overflow: hidden;
 transition: color ease .3s;
 border:solid 2px transparent;
 box-sizing: border-box;

 z-index: 3;
 padding-left: 30px;
 text-align: left;
 font-size: 1.6rem;
 font-weight: bold;
 color:#FFF;
 background-color:transparent; 
 &::after{
  position: absolute;
  content:"";
  width:25px;
  height: 25px;
  top: 50%;
  right: 28px;
  transform: translateY(-50%);
  background: URL("../images/base/ico_arrow-l_wh.svg");
  background-size: cover;
 }
 &:hover {
  border: 2px solid $color-r3;
  color:$color-r3;
   &::after{
   background: URL("../images/base/ico_arrow-l_red.svg");
   background-size: cover;
   color: $color-r3;
   }
 }
 &::before{
  position: absolute;
  content: "";
  width: 120%;
  height: 200%;
  top: 0;
  right: 0;
  z-index: -1;
  background: #fff;
  transform: translateX(-100%);
  transition: transform ease .3s;
 }
 &:hover::before{
  transform: translateX(10%);
 } 
}
.wpcf7cp-cfm-edit-btn{ //btn-prev
 position: relative;
 display: flex;
 align-items: center;
 justify-content: center;//flex-end;
 width: 260px;
 height: 65px;
 padding: 0 28px;
 z-index: 1;
 background-color: #fff;
 overflow: hidden;
 transition: color ease .3s;
 border:solid 2px $color-r3;
 box-sizing: border-box;

  text-align: right; 
  font-size: 1.6rem;
  font-weight: bold;
  color: $color-r3;
//  z-index: 3;
 &::after{
  position: absolute;
  content:"";
  width:26px;
  height: 26px;
  top: 50%;
  left: 28px;
  background: URL("../../common/images/base/ico_arrow-l_red.svg");
  background-size: cover;
  transform: translateY(-50%) scale(-1, 1);
 }
 &:hover {
  border: 2px solid $color-r1;
  color:#fff;
   &::after{
   background: URL("../images/base/ico_arrow-l_wh.svg");
   background-size: cover;
   color: #fff;
   }
 }
  &::before{
  position: absolute;
  content: "";
  width: 120%;
  height: 200%;
  top: 0;
  right: 0;
  z-index: -1;
//  background: $color-r3;
  background: URL("../images/base/bg_btn.png") 0 0; 
  background-size: contain;
  transform: translateX(200%);
  transition: transform ease .3s;
 }
 &:hover::before{
  transform: translateX(10%);
 } 
}
*/
/* form ------------ */
.form-area {
  width: 100%;
  margin-top: -30px;
}

.form-item {
  margin-top: 30px;
  border-bottom: solid 1px #212121;
}
.form-item-name {
  position: relative;
  padding-left: 50px;
  font-size: clamp(1.5rem, 1.5vw, 2rem);
  font-weight: bold;
}
.form-item-name::before {
  position: absolute;
  content: "任意";
  font-size: 1.4rem;
  font-weight: normal;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  margin-right: 10px;
  width: 40px;
  height: 20px;
  background-color: #AFAFAF;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
/******************************************** 20251018追加 ***********************************************/
.gfield_label {
  display: flex;
  align-items: center;
}
.gfield_label .gfield_required {
  order: -1;
  margin-right: 0.2em;
}
.gfield_label .gfield_required_text {
  display: inline;
}
.gfield_required.gfield_required_text {
    display: none;
}
.gfield_label::before {
    content: "必須";
    background-color: #E70012;
	color:#fff;
  font-size: 1.4rem;
  font-weight: normal;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  left: 0;
  margin-right: 10px;
  width: 40px;
  height: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: absolute;
}
legend.gform-field-label,.gform-field-label {
font-size: clamp(1.5rem, 1.5vw, 2rem) !important;
position: relative;
padding-left:50px;
}
.gform-field-label--type-inline,.gform-field-label--type-sub {
  padding-left: 0;
  font-size: 1em !important;
}
#field_1_5 label{
  display:none;
}
#gform_fields_1 .gfield{
border-bottom: solid 1px #212121;
padding-bottom: 1.2em;
}
#gform_fields_1 .gfield--input-type-text input,
#gform_fields_1 .gfield--input-type-email input, 
#gform_fields_1 .gfield--input-type-phone input,
#gform_fields_1 .gform-grid-col input{
  background-color: rgb(243, 237, 235);
  border: none;
  box-shadow: none;
  font-size: 1.1em;
  margin-top: 1em;
  padding: 20px 10px;
}
#gform_fields_1 .gfield--input-type-text input::placeholder,
#gform_fields_1 .gfield--input-type-email input::placeholder, 
#gform_fields_1 .gfield--input-type-phone input::placeholder,
#gform_fields_1 .gform-grid-col input::placeholder {
  color: #888;
}
.wp-block-contact-form-7-contact-form-selector{
width:100%;
}
.gform_page_footer {
  display: flex;
  justify-content: center;
  align-items: center;
}
#gform_next_button_1_10 {
  font-size: 1.2em;
}
#field_1_11 table,#field_1_11 table td,#field_1_11 table tr{
  background:transparent !important;
}
#field_1_11 table td font,#field_1_11 table tr font{
  font-size:16px !important;
}
/* tbodyをflexにして横並びに */
#field_1_11 table tbody {
  display: flex;
  flex-wrap: wrap; /* 複数行対応 */
  gap: 10px;       /* 要素間の余白 */
}
#field_1_11 table tbody tr {
  display: flex;
  flex: 1 1 calc(50% - 5px);
  box-sizing: border-box;
  padding: 2em 0;
  border-bottom: dashed 1px #212121;
}
#field_1_11 table tbody tr:last-child{
  border-bottom:none !important;
}
#gform_previous_button_1,#gform_submit_button_1 {
  width: 40%;
  font-size:1em;
  padding:15px 0;
}
#gform_submit_button_1 {
  background: URL("../images/base/bg_btn.png") 0 0;
  background-size: cover;
}
@media screen and (max-width: 767px){
#field_1_11 table tbody {
  display: block;
}
#field_1_11 table tbody tr,#field_1_11 table tbody td {
  display: block;
  width:100%;
}
#field_1_11 table tbody tr:nth-child(odd) {
   padding: 1em 0;
}

#field_1_11 table tbody tr:nth-child(even) {
   padding:2em 0 2.5em 0 ;
}
}






.form-item-name.require::before {
  content: "必須";
  background-color: #E70012;
}
.form-item-input {
  padding: 10px 0 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.form-item-input label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.form-item-input .radio-field-text .wpcf7-list-item {
  margin: 0 1em 0 0;
}
.form-item-input .radio-field-text .wpcf7-list-item-label {
  margin: 0 20px 0 5px;
}
.form-item-input .check-field-text .wpcf7-list-item {
  margin: 0 1em 0 0;
}
.form-item-input .check-field-text .wpcf7-list-item-label {
  margin: 0 20px 0 5px;
}
.form-item-input .tate-field-text .wpcf7-list-item {
  display: block;
  margin-left: 0;
  margin-bottom: 10px;
}
.form-item-input .tate-field-text .wpcf7-list-item-label {
  margin: 0 20px 0 5px;
}
.form-item input, .form-item textarea {
  padding: 10px 10px;
  width: 100%;
  background-color: #F3EDEB;
  border: none;
  font-size: 1.6rem;
}

.wpcf7 input[type=text],
.wpcf7 input[type=email],
.wpcf7 input[type=url],
.wpcf7 input[type=tel],
.wpcf7 textarea {
  width: 100%;
}

.wpcf7-list-item.first {
  margin-left: 0 !important;
}

/*Conditional Fields for Contact Form 7　plugin使わない場合設定必要
#message-area{
  display: none;
}*/
#wpcf7-f16-p25-o1 #message-area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

input[type=radio] {
  position: relative;
  -moz-appearance: none;
  appearance: none;
  -webkit-appearance: none;
  border: solid 1px #212121;
  -webkit-box-shadow: none;
          box-shadow: none;
  background-color: #fff;
  outline: none;
  width: 20px;
  height: 20px;
  padding: 0;
  vertical-align: middle;
  border-radius: 50% !important;
  cursor: pointer;
}
input[type=radio]::after {
  content: "";
  width: 8px;
  height: 8px;
  background-color: #212121;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-top: -4px;
  margin-left: -4px;
  border-radius: 100%;
  display: none;
}
input[type=radio]:checked:after {
  display: block;
}

input[type=checkbox] {
  position: relative;
  -moz-appearance: none;
  appearance: none;
  -webkit-appearance: none;
  border: solid 1px #212121;
  -webkit-box-shadow: none;
          box-shadow: none;
  background-color: #fff;
  outline: none;
  width: 20px;
  height: 20px;
  padding: 0;
  vertical-align: middle;
}
input[type=checkbox]::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 1px;
  border-left: 2px solid #212121;
  border-top: 2px solid #212121;
  width: 8px;
  height: 12px;
  -webkit-transform: rotate(225deg);
          transform: rotate(225deg);
  display: none;
}
input[type=checkbox]:checked:after {
  display: block;
}

.wpcf7-spinner {
  display: none !important;
}

.form-button {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 80px;
  -webkit-column-gap: 40px;
     -moz-column-gap: 40px;
          column-gap: 40px;
}
.form-button .btn-more, .form-button .btn-prev {
  padding: 0;
  cursor: pointer;
  overflow: hidden;
  display: block;
  margin: 0 auto;
}
.form-button .__next {
  padding-left: 30px;
  text-align: left;
  font-size: 1.6rem;
  font-weight: bold;
  color: #FFF;
  background-color: transparent;
}
.form-button .__prev {
  padding-right: 30px;
  text-align: right;
  font-size: 1.6rem;
  font-weight: bold;
  color: #BC0312;
  background-color: transparent;
}

input[type=submit], input[type=button], input[type=reset] {
  border: none;
  outline: none;
  cursor: pointer;
  width: 260px;
  height: 65px;
}

.form-privacy-title {
  font-weight: 500;
}

.form-privacy-text {
  font-weight: 400;
}

.contact-privacy {
  margin: 50px auto 40px;
  padding: 28px 30px;
  width: 100%;
  max-width: 900px;
  height: 220px;
  font-size: 1.4rem;
  line-height: 1.75;
  background-color: #fff;
  border: solid 1px #E0E0E0;
  overflow-y: scroll;
  overflow-x: hidden !important;
}
.contact-privacy p {
  margin-bottom: 2em;
}

.form-last-check {
  text-align: center;
}
.form-last-check input[type=checkbox] {
  border-radius: 0 !important;
  width: 20px;
  height: 20px;
}
.form-last-check input[type=checkbox]::after {
  content: "";
  width: 8px;
  height: 12px;
  background-color: inherit;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-top: -8px;
  margin-left: -4px;
  border-radius: inherit;
  border-right: 3px solid #808080;
  border-bottom: 3px solid #808080;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  display: none;
}
.form-last-check input[type=checkbox]:checked:after {
  display: block;
}

/* ==========
  00 404
========================================================================== */
.section404 .lead {
  margin: 10px auto;
  text-align: center;
  font-size: clamp(1.5rem, 3vw, 4rem);
  font-weight: bold;
}
.section404 .text {
  margin: 60px auto;
  text-align: center;
  line-height: 2.18;
}

@-webkit-keyframes bg-loop {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -1593px 0;
  }
}

@keyframes bg-loop {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -1593px 0;
  }
}
@-webkit-keyframes rotation {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes rotation {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
.a-infinity-l {
  -webkit-animation: infinity_scroll_left 20s 0.5s linear infinite;
          animation: infinity_scroll_left 20s 0.5s linear infinite;
}

@-webkit-keyframes infinity_scroll_left {
  0% {
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}

@keyframes infinity_scroll_left {
  0% {
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
.a-infinity-r {
  -webkit-animation: infinity_scroll_right 20s 0.5s linear infinite;
          animation: infinity_scroll_right 20s 0.5s linear infinite;
}

@-webkit-keyframes infinity_scroll_right {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  to {
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
  }
}

@keyframes infinity_scroll_right {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  to {
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
  }
}
/*==================================================
 aimation呼び出し
===================================*/
/* effect */
.a-effect > * {
  opacity: 0;
}

.a-effect.is-active > * {
  -webkit-transition: 0.5s;
  transition: 0.5s;
  opacity: 1;
}

.a-effect.fade-up.is-active {
  -webkit-animation-name: fadeUpAnime;
          animation-name: fadeUpAnime;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.fade-up:nth-of-type(2) {
  -webkit-transition-delay: 200ms;
          transition-delay: 200ms;
}

.fade-up:nth-of-type(3) {
  -webkit-transition-delay: 400ms;
          transition-delay: 400ms;
}

.a-effect.fade-right.is-active {
  -webkit-animation-name: fadeRightAnime;
          animation-name: fadeRightAnime;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.a-effect.fade-left.is-active {
  -webkit-animation-name: fadeLeftAnime;
          animation-name: fadeLeftAnime;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.a-effect.fade-in.is-active {
  -webkit-animation: fadeInAnime;
          animation: fadeInAnime;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-delay: 10s;
          animation-delay: 10s;
}

/* その場で */
.fadeIn {
  -webkit-animation-name: fadeInAnime;
          animation-name: fadeInAnime;
  -webkit-animation-duration: 1.5s;
          animation-duration: 1.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

.fadeInTrigger {
  opacity: 0;
}

@-webkit-keyframes fadeInAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes fadeInAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
/* 下から */
.fadeUp {
  -webkit-animation-name: fadeUpAnime;
          animation-name: fadeUpAnime;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

.fadeUpTrigger {
  opacity: 0;
}

@-webkit-keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
/* 上から */
.fadeDown {
  -webkit-animation-name: fadeDownAnime;
          animation-name: fadeDownAnime;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeDownAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fadeDownAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
/* 左から */
.fadeLeft {
  -webkit-animation-name: fadeLeftAnime;
          animation-name: fadeLeftAnime;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeLeftAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(-100px);
            transform: translateX(-100px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes fadeLeftAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(-100px);
            transform: translateX(-100px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
/* 右から */
.fadeRight {
  -webkit-animation-name: fadeRightAnime;
          animation-name: fadeRightAnime;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeRightAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(100px);
            transform: translateX(100px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes fadeRightAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(100px);
            transform: translateX(100px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.fadeInTrigger,
.fadeUpTrigger,
.fadeDownTrigger,
.fadeLeftTrigger,
.fadeRightTrigger {
  opacity: 0;
}

/*==================================================
 svgアニメーション
===================================*/
/*
.svgAnimeTrigger > * { // svgAnime
  opacity: 0;
}
.svgAnimeTrigger.svgAnime > * {
  transition: 0.5s;
  opacity: 1;
}
*/
/* svg animation */
/*左から*/
@-webkit-keyframes line_move_l {
  from {
    stroke-dashoffset: 200%;
  }
  to {
    stroke-dashoffset: 0%;
  }
}
@keyframes line_move_l {
  from {
    stroke-dashoffset: 200%;
  }
  to {
    stroke-dashoffset: 0%;
  }
}
/*右から*/
@-webkit-keyframes line_move_r {
  0% {
    stroke-dashoffset: -200%;
  }
  100% {
    stroke-dashoffset: 0%;
  }
}
@keyframes line_move_r {
  0% {
    stroke-dashoffset: -200%;
  }
  100% {
    stroke-dashoffset: 0%;
  }
}
.a-line-wrap {
  display: none;
}
.svgAnime {
  /* position: relative;
   .a-line-wrap{
    display: block;
    position: absolute;
   }*/
}
.svgAnime.a-line-wrap {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  z-index: -2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  /*
  path{
   width: 100%;
  }*/
}

.a-svg-line {
  width: 0;
  height: 0;
  fill: none;
  stroke-width: 0;
  opacity: 0;
}

.svgAnime .a-svg-line {
  stroke-dasharray: 200%;
  stroke-width: 1;
  opacity: 1;
  width: 100%;
  height: auto;
  visibility: visible;
}

.a-svg-line#line-header {
  -webkit-animation: line_move_l 1.8s ease-in;
          animation: line_move_l 1.8s ease-in;
}
.a-svg-line#line01 {
  -webkit-animation: line_move_r 4s ease-in-out;
          animation: line_move_r 4s ease-in-out;
}
.a-svg-line#line01 .svg-elem-text {
  -webkit-animation: fadeInAnime 0.5s ease-in 1.4s both;
          animation: fadeInAnime 0.5s ease-in 1.4s both;
}
.a-svg-line#line02 {
  -webkit-animation: line_move_r 2.5s ease-in-out;
          animation: line_move_r 2.5s ease-in-out;
}
.a-svg-line#line03 {
  -webkit-animation: line_move_r 2.2s ease-in-out;
          animation: line_move_r 2.2s ease-in-out;
}
.a-svg-line#line04 {
  -webkit-animation: line_move_l 2.8s ease-in-out;
          animation: line_move_l 2.8s ease-in-out;
}
.a-svg-line#line04 .svg-elem-2 {
  -webkit-animation: fadeInAnime 0.3s ease-in 3s both;
          animation: fadeInAnime 0.3s ease-in 3s both;
}
.a-svg-line#line05 {
  -webkit-animation: line_move_r 3s ease-in-out;
          animation: line_move_r 3s ease-in-out;
}
.a-svg-line#line06 {
  -webkit-animation: line_move_l 3.5s ease-in-out;
          animation: line_move_l 3.5s ease-in-out;
}
.a-svg-line#line06 .svg-elem-3 {
  -webkit-animation: fadeInAnime 0.3s ease-in 4s both;
          animation: fadeInAnime 0.3s ease-in 4s both;
}
.a-svg-line#line07 {
  -webkit-animation: line_move_r 4s ease-in-out;
          animation: line_move_r 4s ease-in-out;
}
.a-svg-line#line07 .svg-elem-3 {
  stroke-dasharray: 0;
  stroke-dashoffset: 200%;
}
.a-svg-line#line07 .svg-elem-4 {
  -webkit-animation: fadeInAnime 0.3s ease-in 0.2s both;
          animation: fadeInAnime 0.3s ease-in 0.2s both;
}
.a-svg-line#line01-b {
  -webkit-animation: line_move_r 2.5s ease-in-out;
          animation: line_move_r 2.5s ease-in-out;
}
.a-svg-line#line02-b {
  -webkit-animation: line_move_l 4s ease-in-out;
          animation: line_move_l 4s ease-in-out;
}
.a-svg-line#line01-about {
  -webkit-animation: line_move_r 2.5s ease-in-out;
          animation: line_move_r 2.5s ease-in-out;
}
.a-svg-line#line02-about {
  -webkit-animation: line_move_r 2.5s ease-in-out;
          animation: line_move_r 2.5s ease-in-out;
}
.a-svg-line#line03-about {
  -webkit-animation: line_move_l 2.5s ease-in-out;
          animation: line_move_l 2.5s ease-in-out;
}
.a-svg-line#line01-ocguide {
  -webkit-animation: line_move_r 3s ease-in-out;
          animation: line_move_r 3s ease-in-out;
}
.a-svg-line#line02-ocguide {
  -webkit-animation: line_move_l 3s ease-in-out;
          animation: line_move_l 3s ease-in-out;
}
.a-svg-line#line01-campuslife {
  -webkit-animation: line_move_r 3s ease-in-out;
          animation: line_move_r 3s ease-in-out;
}

.a-svg-wavy {
  width: 100%;
  height: auto;
}

#wavy02 {
  -webkit-animation: line_move_l 5s ease-in-out;
          animation: line_move_l 5s ease-in-out;
}

#txt01 {
  -webkit-animation: line_move_l 5s ease-in-out;
          animation: line_move_l 5s ease-in-out;
}

@-webkit-keyframes fuwafuwa {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(-15px);
            transform: translateY(-15px);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fuwafuwa {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(-15px);
            transform: translateY(-15px);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
.js-vanilla-element {
  cursor: pointer;
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  -webkit-transform: perspective(1000px);
          transform: perspective(1000px);
}

.card__rotator {
  -webkit-transform: rotateY(var(--rotate-x)) rotateX(var(--rotate-y));
          transform: rotateY(var(--rotate-x)) rotateX(var(--rotate-y));
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  /* performance */
  pointer-events: auto;
  /* overflow: hidden; <-- this improves perf on mobile, but breaks backface visibility. */
  /* isolation: isolate; <-- this improves perf, but breaks backface visibility on Chrome. */
}

.card__rotator,
.card.active .card__rotator:focus {
  -webkit-transition: opacity 0.33s ease-out, -webkit-box-shadow 0.4s ease;
  transition: opacity 0.33s ease-out, -webkit-box-shadow 0.4s ease;
  transition: box-shadow 0.4s ease, opacity 0.33s ease-out;
  transition: box-shadow 0.4s ease, opacity 0.33s ease-out, -webkit-box-shadow 0.4s ease;
}

.card__rotator * {
  width: 100%;
  display: -ms-grid;
  display: grid;
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: 1/1;
  aspect-ratio: var(--card-aspect);
  border-radius: var(--card-radius);
  image-rendering: optimizeQuality;
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  pointer-events: none;
  overflow: hidden;
}

/* ---------------------------
 responsive
-----------------------------*/
@media screen and (max-width: 768px) {
  body {
    font-size: min(3.73vw, 1.4rem); /**/
    min-width: inherit;
    letter-spacing: 0;
  }
  #wrapper {
    min-width: inherit;
    width: 100%;
    overflow: hidden;
  }
  a:active {
    -webkit-touch-callout: none;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  /* ==========================================================================
    LAYOUT
  ========================================================================== */
  /* ------
  header
  ---------*/
  .header {
    position: fixed;
    left: 0;
    top: 0;
    height: 60px;
  }
  .header.hide .header-inner {
    -webkit-transform: translateY(-60px);
            transform: translateY(-60px);
  }
  .header.hide #nav-toggle {
    -webkit-transform: translateY(-60px);
            transform: translateY(-60px);
  }
  .header.filter::before {
    height: 60px;
  }
  .header::after {
    width: 3px;
    height: calc(100vh + 60px);
  }
  .header-inner {
    min-height: 60px;
    margin-left: 15px;
    width: calc(100% - 30px);
  }
  .header-logo {
    width: 67vw;
    max-width: 250px;
  }
  .header-menu {
    top: inherit;
    right: 0;
    left: 0;
    bottom: 0;
    width: 100%;
  }
  .header-btn {
    width: 100%;
  }
  .header-btn a {
    width: 100%;
    height: 50px;
    padding-top: inherit;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    font-size: min(3.5vw, 1.4rem);
  }
  .header-btn a .icon {
    position: relative;
    top: 0;
    padding: 0 10px 0 0;
  }
  .header-btn.-btn03 {
    display: none;
  }
  /* nav-toggle */
  #nav-toggle {
    position: fixed;
    width: 60px;
    height: 60px;
    padding: 0 15px;
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
  }
  #nav-toggle span {
    margin-top: -2px;
  }
  /* drawer */
  .drawer-container {
    min-height: inherit;
  }
  .drawer-container::before {
    position: absolute;
    content: "";
    top: -90px;
    left: 0;
    width: 100%;
    height: calc(100% + 90px);
    background-color: #BC0312;
  }
  .drawer-container .col-wrap {
    padding: 0 15px 30px;
  }
  .drawer-container .a-loop {
    z-index: 0;
    opacity: 1;
    bottom: 50px;
  }
  /* drawer open */
  #wrapper.open .header {
    background-color: #BC0312;
    overflow-y: scroll;
    height: 100%;
  }
  #wrapper.open .header-logo {
    position: relative;
  }
  #wrapper.open .header-logo .header-logo-r {
    display: none;
  }
  #wrapper.open .header-logo .header-logo-wh {
    display: block;
  }
  #wrapper.open .header-btn.-btn01 a {
    background-color: #fff;
    color: #BC0312;
    /*.icon {
    fill: $color-r3;
    }*/
  }
  #wrapper.open .header-btn.-btn01 a .icon-01-wh {
    display: none;
  }
  #wrapper.open .header-btn.-btn01 a .icon-01-r {
    display: block;
  }
  #wrapper.open .drawer-container {
    min-height: inherit;
  }
  .drawer-inner {
    margin: 30px auto 60px;
  }
  /* tab */
  .tab-wrap {
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin: 15px auto 30px;
    position: relative;
  }
  .tab-wrap-title {
    font-size: 1.6rem;
  }
  .tab-label {
    margin-bottom: 10px;
    width: calc(50% - 10px);
    font-size: 1.4rem;
  }
  .tab-content {
    display: none;
    margin-top: 10px;
  }
  /* アクティブなタブ */
  .tab-switch:checked + .tab-label {
    background-color: #FFD83D;
    color: #212121;
  }
  .tab-switch:checked + .tab-label + .tab-content {
    width: 100%;
    margin-left: inherit;
    height: 100%;
    position: relative;
    top: 0;
    right: 0;
  }
  /* ラジオボタン非表示 */
  .tab-switch {
    display: none;
  }
  .drawer-nav02 {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-top: 20px;
  }
  .drawer-nav02 li {
    position: relative;
    font-size: 1.2rem;
    line-height: 1.35;
  }
  .drawer-nav02 li a {
    padding: 0 1em;
    color: #fff;
  }
  .drawer-nav02 li::after {
    position: absolute;
    content: "|";
    top: 0;
    left: 0;
    color: #fff;
  }
  .drawer-nav02 li:first-child a {
    padding-left: 0;
  }
  .drawer-nav02 li:first-child::after {
    content: "";
  }
  /* === topic-path  ======================== */
  .topic-path {
    top: min(12vw, 120px);
    width: 100%;
    margin: 0 auto;
    padding: 30px 0;
    text-align: left;
    font-size: 1rem;
    z-index: 1;
  }
  .topic-path ul {
    padding: 0 15px;
  }
  /* === g-nav ======================== */
  .g-nav01 {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: repeat(1, 1fr);
    gap: 6px;
  }
  .g-nav02 {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: repeat(1, 1fr);
    gap: 6px;
    margin-left: inherit;
  }
  .g-nav03 {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: repeat(1, 1fr);
    gap: 6px;
    margin-left: inherit;
  }
  /* nav-list */
  .nav-list li dt {
    padding-bottom: 14px;
    padding-top: 14px;
    border-bottom: solid 1px #fff;
    cursor: pointer;
    height: auto;
  }
  .nav-list li dt a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    color: #FFD83D;
    line-height: 1.1;
    z-index: -1;
  }
  .nav-list li dt a .icon-next {
    display: none;
  }
  .nav-list li dt.nav01-head {
    font-size: clamp(1.3rem, 4vw, 1.4rem);
  }
  .nav-list li dt.nav02-head {
    font-size: clamp(1.3rem, 4vw, 1.4rem);
  }
  .nav-list li dt.nav03-head {
    font-size: clamp(1.3rem, 4vw, 1.4rem);
  }
  .nav-list li dt::before {
    position: absolute;
    content: "";
    top: calc(50% - 2px);
    right: 0;
    width: 15px;
    height: 2px;
    background-color: #fff;
  }
  .nav-list li dt::after {
    position: absolute;
    content: "";
    top: calc(50% - 2px);
    right: 0;
    width: 15px;
    height: 2px;
    background-color: #fff;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  .nav-list li dt.is-open::before {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  .nav-list li dt.is-open::after {
    opacity: 0;
  }
  .nav-list li dd {
    display: none;
    margin-top: 20px;
    font-size: 1.4rem;
    line-height: 1.28;
  }
  .nav-list li dd ul li {
    margin-bottom: 12px;
  }
  .nav-list li dd ul li a {
    color: #fff;
  }
  /*-------------
  	footer
  ---------------*/
  .footer {
    margin-top: 0;
    padding-bottom: 50px;
  }
  .footer .col-wrap {
    padding: 170px 15px 20px;
  }
  .footer-head {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .footer-logo {
    width: min(90vw, 375px);
  }
  .footer-info {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .footer-info-logo {
    max-width: 345px;
  }
  .footer-info-text {
    margin-left: 0;
    line-height: 1.785;
    margin-top: 20px;
    margin-bottom: 20px;
  }
  .footer-sns {
    margin-left: 0;
    -webkit-column-gap: 10px;
       -moz-column-gap: 10px;
            column-gap: 10px;
  }
  .footer-sns-title {
    font-size: 1.6rem;
  }
  .footer-sns-title::after {
    width: 59px;
  }
  .footer-sns-list {
    margin-left: 15px;
  }
  .footer-body {
    margin: 15px auto 5px;
    padding: 10px 0;
  }
  /* footer-nav */
  .footer-body .g-nav01 {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: repeat(1, 1fr);
    gap: 10px 0;
  }
  .footer-body .g-nav01 .nav01-head {
    font-size: clamp(1.3rem, 4vw, 1.6rem);
  }
  .footer-bottom {
    padding-bottom: 25px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .footer-nav02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 5px;
  }
  .footer-nav02 li {
    position: relative;
    font-size: 1.2rem;
    line-height: 2;
  }
  .footer-nav02 li a {
    padding: 0 0.5em;
    color: #E6E6E6;
  }
  .footer-nav02 li::before {
    right: inherit;
    left: 0;
    width: 1px;
    color: #E6E6E6;
  }
  .footer-nav02 li:first-child a {
    padding-left: 0;
  }
  .footer-nav02 li:first-child::before {
    content: "";
  }
  .footer-mark {
    position: relative;
    right: inherit;
    bottom: inherit;
    -webkit-column-gap: 10px;
       -moz-column-gap: 10px;
            column-gap: 10px;
    margin-bottom: 22px;
  }
  .footer-mark img {
    width: 73px;
    height: 27px;
  }
  .footer-mark p {
    font-size: 1.2rem;
  }
  .footer-copy {
    padding-top: 0;
    font-size: 1.2rem;
    border-top: none;
  }
  .footer-menu {
    position: fixed;
    bottom: 0;
    left: 0;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    z-index: 999;
  }
  /* pagetop */
  .to-pagetop {
    bottom: inherit;
    top: 25px;
    right: inherit;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .to-pagetop .-circle {
    width: 123px;
    height: 123px;
  }
  .to-pagetop .-arrow {
    position: absolute;
    z-index: 2;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    width: 17px;
    height: 22px;
  }
  .footer-link .col-wrap {
    padding: 0 0;
  }
  .footer-link-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .footer-link-title {
    margin-right: 0;
    margin-top: 0;
  }
  .footer-link-list {
    margin-top: 10px;
  }
  /* ==========================================================================
     parts
  ========================================================================== */
  /*section*/
  .col-wrap {
    max-width: 768px;
    height: 100%;
    margin: 0 auto;
    padding: 0 0;
  }
  .col-inner {
    display: block;
    width: 100%;
    max-width: 768px;
    margin: 0 auto;
    padding: 0 15px;
  }
  .main {
    width: 100%;
  }
  .side {
    display: none;
  }
  /*list*/
  .normal-list li {
    position: relative;
    margin-top: 0;
    margin-bottom: 0;
  }
  /* icon付きボタンスタイル（リスト） ======================== */
  .m-icon-link-list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 15px 0;
    margin: 30px auto 70px;
  }
  .m-icon-link-list.-list3 {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 15px 0;
  }
  .m-icon-link-list.-list3 .m-icon-link {
    width: 310px;
  }
  .m-icon-link-list.-list3 .m-icon-link a {
    padding: 20px 35px;
    font-size: 1.6rem;
  }
  .m-icon-link-list.-list3 .m-icon-link a::before {
    width: 25px;
    height: 26px;
  }
  .m-icon-link a {
    padding: 12px 20px;
  }
  .m-icon-link a::before {
    width: 20px;
    height: 20px;
  }
  .m-icon-link.icon-blank a::before {
    width: 18px;
    height: 18px;
  }
  .m-icon-link.icon-pdf a::before {
    width: 22px;
    height: 23px;
  }
  .m-icon-link.icon-xls a::before {
    width: 22px;
    height: 23px;
  }
  .btn-icon-link {
    width: 126px;
    height: 25px;
  }
  .icon-arrow {
    width: 20px;
    height: 20px;
  }
  .icon-arrow::before {
    width: 20px;
    height: 20px;
  }
  .icon-arrow::after {
    width: 6px;
    height: 5px;
    background: URL("../images/base/ico_arrow_wh.svg");
    background-size: cover;
  }
  .icon-arrow.-y::before {
    background-color: #FFD83D;
  }
  .icon-arrow.-y::after {
    width: 6px;
    height: 5px;
    background: URL("../images/base/ico_arrow_bk.svg");
    background-size: cover;
  }
  /* button ======================== */
  /* btn */
  .btn-more {
    padding: 0 28px;
    z-index: 1;
    background: URL("../images/base/bg_btn.png") 0 0;
    background-size: cover;
  }
  .btn-more span {
    font-size: 1.6rem;
    font-weight: bold;
  }
  /* pagetop */
  /* === page ======================== */
  /*.page-header*/
  .page-header {
    position: relative;
    margin-top: 60px;
    margin-bottom: 25px;
    height: 245px;
    /*&::after{
     bottom: 0;
     padding-top: calc(105 / 375 * 100% );
     background: URL("../images/base/line_page_sp.svg") 0 0;
     background-size: cover;
    }*/
  }
  .page-header .header-line-wrap.a-line-wrap {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100vw;
    height: auto;
    padding-top: 28%;
  }
  /* ページタイトル === */
  .page-header-title {
    top: 20%;
    left: 15px;
  }
  .page-header-title .en {
    font-size: 4.8rem;
  }
  .page-header-title .ja {
    top: 5px;
    left: 0;
    font-size: 2.8rem;
    line-height: 1.6428;
  }
  /* セクションタイトル === */
  .section-title {
    font-size: 2.8rem;
    line-height: 1.28;
    margin-top: -1.28rem;
    text-align: center;
  }
  .section-en {
    position: absolute;
    font-family: "din-2014", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 5.6rem;
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
  }
  .section-en.-cr {
    height: 100%;
    text-align: center;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .section-en.-r {
    right: 15px;
    margin-right: -1rem;
  }
  .section-en.-l {
    left: 15px;
    margin-left: -1rem;
  }
  .section-lead {
    margin: 50px auto 30px;
    text-align: center;
  }
  /* indexタイトル === */
  .m-index-title {
    padding: 10px 0;
    font-size: 2.4rem;
  }
  .m-index-title::before {
    width: 7px;
    height: 7px;
    background-color: #E70012;
  }
  .m-index-title.-sp-center {
    margin-right: auto;
    margin-left: auto;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
  /* m- */
  .m-content {
    margin-top: 65px;
  }
  .m-content-title {
    margin-top: 25px;
  }
  .m-content h3 .-small {
    display: block;
    margin-top: 10px;
  }
  .m-content p {
    line-height: 2.1875;
  }
  /* post-item, card-item? */
  .post-item {
    position: relative;
    width: 100%;
    height: 343px;
    border-bottom: dashed 1px #212121;
  }
  .post-item a::after {
    position: absolute;
    content: "";
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    pointer-events: auto;
    background-color: transparent;
  }
  .post-item-meta {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-top: 10px;
  }
  .post-item-date {
    font-family: "din-2014-narrow", sans-serif;
    font-weight: 700;
    font-style: normal;
    margin-right: 1em;
    font-size: 1.2rem;
  }
  .post-item-cat {
    font-size: 1rem;
  }
  .post-item-title {
    font-size: 1.6rem;
    font-weight: bold;
    margin-top: 15px;
  }
  .post-item-text {
    margin-top: 10px;
    padding-bottom: 15px;
    font-size: 1.2rem;
    line-height: 2.08;
  }
  /* css animation */
  .a-loop {
    width: 100%;
    height: 58px; /* 画像の高さを指定 */
    position: relative;
    background: URL("../images/base/bg_loop_logo_sp.svg") repeat-x 0 0;
    background-size: auto 100%;
    -webkit-animation: bg-loop 15s linear infinite;
            animation: bg-loop 15s linear infinite;
    margin: 10px 0;
    padding: 0;
    z-index: -3;
  }
  /* ==========================================================================
    コンテンツページ共通
  ========================================================================== */
  /* === menu-contents ======================== */
  .contact-menu {
    margin-top: 40px;
    margin-bottom: 0;
  }
  .contact-menu-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin: 0 auto;
  }
  .contact-menu-btn {
    width: 100%;
    max-width: 345px;
    margin: 10px auto;
  }
  .contact-menu-btn a {
    outline: 1px solid #fff;
  }
  .contact-menu-btn a::before {
    content: "";
    padding-top: 46.3768115942%;
  }
  .contact-menu-btn a p {
    margin-top: 60px;
    font-size: min(6.4vw, 2.4rem);
  }
  .contact-menu-btn a .icon {
    top: 20%;
  }
  /* ==========
    1 トップページ
  ========================================================================== */
  /* MainVisual */
  .section-home-mv {
    position: relative;
    width: 100%;
    display: block;
    margin-bottom: 30px;
  }
  .home-mv {
    height: calc(100vh - 50px);
    max-height: 617px;
  }
  .home-mv-line {
    margin-top: 0px;
  }
  .home-mv-content {
    width: 92%;
    max-width: 345px;
  }
  .home-mv-items {
    top: 40px;
    z-index: -1;
  }
  .home-mv-image {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 85%;
    max-width: 326px;
    margin: 40px auto 20px;
    text-align: center;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    z-index: 1;
  }
  .home-mv-text {
    position: absolute;
    top: 80px;
    left: 15px;
    font-family: "Zen Old Mincho", serif;
    line-height: 1;
    -webkit-writing-mode: inherit;
        -ms-writing-mode: inherit;
            writing-mode: inherit;
    width: inherit;
    font-size: clamp(2.2rem, 4.1vh, 2.8rem);
    line-height: 1.428;
    z-index: 1;
  }
  .home-mv-circle {
    display: none;
  }
  /* home-pickup */
  .home-pickup {
    bottom: 0;
    padding: 10px 100px 10px 25px;
    width: 100%;
    max-width: 375px;
    height: 100px;
  }
  .home-pickup::before {
    position: absolute;
    content: "";
    width: 100vw;
    height: 100%;
    right: 15px;
    top: 0;
    background: #fff;
  }
  .home-pickup-title {
    top: -20px;
    left: 25px;
    font-size: 2rem;
  }
  .home-pickup-body {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .home-pickup-body .post-item-meta {
    margin-top: 10px;
    font-size: 1.2rem;
  }
  .home-pickup-body .post-item-text {
    margin-top: 0.5em;
    font-size: 1.2rem;
    line-height: 1.66;
  }
  .home-pickup-nav {
    right: 15px;
    gap: 5px;
  }
  .home-pickup-nav .icon-nav {
    width: 40px;
    height: 40px;
  }
  /* section-home-news */
  .home-news.col-wrap {
    padding: 0 0;
  }
  .home-news-wrap {
    padding: 20px 15px 30px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .home-news-wrap::before {
    width: 100%;
  }
  .home-news-head {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .home-news-title {
    font-size: 2.4rem;
    margin-bottom: 25px;
  }
  .home-news-list {
    margin-top: -10px;
    width: 100%;
  }
  .home-news-list li {
    padding: 12px 0;
    border-bottom: 1px dashed #A1A1A1;
    min-height: 54px;
  }
  .home-news-list li a {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .home-news-list li a::after {
    position: absolute;
    content: "";
    top: 0;
    right: 0;
    bottom: 0;
    width: 7px;
    height: 7px;
    margin: auto 0;
    border-top: 1px solid #212121;
    border-right: 1px solid #212121;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  .home-news-list-date {
    font-size: 1.2rem;
  }
  .home-news-list-text {
    width: calc(100% - 20px);
  }
  /* section-home-features */
  .section-home-features {
    position: relative;
    padding: 100px 0 100px;
  }
  .section-home-features .col-inner {
    position: relative;
  }
  .section-home-features .section-en.-r.-cr {
    top: 80px;
    right: inherit;
    left: 15px;
    margin-left: -1rem;
  }
  .home-features-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .p-card {
    margin: 0 auto;
    max-width: 320px;
  }
  .p-card::after {
    top: 28px;
    left: 22px;
  }
  .p-card-body {
    padding: 134px 20px 30px;
    height: inherit;
  }
  .p-card-title {
    font-size: 1.6rem;
    line-height: 1.5625;
    letter-spacing: 0.1px;
  }
  .p-card-text {
    font-size: 1.4rem;
    line-height: 2;
  }
  .p-card:nth-child(1) {
    margin-top: 20px;
  }
  .p-card:nth-child(1)::after {
    width: 67px;
    height: 52px;
    background-image: url(../images/home/num_01.svg);
    background-size: cover;
  }
  .p-card:nth-child(2) {
    margin-top: 30px;
  }
  .p-card:nth-child(2)::after {
    width: 74px;
    height: 52px;
    background-image: url(../images/home/num_02.svg);
    background-size: cover;
  }
  .p-card:nth-child(3) {
    margin-top: 30px;
  }
  .p-card:nth-child(3)::after {
    width: 74px;
    height: 52px;
    background-image: url(../images/home/num_03.svg);
    background-size: cover;
  }
  /* section-home-department */
  .section-home-department {
    position: relative;
  }
  .section-home-department .col-wrap {
    padding: 55px 0 60px;
  }
  .section-home-department .col-wrap::before {
    right: 10px;
    width: 100%;
  }
  .section-home-department .section-en {
    -webkit-writing-mode: inherit;
        -ms-writing-mode: inherit;
            writing-mode: inherit;
    top: -30px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .section-home-department .btn-more {
    width: 250px;
    height: 55px;
  }
  .home-department-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-column-gap: 47px;
       -moz-column-gap: 47px;
            column-gap: 47px;
    margin-top: 25px;
    width: 100%;
  }
  .home-department-wrap.-r {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-column-gap: 33px;
       -moz-column-gap: 33px;
            column-gap: 33px;
    margin-top: 20px;
  }
  .home-department-wrap.-r .home-department-image {
    margin-right: 30px;
    width: 93%;
    max-width: 375px;
    margin-top: 0;
  }
  .home-department-wrap.-r .home-department-lead {
    position: absolute;
    top: 60px;
    right: -10px;
  }
  .home-department-wrap.-r .home-department-content {
    margin-top: 60px;
  }
  .home-department-wrap.-l {
    margin-left: 0;
    margin-top: 0;
  }
  .home-department-image {
    position: relative;
    margin-left: 15px;
    width: 95%;
    max-width: 375px;
    margin-top: 40px;
  }
  .home-department-image .-student01 {
    left: 10px;
  }
  .home-department-image .-student02 {
    right: 15px;
  }
  .home-department-lead {
    top: 40px;
    left: -15px;
    font-size: clamp(1.3rem, 4.1vw, 1.4rem);
    letter-spacing: 0;
    line-height: 2.5;
  }
  .home-department-lead span {
    padding: 10px 2px;
  }
  .home-department-content {
    margin-top: 0;
    width: 100%;
    min-width: inherit;
    padding-right: 10px;
  }
  .home-department-content-title {
    font-size: 2.4rem;
  }
  .home-department-content-text {
    margin-top: 20px;
    line-height: 2.14;
  }
  .home-department-tag-box {
    margin: 15px 0 30px;
    padding: 15px 10px 12px;
    background-color: #FCF4F2;
  }
  .home-department-tag-title {
    font-weight: bold;
  }
  .home-department-tag-list {
    margin-top: 1em;
    font-size: 1.2rem;
  }
  .home-department-tag-list li {
    display: inline-block;
    margin-right: 0.5em;
  }
  .home-department-tag-list li a {
    position: relative;
    color: #E70012;
  }
  .home-department-tag-list li a::before {
    content: "#";
    color: #212121;
  }
  .home-course {
    margin-top: 70px;
    margin-left: 0;
    width: calc(100% - 10px);
    padding: 15px 15px 35px 15px;
  }
  .home-course .txt-wrap01 {
    top: -18px;
    right: -7px;
    width: 146px;
    height: 36px;
  }
  .home-course-image {
    width: 86px;
    height: 86px;
    margin-right: 15px;
  }
  .home-course-head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .home-course-title {
    margin-top: 0;
    font-size: 2rem;
    line-height: 1.5;
  }
  .home-course-title .lead {
    display: block;
    font-size: 1.4rem;
  }
  .home-course-text {
    line-height: 1.875;
    margin-top: 10px;
    margin-bottom: 20px;
  }
  .home-course .btn-more {
    margin: 0px auto;
  }
  /* section-home-opencampus */
  .section-home-opencampus {
    position: relative;
    padding: 100px 0 0;
  }
  .section-home-opencampus .section-en.-l {
    top: -60px;
  }
  .section-home-opencampus .col-wrap {
    padding: 0;
  }
  .home-opencampus-head {
    padding-left: 15px;
    padding-right: 15px;
  }
  .home-opencampus-head .btn-icon-link {
    margin-top: 10px;
  }
  .home-opencampus-slider {
    position: relative;
    padding-left: 0px;
    margin: 40px 0 35px 15px;
    width: inherit;
  }
  .home-opencampus-slider .swiper-nav01 {
    display: none;
  }
  .home-opencampus-foot {
    display: block;
  }
  .home-opencampus-foot .btn-more {
    margin: 35px auto;
    width: 250px;
    height: 55px;
  }
  /* section-home-events */
  .section-home-events {
    padding: 60px 0 10px;
  }
  .section-home-events .section-en.-l {
    top: -60px;
  }
  .section-home-events .col-wrap {
    padding: 0;
  }
  .home-events-head {
    padding-left: 15px;
    padding-right: 15px;
  }
  .home-events-head .btn-icon-link {
    margin-top: 10px;
  }
  /* swiper設定 */
  .swiper-wrapper {
    z-index: -1;
  }
  .card01 .swiper-button-prev {
    width: 40px;
    height: 40px;
  }
  .card01 .swiper-button-next {
    width: 40px;
    height: 40px;
  }
  .card03-1 .swiper-button-prev, .card03-2 .swiper-button-prev, .opencampus-slider .swiper-button-prev {
    display: none;
  }
  .card03-1 .swiper-button-next, .card03-2 .swiper-button-next, .opencampus-slider .swiper-button-next {
    display: none;
  }
  .card03-1 .swiper-slide, .card03-2 .swiper-slide, .opencampus-slider .swiper-slide {
    width: 100%;
    max-width: 307px;
  }
  .card04 {
    overflow: visible;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .card04 .swiper {
    overflow: hidden;
  }
  .card04 .swiper-slide {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
  }
  /* section-home-campuslife */
  .section-home-campuslife {
    margin-top: 40px;
    position: relative;
  }
  .section-home-campuslife .section-en.-r {
    display: none;
  }
  /* section-home-addmissions */
  .section-home-admissions {
    margin-top: 40px;
  }
  .section-home-admissions .section-en.-l {
    display: none;
  }
  /* home-menu */
  .home-menu-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .home-menu-image {
    margin-left: auto;
    margin-right: auto;
  }
  .home-menu-image .photo {
    width: 345px;
    height: 230px;
  }
  .home-menu-image .wavy-wrap01 {
    position: absolute;
    left: -15px;
    bottom: 10px;
  }
  .home-menu-image .wavy-wrap02 {
    position: absolute;
    right: -30px;
    bottom: -15px;
  }
  .home-menu-content {
    margin: 0 auto;
    padding: 0 0 35px;
    width: 100%;
    max-width: 463px;
    min-height: inherit;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .home-menu-content::before {
    width: 100vw;
    height: 100%;
    left: -15px;
    top: -20px;
  }
  .home-menu-textarea {
    margin: 25px 0 20px;
    position: relative;
  }
  .home-menu-title {
    font-size: 2.8rem;
  }
  .home-menu-wrap.-r {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .home-menu-wrap.-r .home-menu-image {
    margin-left: inherit;
    margin-right: auto;
    margin-left: auto;
  }
  .home-menu-wrap.-r .home-menu-content {
    margin: 0 -15px;
    padding-left: 0;
  }
  .home-menu-wrap.-r .home-menu-content::before {
    top: 0;
    right: -15px;
    left: inherit;
    top: -20px;
  }
  /* home-nav-list */
  .home-nav-list {
    margin-top: 20px;
    width: 100%;
    font-size: 1.6rem;
  }
  .home-nav-list li a {
    padding: 0.8em 0 0.8em 0;
    border-bottom: 1px solid #212121;
  }
  .home-nav-list li a:hover {
    opacity: 0.7;
  }
  /*section-home-ogob */
  .section-home-ogob .section-en.-cr {
    top: 0;
    -webkit-transform: translateY(-30%);
            transform: translateY(-30%);
  }
  .home-ogob {
    padding-top: 30px;
    padding-bottom: 40px;
    /* swiper */
  }
  .home-ogob-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-column-gap: 50px;
       -moz-column-gap: 50px;
            column-gap: 50px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .home-ogob-wrap .btn-more {
    margin: 35px auto;
    width: 250px;
    height: 55px;
  }
  .home-ogob-content {
    width: 100%;
    max-width: inherit;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .home-ogob-content-text {
    margin: 20px 0 30px;
    line-height: 2.1875;
  }
  .home-ogob-slider {
    padding-left: 63px;
  }
  .home-ogob .card04_sub {
    margin-top: -80px;
    margin-left: -63px;
    width: 290px;
    height: 204px;
  }
  .home-ogob .swiper-wrapper {
    width: 100%;
    height: 240px;
    /*display: flex;
    column-gap: 63px;*/
  }
  .home-ogob-item {
    position: relative;
    width: 240px;
    height: auto;
  }
  .home-ogob-item-thumb {
    width: 240px;
    height: 240px;
  }
  .home-ogob-item-content__title {
    font-size: 1.4rem;
    line-height: 1.4;
  }
  .home-ogob-item-content__title .-txt02 {
    font-size: 2rem;
  }
  .home-ogob-item-content__title .-txt03 {
    font-size: 1.2rem;
  }
  .home-ogob-item-content__text {
    line-height: 1.785;
  }
  /*section-home-instagram */
  .section-home-instagram {
    padding: 80px 0 0;
  }
  .section-home-instagram .section-en.-r.-cr {
    right: inherit;
    left: 15px;
    top: 0;
    -webkit-transform: translateY(-20%);
            transform: translateY(-20%);
  }
  .home-instagram-head .btn-icon-link {
    margin-top: 10px;
  }
  .home-instagram-body {
    margin: 40px -10px 0px;
    text-align: center;
  }
  /* instagram プラグイン用 */
  #sbi_images {
    padding: 5px !important;
  }
  /* section-home-contact */
  .section-home-contact {
    padding-bottom: 0;
  }
  /* svg animation */
  .a-line-wrap {
    /*position:absolute;
    content:"";
    width: 100%;
    height: 100%;
    z-index: -1;
    display: flex;
    justify-content: center;*/
  }
  .line01-wrap {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .line02-wrap {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-top: -5px;
  }
  .line03-wrap {
    margin-top: 95px;
  }
  .line04-wrap {
    margin-top: -9%;
  }
  .line05-wrap {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-top: -35%;
  }
  .line06-wrap {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-top: 55px;
  }
  .line07-wrap {
    margin-top: 56%;
  }
  #line-header_sp {
    -webkit-animation: line_move_l 2s ease-in-out;
            animation: line_move_l 2s ease-in-out;
  }
  #line01_sp {
    -webkit-animation: line_move_r 5s;
            animation: line_move_r 5s;
  }
  #line02_sp {
    -webkit-animation: line_move_l 5s ease-in-out;
            animation: line_move_l 5s ease-in-out;
  }
  #line03_sp {
    -webkit-animation: line_move_r 2s ease-in-out;
            animation: line_move_r 2s ease-in-out;
  }
  #line04_sp {
    -webkit-animation: line_move_l 3s ease-in-out;
            animation: line_move_l 3s ease-in-out;
  }
  #line05_sp {
    -webkit-animation: line_move_r 3s ease-in-out;
            animation: line_move_r 3s ease-in-out;
  }
  #line06_sp {
    -webkit-animation: line_move_r 5s ease-in-out;
            animation: line_move_r 5s ease-in-out;
  }
  #line06_sp.a-svg-line {
    stroke-dasharray: 0;
  }
  #line07_sp {
    -webkit-animation: line_move_r 14s ease-in-out;
            animation: line_move_r 14s ease-in-out;
  }
  #line07_sp.a-svg-line {
    stroke-dasharray: 0;
    stroke-width: 0;
  }
  .a-svg-line {
    /* &#line02-b {//course-menu
     animation:line_move_l 4s ease-in-out;
    } */
  }
  .a-svg-line#line01-b {
    -webkit-animation: line_move_r 1.5s ease-in-out;
            animation: line_move_r 1.5s ease-in-out;
  }
  .a-svg-line#line01-about {
    -webkit-animation: line_move_r 1.5s ease-in-out;
            animation: line_move_r 1.5s ease-in-out;
  }
  .a-svg-line#line02-about {
    -webkit-animation: line_move_l 1.5s ease-in-out;
            animation: line_move_l 1.5s ease-in-out;
  }
  .a-svg-line#line03-about {
    -webkit-animation: line_move_r 2.5s ease-in-out;
            animation: line_move_r 2.5s ease-in-out;
  }
  .a-svg-line#line01-ocguide {
    -webkit-animation: line_move_r 2s ease-in-out;
            animation: line_move_r 2s ease-in-out;
  }
  .a-svg-line#line02-ocguide {
    -webkit-animation: line_move_l 2s ease-in-out;
            animation: line_move_l 2s ease-in-out;
  }
  .a-svg-line#line01-campuslife {
    -webkit-animation: line_move_r 2s ease-in-out;
            animation: line_move_r 2s ease-in-out;
  }
  .a-article.item-01 {
    left: -15px;
    top: -60px;
    width: 100%;
  }
  .a-article.item-02 {
    right: 5%;
    top: 5px;
    width: 45px;
  }
  .a-article.item-03 {
    left: inherit;
    right: 7%;
    bottom: -70px;
    width: 36px;
  }
  .a-article.item-04 {
    right: 4%;
    top: -21%;
    width: 45px;
  }
  .a-article.item-05 {
    left: 4%;
    top: -14%;
    width: 70px;
  }
  .a-article.item-06 {
    left: 5%;
    top: -11%;
    width: 45px;
  }
  .a-article.item-07 {
    bottom: -6%;
    left: 8%;
    width: 38px;
  }
  .a-article.item-08 {
    left: 48%;
    top: inherit;
    bottom: -24%;
    width: 65px;
  }
  .a-article.item-09 {
    bottom: -68%;
    right: 73%;
    width: 58px;
  }
  /* ==========
    02 about //
  ========================================================================== */
  .about-lead {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: inherit;
  }
  .about-lead-image {
    max-width: 282px;
    max-height: 241px;
    margin: 0 auto;
  }
  .about-lead-content {
    margin-top: 50px;
  }
  .about-lead-text {
    margin-top: 25px;
    line-height: 2.14285;
  }
  .about-style {
    margin-top: 150px;
  }
  .about-style .col-wrap::before {
    top: 20px;
    height: calc(100% - 185px);
  }
  .about-style .col-wrap.-r::before {
    right: min(4vw, 15px);
  }
  .about-style .col-wrap.-l::before {
    left: inherit;
    right: min(4vw, 15px);
  }
  .about-style-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-column-gap: inherit;
       -moz-column-gap: inherit;
            column-gap: inherit;
    margin-top: 75px;
  }
  .about-style-wrap.-r {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .about-style-wrap.-r .about-style-image {
    margin-right: -15px;
    margin-left: auto;
  }
  .about-style-wrap.-l {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 60px;
  }
  .about-style-wrap.-l .about-style-image {
    margin-left: inherit;
    margin-right: -15px;
  }
  .about-style-content {
    margin-top: -35px;
    margin-bottom: 10px;
  }
  .about-style-num {
    font-size: 6.4rem;
    color: transparent;
    -webkit-text-stroke: 1px #BC0312;
    line-height: 1.6;
  }
  .about-style-title {
    font-size: 2.4rem;
    line-height: 2;
  }
  .about-style-text {
    margin-top: 15px;
    margin-right: 15px;
  }
  .about-style-image {
    margin-top: 20px;
    max-width: 360px;
    max-height: 262px;
    overflow: hidden;
  }
  .about-greeting {
    margin-top: 0;
  }
  .about-greeting .col-inner {
    position: relative;
    padding-top: 130px;
  }
  .about-greeting-wrap {
    position: relative;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-column-gap: 70px;
       -moz-column-gap: 70px;
            column-gap: 70px;
    margin-top: 25px;
  }
  .about-greeting-image {
    max-width: 156px;
    max-height: 162px;
    overflow: hidden;
  }
  .about-greeting-image img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .about-greeting-head {
    position: absolute;
    top: 0;
    left: 173px;
  }
  .about-greeting-name {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .about-greeting-name .-en {
    font-family: "din-2014-narrow", sans-serif;
    font-weight: 700;
    font-style: normal;
    font-size: min(10vw, 3.8rem);
    line-height: 0.89;
  }
  .about-greeting-name .-ja {
    position: absolute;
    font-size: 2.4rem;
  }
  .about-greeting-name .-ja .-txt01 {
    margin-right: 10px;
    font-size: 1.6rem;
  }
  .about-greeting-title {
    margin-top: 20px;
    font-size: 1.6rem;
    line-height: 1.5;
  }
  .about-greeting-text {
    margin-top: 30px;
    line-height: 2.14285;
  }
  .about-rinen-section {
    position: relative;
  }
  .about-rinen {
    position: relative;
    margin-top: 45px;
    padding: 20px 20px 40px 20px;
    background-color: #fff;
  }
  .about-rinen .m-index-title {
    margin-top: 30px;
    font-size: 2.4rem;
  }
  .about-rinen-lead {
    margin-top: 20px;
    padding-bottom: 20px;
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .about-rinen-list {
    margin-top: 20px;
    font-size: 1.6rem;
    counter-reset: list-count;
    list-style: none;
  }
  .about-rinen-list li {
    margin-left: 2em;
    margin-bottom: 6px;
    text-indent: -2em;
    line-height: 1.875;
    /* &::marker{
     color:$color-r1;
     }*/
  }
  .about-rinen-list li::before {
    content: counter(list-count) ".";
    counter-increment: list-count;
    margin-right: 1em;
    color: #E70012;
  }
  .line01-about-wrap {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    top: -120px;
    z-index: 0;
  }
  .line02-about-wrap {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    top: -5%;
    z-index: 0;
  }
  .line03-about-wrap {
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    bottom: -70px;
    z-index: 10;
  }
  .a-article.item-about-01 {
    display: none;
    bottom: -90px;
    left: 80px;
    width: 40px;
  }
  .a-article.item-about-02 {
    top: 15px;
    right: 20px;
    width: 38px;
  }
  /* ==========
    18 guide //
  ========================================================================== */
  .section-guide-tab {
    margin-top: 70px;
    margin-bottom: 50px;
    padding: 0 0 30px;
  }
  .section-guide-tab::before {
    top: 50px;
    left: 0;
  }
  /* guide */
  .guide-menu-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    height: 70px;
  }
  .guide-menu-wrap::before {
    position: absolute;
    left: 15px;
    content: "入学方法別";
    font-size: min(3.73vw, 1.4rem);
    font-weight: bold;
  }
  .guide-menu-list {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 0;
    position: absolute;
    top: 15px;
    right: 15px;
  }
  .guide-menu-list li {
    padding: 0 15px;
    width: min(60vw, 230px);
    background-color: #E70012;
  }
  .guide-menu-list li.li-parent {
    position: relative;
  }
  .guide-menu-list li.li-parent::after {
    position: absolute;
    content: "";
    top: 50%;
    right: 10px;
    width: 8px;
    height: 8px;
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
    -webkit-transform: translateY(-50%) rotate(45deg);
            transform: translateY(-50%) rotate(45deg);
  }
  .guide-menu-list li.li-parent.is-active::after {
    position: absolute;
    content: "";
    top: 50%;
    right: 10px;
    width: 8px;
    height: 8px;
    border-right: none;
    border-bottom: none;
    border-left: 1px solid #fff;
    border-top: 1px solid #fff;
    -webkit-transform: translateY(-50%) rotate(45deg);
            transform: translateY(-50%) rotate(45deg);
  }
  .guide-menu-list li.li-child {
    display: none;
  }
  .tab_list {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    height: auto;
    line-height: 1.3em;
    font-size: 1.4rem;
    background-color: #E70012;
    border-top: dotted 1px #fff;
    padding: 0.5em 10px;
    z-index: 1;
	min-height:40px;
	max-height: 70px;
    display: flex;
    justify-content: center;
  }
  .tab_list.-first {
    border-top: none;
  }
  .guide-flow {
    position: relative;
    margin-top: 70px;
    margin-bottom: 0;
    padding: 50px 0 0;
  }
  .guide-flow::before {
    left: 0;
    height: calc(100% - 50px);
  }
  .guide-flow-items {
    margin-top: 25px;
  }
  .guide-flow-item {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-bottom: 65px;
  }
  .guide-flow-item::before {
    bottom: -40px;
    width: 40px;
    height: 40px;
    border-bottom: 5px solid #BC0312;
    border-right: 5px solid #BC0312;
  }
  .guide-flow-item.-last {
    margin-bottom: 0;
  }
  .guide-flow-item.-last::before {
    display: none;
  }
  .guide-flow-head {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    padding: 10px 0;
    width: 100%;
    -webkit-writing-mode: inherit;
        -ms-writing-mode: inherit;
            writing-mode: inherit;
    text-orientation: inherit;
  }
  .guide-flow-body {
    padding: 5px 22px 15px;
    width: 100%;
    background-color: #fff;
  }
  .guide-flow-title {
    margin-top: 10px;
    font-size: clamp(1.6rem, 2.4vw, 2.8rem);
    font-weight: bold;
    line-height: 1.875;
    color: #E70012;
  }
  .guide-flow-text {
    margin-top: 10px;
    line-height: 2.1428;
  }
  /* ==========
    19 guidelines //
  ========================================================================== */
  .guidelines-lead {
    margin-bottom: 70px;
  }
  .guidelines-content {
    margin-top: 65px;
  }
  .guidelines-content h3 .-small {
    display: block;
    margin-top: 10px;
  }
  .guidelines-content-info h4 {
    font-size: 1.4rem;
  }
  .guidelines-table-title {
    margin-top: 30px;
    font-size: clamp(2rem, 2vw, 2.4rem);
    font-weight: bold;
  }
  .guidelines-table {
    margin-top: 20px;
  }
  .guidelines-table.-table01 th {
    min-width: 107px;
  }
  .guidelines-table.-table02 th {
    min-width: 120px;
  }
  .guidelines-table.-table02 .note {
    bottom: 20px;
  }
  .guidelines-table.-table03 {
    margin-top: 30px;
  }
  .guidelines-table.-table03 th {
    width: 20%;
    min-width: 125px;
    font-size: 2rem;
  }
  .guidelines-table.-table03 th.cell-1 {
    min-width: 130px;
  }
  .guidelines-table th {
    font-size: 1.6rem;
  }
  .guidelines-table td {
    font-size: 1.6rem;
  }
  .scroll-wrap {
    margin-inline: auto;
    width: calc(100% + 15px);
    padding-bottom: 30px;
    margin-bottom: 60px;
    /*
     // スクロールバー（幅・高さ）
     &::-webkit-scrollbar {
      width: calc(100% - 30px);
      height: 6px; // 横スクロールバーの幅
      background-color: #A8A8A8;
     }
    // スクロールバーのつまみ
     &::-webkit-scrollbar-thumb {
       background-color: $color-r3;
       width: 140px;
     }
    */
  }
  /* ==========
   21 qualification_contest-results
  ========================================================================== */
  .contest-results {
    margin-top: 60px;
    padding-bottom: 10px;
  }
  .contest-results-wrap {
    margin-top: 20px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .contest-results-wrap-2 {
    -ms-grid-columns: 1fr 10px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px 10px;
    margin-top: 10px;
  }
  .contest-results-data {
    margin-top: 0;
  }
  .contest-results-data-text {
    margin-top: 10px;
    line-height: 2.1875;
  }
  .contest-results-data-text strong {
    color: #BC0312;
    font-weight: normal;
  }
  .contest-results-data-content {
    padding: 35px 20px 25px;
  }
  .contest-results-data-tag {
    padding: 15px 20px;
    min-height: 60px;
  }
  .contest-results-data-tag-content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .contest-results-data-tag-content + .contest-results-data-tag-content {
    padding-top: 5px;
    border-top: solid 1px #fff;
  }
  .contest-results-data-tag-title {
    padding: 2px 0px 0px 10px;
  }
  .contest-results-data-tag-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 10px 5px;
    padding: 5px 0 8px 10px;
  }
  .contest-results-data-tag-list li {
    padding: 2px 10px;
    font-size: 1.2rem;
    line-height: 1.2;
  }
  .contest-results-image img {
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .contest-results-image.item-01 {
    margin-top: 10px;
    width: 100%;
    height: 100%;
    max-height: inherit;
  }
  .contest-results-image.item-01 .contest-results-image-title {
    top: 30px;
    font-size: 2.2rem;
    color: #fff;
  }
  .contest-results-image.item-01 .contest-results-image-title .-txt01 {
    padding-top: 5px;
  }
  .contest-results-image.item-01 .contest-results-image-name {
    position: absolute;
    bottom: 40px;
    right: 25px;
    color: #fff;
  }
  .contest-results-image.item-02 {
    max-width: inherit;
  }
  .contest-results-image.item-02 img {
    aspect-ratio: 167/135;
    height: auto;
  }
  .contest-results-image-icon {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    text-align: center;
    position: absolute;
    content: "";
    width: 54px;
    height: 54px;
    font-family: "Zen Old Mincho", serif;
    line-height: 1;
    color: #fff;
  }
  .contest-results-image-icon .icon-text-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
  .contest-results-image-icon.-icon01 {
    bottom: 20px;
    left: 15px;
    width: 140px;
    height: 112px;
  }
  .contest-results-image-icon.-icon01 .-txt01 {
    font-size: 1.4rem;
  }
  .contest-results-image-icon.-icon01 .-txt02 {
    font-size: 4rem;
    line-height: 1;
  }
  .contest-results-image-icon.-icon01 .-txt03 {
    font-size: 2.2rem;
    line-height: 1.2;
  }
  .contest-results-image-icon.-icon02 {
    top: 10px;
    left: 10px;
    width: 54px;
    height: 54px;
    background: URL("../images/contest-results/ico_02.png") no-repeat;
    background-size: cover;
  }
  .contest-results-image-icon.-icon02 .-txt01 {
    font-size: 1rem;
  }
  .contest-results-image-title {
    position: absolute;
    top: 10px;
    right: 10px;
    font-size: 1.4rem;
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
  }
  .contest-results-image-title .-txt01 {
    font-size: 1.2rem;
  }
  .contest-results-image-name {
    margin-top: 10px;
  }
  .contest-results-image-name .-txt01 {
    padding-bottom: 7px;
    font-size: 1.2rem;
  }
  .contest-results-image-name .-txt02 {
    font-size: 1.4rem;
  }
  .contest-results-image-name .-txt03 {
    font-size: 1.2rem;
  }
  /* ==========
   20 qualification_exam
  ========================================================================== */
  .exam-lead-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    gap: 0;
  }
  .exam-lead-content {
    width: 100%;
  }
  .exam-lead-title {
    margin-top: 35px;
    font-size: 1.6rem;
  }
  .exam-lead-text {
    margin-top: 35px;
    line-height: 2.1428;
  }
  .exam-card-item {
    margin-top: 20px;
    width: 100%;
    max-width: 420px;
    height: 100%;
    max-height: 329px;
    padding: 15px 15px;
    border-top: solid 7px #E70012;
  }
  .exam-card-title {
    margin: 5px auto;
  }
  .exam-card-icon {
    margin-top: 5px;
    font-size: min(5.33vw, 2rem);
    width: min(24.53vw, 92px);
    height: min(24.53vw, 92px);
  }
  .exam-card-num {
    margin-top: 20px;
    margin-right: 10px;
    font-size: min(24.8vw, 9.3rem);
  }
  .exam-card-lead {
    margin-top: 5px;
    font-size: 1.1rem;
  }
  .exam-card-lead .-txt01 {
    font-size: 1.3rem;
  }
  .exam-greeting {
    margin-top: 65px;
  }
  .exam-greeting .col-wrap {
    padding-top: 70px;
    padding-bottom: 130px;
  }
  .exam-greeting .col-wrap::before {
    right: 0;
  }
  .exam-greeting-wrap {
    margin-top: 20px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-column-gap: 0;
       -moz-column-gap: 0;
            column-gap: 0;
  }
  .exam-greeting-content {
    width: 100%;
  }
  .exam-greeting-text {
    line-height: 2.1875;
    padding-bottom: 75px;
  }
  .exam-greeting-image {
    position: absolute;
    right: 15px;
    bottom: 0px;
    margin-bottom: 70px;
    width: 100%;
    height: auto;
    max-width: 173px;
    max-height: 177px;
    aspect-ratio: 173/177;
  }
  .exam-greeting-name {
    position: relative;
    margin-left: 10px;
  }
  .exam-greeting-name .-txt02 {
    font-size: 2rem;
  }
  .exam-data {
    margin-top: 70px;
  }
  .exam-data-index {
    margin-top: 25px;
    font-size: 1.6rem;
  }
  .exam-data-items {
    margin-top: 15px;
    padding-bottom: 25px;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 20px 0;
  }
  .exam-data-head {
    padding: 5px;
    font-size: 1.6rem;
    font-weight: bold;
    text-align: center;
    color: #fff;
  }
  .exam-data-head.-item01 {
    background-color: #E83928;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .exam-data-head.-item02 {
    -ms-grid-column: 1;
    grid-column: 1;
    background-color: #BC0312;
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
  .exam-data-item {
    margin: 0 auto;
    width: 89.85%;
  }
  .exam-data-item.-item03 {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .exam-data-item.-item04 {
    -webkit-box-ordinal-group: 5;
        -ms-flex-order: 4;
            order: 4;
  }
  .exam-data-item.-item05 {
    -webkit-box-ordinal-group: 6;
        -ms-flex-order: 5;
            order: 5;
  }
  .exam-data-title {
    margin-top: 25px;
    font-size: 1.6rem;
  }
  .exam-data-text {
    margin-top: 10px;
  }
  .exam-data2 {
    margin-top: 45px;
  }
  .exam-data2 dl {
    position: relative;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 30px;
    min-height: 55px;
  }
  .exam-data2 dt {
    position: absolute;
    top: -15px;
    left: 15px;
    width: 137px;
    padding: 3px 10px;
    text-align: center;
  }
  .exam-data2 dd {
    padding: 30px 20px 20px;
    font-size: clamp(1.4rem, 1.4vw, 1.6rem);
  }
  .exam-flow {
    position: relative;
    margin-top: 70px;
    margin-bottom: 0;
    padding: 70px 0 0;
  }
  .exam-flow::before {
    left: 0;
    height: calc(100% - 50px);
  }
  .exam-flow-items {
    margin-top: 25px;
  }
  .exam-flow-item {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 65px;
  }
  .exam-flow-item::before {
    bottom: -40px;
    width: 40px;
    height: 40px;
    border-bottom: 5px solid #BC0312;
    border-right: 5px solid #BC0312;
  }
  .exam-flow-item.-last {
    margin-bottom: 0;
  }
  .exam-flow-item.-last::before {
    display: none;
  }
  .exam-flow-head {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    padding: 25px 0;
    line-height: 1.375;
  }
  .exam-flow-body {
    padding: 5px 22px 15px;
    width: 100%;
    background-color: #fff;
  }
  .exam-flow-title {
    margin-top: 10px;
    font-size: clamp(1.6rem, 2.4vw, 2.8rem);
    font-weight: bold;
    line-height: 1.875;
    color: #E70012;
  }
  .exam-flow-text {
    margin-top: 10px;
    line-height: 2.1428;
  }
  /* ==========
    22 qualification_data 
  ========================================================================== */
  .data-card-items {
    margin-top: 25px;
    gap: 25px;
  }
  .data-card-items.hair-items-01 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-column-gap: 0;
       -moz-column-gap: 0;
            column-gap: 0;
  }
  .data-card-items.hair-items-02 {
    margin-top: 25px;
    -ms-grid-columns: 1fr min(4vw, 15px) 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px min(4vw, 15px);
  }
  .data-card-items.total-items-01 {
    margin-top: 25px;
    -ms-grid-columns: 1fr min(4vw, 15px) 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px min(4vw, 15px);
  }
  .data-card-items.total-items-02 {
    margin-top: 25px;
    -ms-grid-columns: 1fr min(4vw, 15px) 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px min(4vw, 15px);
  }
  .data-card-item {
    padding: 10px 10px 10px;
    border-top: solid 3px #008EAA;
  }
  .data-card-item.item-hair-01 {
    max-width: 100%;
    min-height: inherit;
    padding: 10px 15px 5px;
  }
  .data-card-item.item-hair-01 .data-card-body {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-column-gap: 15px;
       -moz-column-gap: 15px;
            column-gap: 15px;
    margin-top: 5px;
  }
  .data-card-item.item-hair-01 .data-card-en {
    top: 15px;
    font-size: 2rem;
  }
  .data-card-item.item-hair-01 .data-card-title {
    text-align: center;
    font-size: clamp(2.4rem, 2.99vw, 4rem);
  }
  .data-card-item.item-hair-01 .data-card-wrap {
    margin-top: 5px;
    -webkit-column-gap: 15px;
       -moz-column-gap: 15px;
            column-gap: 15px;
  }
  .data-card-item.item-hair-01 .data-card-num-title {
    margin-top: 5px;
    padding-bottom: 0;
    font-size: 1.6rem;
  }
  .data-card-item.item-hair-01 .data-card-num .-txt01 {
    font-size: clamp(5.6rem, 7.11vw, 9.5rem);
  }
  .data-card-item.item-hair-01 .data-card-num .-txt02 {
    font-size: clamp(4.4rem, 5.16vw, 6.9rem);
  }
  .data-card-item.item-hair-01 .data-card-num .-txt03 {
    font-size: clamp(2.8rem, 3.82vw, 5.1rem);
  }
  .data-card-item.item-hair-01 .data-card-num.-sub .data-card-num-title {
    font-size: 1.2rem;
  }
  .data-card-item.item-hair-01 .data-card-num.-sub .-txt01 {
    font-size: clamp(2.8rem, 5.1vw, 5.1rem);
  }
  .data-card-item.item-hair-01 .data-card-num.-sub .-txt02 {
    font-size: clamp(2rem, 3.8vw, 3.8rem);
  }
  .data-card-item.item-hair-01 .data-card-num.-sub .-txt03 {
    font-size: clamp(1.6rem, 3vw, 3rem);
  }
  .data-card-item.item-hair-02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-column-gap: 15px;
       -moz-column-gap: 15px;
            column-gap: 15px;
    max-width: 100%;
    min-height: inherit;
    padding: 30px 15px 15px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
  .data-card-item.item-hair-02 .data-card-en {
    top: 15px;
    font-size: 2rem;
  }
  .data-card-item.item-hair-02 .data-card-title {
    font-size: 1.6rem;
    line-height: 1.5625;
    text-align: left;
  }
  .data-card-item.item-hair-02 .data-card-body {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 0;
  }
  .data-card-item.item-hair-02 .data-card-icon {
    width: 55px;
    height: 55px;
    font-size: 1.2rem;
  }
  .data-card-item.item-hair-02 .data-card-icon .data-card-num-title {
    font-size: 2rem;
  }
  .data-card-item.item-hair-02 .data-card-num-title {
    font-size: 1.4rem;
  }
  .data-card-item.item-hair-02 .data-card-num .-txt01 {
    font-size: clamp(4.8rem, 7.2vw, 7.2rem);
  }
  .data-card-item.item-hair-02 .data-card-num .-txt02 {
    font-size: clamp(3.4rem, 6vw, 6rem);
  }
  .data-card-item.item-hair-02 .data-card-num .-txt03 {
    font-size: clamp(2.8rem, 4.2vw, 4.2rem);
  }
  .data-card-item.item-hair-02 .data-card-text {
    font-size: min(3.2vw, 1.2rem);
    text-align: center;
  }
  .data-card-item.item-hair-03 {
    max-width: 100%;
    min-height: inherit;
  }
  .data-card-item.item-total-01 {
    padding: 20px 15px 15px;
    max-width: 100%;
    min-height: inherit;
    -ms-grid-row: 1;
    grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
    grid-column: 1/span 2;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-column-gap: 30px;
       -moz-column-gap: 30px;
            column-gap: 30px;
  }
  .data-card-item.item-total-01 .data-card-en {
    top: 2px;
    font-size: 2rem;
  }
  .data-card-item.item-total-01 .data-card-body {
    margin-top: 0;
  }
  .data-card-item.item-total-02 {
    padding: 10px 10px 5px;
    max-width: 100%;
    min-height: inherit;
  }
  .data-card-item.item-total-02 .data-card-en {
    -webkit-text-stroke: 1px #A51890;
  }
  .data-card-item.item-total-02 .data-card-title {
    margin-top: 0;
  }
  .data-card-item.item-total-02 .data-card-title .-txt01 {
    font-size: 1.2rem;
  }
  .data-card-item.item-total-02 .data-card-title .-txt01.-small {
    font-size: 1rem;
  }
  .data-card-item.item-total-02 .data-card-icon {
    width: min(15.2vw, 57px);
    height: min(15.2vw, 57px);
    font-size: min(2.4vw, 0.9rem);
    background-color: #A51890;
  }
  .data-card-item.item-total-02 .data-card-num-title {
    font-size: min(3.2vw, 1.2rem);
  }
  .data-card-item.item-total-02 .data-card-num .-txt01 {
    font-size: min(9.6vw, 3.6rem);
  }
  .data-card-item.item-total-02 .data-card-num .-txt03 {
    font-size: min(5.33vw, 2rem);
  }
  .data-card-item.item-total-02 .data-card-body {
    margin-top: 15px;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .data-card-item.item-total-02-text {
    font-size: min(3.2vw, 1.2rem);
  }
  .data-card-item.item-total-03 {
    max-width: 100%;
    min-height: inherit;
  }
  .data-card-item.item-total-03 .data-card-icon {
    width: min(15.2vw, 57px);
    height: min(15.2vw, 57px);
    font-size: min(2.4vw, 0.9rem);
  }
  .data-card-en {
    top: 10px;
    font-size: 2rem;
  }
  .data-card-title .-txt01.-small {
    font-size: min(2.67vw, 1rem);
  }
  .data-card-title .-txt01.-small-sp {
    font-size: min(2.4vw, 0.9rem);
  }
  .data-card-body {
    margin-top: 15px;
  }
  .data-card-icon {
    font-size: min(3.2vw, 1.2rem);
    width: min(13.3vw, 50px);
    height: min(13.3vw, 50px);
  }
  .data-card-num-title {
    margin-top: 0;
    padding-bottom: 5px;
    font-size: 1.2rem;
  }
  .data-card-num .-txt01 {
    font-size: min(9.6vw, 3.6rem);
  }
  .data-card-lead {
    padding: 2px 5px;
  }
  .data-card-text {
    font-size: min(3.2vw, 1.2rem);
  }
  .data-total-content {
    margin-top: 70px;
    padding-bottom: 0;
  }
  /* ==========
    15 campus-life 
  ========================================================================== */
  .section-campuslife-item {
    margin-bottom: 200px;
  }
  .campuslife-items {
    margin-top: -140px;
  }
  .campuslife-items .col-wrap::before {
    top: 8px;
    width: 100vw;
    height: calc(100% - 50px);
  }
  .campuslife-items .col-wrap.-r::before {
    right: min(4vw, 15px);
  }
  .campuslife-items .col-wrap.-l::before {
    left: min(4vw, 15px);
  }
  .campuslife-item-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-top: 180px;
    -webkit-column-gap: inherit;
       -moz-column-gap: inherit;
            column-gap: inherit;
  }
  .campuslife-item-wrap.item01 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-right: 15px;
  }
  .campuslife-item-wrap.item01 .campuslife-item-image {
    margin-right: 0;
  }
  .campuslife-item-wrap.item01 .campuslife-item-image .img01 {
    top: 0;
    right: 0;
  }
  .campuslife-item-wrap.item01 .campuslife-item-image .img02 {
    top: min(32vw, 120px);
    left: 0;
  }
  .campuslife-item-wrap.item01 .campuslife-item-image .img03 {
    position: absolute;
    top: min(3vw, -10px);
    right: min(53vw, 200px);
  }
  .campuslife-item-wrap.item01 .campuslife-item-text {
    max-width: inherit;
  }
  .campuslife-item-wrap.item02 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-left: 15px;
  }
  .campuslife-item-wrap.item02 .campuslife-item-image {
    margin-left: -63px;
  }
  .campuslife-item-wrap.item02 .campuslife-item-image .img01 {
    position: absolute;
    top: 50px;
    left: 30px;
  }
  .campuslife-item-wrap.item02 .campuslife-item-image .img02 {
    position: absolute;
    top: 0px;
    right: -35px;
  }
  .campuslife-item-wrap.item02 .campuslife-item-image .img03 {
    position: absolute;
    top: 105px;
    right: -10px;
  }
  .campuslife-item-wrap.item02 .campuslife-item-title::before {
    right: 0;
    left: inherit;
  }
  .campuslife-item-wrap.item03 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-right: 15px;
  }
  .campuslife-item-wrap.item03 .campuslife-item-image {
    margin-right: -63px;
  }
  .campuslife-item-wrap.item03 .campuslife-item-image .img01 {
    position: absolute;
    top: 0px;
    left: -30px;
  }
  .campuslife-item-wrap.item03 .campuslife-item-image .img02 {
    position: absolute;
    top: 120px;
    right: 30px;
  }
  .campuslife-item-wrap.item03 .campuslife-item-image .img03 {
    position: absolute;
    top: 100px;
    left: 0px;
  }
  .campuslife-item-wrap.item03 .campuslife-item-text {
    max-width: 400px;
  }
  .campuslife-item-content {
    margin-top: -35px;
    margin-bottom: 10px;
    max-width: inherit;
  }
  .campuslife-item-num {
    font-size: 5.6rem;
    color: transparent;
    -webkit-text-stroke: 1px #BC0312;
  }
  .campuslife-item-title {
    font-size: min(6vw, 2rem);
    line-height: 1.5625;
    margin-top: 0;
    padding-bottom: 10px;
  }
  .campuslife-item-title::before {
    width: min(100vw, 100%);
    height: 1px;
    background-color: #212121;
  }
  .campuslife-item-text {
    max-width: inherit;
    margin-top: 20px;
    margin-bottom: 20px;
    line-height: 2.1875;
  }
  .campuslife-item-image {
    position: relative;
    max-height: inherit;
    width: 100%;
    max-width: 345px;
    min-height: 120px;
  }
  .campuslife-item-image img {
    width: 100%;
    height: auto;
  }
  .campuslife-gallery {
    margin-top: 40px;
  }
  .campuslife-gallery-images {
    margin-top: 20px;
  }
  .campuslife-gallery-wrap-sp {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100vw;
    overflow: hidden;
  }
  .campuslife-cta {
    margin-top: 50px;
    margin-bottom: 70px;
    padding: 45px 35px 45px;
    background-size: 150% auto;
  }
  .campuslife-cta .btn-wh {
    margin: 25px auto 0;
    padding: 0 40px 0 15px;
  }
  .campuslife-cta .btn-wh::after {
    right: 12px;
  }
  .section-campuslife-menu .col-wrap {
    padding: 50px 0 50px;
  }
  .section-campuslife-menu .col-wrap::before {
    right: 0;
    z-index: -3;
  }
  .campuslife-menu {
    position: relative;
    width: 100%;
    max-width: 475px;
  }
  .campuslife-menu-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-column-gap: 15px;
       -moz-column-gap: 15px;
            column-gap: 15px;
  }
  .campuslife-menu-image {
    aspect-ratio: 164/125;
  }
  .campuslife-menu-image img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .campuslife-menu .btn-icon-link {
    position: relative;
    padding-top: 15px;
    padding-bottom: 10px;
    width: 100%;
    height: inherit;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 1.6rem;
  }
  .line01-campuslife-wrap {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    top: -60px;
    z-index: 0;
  }
  .a-article.item-c-01 {
    bottom: inherit;
    top: -15px;
    left: inherit;
    right: 25px;
    width: 58px;
  }
  .a-article.item-c-02 {
    top: -20px;
    bottom: inherit;
    right: 60px;
    width: 68px;
  }
  .a-article.item-c-03 {
    top: -20px;
    bottom: inherit;
    left: 110px;
    width: 74px;
  }
  .a-article.item-c-04 {
    top: 0;
    bottom: inherit;
    left: 210px;
    width: 40px;
  }
  .a-article.item-c-05 {
    top: -25px;
    left: 15px;
    width: 42px;
  }
  .a-article.item-c-06 {
    top: -8px;
    right: 18px;
    width: 34px;
  }
  .a-article.item-c-07 {
    bottom: -32px;
    right: 42px;
    width: 42px;
  }
  /* ==========
   16 campus-life/school-event/
  ========================================================================== */
  .school-event-month {
    bottom: -25px;
  }
  .school-event-items {
    margin-top: 65px;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 35px 0px;
  }
  .school-event-month {
    right: 15px;
  }
  .school-event-title {
    margin-top: 30px;
    line-height: 2;
  }
  /* ==========
    17 campus-life/beauty-contest/
  ========================================================================== */
  .beauty-contest-lead-text {
    margin-top: 20px;
    line-height: 2.1428;
  }
  .beauty-contest-gallery {
    margin-top: 60px;
  }
  .beauty-contest-gallery-title {
    margin-top: 10px;
    font-size: 2rem;
    line-height: 1.5;
  }
  .beauty-contest-gallery-text {
    margin-top: 30px;
    line-height: 2.1875;
  }
  .beauty-contest-gallery-list {
    margin-top: 30px;
    padding-bottom: 10px;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 3px 1fr 3px 1fr;
    grid-template-columns: repeat(3, 1fr);
    gap: 3px 3px;
  }
  .beauty-contest-gallery-list li {
    width: 100%;
    height: auto;
    aspect-ratio: 245/162;
  }
  .beauty-contest-gallery-list li img {
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  /* ==========
    12 career support //
  ========================================================================== */
  .support-lead-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    gap: 0;
  }
  .support-lead-content {
    width: 100%;
  }
  .support-lead-title {
    margin-top: 30px;
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .support-lead-text {
    margin-top: 30px;
    line-height: 2.1428;
  }
  .support-card-item {
    margin-top: 20px;
    width: 100%;
    max-width: 420px;
    height: 100%;
    max-height: 329px;
    padding: 15px 15px;
    border-top: solid 7px #E70012;
  }
  .support-card-nai_image {
  padding:0;
  border: none;
}
  .support-card-title {
    margin: 5px auto;
  }
  .support-card-icon {
    margin-top: 5px;
  }
  .support-card-num {
    margin-top: 20px;
    margin-right: 10px;
  }
  .support-card-lead {
    margin-top: 5px;
    font-size: 1.1rem;
  }
  .support-card-lead .-txt01 {
    font-size: 1.3rem;
  }
  .section-support-item .col-wrap {
    margin-top: 60px;
    padding: 70px 0 70px;
  }
  .section-support-item .col-wrap::before {
    left: 0;
  }
  .support-items {
    margin-top: -20px;
  }
  .support-items-title {
    margin-top: 20px;
  }
  .support-items-lead {
    margin-top: 35px;
    line-height: 1.5;
  }
  .support-item {
    margin-top: 80px;
    padding: 0 20px 15px 20px;
    position: relative;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-column-gap: 0;
       -moz-column-gap: 0;
            column-gap: 0;
  }
  .support-item-image {
    position: absolute;
    margin-top: -47px;
    left: 15px;
  }
  .support-item-image img {
    overflow: hidden;
    width: 100%;
    height: 100%;
    border-radius: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .support-item-image::before {
    bottom: -5px;
  }
  .support-item-head {
    position: relative;
    margin-left: 155px;
    min-height: 120px;
  }
  .support-item-num {
    font-size: 4.8rem;
    color: transparent;
    -webkit-text-stroke: 2px #BC0312;
    margin-top: -30px;
  }
  .support-item-title {
    margin-top: 10px;
  }
  .support-item-text {
    margin-top: 25px;
    line-height: 2.1875;
  }
  .section-support-career {
    margin-top: 70px;
    padding-bottom: 0;
  }
  .support-career {
    margin-top: 20px;
    /* &-group{
      margin-bottom: 100px;
      .m-index-title{
       margin-bottom: 20px;
      }
     }*/
  }
  .support-career-title {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    min-height: 70px;
    margin: 0;
    padding: 15px 50px 15px 20px;
    font-size: 2rem;
  }
  .support-career-title::after {
    position: absolute;
    content: "";
    top: 50%;
    right: 25px;
    width: 14px;
    height: 14px;
    border-right: none;
    border-bottom: none;
    border-right: 3px solid #212121;
    border-bottom: 3px solid #212121;
    -webkit-transform: translateY(-50%) rotate(45deg);
            transform: translateY(-50%) rotate(45deg);
  }
  .support-career-title.is-active {
    position: relative;
  }
  .support-career-title.is-active::after {
    position: absolute;
    content: "";
    top: 50%;
    right: 30px;
    bottom: 0;
    width: 15px;
    height: 15px;
    border-right: none;
    border-bottom: none;
    border-left: 3px solid #212121;
    border-top: 3px solid #212121;
    -webkit-transform: translateY(-50%) rotate(45deg);
            transform: translateY(-50%) rotate(45deg);
  }
  .support-career-text {
    display: none;
    padding: 0 20px 30px 20px;
    line-height: 2.1875;
  }
  .support-career-list {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    font-size: min(3.2vw, 1.2rem);
    line-height: 1.666;
  }
  .support-career-list li {
    margin-bottom: 0.2em;
  }
  /* ==========
    13 career system //
  ========================================================================== */
  .system-lead-title {
    margin-top: 25px;
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .system-lead-text {
    margin-top: 20px;
    line-height: 2.14285;
  }
  .section-system-item {
    position: relative;
    margin-top: 60px;
  }
  .section-system-item .col-wrap {
    position: relative;
    padding-top: 70px;
    padding-bottom: 70px;
  }
  .system-item {
    position: relative;
    margin-top: 25px;
    -webkit-column-gap: inherit;
       -moz-column-gap: inherit;
            column-gap: inherit;
  }
  .system-item.item01 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    padding-bottom: 90px;
  }
  .system-item.item01 .system-item-image {
    margin-top: 60px;
  }
  .system-item.item02 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  .system-item.item02 .system-item-title {
    top: 30px;
  }
  .system-item.item02 .system-item-image {
    margin-top: 90px;
  }
  .system-item-content {
    width: 100%;
  }
  .system-item-title {
    position: absolute;
    top: 0;
    margin-top: 5px;
    font-size: 2.4rem;
  }
  .system-item-text {
    margin-top: 25px;
  }
  .system-item-image {
    width: 100%;
    max-width: 345px;
    margin-right: auto;
    margin-left: auto;
  }
  .system-interview-items {
    margin-top: -10px;
  }
  .system-interview {
    margin-top: 70px;
    margin-bottom: 70px;
  }
  .system-interview-item {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 35px;
    background-color: #fff;
  }
  .system-interview-item::after {
    position: absolute;
    content: "";
    bottom: 0;
    height: 5px;
    width: 100%;
    background-color: #E70012;
  }
  .system-interview-content {
    position: relative;
    padding: 35px 19px 20px;
    width: 100%;
  }
  .system-interview-title {
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .system-interview-text {
    margin-top: 25px;
    padding-bottom: 20px;
    line-height: 2.1428;
  }
  .system-interview-name {
    position: relative;
    right: inherit;
    bottom: inherit;
    margin-top: 15px;
    font-size: min(4vw, 1.4rem);
    line-height: 1.4;
  }
  .system-interview-name .-txt01 {
    margin-bottom: 0;
  }
  .system-interview-name .-txt02 {
    font-size: min(7vw, 2.4rem);
  }
  .system-interview-image {
    position: relative;
    min-height: 110px;
  }
  .system-interview-image .-en {
    position: absolute;
    top: inherit;
    bottom: 5px;
    right: 10px;
  }
  .system-interview-image .-image {
    width: min(24vw, 90px);
  }
  .a-article.item-system-01 {
    top: 49.5%;
    left: 20px;
    width: 25px;
  }
  /* ==========
    03 about_teachers
  ========================================================================== */
  .line03-t-wrap {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    top: -20px;
    z-index: 1;
  }
  .line04-t-wrap {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-top: -12.5%;
    z-index: 1;
  }
  .line04-t-wrap .svg-elem-2 {
    display: none;
  }
  .a-article.item-t-01 {
    top: -80px;
    right: 46px;
    width: 63px;
  }
  .a-article.item-t-02 {
    bottom: -30px;
    right: 15px;
    width: 54px;
  }
  .a-article.item-t-03 {
    top: -5px;
    left: 30px;
    width: 24px;
  }
  .a-article.item-t-04 {
    top: -60px;
    right: 30px;
    width: 37px;
  }
  .teachers-lead {
    margin-bottom: 65px;
  }
  .teachers-lead-title {
    margin-top: 30px;
    font-size: 1.6rem;
  }
  .teachers-lead-text {
    margin-top: 20px;
    line-height: 2.142;
  }
  .section-teachers-01 .col-wrap {
    position: relative;
    padding: 50px 0 50px;
  }
  .section-teachers-01 .col-wrap::before {
    right: 0;
  }
  .section-teachers-02 .col-wrap {
    position: relative;
    padding: 70px 0 50px;
  }
  .section-teachers-03 .col-wrap {
    padding: 50px 0 50px;
  }
  .section-teachers-03 .col-wrap::before {
    left: 0;
  }
  .teacher-items {
    margin-top: 30px;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 18px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 50px 18px;
  }
  .teacher-item {
    position: relative;
    margin: 0 auto;
  }
  .teacher-item-image {
    max-width: 163px;
    height: 163px;
    -webkit-mask-image: url(../images/teachers/mask_teacher.png);
            mask-image: url(../images/teachers/mask_teacher.png);
    -webkit-mask-size: contain;
            mask-size: contain;
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    -webkit-mask-position: center;
            mask-position: center;
  }
  .teacher-item-image img {
    height: 100%;
    /*width: 295px;
    height: 295px;*/
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: 0 0;
       object-position: 0 0;
  }
  .teacher-item-name {
    margin-top: 25px;
    font-size: 1.6rem;
  }
  .teacher-item-en {
    margin-top: 5px;
    font-size: 1.2rem;
  }
  .section-related-menu {
    margin-top: 70px;
    padding-bottom: 0;
    margin-bottom: 0;
  }
  .section-related-menu .col-inner {
    padding-top: 30px;
    padding-bottom: 15px;
  }
  .section-related-menu .col-inner::before {
    position: absolute;
    content: "";
    top: 0;
    left: 15px;
    width: 100vw;
    height: 100%;
    background-color: #EFE3DF;
  }
  .section-related-menu .m-index-title {
    margin-left: 20px;
  }
  .section-related-menu .m-index-title.-sp-center {
    margin-left: auto;
  }
  .related-menu-list {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 10px 0;
    margin: 15px auto 20px;
    max-width: 310px;
  }
  .related-menu a {
    padding: 0 20px;
    height: 50px;
    font-size: min(4vw, 1.4rem);
  }
  .related-menu a::before {
    right: 20px;
    width: 20px;
    height: 20px;
  }
  /* ==========
    04 about_facility 
  ========================================================================== */
  .facility-lead-text {
    margin-top: 30px;
    line-height: 2.1875;
  }
  .facility-items {
    margin-top: 40px;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 50px 0;
  }
  .facility-item {
    position: relative;
    padding-bottom: 15px;
    border-bottom: solid 1px #212121;
  }
  .facility-item-image {
    height: auto;
    margin-right: auto;
    margin-left: auto;
  }
  .facility-item-image img {
    /*height: 295px;*/
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: 0 0;
       object-position: 0 0;
  }
  .facility-item-tag {
    position: absolute;
    top: 15px;
    right: 15px;
    padding: 3px 15px;
    display: inline-block;
    font-weight: bold;
    color: #fff;
    background-color: #E70012;
  }
  .facility-item-title {
    margin-top: 20px;
    padding-left: 20px;
    font-size: 1.6rem;
    font-weight: bold;
  }
  .facility-item-text {
    margin-top: 15px;
    line-height: 2.142;
  }
  /* ==========
    05 about_faq
  ========================================================================== */
  .faq {
    border-bottom: dashed 1px #212121;
  }
  .faq-group {
    margin-bottom: 70px;
  }
  .faq-group .m-index-title {
    margin-bottom: 0;
    font-size: 2rem;
  }
  .faq-title {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    min-height: 90px;
    padding: 30px 43px 10px 43px;
    font-size: 1.6rem;
  }
  .faq-title::before {
    top: 28px;
    left: 0;
    width: 33px;
    height: 33px;
    font-size: 2.4rem;
  }
  .faq-title::after {
    right: 3px;
    width: 10px;
    height: 10px;
    border-right: 2px solid #212121;
    border-bottom: 2px solid #212121;
    -webkit-transform: translateY(-50%) rotate(45deg);
            transform: translateY(-50%) rotate(45deg);
  }
  .faq-title.is-active {
    position: relative;
  }
  .faq-title.is-active::after {
    right: 3px;
    width: 10px;
    height: 10px;
    border-left: 2px solid #212121;
    border-top: 2px solid #212121;
    -webkit-transform: translateY(-50%) rotate(45deg);
            transform: translateY(-50%) rotate(45deg);
  }
  .faq-text {
    padding: 50px 20px 20px 20px;
    line-height: 2.1875;
  }
  .faq-text::before {
    top: 10px;
    left: 20px;
    width: 28px;
    height: 28px;
    font-size: 2rem;
  }
  /* ==========
    06 hair-beauty
  ========================================================================== */
  .hair-beauty-mv,
  .total-beauty-mv {
    margin-bottom: 40px;
    aspect-ratio: 345/260;
  }
  .hair-beauty-mv-content,
  .total-beauty-mv-content {
    width: 90%;
    height: 90px;
  }
  .hair-beauty-mv-content .-txt,
  .total-beauty-mv-content .-txt {
    margin-top: 15px;
  }
  .hair-beauty-lead-text,
  .total-beauty-lead-text {
    margin-top: 20px;
    line-height: 2.1875;
  }
  .course-data {
    margin-top: 45px;
    padding: 30px 15px 20px;
  }
  .course-data-title {
    padding-left: 20px;
  }
  .course-data-title::before {
    top: 3px;
    left: 0;
    width: 13px;
    height: 13px;
  }
  .course-data-tag {
    margin-top: 15px;
    padding: 1px 15px;
  }
  .course-data-text {
    margin-top: 10px;
    padding-bottom: 10px;
    font-size: 1.2rem;
  }
  .course-data-item-wrap {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-top: 25px;
    padding-bottom: 10px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .course-data-item-title {
    margin-right: 35px;
  }
  .course-data-item-list {
    margin-top: 10px;
  }
  .course-data-item-list li {
    margin-right: 10px;
    margin-top: 7px;
    padding: 2px 10px;
    font-size: 1.2rem;
  }
  .anchor-link-list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 17px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 0 17px;
    margin: 40px auto 70px;
  }
  .anchor-link a {
    padding-top: 10px;
    height: 40px;
  }
  .anchor-link a::after {
    width: 15px;
    height: 16px;
    background: url("../images/hair-beauty/ico_down.svg") no-repeat;
    background-size: contain;
    -webkit-transform: inherit;
            transform: inherit;
  }
  .anchor-link a:hover {
    opacity: 0.7;
  }
  .anchor-link a:hover::after {
    -webkit-transform: translateY(-45%);
            transform: translateY(-45%);
  }
  .course-point-item {
    margin-top: 40px;
    margin-bottom: 60px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-column-gap: 50px;
       -moz-column-gap: 50px;
            column-gap: 50px;
    counter-increment: number;
  }
  .course-point-item-wrap {
    margin-top: -30px;
  }
  .course-point-item-image {
    max-width: 345px;
    max-height: 230px;
  }
  .course-point-item-image img {
    aspect-ratio: 345/230;
  }
  .course-point-item-image::before {
    position: absolute;
    counter-increment: number 0;
    content: "0" counter(number);
    top: -25px;
    left: 2px;
    font-family: "din-2014", sans-serif;
    font-weight: 400;
    font-style: normal;
    letter-spacing: 0.025em;
    font-size: 7.2rem;
    line-height: 1;
    color: #E70012;
  }
  .course-point-item-title {
    margin-top: 20px;
    line-height: 1.666;
  }
  .course-point-item-text {
    margin-top: 15px;
    line-height: 2.1428;
  }
  .section-schedule {
    margin-top: 65px;
  }
  .section-schedule .col-wrap {
    position: relative;
    padding-top: 10px;
    padding-bottom: 95px;
  }
  .section-schedule .col-wrap::before {
    left: 0;
  }
  .section-schedule .col-wrap .m-index-title {
    margin-top: 40px;
    margin-bottom: 20px;
  }
  .section-schedule .line01-b-wrap {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    top: -60px;
    z-index: 0;
  }
  .schedule-table {
    margin-top: 25px;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    -webkit-column-gap: 20px;
       -moz-column-gap: 20px;
            column-gap: 20px;
  }
  .schedule-head {
    padding: 10px 20px;
  }
  .schedule-body {
    display: -ms-grid;
    display: grid;
    gap: 15px;
    margin-top: 15px;
  }
  .schedule-body-inner {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-column-gap: 15px;
       -moz-column-gap: 15px;
            column-gap: 15px;
    padding: 25px 20px 10px;
  }
  .schedule-month {
    line-height: 1.3;
    margin-top: 0;
  }
  .schedule-detail + .schedule-detail {
    margin-top: 25px;
  }
  .schedule-detail-title {
    margin-top: 0;
    line-height: 1.3;
  }
  .schedule-detail-text {
    margin-top: 10px;
    margin-bottom: 10px;
    line-height: 2.1428;
  }
  .schedule-detail > .schedule-detail-text {
    margin-top: 0;
  }
  .schedule-detail > .schedule-tags {
    margin-top: 0;
  }
  .schedule-tags {
    margin-top: 10px;
    margin-bottom: 10px;
  }
  .schedule-tag {
    margin-right: 10px;
    padding-left: 10px;
    font-size: 1.2rem;
  }
  .schedule-tag::before {
    top: 8px;
    width: 5px;
    height: 5px;
  }
  .section-course-select {
    margin-top: 65px;
  }
  .section-course-select .col-inner {
    position: relative;
  }
  .course-select {
    margin-top: -25px;
  }
  .course-select-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .course-select-item.-item03 .course-select-item-image .-en {
    margin-left: 50px;
  }
  .course-select-item-image {
    max-width: 100%;
  }
  .course-select-item-image .-image {
    aspect-ratio: 345/225;
    width: 100%;
    height: auto;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .course-select-item-image .-en {
    position: absolute;
    max-width: calc(100% - 30px);
    height: auto;
    min-height: inherit;
    top: inherit;
    left: 0;
    bottom: 12px;
    right: 0;
    margin: 0 auto;
    -webkit-transform: inherit;
            transform: inherit;
  }
  .course-select-item-content {
    padding: 15px 20px 35px;
  }
  .course-select-item-title {
    line-height: 2.343;
  }
  .course-select-item-text {
    line-height: 2.1875;
  }
  .course-select-tags {
    margin-top: 10px;
  }
  .course-select-tags-title {
    margin-top: 30px;
  }
  .course-select-tag {
    margin-right: 9px;
    margin-top: 10px;
    padding: 1px 8px;
    font-size: 1.2rem;
    border: solid 1.5px #E70012;
  }
  .section-course-unique {
    margin-top: 65px;
  }
  .course-unique {
    margin-top: -10px;
  }
  .course-unique-item {
    margin-top: 40px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .course-unique-item-image {
    max-width: 345px;
    max-height: 216px;
  }
  .course-unique-item-image img {
    aspect-ratio: 345/216;
  }
  .course-unique-item-content {
    margin-left: 0;
  }
  .course-unique-item-title {
    margin-top: 20px;
    line-height: 1.4285;
  }
  .course-unique-item-text {
    line-height: 2.1428;
  }
  .section-course-menu {
    margin-top: 45px;
    margin-bottom: 70px;
  }
  .section-course-menu .col-wrap {
    padding-top: 30px;
    padding-bottom: 30px;
  }
  .section-course-menu .col-wrap::before {
    right: 0;
  }
  .section-course-menu .m-index-title {
    margin-top: 0;
  }
  .course-menus {
    margin-top: 10px;
    padding-bottom: 20px;
    gap: 0 17px;
  }
  .course-menus.-menu01 {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    padding-bottom: 70px;
  }
  .course-menu {
    padding: 24px 0 14px;
    border-bottom: solid 1px #212121;
  }
  .course-menu.-no-border {
    border-bottom: none;
  }
  .course-menu-title {
    position: relative;
    padding-left: 15px;
    font-weight: bold;
    line-height: 1.3;
  }
  .course-menu-title::before {
    position: absolute;
    content: "";
    left: 0;
    top: 5px;
    width: 10px;
    height: 10px;
    border-radius: 100%;
    background-color: #E70012;
  }
  .course-menu-title .-txt01 {
    margin-left: 10px;
    font-size: 1.2rem;
    font-weight: normal;
  }
  .course-menu-title .-txt02 {
    font-size: 1.2rem;
    font-weight: normal;
  }
  .course-menu-text {
    margin-top: 10px;
    line-height: 1.666;
    font-size: 1.2rem;
  }
  #section01, #section02, #section03, #section04, #section05, #section06 {
    margin-top: -45px;
    padding-top: 45px;
  }
  .a-article.item-b-01 {
    top: -40px;
    right: 15px;
  }
  .a-article.item-b-02 {
    top: -40px;
    left: 15px;
  }
  .a-article.item-b-03 {
    top: -40px;
    right: 20px;
  }
  .a-article.item-b-04 {
    top: -50px;
    left: 15px;
  }
  .a-article.item-b-05 {
    top: -30px;
    left: 20px;
  }
  /* ==========
    07 total-beauty
  ========================================================================== */
  /* ==========
    08 hair-beauty-tsushin
  ========================================================================== */
  .tsushin-lead {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 50px;
  }
  .tsushin-lead-image {
    margin: 0 auto;
    max-width: 280px;
    max-height: 280px;
  }
  .tsushin-lead-content .m-index-title {
    line-height: 1.666;
  }
  .tsushin-lead-text {
    max-width: inherit;
    margin-top: 15px;
    line-height: 2.1875;
  }
  .section-tsushin-item {
    margin-top: 70px;
  }
  .section-tsushin-item .col-wrap {
    position: relative;
    padding-top: 70px;
    padding-bottom: 70px;
  }
  .section-tsushin-item .col-wrap::before {
    left: 0;
  }
  .tsushin-items {
    margin-top: -50px;
  }
  .tsushin-item-lead {
    line-height: 1.875;
  }
  .tsushin-item-wrap {
    margin-top: 60px;
    padding: 0 0px 30px 15px;
  }
  .tsushin-item-wrap.item01 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .tsushin-item-wrap.item01 .tsushin-item-image {
    margin-right: min(-6vw, -63px);
  }
  .tsushin-item-wrap.item01 .tsushin-item-image .img01 {
    top: 0px;
    right: 0;
  }
  .tsushin-item-wrap.item01 .tsushin-item-image .img02 {
    top: 180px;
    left: -10px;
  }
  .tsushin-item-wrap.item02 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-left: 0;
  }
  .tsushin-item-wrap.item02 .tsushin-item-content::before {
    left: -15px;
    right: inherit;
  }
  .tsushin-item-wrap.item02 .tsushin-item-num {
    left: inherit;
  }
  .tsushin-item-wrap.item02 .tsushin-item-image {
    margin-left: auto;
  }
  .tsushin-item-wrap.item02 .tsushin-item-image .img01 {
    position: absolute;
    top: 100px;
    left: -15px;
  }
  .tsushin-item-wrap.item02 .tsushin-item-image .img02 {
    position: absolute;
    top: 10px;
    right: 0;
  }
  .tsushin-item-wrap.item03 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .tsushin-item-wrap.item03 .tsushin-item-image {
    margin-right: 0;
  }
  .tsushin-item-wrap.item03 .tsushin-item-image .img01 {
    top: 0px;
    right: 0px;
  }
  .tsushin-item-wrap.item03 .tsushin-item-image .img02 {
    top: 120px;
    left: -15px;
  }
  .tsushin-item-content {
    width: 100%;
    max-width: inherit;
    padding-top: 80px;
    padding-bottom: 20px;
  }
  .tsushin-item-content::before {
    top: 35px;
    left: -15px;
    background-color: #fff;
    z-index: -1;
  }
  .tsushin-item-num {
    top: 0;
    left: 5px;
  }
  .tsushin-item-title {
    font-size: 2.4rem;
    line-height: 1.666;
  }
  .tsushin-item-image {
    position: relative;
    top: 0;
    max-height: 451px;
    min-height: 257px;
    width: 100%;
    max-width: 345px;
  }
  .tsushin-item-image img {
    width: 100%;
    height: auto;
  }
  .tsushin-item-tag {
    margin-top: 35px;
    padding: 20px 20px 10px 20px;
  }
  .tsushin-item-tag-title {
    margin-top: -30px;
    font-size: 1.6rem;
  }
  .tsushin-item-tag-list {
    margin-top: 20px;
    -webkit-column-count: 1;
       -moz-column-count: 1;
            column-count: 1;
  }
  .tsushin-item-tag .course-menus {
    padding-bottom: 40px;
  }
  .section-tsushin-flow {
    margin-top: 70px;
  }
  .tsushin-flow-menu {
    padding: 25px 20px 20px;
    background-color: #fff;
    border-top: solid 6px #BC0312;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
  .tsushin-flow-menu-wrap {
    margin-top: 30px;
    margin-right: auto;
    margin-left: auto;
    width: calc(100% - 40px);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 10px;
  }
  .tsushin-flow-menu-title {
    font-size: 2rem;
  }
  .tsushin-flow-menu-text {
    margin-top: 10px;
    min-height: 50px;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .tsushin-flow-items {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .tsushin-flow-item {
    position: relative;
    margin-bottom: 65px;
  }
  .tsushin-flow-item::before {
    position: absolute;
    content: "";
    bottom: -40px;
    left: 50%;
    display: inline-block;
    width: 40px;
    height: 40px;
    border-bottom: 5px solid #BC0312;
    border-right: 5px solid #BC0312;
    -webkit-transform: translateX(-50%) rotate(45deg);
            transform: translateX(-50%) rotate(45deg);
  }
  .tsushin-flow-item.-last {
    margin-bottom: 0;
  }
  .tsushin-flow-item.-last::before {
    display: none;
  }
  .tsushin-flow-head {
    padding: 5px 0;
    min-height: 50px;
    font-size: clamp(2.4rem, 3vw, 3.2rem);
    font-weight: bold;
    line-height: 1.1;
    text-align: center;
    color: #fff;
  }
  .tsushin-flow-head.-season01 {
    background-color: #E83928;
  }
  .tsushin-flow-head.-season02 {
    background-color: #BC0312;
  }
  .tsushin-flow-head.-season03 {
    background-color: #80000A;
  }
  .tsushin-flow-body {
    padding: 25px min(5vw, 20px);
    width: 100%;
  }
  .tsushin-flow-title {
    margin-top: 25px;
    font-size: clamp(1.6rem, 2.4vw, 2.8rem);
    font-weight: bold;
    line-height: 1.875;
    color: #E70012;
  }
  .tsushin-flow-text {
    margin-top: 10px;
    line-height: 1.875;
  }
  .tsushin-flow-table {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 5px;
  }
  .tsushin-flow-table.-table02 .tsushin-flow-table-head {
    padding-top: 20px;
  }
  .tsushin-flow-table.-table02 .tsushin-flow-table-head::before {
    top: -42px;
    bottom: inherit;
    left: -5px;
    margin: auto;
  }
  .tsushin-flow-table.-table02 .tsushin-flow-table-head::after {
    top: -35px;
    bottom: inherit;
    left: 2px;
    margin: auto;
  }
  .tsushin-flow-table.-table03 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .tsushin-flow-table.-table03 .tsushin-flow-table-body.-col01 {
    -webkit-writing-mode: vertical-lr;
        -ms-writing-mode: tb-lr;
            writing-mode: vertical-lr;
  }
  .tsushin-flow-table.-table03 .tsushin-flow-table-item {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .tsushin-flow-table-wrap {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 35px 0;
  }
  .tsushin-flow-table-head {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    letter-spacing: 0.25rem;
  }
  .tsushin-flow-table-body {
    margin-top: 0;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 5px;
    width: 100%;
  }
  .tsushin-flow-table-body.-col01 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    row-gap: 5px;
  }
  .tsushin-flow-table-item {
    padding-top: 20px;
    min-height: 60px;
    padding: 10px 5px;
  }
  .tsushin-flow-table-item-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 5px;
  }
  .tsushin-flow-table-item-wrap.-col02 {
    gap: 5px;
  }
  .tsushin-flow-table-item-wrap.-col02 .tsushin-flow-table-item-text {
    text-align: left;
    -webkit-writing-mode: vertical-lr;
        -ms-writing-mode: tb-lr;
            writing-mode: vertical-lr;
    text-orientation: upright;
  }
  .tsushin-flow-table-item-text {
    text-align: center;
    line-height: 1.25;
  }
  .tsushin-flow-table-item-text .-txt01 {
    font-weight: bold;
    line-height: 1.5;
  }
  .tsushin-flow-table-item-text .-txt-en {
    font-family: "din-2014", sans-serif;
    font-weight: 400;
    font-style: normal;
  }
  .tsushin-flow-table-item-text .-label01 {
    position: absolute;
    left: 0;
    top: 50%;
    display: inline-block;
    padding: 8px 10px;
    font-size: 1.6rem;
    background-color: #212121;
    color: #fff;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .tsushin-flow-table-item-text .-label02 {
    position: absolute;
    left: 5px;
    right: 5px;
    top: 0;
    padding: 0 3px;
    background-color: #fff;
    color: #212121;
    -webkit-writing-mode: lr;
        -ms-writing-mode: lr;
            writing-mode: lr;
  }
  .tsushin-flow-table-item-tag-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 5px;
    margin-left: 0;
  }
  .tsushin-flow-table-item-tag-list li {
    padding: 5px 6px;
    font-size: min(3.2vw, 1.2rem);
    font-weight: bold;
    background-color: #fff;
  }
  .tsushin-flow-table-item.-labelcell {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .tsushin-flow-table-item.-labelcell .tsushin-flow-table-item-text {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 10px;
    text-align: left;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .tsushin-flow-table-item.-cell01 {
    padding-top: 30px;
  }
  .tsushin-flow-table-bottom {
    margin-bottom: 10px;
  }
  .tsushin-flow-table-bottom.-col02 {
    margin-top: 10px;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
  .tsushin-data {
    position: relative;
    margin-top: 70px;
    margin-bottom: 70px;
    padding: 70px 0 70px;
  }
  .tsushin-data::before {
    left: 0;
  }
  .tsushin-guide {
    padding-top: 25px;
    padding-bottom: 30px;
    margin-bottom: 90px;
  }
  .tsushin-guide-title {
    margin-top: 40px;
  }
  .tsushin-guide-lead {
    margin-top: 15px;
    line-height: 1.785;
  }
  .tsushin-guide-table {
    margin-top: 10px;
  }
  .tsushin-guide-table.-table01 {
    table-layout: fixed;
    -webkit-writing-mode: inherit;
        -ms-writing-mode: inherit;
            writing-mode: inherit;
  }
  .tsushin-guide-table.-table01 th {
    width: 89px;
    max-width: 89px;
    -webkit-writing-mode: inherit;
        -ms-writing-mode: inherit;
            writing-mode: inherit;
  }
  .tsushin-guide-table.-table01 th.cell-1 {
    width: 89px;
    max-width: 89px;
  }
  .tsushin-guide-table.-table01 td {
    -webkit-writing-mode: inherit;
        -ms-writing-mode: inherit;
            writing-mode: inherit;
    text-align: left;
  }
  .tsushin-guide-table.-table02 {
    table-layout: fixed;
  }
  .tsushin-guide-table.-table02 th {
    width: 89px;
    max-width: 89px;
    font-size: 1.4rem;
  }
  .tsushin-guide-table.-table02 td {
    white-space: normal;
  }
  .tsushin-guide-table.-table02 .note {
    bottom: 20px;
  }
  .tsushin-guide-table.-table03 {
    margin-top: 30px;
  }
  .tsushin-guide-table.-table03 th {
    width: 12%;
    min-width: 100px;
  }
  .tsushin-guide-table.-table03 th.cell-1 {
    min-width: 130px;
  }
  .tsushin-guide-table.-table04 {
    margin-top: 10px;
  }
  .tsushin-guide-table.-table04 th {
    width: 12%;
    min-width: 100px;
  }
  .tsushin-guide-table.-table04 th.cell-1 {
    min-width: 103px;
  }
  .tsushin-guide-table th {
    height: 38px;
  }
  .tsushin-guide-table td {
    height: 38px;
    font-size: 1.4rem;
  }
  .tsushin-arrow {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: inherit;
    width: 100%;
    max-width: 345px;
    margin: 25px auto;
  }
  .tsushin-arrow-item {
    padding-left: inherit;
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    min-height: 88px;
    text-align: center;
    /*
     &::before{
      position: absolute;
      content:"";
      top:inherit;
      right:0;
      left:0;
      bottom: -20px;
      width:0;
      height:0;
      border-style:solid;
      border-width: 20px 391px 0 391px;
      border-color: #EFE3DE transparent transparent transparent;
     }
     &::after{
      position: absolute;
      content:"";
      top:inherit;
      right:0;
      left:0;
      bottom: -21px;
      width:0;
      height:0;
      border-style:solid;
      border-width: 20px 391px 0 391px;
      border-color: $color-r1 transparent transparent transparent;
     }
     */
  }
  .tsushin-arrow-item::after {
    position: absolute;
    content: "";
    top: inherit;
    right: inherit;
    bottom: -10px;
    left: inherit;
    width: 100%;
    max-width: 345px;
    height: 22px;
    background-image: url("../../common/images/hair-beauty-tsushin/img_arrow_sp.svg");
    background-size: cover;
    background-position-x: center;
  }
  .tsushin-arrow-item.-last::beore {
    display: none;
  }
  .tsushin-arrow-item.-last::after {
    display: none;
  }
  .tsushin-arrow-item-text .-txt01 {
    font-weight: bold;
    line-height: 1.5;
  }
  .tsushin-arrow-item-text .-txt02 {
    display: inline-block;
    font-size: 1.2rem;
    line-height: 1.5;
    font-weight: normal;
    text-align: left;
  }
  /* ==========
    09 opencampus
  ========================================================================== */
  .section-opencampus {
    padding-top: 70px;
  }
  .section-opencampus .opencampus-slider {
    margin-bottom: 70px;
  }
  .opencampus-slider {
    position: relative;
    padding-left: 15px;
    margin: 20px 0 45px 0;
    width: 100%;
    overflow: auto;
  }
  .opencampus-cat-menu-wrap {
    margin-top: 20px;
  }
  .opencampus-cat-menu-wrap .m-select {
    min-width: 220px;
  }
  .opencampus-cat-menu-title {
    margin-right: min(4.2vw, 20px);
    font-size: 1.4rem;
  }
  .m-select {
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    padding: 9px 40px 8px 20px;
    width: 66.66%;
    height: 40px;
    font-size: 1.4rem;
    font-weight: bold;
    background-size: 12px 7px;
    background-position: center right 20px;
  }
  .opencampus-calendar {
    margin-top: 70px;
  }
  .opencampus-calendar .col-wrap {
    position: relative;
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .opencampus-calendar .col-wrap::before {
    right: 0;
    width: 100vw;
    height: 100%;
  }
  .open-campus-calendar {
    margin-top: 50px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .open-campus-calendar .calendar-left {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
  }
  .open-campus-calendar .calendar-right {
    margin-top: 0;
    width: 100%;
    max-width: 445px;
    margin-right: auto;
    margin-left: auto;
  }
  .js-calendar-slider .swiper-navi {
    position: absolute;
    z-index: 2;
    width: 100%;
    top: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .js-calendar-slider .swiper-button-prev,
  .js-calendar-slider .swiper-button-next {
    width: 10px;
    height: 15px;
    top: 25px;
  }
  .js-calendar-slider .swiper-button-prev::after,
  .js-calendar-slider .swiper-button-next::after {
    display: none;
  }
  .js-calendar-slider .swiper-button-next {
    right: 0;
    left: auto;
    scale: 1;
  }
  .calendar {
    padding-bottom: 30px;
  }
  .calendar-title {
    font-size: 2.4rem;
    margin-bottom: 15px;
  }
  .calendar-head {
    margin-bottom: 10px;
    padding-bottom: 5px;
  }
  .calendar-head-cells {
    font-size: 1.2rem;
    font-weight: 500;
  }
  .calendar-cells {
    gap: 12px 15px;
    font-size: 1.3rem;
  }
  /* calendar-list === */
  .calendar-list {
    padding: 20px 0;
    min-height: 115px;
    border-bottom: dotted 1px #707070;
  }
  .calendar-list-thumb {
    aspect-ratio: 100/75;
    margin-right: min(4vw, 15px);
    max-width: 100px;
  }
  .calendar-list-thumb img {
    aspect-ratio: 100/75;
  }
  .calendar-list-content {
    width: 66%;
  }
  .calendar-list-date {
    font-size: 1.2rem;
    margin-right: 10px;
  }
  .calendar-list-cat {
    font-size: min(1vw, 1.2rem);
    margin-right: 5px;
  }
  .calendar-list-cat a, .calendar-list-cat span {
    padding: 3px min(1vw, 10px);
  }
  .calendar-list-title {
    margin-top: 10px;
    line-height: 1.642;
  }
  .opencampus-faq {
    margin-top: 70px;
  }
  .opencampus-faq .col-wrap {
    padding-top: 50px;
    padding-bottom: 30px;
  }
  .opencampus-faq .col-wrap::before {
    left: 0;
    width: 100vw;
    height: 100%;
  }
  .opencampus-faq .btn-wrap-c {
    margin-top: 50px;
  }
  .opencampus-tokuten {
    margin: 50px auto -25px;
  }
  .opencampus-tokuten .tokuten-items {
    margin-top: -25px;
  }
  .opencampus-tokuten .tokuten-item {
    margin-top: 50px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-column-gap: 50px;
       -moz-column-gap: 50px;
            column-gap: 50px;
  }
  .opencampus-tokuten .tokuten-item-image {
    aspect-ratio: 345/220;
    max-width: 345px;
    max-height: 220px;
  }
  .opencampus-tokuten .tokuten-item-image img {
    aspect-ratio: 345/220;
  }
  .opencampus-tokuten .tokuten-item-image::before {
    right: 5px;
  }
  .opencampus-tokuten .tokuten-item-title {
    margin-top: 15px;
    font-size: min(5.5vw, 2rem);
    line-height: 2;
  }
  .opencampus-tokuten .tokuten-item-text {
    margin-top: 10px;
    padding-bottom: 20px;
    line-height: 2.1875;
  }
  /* ==========
    09_ opencampus_details
  ========================================================================== */
  .oc-detail-wrap {
    margin-top: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .oc-detail-thumb {
    max-width: 424px;
    height: auto;
  }
  .oc-detail-thumb img {
    position: inheritre;
    top: 100px;
  }
  .oc-detail-content {
    width: 100%;
    margin-left: auto;
    margin-top: 25px;
  }
  .oc-detail-meta {
    margin-top: -5px;
  }
  .oc-detail-title {
    margin-top: 15px;
    font-size: 2.4rem;
    line-height: 1.458;
  }
  .oc-detail-text {
    margin: 25px 0 50px;
    line-height: 2.142;
  }
  .oc-detail-data {
    margin-bottom: 50px;
  }
  .oc-detail-data dl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: dotted 1px #707070;
  }
  .oc-detail-data dl.oc-detail-support {
    padding-bottom: 0;
  }
  .oc-detail-data dl.oc-detail-support dd {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .oc-detail-data dt {
    width: 100%;
    font-size: 1.6rem;
    padding-bottom: 10px;
  }
  .oc-detail-data dd {
    margin-left: 0;
  }
  .oc-detail-data .icon-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 20px;
    margin-right: 15px;
  }
  .oc-detail-data .icon-item .icon {
    width: 25px;
    height: 25px;
  }
  .oc-detail-data .icon-item-text {
    margin-left: 5px;
  }
  /* oc-summary */
  .oc-summary {
    margin: 70px auto 70px;
  }
  .oc-summary-text {
    margin-top: 30px;
  }
  .m-card {
    max-width: 475px;
    margin-right: auto;
    margin-left: auto;
  }
  .m-card-wrap {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 0;
  }
  .m-card-image {
    margin-top: 50px;
    aspect-ratio: 475/320;
  }
  .m-card-image img {
    aspect-ratio: 475/320;
    width: 100%;
    height: auto;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .m-card-title {
    margin-top: 20px;
    font-size: 2rem;
    line-height: 2;
  }
  .m-card-text {
    margin-top: 5px;
    padding-bottom: 20px;
    line-height: 2.142;
  }
  /* oc-point */
  .oc-point {
    margin: 70px auto 60px;
  }
  .m-number-card {
    margin-top: 30px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-column-gap: 50px;
       -moz-column-gap: 50px;
            column-gap: 50px;
    margin-right: auto;
    margin-left: auto;
    max-width: 475px;
  }
  .m-number-card-image {
    position: relative;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    aspect-ratio: 345/200;
    max-width: 100%;
  }
  .m-number-card-image img {
    aspect-ratio: 345/200;
    width: 100%;
    height: auto;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .m-number-card-title {
    font-size: min(5vw, 2rem);
    line-height: 2;
    margin-top: 20px;
  }
  .m-number-card-text {
    margin-top: 10px;
    line-height: 2.142;
  }
  /* oc-form */
  .oc-form {
    margin-top: 60px;
    padding: 50px 0 60px;
    position: relative;
  }
  .oc-form::before {
    right: 0;
  }
  .oc-form .col-inner {
    padding-right: 15px;
  }
  .oc-form .contact-head {
    margin-top: 40px;
    margin-bottom: 20px;
  }
  .oc-form .form-steps-list li {
    background-color: #EFE3DF;
  }
  .oc-form .form-area {
    margin-top: 40px;
    max-width: 550px;
  }
  .oc-form-wrap {
    padding: 15px;
  }
  .oc-form-content {
    margin-left: 10px;
  }
  .oc-form-date {
    font-size: 1.2rem;
  }
  .oc-form-title {
    margin-top: 5px;
    font-size: 1.4rem;
    line-height: 1.428;
  }
  .oc-form .form-items {
    margin-top: 30px;
  }
  .oc-form .form-item-input {
    padding: 10px 0;
  }
  .oc-form .form-button {
    margin-top: 50px;
  }
  /* oc-osusume */
  .oc-osusume {
    margin-bottom: 30px;
    padding-top: 70px;
    overflow: hidden;
  }
  /* ==========
    11 opencampus/ocguide
  ========================================================================== */
  .ocguide-mv-content {
    padding: 35px 35px;
    position: absolute;
    width: 100%;
  }
  .ocguide-mv-title {
    font-size: 2rem;
  }
  .ocguide-mv-title .-en {
    display: block;
    margin-top: 10px;
    font-family: "din-2014-narrow", sans-serif;
    font-weight: 700;
    font-style: normal;
    font-size: 5.6rem;
    letter-spacing: 0.25rem;
  }
  .ocguide-mv-text {
    margin-top: 15px;
    font-size: 1.6rem;
    line-height: 1.5625;
  }
  .ocguide-lead {
    margin-top: 45px;
  }
  .ocguide-lead-wrap {
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 25px 20px;
  }
  .ocguide-lead-wrap::before {
    position: absolute;
    content: "";
    bottom: 0;
    left: 0;
    height: 406px;
    width: 100%;
    background-color: #fff;
    z-index: -1;
  }
  .ocguide-lead-content {
    width: 100%;
  }
  .ocguide-lead-content .m-index-title {
    margin-left: -20px;
  }
  .ocguide-lead-title {
    margin-top: 25px;
    font-size: 2.1rem;
    text-align: center;
  }
  .ocguide-lead-title .-txt01 {
    font-size: 3.1rem;
  }
  .ocguide-lead-title .-txt02 {
    margin-left: 20px;
    font-size: 7.6rem;
  }
  .ocguide-lead-title .-txt03 {
    margin-left: 10px;
    font-size: 3.7rem;
  }
  .ocguide-lead-text {
    margin-top: 15px;
    font-size: 1.6rem;
    line-height: 1.9375;
  }
  .ocguide-lead-caption {
    display: none;
    /* margin-top: 10px;
     font-size: 1.2rem;*/
  }
  .ocguide-lead-image {
    width: 100%;
    margin-top: 30px;
  }
  .ocguide-lead-image .img01 {
    position: relative;
    top: 0;
    width: calc(100% - 74px);
    max-width: 217px;
  }
  .ocguide-lead-image .img02 {
    position: absolute;
    right: 35px;
    width: min(20vw, 74px);
  }
  .ocguide-faq .col-wrap {
    position: relative;
    margin-top: 70px;
    padding-top: 70px;
    padding-bottom: 70px;
  }
  .ocguide-faq .col-wrap::before {
    left: 0;
  }
  .ocguide-faq-lead {
    margin-top: 20px;
    line-height: 2.1428;
  }
  .section-ocguide-menu {
    margin-top: 70px;
    padding-bottom: 0;
  }
  .ocguide-menus {
    margin-top: -35px;
  }
  .ocguide-menu {
    position: relative;
    margin-top: 55px;
  }
  .ocguide-menu::before {
    position: absolute;
    content: "";
    top: 25px;
    width: 100vw;
    height: calc(100% - 25px);
  }
  .ocguide-menu.-year1 {
    padding-right: 15px;
    padding-left: 30px;
  }
  .ocguide-menu.-year1::before {
    left: 0;
    background-color: #E70012;
    background-image: URL("../images/ocguide/bg_menu_01.jpg");
    background-position: right;
  }
  .ocguide-menu.-year1::after {
    position: absolute;
    content: "";
    left: 0;
    top: 25px;
    width: 100vw;
    height: calc(100% - 25px);
    background: linear-gradient(165deg, rgb(231, 0, 18) 0%, rgb(231, 0, 18) 20%, rgba(231, 0, 18, 0) 80%);
    z-index: -1;
  }
  .ocguide-menu.-year2 {
    padding-left: 15px;
    padding-right: 30px;
  }
  .ocguide-menu.-year2::before {
    right: 0;
    background-color: #E83928;
    background-image: URL("../images/ocguide/bg_menu_02.jpg");
    background-position: left;
    -webkit-transform: scale(-1, 1);
            transform: scale(-1, 1);
  }
  .ocguide-menu.-year2::after {
    position: absolute;
    content: "";
    right: 0;
    top: 25px;
    width: 100vw;
    height: calc(100% - 25px);
    background: linear-gradient(330deg, rgb(232, 57, 40) 0%, rgb(232, 57, 40) 20%, rgba(231, 0, 18, 0) 70%);
    z-index: -1;
  }
  .ocguide-menu.-year2 .ocguide-menu-title {
    border: solid 3px #E83928;
    position: relative;
    float: right;
  }
  .ocguide-menu.-year3 {
    padding-right: 15px;
    padding-left: 30px;
    padding-bottom: 25px;
  }
  .ocguide-menu.-year3::before {
    left: 0;
    background-color: #FFB13A;
    background-image: URL("../images/ocguide/bg_menu_03.jpg");
    background-position: right;
    background-size: 150% 100%;
  }
  .ocguide-menu.-year3::after {
    position: absolute;
    content: "";
    left: 0;
    top: 25px;
    width: 100vw;
    height: calc(100% - 25px);
    background: linear-gradient(165deg, rgb(255, 177, 61) 0%, rgb(255, 177, 61) 20%, rgba(255, 216, 61, 0) 80%);
    z-index: -1;
  }
  .ocguide-menu.-year3 .ocguide-menu-title {
    border: solid 3px #E70012;
  }
  .ocguide-menu.-year3 .ocguide-menu-lead {
    margin-right: 70px;
  }
  .ocguide-menu-title {
    padding: 6px 16px 10px;
    display: inline-block;
    background-color: #fff;
    border: solid 3px #E70012;
    font-size: min(6.2vw, 2.4rem);
    font-weight: bold;
  }
  .ocguide-menu-title .-txt01 {
    font-size: min(9vw, 3.2rem);
  }
  .ocguide-menu-item {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    width: 100%;
    max-width: 380px;
  }
  .ocguide-menu-item-wrap {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-column-gap: 30px;
       -moz-column-gap: 30px;
            column-gap: 30px;
    padding-bottom: 40px;
  }
  .ocguide-menu-lead {
    margin-top: 20px;
    font-size: min(4vw, 1.4rem);
    line-height: 1.857;
  }
  .ocguide-menu-text {
    clear: both;
    padding-top: 15px;
    margin-left: 70px;
    font-size: min(4vw, 1.4rem);
    line-height: 1.857;
  }
  .ocguide-menu-image {
    position: absolute;
  }
  .ocguide-menu-image.-student01 {
    top: 0px;
    right: 20px;
    width: min(13vw, 44px);
    height: auto;
  }
  .ocguide-menu-image.-student02 {
    top: 0px;
    left: 20px;
    width: min(13vw, 41px);
    height: auto;
  }
  .ocguide-menu-image.-student03 {
    top: 0px;
    right: 25px;
    width: min(13vw, 47px);
    height: auto;
  }
  .ocguide-menu-btn {
    margin-top: 15px;
    width: 100%;
    -webkit-transition: 0.35s ease-in-out;
    transition: 0.35s ease-in-out;
  }
  .ocguide-menu-btn a {
    outline: 3px solid #fff;
    position: relative;
    width: 100%;
    max-width: 300px;
    height: 74px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    text-align: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .ocguide-menu-btn a::before {
    display: none;
    content: "";
    padding-top: 53.3333333333%;
  }
  .ocguide-menu-btn a p {
    margin-top: auto;
    padding-right: 40px;
    position: absolute;
    font-size: min(5.2vw, 2rem);
    line-height: 1;
    font-weight: 500;
    color: #fff;
  }
  .ocguide-menu-btn a p::after {
    position: absolute;
    content: "";
    width: 21px;
    height: 21px;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    background: URL("../images/base/ico_arrow-l_wh.svg");
    background-size: cover;
  }
  .ocguide-menu-btn a .icon {
    position: absolute;
    top: inherit;
    left: 25px;
  }
  .ocguide-menu-btn a:hover {
    opacity: 0.7;
  }
  .ocguide-menu-btn.-btn01 .icon {
    left: 18px;
    width: 30px;
    height: 25px;
    background: URL("../images/base/ico_menu_01.svg") 0 0;
    background-size: cover;
  }
  .ocguide-menu-btn.-btn01 p {
    margin-left: 35px;
    padding-right: 30px;
  }
  .ocguide-menu-btn.-btn02 .icon {
    width: 27px;
    height: 34px;
    background: URL("../images/base/ico_menu_02.svg") 0 0;
    background-size: cover;
  }
  .line01-ocguide-wrap {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    top: -20px;
  }
  .line02-ocguide-wrap {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-top: -14.5%;
  }
  .a-article.item-ocguide-01 {
    top: -30px;
    left: 40px;
    width: 50px;
  }
  .a-article.item-ocguide-02 {
    top: -100px;
    right: 40px;
    width: 50px;
  }
  /* ==========
    14 ogob
  ========================================================================== */
  .ogob-list {
    margin-bottom: -25px;
    -ms-grid-columns: 1fr 17px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px 17px;
  }
  .ogob-item-thumb {
    aspect-ratio: 164/125;
  }
  .ogob-item-thumb img {
    aspect-ratio: 164/125;
  }
  .ogob-item-name {
    font-size: 1.2rem;
    line-height: 1.5;
  }
  .ogob-item-name .-txt01 {
    color: #E70012;
  }
  .ogob-item-name .-txt02 {
    font-size: 1.4rem;
  }
  .ogob-item-name .-txt03 {
    margin-left: 5px;
  }
  .ogob-item-lead {
    padding-bottom: 20px;
    font-size: 1.2rem;
    line-height: 2.08;
  }
  /* ==========
    14_ ogob_details
  ========================================================================== */
  .ogob-detail-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .ogob-detail-thumb {
    aspect-ratio: 345/278;
    max-width: 345px;
    height: auto;
  }
  .ogob-detail-thumb img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .ogob-detail-content {
    width: auto;
    margin-left: inherit;
  }
  .ogob-detail-title {
    margin-top: 25px;
    font-size: min(5.35vw, 2rem);
    font-weight: bold;
    line-height: 1.75;
    min-height: inherit;
  }
  .ogob-detail-name {
    margin-top: 20px;
    font-size: min(4vw, 1.4rem);
    line-height: 1.4;
  }
  .ogob-detail-name .-txt01 {
    margin-bottom: 5px;
  }
  .ogob-detail-name .-txt02 {
    font-size: min(5.35vw, 2rem);
  }
  .ogob-detail-name .-txt03 {
    margin-left: 15px;
  }
  .ogob-detail-lead {
    margin: 30px 0;
    line-height: 2.1875;
  }
  .ogob-sonota {
    margin-top: 70px;
  }
  .ogob-sonota .ogob-list {
    margin-top: 30px;
  }
  /* ==========
    23 お知らせ /news/
  ========================================================================== */
  /* news */
  .cat-menu-wrap {
    display: none;
  }
  .cat-menu-select {
    display: block;
    padding: 0 10px;
    width: 200px;
    background-color: #fff;
    color: #212121;
  }
  .cat-menu-select dt {
    position: relative;
    height: 40px;
    line-height: 40px;
    cursor: pointer;
  }
  .cat-menu-select dt::before {
    position: relative;
    content: "カテゴリから探す";
  }
  .cat-menu-select dt::after {
    position: absolute;
    content: "";
    top: 50%;
    right: 0;
    width: 5px;
    height: 5px;
    border-right: 1px solid #212121;
    border-bottom: 1px solid #212121;
    -webkit-transform: translateY(-50%) rotate(45deg);
            transform: translateY(-50%) rotate(45deg);
  }
  .cat-menu-select dt.is-active::before {
    content: "All";
  }
  .cat-menu-select dt.is-active::after {
    position: absolute;
    content: "";
    top: 50%;
    right: 0;
    width: 5px;
    height: 5px;
    border-right: none;
    border-bottom: none;
    border-left: 1px solid #212121;
    border-top: 1px solid #212121;
    -webkit-transform: translateY(-50%) rotate(45deg);
            transform: translateY(-50%) rotate(45deg);
  }
  .cat-menu-select dd {
    display: none;
    padding-top: 5px;
    padding-bottom: 15px;
    border-top: dashed 1px #212121;
  }
  .cat-menu-select a {
    display: block;
    padding: 3px 0;
    color: #212121;
  }
  .news-list {
    margin: 35px auto;
  }
  .news-list li {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 15px 0;
    border-bottom: 1px solid #707070;
    min-height: 80px;
  }
  .news-list li > a {
    width: calc(100% - 20px);
    margin-top: 0px;
  }
  .news-list-meta {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .news-list-date {
    width: 60px;
  }
  .news-list-cat {
    margin-left: 5px;
  }
  .news-list-cat-wrap {
    width: inherit;
  }
  .news-list-cat > a {
    margin-top: 4px;
    padding: 2px 5px;
    width: inherit;
  }
  .news-list-text {
    display: block;
    padding-right: 20px;
    margin-left: 0;
  }
  /* pagenavi */
  .wp-pagenavi {
    margin: 60px auto 70px;
    padding-bottom: 0;
  }
  .wp-pagenavi a, .wp-pagenavi span {
    width: 40px;
    height: 40px;
    margin-top: 10px;
    margin-right: 5px;
    margin-left: 5px;
    line-height: 38px;
    font-size: 1.4rem;
  }
  .prev::before {
    width: 7px;
    height: 7px;
    border-bottom: 1px solid #000;
    border-left: 1px solid #000;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  .prev:hover::before {
    border-bottom: 1px solid #fff;
    border-left: 1px solid #fff;
  }
  .next::before {
    width: 7px;
    height: 7px;
    border-top: 1px solid #000;
    border-right: 1px solid #000;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  .next:hover::before {
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
  }
  /* post */
  .post-title {
    margin-top: 15px;
    font-size: 2rem;
    line-height: 1.75;
  }
  .post-body {
    margin: 40px 0 30px;
    /* p a, table a, li a,
     .wp-block-file a{ //link設定共通
      position: relative;
      color: #283593;
      border-bottom: solid 1px #283593;
      &:hover{
        border-bottom: solid 1px rgba(255,255,255, 0.5);
        }
      }
     */
  }
  .post-body img {
    margin-bottom: 35px;
  }
  .post-body p {
    margin-bottom: 2em;
    line-height: 2.142;
  }
  .post-body h2 {
    font-size: 1.6rem;
    line-height: 1.75;
  }
  .post-body h3 {
    font-size: 1.6rem;
  }
  .post-body h3::before {
    height: 90%;
  }
  .post-body .alignleft {
    float: left;
    margin-right: 45px;
    margin-bottom: 45px;
  }
  .post-body .alignright {
    float: right;
    margin-left: 45px;
    margin-bottom: 45px;
  }
  .post-body .aligncenter {
    margin: 40px auto;
    text-align: center;
  }
  .post-body .wp-block-file a.wp-block-file__button {
    color: #fff !important;
  }
  .post-body em {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(65%, transparent), color-stop(65%, #FFF33F));
    background: linear-gradient(transparent 65%, #FFF33F 65%);
    font-style: normal;
    font-weight: normal;
  }
  .post-body pre {
    padding: 1em 1.5em;
    line-height: 2.142;
  }
  .post-body table {
    margin: 40px 0;
  }
  .post-body table th {
    background-color: #f5f5f5;
    padding: 20px 20px;
    color: #333;
    border: solid 1px #e0e0e0;
    font-weight: bold;
    width: 250px;
    line-height: 2;
  }
  .post-body table td {
    padding: 20px 20px;
    border: solid 1px #e0e0e0;
    color: #333;
    line-height: 2;
    word-break: break-word;
  }
  .post-body ul {
    margin: 20px 0;
  }
  .post-body ul li {
    margin-bottom: 0.5em;
    margin-left: 1.5em;
    line-height: 1.35;
    list-style-type: disc;
  }
  .post-body ul li ul {
    margin: 0.5em 0;
  }
  .post-body ol {
    margin: 40px auto;
    padding: 22px 26px;
    counter-reset: list-count;
    list-style: none;
    background-color: #fff;
  }
  .post-body ol li {
    margin-bottom: 0.5em;
    margin-left: 1em;
    text-indent: -1.5em;
  }
  .post-body ol li::before {
    font-size: 1.6rem;
  }
  /* ==========
    26 アクセス /access/
  ========================================================================== */
  .access-info {
    margin: 30px auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 0;
       -moz-column-gap: 0;
            column-gap: 0;
  }
  .access-info-map {
    width: 100%;
  }
  .access-info-content {
    width: 100%;
    margin-bottom: 15px;
  }
  .access-info-logo {
    padding-bottom: 20px;
  }
  .access-info-logo img {
    width: 290px;
  }
  .access-info-data {
    margin-top: 20px;
  }
  .access-info-data dl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .access-info-data dt {
    width: 100%;
    margin-bottom: 10px;
    font-size: min(4.8vw, 1.6rem);
  }
  .access-info-data dd {
    font-size: 1.4rem;
    line-height: 1.7857;
  }
  .access-spot {
    margin-top: 70px;
    margin-bottom: -10px;
  }
  .access-spot-items {
    margin-top: 25px;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 50px;
  }
  .access-spot-item-image img {
    width: 100%;
    aspect-ratio: 345/220;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .access-spot-item-title {
    margin-top: 25px;
  }
  /* ==========
    27 プライバシーポリシー /privacy/
  ========================================================================== */
  /* privacy */
  .privacy-area {
    padding: 35px 15px;
    margin-bottom: -10px;
  }
  .privacy-body h2 {
    font-size: 1.6rem;
  }
  .privacy-body h3 {
    margin-top: 35px;
    font-size: 1.6rem;
  }
  .privacy-body p {
    margin-top: 15px;
    line-height: 1.785;
  }
  /* ==========
    25  情報公開/information/
  ========================================================================== */
  .information-area {
    margin-bottom: -30px;
  }
  /* ==========
    31  企業の方へ　/company/
  ========================================================================== */
  .company-content {
    margin-top: 55px;
  }
  .company-text {
    margin-top: 20px;
    line-height: 2.1428;
  }
  /* ==========
    28  保護者の方へ　/parent/
  ========================================================================== */
  .parent-content {
    margin-top: 60px;
  }
  .parent-title {
    font-size: 2rem;
    padding-bottom: 10px;
  }
  .parent-text {
    margin-top: 20px;
    margin-bottom: 35px;
    line-height: 2.1428;
  }
  /* ==========
    10_ 交通費補助　/opencampus/support/
  ========================================================================== */
  .oc-support-content {
    width: 100%;
  }
  .oc-support-text {
    margin-top: 20px;
    line-height: 2.1428;
  }
  /* .m-data-table */
  /* ==========
    29_ 既卒生の方へ /alumnus/
    30_ 県外から進学を目指す方へ　/outside/
  ========================================================================== */
  .section-voice-item {
    margin-top: 60px;
  }
  .voice-items {
    margin-top: 25px;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 35px 40px;
  }
  .voice-item {
    padding: 20px 15px 15px;
    background-color: #fff;
  }
  .voice-item-head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .voice-item-head-image {
    margin-right: 15px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: 73px;
    height: 94px;
  }
  .voice-item-head-image img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .voice-item-head-title {
    margin-top: 0;
    font-size: 1.6rem;
    line-height: 1.375;
  }
  .voice-item-head-text {
    margin-top: 0;
    font-size: 1.2rem;
    line-height: 1.5;
  }
  .voice-item-head-name {
    margin-top: 15px;
    text-align: left;
    font-size: 1.2rem;
    line-height: 1.25;
  }
  .voice-item-head-name .-small {
    font-size: 1rem;
  }
  .voice-item-body {
    position: relative;
    margin-top: 5px;
    background-image: linear-gradient(90deg, transparent 0%, transparent 50%, #fff 50%, #fff 100%), linear-gradient(180deg, #DBDBDB 1px, transparent 1px);
    background-size: 4px 100%, 100% 2.857em;
    line-height: 2.857em; /* 文字の高さ */
    padding-bottom: 5px;
  }
  .voice-item-body::before {
    position: absolute;
    content: "";
    top: 0;
    width: 100%;
    height: 2px;
    background-color: #fff;
  }
  /* ==========
    24 お問い合わせ /contact/
  ========================================================================== */
  .contact-head {
    margin: 10px auto 20px;
    max-width: 836px;
  }
  .form-steps-list {
    margin: 0 -10px;
  }
  .form-steps-list li {
    padding: 0 8px;
    font-size: min(3.8vw, 1.4rem);
  }
  .form-steps-list li .num {
    font-size: 1.6rem;
  }
  .form-lead-image {
    margin: 0 auto 20px;
  }
  .form-lead-title {
    margin: 20px auto 30px;
    font-size: 2rem;
    font-weight: bold;
    line-height: 1.2;
    text-align: center;
  }
  .form-lead-text {
    margin: 20px auto;
  }
  .form-lead-text p {
    margin-bottom: 1em;
    line-height: 1.875;
  }
  .form-lead .btn-more {
    margin: 80px auto;
  }
  .contact-body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .contact-aside {
    margin-right: inherit;
    width: 100%;
    line-height: 2.14;
  }
  .confirm-area .form-items {
    padding: 0 10px;
  }
  .confirm-area .form-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 30px 0;
  }
  .confirm-area .form-item-name {
    width: min(31vw, 120px);
    margin-right: min(8vw, 90px);
    text-align: right;
    font-size: 1.4rem;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    padding-left: 0;
  }
  .confirm-area .form-item-input {
    padding: 0;
    max-width: 450px;
    font-size: 1.4rem;
  }
  /* form ------------ */
  .form-area {
    margin-top: 20px;
  }
  .form-item {
    margin-top: 22px;
    border-bottom: solid 1px #707070;
  }
  .form-item-name {
    padding-left: 50px;
  }
  .form-item-input {
    padding: 10px 0 15px;
  }
  .form-item-input .radio-field-text .wpcf7-list-item {
    margin: 0 0 0 1em;
  }
  .form-item-input .check-field-text .wpcf7-list-item {
    margin: 0 0 0 1em;
  }
  .form-item-input .tate-field-text .wpcf7-list-item {
    margin-left: 1em;
  }
  .form-item input, .form-item textarea {
    font-size: 1.4rem;
  }
  .wpcf7-list-item.first {
    margin-left: 1em !important;
  }
  input[type=radio] {
    width: 15px;
    height: 15px;
    padding: 0;
  }
  input[type=radio]::after {
    width: 7px;
    height: 7px;
    margin-top: -3.5px;
    margin-left: -3.5px;
  }
  input[type=checkbox] {
    width: 15px;
    height: 15px;
    padding: 0;
    border-radius: 0;
  }
  input[type=checkbox]::after {
    left: 4px;
    width: 6px;
    height: 10px;
  }
  .form-button {
    display: block;
    width: 260px;
    margin: 50px auto 0;
  }
  .form-button .btn-more, .form-button .btn-prev {
    padding: 0;
    margin-top: 20px;
    width: 260px;
    height: 65px;
  }
  /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  テーブル
  +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
  /*
  .data-tbl-column{
  dt{
  	display:block; width:100%;
  	padding:5px 10px;
  	border-top:solid 1px #e8e3e0;
  	border-right:solid 1px #e8e3e0;
  	border-bottom:none;
  	border-left:solid 1px #e8e3e0;
  	&.dt-thin{width:100%;
  	}
  }
  dd{
  	display:block; width:100%;}
  }
  .data-tbl tbody th {
  	width: 30%;
  	padding: 14px;
  	font-size: 1.4rem;
  }
  .data-tbl td {
  	padding: 14px;
  	font-size: 1.4rem;
  	}

  .data-tbl-title{
  	font-size: 1.4rem;
  }
  */
  .m-data-table {
    margin-top: 35px;
    padding: 33px 11px 10px 11px;
  }
  .m-data-table > dl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-bottom: 25px;
    padding-bottom: 22px;
    font-size: 1.4rem;
  }
  .m-data-table > dl.-last {
    border-bottom: none;
  }
  .m-data-table > dl > dt {
    width: 100%;
    text-align: left;
    font-size: 1.6rem;
  }
  .m-data-table > dl > dd {
    margin-left: 0;
    margin-top: 15px;
  }
  .m-data-table .icon-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 15px;
  }
  .m-data-table .icon-item .icon {
    background-color: #E83928;
    width: 35px;
    height: 35px;
  }
  .m-data-table .icon-item-text {
    margin-left: 10px;
    font-weight: bold;
  }
  .m-sub-table {
    margin-top: 0px;
    padding: 10px 7px 5px 7px;
  }
  .m-sub-table > dl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-column-gap: 0;
       -moz-column-gap: 0;
            column-gap: 0;
    margin-bottom: 10px;
    padding-bottom: 10px;
    padding-left: 0;
    padding-right: 0;
  }
  .m-sub-table > dl.-head {
    padding-bottom: 5px;
  }
  .m-sub-table > dl.-head > dd {
    font-size: 1.4rem;
  }
  .m-sub-table > dl > dd {
    margin-top: 5px;
    width: 100%;
    -webkit-column-gap: 7px;
       -moz-column-gap: 7px;
            column-gap: 7px;
    font-size: 1.2rem;
  }
  .m-sub-table > dl > dd .-cell1 {
    width: 66%;
  }
  /* Slider */
  .slider-area {
    width: 100%;
    height: inherit; /*320px;*/
    overflow: hidden;
  }
  .slider-area .slide_arrow {
    width: 30px;
    height: 30px;
    margin-top: -15px;
  }
  .slider-area .slide_arrow.l {
    margin-left: calc(-50% + 5px);
  }
  .slider-area .slide_arrow.r {
    margin-left: calc(50% - 35px);
  }
  /* slide-item */
  .slide-item {
    height: auto;
  }
  .slick-slide {
    margin: 10px 40px;
  }
  .slick-slide img {
    /*	width:100%;
    	max-width:375px;
    	height:auto;*/
  }
  .slider-txt {
    margin-bottom: 20px;
    position: relative;
    bottom: 0;
    font-size: 1.3rem;
  }
  .slide-head {
    margin-bottom: 20px;
  }
  .slide-number.en {
    font-size: 3rem;
  }
  .slide-title {
    font-size: 1.6rem;
  }
  .slide-image {
    float: none;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 20px;
    text-align: center;
  }
  /* helper */
  .m-mt-30 {
    margin-top: 15px;
  }
  .m-mt-40 {
    margin-top: 20px;
  }
  .m-mt-50 {
    margin-top: 25px;
  }
  .m-mt-80 {
    margin-top: 40px;
  }
  .bc-wh {
    background-color: #fff !important;
  }
  .btn-wrap {
    margin-top: 15px;
    margin-bottom: 15px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
  }
  .btn-wrap-c a {
    margin: 20px auto;
  }
  .txt-l-sp {
    text-align: left !important;
  }
  .m-pc-only,
  .br-pc {
    display: none !important;
  }
  .m-sp-only,
  .br-sp {
    display: block !important;
  }
  .no-sp {
    display: none;
  }
}
@media all and (-ms-high-contrast: none) and (max-width: 768px) {
  .m-column-cont {
    margin-top: 200px !important; /* IE10以上 */
  }
}
@-webkit-keyframes scroll-hint-appear {
  0% {
    -webkit-transform: translateX(40px);
            transform: translateX(40px);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  50%, 100% {
    -webkit-transform: translateX(-40px);
            transform: translateX(-40px);
    opacity: 0;
  }
}
@keyframes scroll-hint-appear {
  0% {
    -webkit-transform: translateX(40px);
            transform: translateX(40px);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  50%, 100% {
    -webkit-transform: translateX(-40px);
            transform: translateX(-40px);
    opacity: 0;
  }
}
.scroll-hint.is-right-scrollable {
  background: linear-gradient(270deg, rgba(0, 0, 0, 0.15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
}

.scroll-hint.is-right-scrollable.is-left-scrollable {
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0)), linear-gradient(270deg, rgba(0, 0, 0, 0.15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
}

.scroll-hint.is-left-scrollable {
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
}

.scroll-hint-icon {
  position: absolute;
  top: calc(50% - 25px);
  left: calc(50% - 60px);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 120px;
  height: 80px;
  border-radius: 5px;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  opacity: 0;
  background: rgba(0, 0, 0, 0.7);
  text-align: center;
  padding: 20px 10px 10px 10px;
}

.scroll-hint-icon-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  max-height: 100%;
  pointer-events: none;
}

.scroll-hint-text {
  font-size: 10px;
  color: #FFF;
  margin-top: 5px;
}

.scroll-hint-icon-wrap.is-active .scroll-hint-icon {
  opacity: 0.8;
}

.scroll-hint-icon:before {
  display: inline-block;
  width: 40px;
  height: 40px;
  color: #FFF;
  vertical-align: middle;
  text-align: center;
  content: "";
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNS43NyIgaGVpZ2h0PSIzMC41MiIgdmlld0JveD0iMCAwIDI1Ljc3IDMwLjUyIj48dGl0bGU+44Ki44K744OD44OIIDM8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxwYXRoIGQ9Ik0yMS4zMywzMC41Mkg3Ljg1QTEuNTUsMS41NSwwLDAsMSw2LjMsMjlhMTIuNDYsMTIuNDYsMCwwLDAtLjYzLTQuNDIsMjUuMTYsMjUuMTYsMCwwLDAtNC4yNS01bC0uMDYtLjA2QTUsNSwwLDAsMSwwLDE1Ljg2YTMuNjQsMy42NCwwLDAsMSwxLjE3LTIuNjIsMy42MywzLjYzLDAsMCwxLDUuMTQuMDdWMy43N2EzLjc3LDMuNzcsMCwxLDEsNy41NCwwVjguMzNhMy4zNSwzLjM1LDAsMCwxLDEuMjYsMCwzLDMsMCwwLDEsMiwxLjIyLDMuNSwzLjUsMCwwLDEsMi0uMDYsMy4yMSwzLjIxLDAsMCwxLDIsMS41NCwzLjc0LDMuNzQsMCwwLDEsMywuNDdBNC4yMSw0LjIxLDAsMCwxLDI1Ljc0LDE1YzAsLjExLDAsLjI3LDAsLjQ2YTE5LjI2LDE5LjI2LDAsMCwxLS44NCw3Yy0uMTQuMzgtLjM2LjgxLS41NiwxLjIybC0uMTEuMjJjMCwuMDctLjA5LjE0LS4xNC4yMWE3LjEzLDcuMTMsMCwwLDAtMS4xNywyLjE3Yy0uMDYuNTYtLjA2LDIuMTUtLjA1LDIuNzFBMS41NSwxLjU1LDAsMCwxLDIxLjMzLDMwLjUyWk04LjYxLDI4LjIxaDEyYzAtLjcxLDAtMS43MS4wNy0yLjIzYTguNzQsOC43NCwwLDAsMSwxLjU5LTMuMjVsLjA2LS4xMmExMCwxMCwwLDAsMCwuNDYtMSwxNi44LDE2LjgsMCwwLDAsLjctNi4xMmMwLS4yMywwLS40MSwwLS41NGgwYTIsMiwwLDAsMC0uNjQtMS41MiwxLjMzLDEuMzMsMCwwLDAtMS41NS4wOCwxLjEzLDEuMTMsMCwwLDEtMS4xOC4yOCwxLjE1LDEuMTUsMCwwLDEtLjc4LS45NCwxLjI2LDEuMjYsMCwwLDAtLjc1LTEuMTEsMSwxLDAsMCwwLTEuMTEuMjhsLS4xLjFhMS4xNSwxLjE1LDAsMCwxLTEuMTkuMjksMS4xNiwxLjE2LDAsMCwxLS43OC0uOTVjLS4wOS0uNjgtLjIxLS43Ny0uNy0uODdhLjgyLjgyLDAsMCwwLTEsLjQ4LDEuMTYsMS4xNiwwLDAsMS0yLjE2LS41OFYzLjc3YTEuNDYsMS40NiwwLDEsMC0yLjkyLDB2Ny44NWwwLDQuMzNhMS4xNywxLjE3LDAsMCwxLS44MywxLjExLDEuMTUsMS4xNSwwLDAsMS0xLjItLjM1bC0xLS45MWMtLjQ3LS40Mi0uNzMtLjY2LS44NC0uNzdhMS4zNSwxLjM1LDAsMCwwLTItLjEyTDIuNywxNWExLjMyLDEuMzIsMCwwLDAtLjM5LDFBMi41NywyLjU3LDAsMCwwLDMsMTcuODVsMCwwYTI3LjI0LDI3LjI0LDAsMCwxLDQuNyw1LjYyQTEyLjYzLDEyLjYzLDAsMCwxLDguNjEsMjguMjFaTTIzLjIsMjMuMzVaTTYuNTEsMTYuNTlaIiBmaWxsPSIjZmZmIi8+PC9nPjwvZz48L3N2Zz4=);
}

.scroll-hint-icon:after {
  content: "";
  width: 34px;
  height: 14px;
  display: block;
  position: absolute;
  top: 10px;
  left: 50%;
  margin-left: -20px;
  background-repeat: no-repeat;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMy4yOSIgaGVpZ2h0PSIxMi4wMiIgdmlld0JveD0iMCAwIDMzLjI5IDEyLjAyIj48dGl0bGU+44Ki44K744OD44OIIDE8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxsaW5lIHgxPSIxLjg1IiB5MT0iNi4wMSIgeDI9IjEwLjQiIHkyPSI2LjAxIiBmaWxsPSIjZmZmIi8+PHBhdGggZD0iTTEwLjQsNy4xN0gxLjg1YTEuMTYsMS4xNiwwLDEsMSwwLTIuMzFIMTAuNGExLjE2LDEuMTYsMCwxLDEsMCwyLjMxWiIgZmlsbD0iI2ZmZiIvPjxwYXRoIGQ9Ik03LjQsMTJhMS4xNSwxLjE1LDAsMCwxLS43Mi0uMjVsLTYuMjUtNUExLjIsMS4yLDAsMCwxLDAsNS44NywxLjE0LDEuMTQsMCwwLDEsLjQ2LDVMNi43LjIzQTEuMTYsMS4xNiwwLDAsMSw4LjEsMi4wOEwzLDUuOTEsOC4xMiwxMEExLjE2LDEuMTYsMCwwLDEsNy40LDEyWiIgZmlsbD0iI2ZmZiIvPjxsaW5lIHgxPSIzMS40NSIgeTE9IjYuMDEiIHgyPSIyMi44OSIgeTI9IjYuMDEiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNMzEuNDUsNy4xN0gyMi44OWExLjE2LDEuMTYsMCwxLDEsMC0yLjMxaDguNTZhMS4xNiwxLjE2LDAsMCwxLDAsMi4zMVoiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNMjUuOSwxMmExLjE4LDEuMTgsMCwwLDEtLjkxLS40M0ExLjE3LDEuMTcsMCwwLDEsMjUuMTcsMTBsNS4wOS00LjA1TDI1LjIsMi4wOEExLjE2LDEuMTYsMCwwLDEsMjYuNTkuMjNMMzIuODQsNWExLjE2LDEuMTYsMCwwLDEsLjQ1LjkxLDEuMTQsMS4xNCwwLDAsMS0uNDMuOTJsLTYuMjQsNUExLjE3LDEuMTcsMCwwLDEsMjUuOSwxMloiIGZpbGw9IiNmZmYiLz48L2c+PC9nPjwvc3ZnPg==);
  opacity: 0;
  -webkit-transition-delay: 2.4s;
          transition-delay: 2.4s;
}

.scroll-hint-icon-wrap.is-active .scroll-hint-icon:after {
  opacity: 1;
}

.scroll-hint-icon-wrap.is-active .scroll-hint-icon:before {
  -webkit-animation: scroll-hint-appear 1.2s linear;
          animation: scroll-hint-appear 1.2s linear;
  -webkit-animation-iteration-count: 2;
          animation-iteration-count: 2;
}

.scroll-hint-icon-white {
  background-color: #FFF;
  -webkit-box-shadow: 0 4px 5px rgba(0, 0, 0, 0.4);
          box-shadow: 0 4px 5px rgba(0, 0, 0, 0.4);
}

.scroll-hint-icon-white:before {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNS43NyIgaGVpZ2h0PSIzMC41MiIgdmlld0JveD0iMCAwIDI1Ljc3IDMwLjUyIj48dGl0bGU+44Ki44K744OD44OIIDQ8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxwYXRoIGQ9Ik0yMS4zMywzMC41Mkg3Ljg1QTEuNTUsMS41NSwwLDAsMSw2LjMsMjlhMTIuNDYsMTIuNDYsMCwwLDAtLjYzLTQuNDIsMjUuMTYsMjUuMTYsMCwwLDAtNC4yNS01bC0uMDYtLjA2QTUsNSwwLDAsMSwwLDE1Ljg2YTMuNjQsMy42NCwwLDAsMSwxLjE3LTIuNjIsMy42MywzLjYzLDAsMCwxLDUuMTQuMDdWMy43N2EzLjc3LDMuNzcsMCwxLDEsNy41NCwwVjguMzNhMy4zNSwzLjM1LDAsMCwxLDEuMjYsMCwzLDMsMCwwLDEsMiwxLjIyLDMuNSwzLjUsMCwwLDEsMi0uMDYsMy4yMSwzLjIxLDAsMCwxLDIsMS41NCwzLjc0LDMuNzQsMCwwLDEsMywuNDdBNC4yMSw0LjIxLDAsMCwxLDI1Ljc0LDE1YzAsLjExLDAsLjI3LDAsLjQ2YTE5LjI2LDE5LjI2LDAsMCwxLS44NCw3Yy0uMTQuMzgtLjM2LjgxLS41NiwxLjIybC0uMTEuMjJjMCwuMDctLjA5LjE0LS4xNC4yMWE3LjEzLDcuMTMsMCwwLDAtMS4xNywyLjE3Yy0uMDYuNTYtLjA2LDIuMTUtLjA1LDIuNzFBMS41NSwxLjU1LDAsMCwxLDIxLjMzLDMwLjUyWk04LjYxLDI4LjIxaDEyYzAtLjcxLDAtMS43MS4wNy0yLjIzYTguNzQsOC43NCwwLDAsMSwxLjU5LTMuMjVsLjA2LS4xMmExMCwxMCwwLDAsMCwuNDYtMSwxNi44LDE2LjgsMCwwLDAsLjctNi4xMmMwLS4yMywwLS40MSwwLS41NGgwYTIsMiwwLDAsMC0uNjQtMS41MiwxLjMzLDEuMzMsMCwwLDAtMS41NS4wOCwxLjEzLDEuMTMsMCwwLDEtMS4xOC4yOCwxLjE1LDEuMTUsMCwwLDEtLjc4LS45NCwxLjI2LDEuMjYsMCwwLDAtLjc1LTEuMTEsMSwxLDAsMCwwLTEuMTEuMjhsLS4xLjFhMS4xNSwxLjE1LDAsMCwxLTEuMTkuMjksMS4xNiwxLjE2LDAsMCwxLS43OC0uOTVjLS4wOS0uNjgtLjIxLS43Ny0uNy0uODdhLjgyLjgyLDAsMCwwLTEsLjQ4LDEuMTYsMS4xNiwwLDAsMS0yLjE2LS41OFYzLjc3YTEuNDYsMS40NiwwLDEsMC0yLjkyLDB2Ny44NWwwLDQuMzNhMS4xNywxLjE3LDAsMCwxLS44MywxLjExLDEuMTUsMS4xNSwwLDAsMS0xLjItLjM1bC0xLS45MWMtLjQ3LS40Mi0uNzMtLjY2LS44NC0uNzdhMS4zNSwxLjM1LDAsMCwwLTItLjEyTDIuNywxNWExLjMyLDEuMzIsMCwwLDAtLjM5LDFBMi41NywyLjU3LDAsMCwwLDMsMTcuODVsMCwwYTI3LjI0LDI3LjI0LDAsMCwxLDQuNyw1LjYyQTEyLjYzLDEyLjYzLDAsMCwxLDguNjEsMjguMjFaTTIzLjIsMjMuMzVaTTYuNTEsMTYuNTlaIi8+PC9nPjwvZz48L3N2Zz4=);
}

.scroll-hint-icon-white:after {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMy4yOSIgaGVpZ2h0PSIxMi4wMiIgdmlld0JveD0iMCAwIDMzLjI5IDEyLjAyIj48dGl0bGU+44Ki44K744OD44OIIDI8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxsaW5lIHgxPSIxLjg1IiB5MT0iNi4wMSIgeDI9IjEwLjQiIHkyPSI2LjAxIi8+PHBhdGggZD0iTTEwLjQsNy4xN0gxLjg1YTEuMTYsMS4xNiwwLDEsMSwwLTIuMzFIMTAuNGExLjE2LDEuMTYsMCwxLDEsMCwyLjMxWiIvPjxwYXRoIGQ9Ik03LjQsMTJhMS4xNSwxLjE1LDAsMCwxLS43Mi0uMjVsLTYuMjUtNUExLjIsMS4yLDAsMCwxLDAsNS44NywxLjE0LDEuMTQsMCwwLDEsLjQ2LDVMNi43LjIzQTEuMTYsMS4xNiwwLDAsMSw4LjEsMi4wOEwzLDUuOTEsOC4xMiwxMEExLjE2LDEuMTYsMCwwLDEsNy40LDEyWiIvPjxsaW5lIHgxPSIzMS40NSIgeTE9IjYuMDEiIHgyPSIyMi44OSIgeTI9IjYuMDEiLz48cGF0aCBkPSJNMzEuNDUsNy4xN0gyMi44OWExLjE2LDEuMTYsMCwxLDEsMC0yLjMxaDguNTZhMS4xNiwxLjE2LDAsMCwxLDAsMi4zMVoiLz48cGF0aCBkPSJNMjUuOSwxMmExLjE4LDEuMTgsMCwwLDEtLjkxLS40M0ExLjE3LDEuMTcsMCwwLDEsMjUuMTcsMTBsNS4wOS00LjA1TDI1LjIsMi4wOEExLjE2LDEuMTYsMCwwLDEsMjYuNTkuMjNMMzIuODQsNWExLjE2LDEuMTYsMCwwLDEsLjQ1LjkxLDEuMTQsMS4xNCwwLDAsMS0uNDMuOTJsLTYuMjQsNUExLjE3LDEuMTcsMCwwLDEsMjUuOSwxMloiLz48L2c+PC9nPjwvc3ZnPg==);
}

.scroll-hint-icon-white .scroll-hint-text {
  color: #000;
}
div.cat-miniopen span {
  background-color: #ffd83d !important;
  color: #000000 !important;
}
.top_img {
  margin: 0 auto 3em auto;
  display: block;
  width: 80%;
}
.top_img img{
  width: 100%;
  max-width:100%;
}
/* オープンキャンパスお申し込みの際の必須項目未入力の警告文 */
@keyframes slowBlink {
    0% { opacity: 1; }
    50% { opacity: 0.3; }
    100% { opacity: 1; }
}

.wpcf7 form.invalid .wpcf7-response-output {
    color: #BC0312;
    border: none;
    font-weight: bold;
    font-size: 1.1em;
    animation: slowBlink 2s infinite;
  padding: 0;
  margin: 1em 0;
}
@media screen and (max-width: 767px){
.wpcf7 form.invalid .wpcf7-response-output {
  font-size: 3.5vw;
}
}
.top_img img {
  transition: opacity 0.5s ease;
}
.top_img img:hover {
  opacity: 0.6; /* 少し透過して白っぽく */
}
/* 問い合わせの際の確認画面用 */
.map-it-link{
  position: relative;
  display: inline-block;
  margin: 0.5em 0;
  color: transparent !important;
  text-decoration: none;
  overflow: visible;
  white-space: nowrap;
}
.map-it-link::before{
  content: "住所地図";
  position: absolute;
  left: 0;
  top: 0;
  font-size: 14px;
  line-height: 1;
  color: #fff;
  display: inline-block;
  pointer-events: none;
  background:#E70012;
  padding:0.3em 0.5em;
  border-radius:5px;
}
#gform_confirmation_message_1 table td{
padding: 0.5em;
}

/* お申し込みフォームの特定日の表示・非表示用 */
.is-hidden {
  display: none;
}
.gakka-radio-label {
  display: block;
  margin-bottom: 8px;
  cursor: pointer;
}

.gakka-radio-label input {
  margin-right: 6px;
}

