@charset "UTF-8";

:root {
--sociology02-color: #333333;
--sociology02-bgcolor: #ffea00;
}

.l-container {
  position: relative; }

.p-container-title {
  line-height: 1;
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  @media screen and (max-width: 520px) {
    .p-container-title {
      font-size: 16px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container-title {
      font-size: 26px; } }
  @media screen and (min-width: 1025px) {
    .p-container-title {
      font-size: 35px; } }
  @media screen and (max-width: 520px) {
    .p-container-title {
      white-space: nowrap; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container-title {
      white-space: nowrap; } }
  .p-container-title .title-lead {
    display: block;
    padding: 0 0 .5em; }
    @media screen and (max-width: 520px) {
      .p-container-title .title-lead {
        font-size: 22px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container-title .title-lead {
        font-size: 26px; } }
    @media screen and (min-width: 1025px) {
      .p-container-title .title-lead {
        font-size: 45px; } }
    @media screen and (max-width: 520px) {
      .p-container-title .title-lead {
        white-space: nowrap; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container-title .title-lead {
        white-space: nowrap; } }
  .p-container-title .title-small {
	  display: block;
	  white-space: normal;
	  line-height: 1.6;
  }
  .p-container-title .title-small:not(:last-of-type) {
	  margin: 1rem 0 0;
  }
  @media screen and (max-width: 520px) {
      .p-container-title .title-small {
        font-size: 12px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container-title .title-small {
        font-size: 14px; } }
    @media screen and (min-width: 1025px) {
      .p-container-title .title-small {
        font-size: 16px; } }

.p-container-subtitle {
  margin-bottom: 30px;
  padding-bottom: .5em;
  text-align: center;
  position: relative;
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  @media screen and (max-width: 520px) {
    .p-container-subtitle {
      font-size: 22px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container-subtitle {
      font-size: 25px; } }
  @media screen and (min-width: 1025px) {
    .p-container-subtitle {
      font-size: 27px; } }
  .p-container-subtitle::after {
    content: '';
    height: 2px;
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 0); }
    @media screen and (max-width: 520px) {
      .p-container-subtitle::after {
        width: 40px;
        background-size: 12px 2px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container-subtitle::after {
        width: 50px;
        background-size: 15px 2px; } }
    @media screen and (min-width: 1025px) {
      .p-container-subtitle::after {
        width: 60px;
        background-size: 18px 2px; } }

.p-container-text {
	padding-bottom: 2em; }
	
.p-container-desc {
  padding-bottom: 2em;
  line-height: 1.8; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container-desc {
      max-width: 700px;
      margin-left: auto;
      margin-right: auto; } }
  @media screen and (min-width: 1025px) {
    .p-container-desc {
      max-width: 1100px;
      margin-left: auto;
      margin-right: auto; } }

.p-container .dep-list {
  padding-bottom: 2em; } 
	.p-container .dep-list .dep-list-item {
      padding-left: 1em;
      position: relative; }
      .p-container .dep-list .dep-list-item::before {
        content: '';
        width: .6em;
        height: .6em;
        border-radius: 50%;
        position: absolute;
        top: .55em;
        left: 0; }
    .p-container .dep-list .dep-list-item:not(:last-of-type) {
    margin-bottom: .5em; }
    .p-container .dep-list .dep-list-item span {
      display: inline-block; }

.p-container .table-of-contents {
  width: 100%;
  position: absolute;
  z-index: 10; }
  @media screen and (max-width: 520px) {
  	.p-container .table-of-contents {
 		top: 60px; } }
	@media print, screen and (min-width: 521px) and (max-width: 1024px) {
	.p-container .table-of-contents {
	    top: 60px; } }
	@media screen and (min-width: 1025px) {
	.p-container .table-of-contents {
	    top: 70px; } }
  .p-container .table-of-contents-btn {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
        justify-content: center;
    -ms-flex-align: center;
        align-items: center;
    position: absolute;
    top: 0;
    right: 0;
    transition: background-color .2s, width .2s, height .2s ease-in-out; }
    @media screen and (max-width: 520px) {
      .p-container .table-of-contents-btn {
        width: 62px;
        height: 62px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .table-of-contents-btn {
        width: 68px;
        height: 68px; } }
    @media screen and (min-width: 1025px) {
      .p-container .table-of-contents-btn {
        width: 74px;
        height: 74px; } }
    .p-container .table-of-contents-btn.is-hidden {
      background-color: transparent; }
      @media screen and (max-width: 520px) {
      .p-container .table-of-contents-btn.is-hidden {
        width: 48px;
        height: 48px; } }
    .p-container .table-of-contents-btn .btn-icon {
      display: block;
      margin-top: 5px;
      opacity: 1;
      visibility: visible;
      transition: opacity .2s, visibility .2s ease-in-out; }
      @media screen and (max-width: 520px) {
        .p-container .table-of-contents-btn .btn-icon {
          width: 18px;
          height: 18px; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .table-of-contents-btn .btn-icon {
          width: 20px;
          height: 20px; } }
      @media screen and (min-width: 1025px) {
        .p-container .table-of-contents-btn .btn-icon {
          width: 22px;
          height: 22px; } }
    .p-container .table-of-contents-btn .btn-text {
      display: block;
      width: 100%;
      padding-top: 5px;
      text-align: center;
      font-size: 10px;
      opacity: 1;
      visibility: visible;
      transition: opacity .2s, visibility .2s ease-in-out; }
      @media screen and (max-width: 520px) {
	  	.p-container .table-of-contents-btn .btn-text {
	  		transform: scale(.85); } }
    .p-container .table-of-contents-btn .btn-close {
      display: none;
      opacity: 0;
      visibility: hidden;
      position: relative;
      transition: opacity .2s, visibility .2s ease-in-out; }
      @media screen and (max-width: 520px) {
        .p-container .table-of-contents-btn .btn-close {
          width: 24px;
          height: 24px; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .table-of-contents-btn .btn-close {
          width: 26px;
          height: 26px; } }
      @media screen and (min-width: 1025px) {
        .p-container .table-of-contents-btn .btn-close {
          width: 28px;
          height: 28px; } }
      .p-container .table-of-contents-btn .btn-close::before, .p-container .table-of-contents-btn .btn-close::after {
        content: '';
        width: 1.2em;
        height: 1px;
        background: #fff;
        position: absolute;
        top: 50%;
        left: 50%; }
      .p-container .table-of-contents-btn .btn-close::before {
        transform: translate(-50%, -50%) rotate(45deg); }
      .p-container .table-of-contents-btn .btn-close::after {
        transform: translate(-50%, -50%) rotate(-45deg); }
    .p-container .table-of-contents-btn .btn-block {
      display: -ms-flexbox;
      display: flex;
      -ms-flex-flow: row wrap;
          flex-flow: row wrap;
      -ms-flex-pack: center;
          justify-content: center;
      -ms-flex-align: center;
          align-items: center; }
      .p-container .table-of-contents-btn .btn-block.is-active .btn-icon {
        opacity: 0;
        visibility: hidden; }
      .p-container .table-of-contents-btn .btn-block.is-active .btn-text {
        opacity: 0;
        visibility: hidden; }
      .p-container .table-of-contents-btn .btn-block.is-active .btn-close {
        opacity: 1;
        visibility: visible; }
      .p-container .table-of-contents-btn .btn-block.is-show .btn-icon {
        display: none; }
      .p-container .table-of-contents-btn .btn-block.is-show .btn-text {
        display: none; }
      .p-container .table-of-contents-btn .btn-block.is-show .btn-close {
        display: block; }

.p-container-nav {
  display: none;
  margin: 0 auto; }
  @media screen and (max-width: 520px) {
    .p-container-nav {
      padding-left: 20px;
      padding-right: 20px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container-nav {
      padding-left: 40px;
      padding-right: 40px; } }
  @media screen and (min-width: 1025px) {
    .p-container-nav {
      padding-left: 60px;
      padding-right: 60px; } }
  .p-container-nav .nav-list {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-flow: row wrap;
        flex-flow: row wrap;
    -ms-flex-align: center;
        align-items: center;
    padding: 20px 0; }
  @media screen and (max-width: 520px) {
    .p-container-nav .nav-item {
      width: 49%; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container-nav .nav-item {
      width: 49%; } }
  @media screen and (min-width: 1025px) {
    .p-container-nav .nav-item {
      width: calc(100% / 5); } }
  @media screen and (max-width: 520px) {
    .p-container-nav .nav-item:nth-of-type(n + 3) {
      margin-top: 15px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container-nav .nav-item:nth-of-type(n + 3) {
      margin-top: 15px; } }
  @media screen and (min-width: 1025px) {
    .p-container-nav .nav-item:nth-of-type(n + 6) {
      margin-top: 15px; } }
  @media screen and (max-width: 520px) {
    .p-container-nav .nav-item:not(:nth-of-type(2n)) {
      margin-right: 2%; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container-nav .nav-item:not(:nth-of-type(2n)) {
      margin-right: 2%; } }
  .p-container-nav .nav-link {
    display: inline-block;
    padding-left: 1em;
    position: relative; }
    @media screen and (max-width: 520px) {
      .p-container-nav .nav-link {
        font-size: 12px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container-nav .nav-link {
        font-size: 13px; } }
    @media screen and (min-width: 1025px) {
      .p-container-nav .nav-link {
        font-size: clamp(13px, 1.2vw, 16px); } }
    .p-container-nav .nav-link::before {
      content: '';
      border-top: .4em solid transparent;
      border-bottom: .4em solid transparent;
      position: absolute;
      top: 50%;
      left: 0;
      transform: translate(0, -50%); }

.p-container-head {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  position: relative; }
  @media screen and (max-width: 520px) {
    .p-container-head {
      margin-bottom: 20px;
      height: 300px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container-head {
      height: 400px;
      margin-bottom: 50px; } }
  @media screen and (min-width: 1025px) {
    .p-container-head {
      height: 500px;
      margin-bottom: 50px; } }
  .p-container-head .head-block {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
        align-items: center;
    background: rgba(255,255,255, .9);
    position: absolute;
    bottom: 0; 
    .--sociology02 &{
      background: color-mix(in srgb, var(--sociology02-bgcolor) 90%, transparent);
    }
  }
    @media screen and (max-width: 520px) {
      .p-container-head .head-block {
        padding: 20px 35px;
        left: 50%;
        transform: translate(-50%, 0); } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container-head .head-block {
        padding: 30px 40px;
        left: 0; } }
    @media screen and (min-width: 1025px) {
      .p-container-head .head-block {
        padding: 35px 50px;
        left: 0; } }

@media screen and (max-width: 520px) {
  .p-container-body {
    padding: 10px 0; } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container-body {
    padding: 15px 0; } }

@media screen and (min-width: 1025px) {
  .p-container-body {
    padding: 20px 0; } }

.p-container .breadcrumb {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-align: center;
      align-items: center;
  margin: 0 auto; }
  @media screen and (max-width: 520px) {
    .p-container .breadcrumb {
      padding-left: 10px;
      padding-right: 10px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .breadcrumb {
      padding-left: 20px;
      padding-right: 20px; } }
  @media screen and (min-width: 1025px) {
    .p-container .breadcrumb {
      padding-left: 40px;
      padding-right: 40px; } }
  @media screen and (max-width: 520px) {
    .p-container .breadcrumb {
      padding-bottom: 10px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .breadcrumb {
      padding-bottom: 15px; } }
  @media screen and (min-width: 1025px) {
    .p-container .breadcrumb {
      padding-bottom: 20px; } }
  .p-container .breadcrumb-item.item-parent {
    margin-right: 1em;
    padding-right: calc(1em + .4em / 2);
    position: relative; }
    .p-container .breadcrumb-item.item-parent::before {
      content: '';
      width: .4em;
      height: .4em;
      border-top: solid 1px #333;
      border-right: solid 1px #333;
      position: absolute;
      top: 50%;
      right: 0;
      transform: translate(0, -50%) rotate(45deg); }

.p-container-wrap {
  margin: 0 auto; }
  @media screen and (max-width: 520px) {
    .p-container-wrap {
      padding-left: 20px;
      padding-right: 20px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container-wrap {
      padding-left: 40px;
      padding-right: 40px; } }
  @media screen and (min-width: 1025px) {
    .p-container-wrap {
      padding-left: 60px;
      padding-right: 60px; } }
  @media screen and (max-width: 520px) {
    .p-container-wrap {
      padding-top: 80px;
      padding-bottom: 80px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container-wrap {
      padding-top: 90px;
      padding-bottom: 90px; } }
  @media screen and (min-width: 1025px) {
    .p-container-wrap {
      padding-top: 100px;
      padding-bottom: 100px; } }
  @media screen and (max-width: 520px) {
    .p-container-wrap .head-title {
      margin-bottom: calc(40px - 25px);
      padding-bottom: 40px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container-wrap .head-title {
      margin-bottom: calc(45px - 25px);
      padding-bottom: 45px; } }
  @media screen and (min-width: 1025px) {
    .p-container-wrap .head-title {
      margin-bottom: calc(50px - 30px);
      padding-bottom: 50px; } }
  .p-container-wrap .head-title::before {
    content: '';
    width: 1px;
    background: #b8bfc9;
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 0); }
    @media screen and (max-width: 520px) {
      .p-container-wrap .head-title::before {
        height: 25px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container-wrap .head-title::before {
        height: 25px; } }
    @media screen and (min-width: 1025px) {
      .p-container-wrap .head-title::before {
        height: 30px; } }
  .p-container-wrap .head-title::after {
    display: none; }
  .p-container-wrap .head-text {
    line-height: 2;
    font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container-wrap .head-text {
        max-width: 700px;
        margin-left: auto;
        margin-right: auto; } }
    @media screen and (min-width: 1025px) {
      .p-container-wrap .head-text {
        max-width: 1100px;
        margin-left: auto;
        margin-right: auto; } }

.p-container .c-policy-text {
  margin-bottom: 2em;
  text-align: center;
  font-weight: bold;
  line-height: 1.8;
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-policy-text {
      max-width: 700px;
      margin-left: auto;
      margin-right: auto; } }
  @media screen and (max-width: 520px) {
    .p-container .c-policy-text {
      font-size: 16px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-policy-text {
      font-size: 17px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-policy-text {
      font-size: 18px; } }
  @media screen and (max-width: 520px) {
    .p-container .c-policy-text {
      text-align: left; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-policy-text {
      text-align: left; } }

.p-container .c-policy-link {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-policy-link {
      max-width: 500px;
      margin: 0 auto; } }

.p-container .c-policy-btn {
  width: 100%; }
  @media screen and (min-width: 1025px) {
    .p-container .c-policy-btn {
      max-width: 380px; } }
  @media screen and (max-width: 520px) {
    .p-container .c-policy-btn:not(:last-of-type) {
      margin-bottom: 15px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-policy-btn:not(:last-of-type) {
      margin-bottom: 20px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-policy-btn:not(:last-of-type) {
      margin-right: 80px; } }
  .p-container .c-policy-btn-text {
    display: block;
    padding: 1em 1.5em;
    background: #fff;
    border-radius: 999px;
    text-align: center;
    font-weight: bold;
    position: relative; }
    @media screen and (max-width: 520px) {
      .p-container .c-policy-btn-text {
        font-size: 16px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-policy-btn-text {
        font-size: 17px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-policy-btn-text {
        font-size: 18px; } }
    .p-container .c-policy-btn-text::before {
      content: '';
      width: 1.6em;
      height: 2px;
      position: absolute;
      top: 50%;
      right: 1em;
      transform: translate(-50%, -50%) skew(60deg); }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container .c-feature-list {
    max-width: 700px;
    margin-left: auto;
    margin-right: auto; } }

@media screen and (min-width: 1025px) {
  .p-container .c-feature-list {
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto; } }

.p-container .c-feature-item {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between; }
  .p-container .c-feature-item:not(:last-of-type) {
    margin-bottom: 40px; }
  .p-container .c-feature-item .item-image-wrap {
    min-height: 100%;
    overflow: hidden;
    position: relative; }
    @media screen and (max-width: 520px) {
      .p-container .c-feature-item .item-image-wrap {
        min-width: 100vw;
        height: 280px;
        position: relative;
        left: -20px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-feature-item .item-image-wrap {
        width: 100%;
        height: 360px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-feature-item .item-image-wrap {
        width: 480px; } }
  .p-container .c-feature-item .item-text-wrap {
    background: #fff;
    position: relative; }
    @media screen and (max-width: 520px) {
      .p-container .c-feature-item .item-text-wrap {
        width: 100%;
        margin-top: -40px;
        padding: 40px 30px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-feature-item .item-text-wrap {
        width: calc(100% - 40px * 2);
        margin: -40px auto 0;
        padding: 40px 30px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-feature-item .item-text-wrap {
        width: calc(100% - 480px);
        padding: 80px 40px; } }
  .p-container .c-feature-item .item-image {
    max-width: inherit;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); }
    @media screen and (max-width: 520px) {
      .p-container .c-feature-item .item-image {
        width: 100%; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-feature-item .item-image {
        width: 100%; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-feature-item .item-image {
        width: auto;
        height: 100%; } }
  .p-container .c-feature-item .item-num {
	text-shadow: 0 0 8px #fff;
    line-height: 1;
    font-weight: bold;
    position: absolute;
    top: -25px;
    right: 20px;
    font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
    @media screen and (max-width: 520px) {
      .p-container .c-feature-item .item-num {
        font-size: 46px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-feature-item .item-num {
        font-size: 58px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-feature-item .item-num {
        font-size: 80px; } }
  .p-container .c-feature-item .item-title {
    margin-bottom: .8em;
    padding-bottom: .6em;
    color: #0f4277;
    position: relative;
    font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
    @media screen and (max-width: 520px) {
      .p-container .c-feature-item .item-title {
        font-size: 18px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-feature-item .item-title {
        font-size: 20px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-feature-item .item-title {
        font-size: 24px; } }
    .p-container .c-feature-item .item-title::before {
      content: '';
      width: 25px;
      height: 2px;
      background: #0f4277;
      position: absolute;
      left: 0;
      bottom: 0; }
  @media screen and (max-width: 520px) {
    .p-container .c-feature-item .item-text {
      font-size: 12px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-feature-item .item-text {
      font-size: 13px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-feature-item .item-text {
      font-size: 14px; } }

.p-container .c-flow-wrap {
  padding-bottom: 50px; }

.p-container .c-flow-block {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
  position: relative; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-flow-block {
      max-width: 700px;
      margin-left: auto;
      margin-right: auto; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-flow-block {
      max-width: 1100px;
      margin-left: auto;
      margin-right: auto; } }
  .p-container .c-flow-block::before {
    content: '';
    width: 2px;
    background-repeat: repeat-y;
    position: absolute; }
    @media screen and (max-width: 520px) {
      .p-container .c-flow-block::before {
        height: calc(50px + 90px);
        background-size: 2px 10px;
        top: -50px;
        left: 50%;
        transform: translate(-50%, 0); } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-flow-block::before {
        height: calc(50px + 110px);
        background-size: 2px 10px;
        top: -50px;
        left: 50%;
        transform: translate(-50%, 0); } }
    @media screen and (min-width: 1025px) {
      .p-container .c-flow-block::before {
        height: 100%;
        background-size: 2px 14px;
        top: 30px;
        left: calc(126px / 2 - 1px); } }
  .p-container .c-flow-block:not(:last-of-type) {
    padding-bottom: 50px; }
  @media screen and (max-width: 520px) {
    .p-container .c-flow-block:first-of-type::before {
      display: none; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-flow-block:first-of-type::before {
      display: none; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-flow-block:last-of-type::before {
      display: none; } }

.p-container .c-flow-annual {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  background: #fff;
  border-radius: 50%;
  position: relative;
  z-index: 1; }
  @media screen and (max-width: 520px) {
    .p-container .c-flow-annual {
      width: 90px;
      height: 90px;
      margin: 0 auto 15px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-flow-annual {
      width: 110px;
      height: 110px;
      margin: 0 auto 20px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-flow-annual {
      width: 126px;
      height: 126px;
      margin-top: 30px;
      margin-right: 30px; } }
  .p-container .c-flow-annual-box {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-flow: row wrap;
        flex-flow: row wrap;
    -ms-flex-pack: center;
        justify-content: center;
    -ms-flex-align: baseline;
        align-items: baseline;
    position: relative; }
  .p-container .c-flow-annual .num {
    display: block;
    line-height: 1;
    font-weight: bold;
    font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
    @media screen and (max-width: 520px) {
      .p-container .c-flow-annual .num {
        font-size: 25px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-flow-annual .num {
        font-size: 30px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-flow-annual .num {
        font-size: 46px; } }
  .p-container .c-flow-annual .annual {
    display: block;
    line-height: 1;
    font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
    @media screen and (max-width: 520px) {
      .p-container .c-flow-annual .annual {
        font-size: 16px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-flow-annual .annual {
        font-size: 17px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-flow-annual .annual {
        font-size: 18px; } }
  .p-container .c-flow-annual .period {
    display: block;
    width: 100%;
    text-align: center; }

.p-container .c-flow-body {
  background: #fff;
  position: relative; }
  @media screen and (max-width: 520px) {
    .p-container .c-flow-body {
      padding: 20px 20px 30px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-flow-body {
      padding: 30px 40px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-flow-body {
      width: calc(100% - (126px + 30px));
      padding: 40px 50px; } }
  .p-container .c-flow-body::before {
    content: '';
    position: absolute; }
    @media screen and (max-width: 520px) {
      .p-container .c-flow-body::before {
        border-right: 10px solid transparent;
        border-bottom: 15px solid #fff;
        border-left: 10px solid transparent;
        top: -15px;
        left: 50%;
        transform: translate(-50%, 0); } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-flow-body::before {
        border-right: 15px solid transparent;
        border-bottom: 20px solid #fff;
        border-left: 15px solid transparent;
        top: -20px;
        left: 50%;
        transform: translate(-50%, 0); } }
    @media screen and (min-width: 1025px) {
      .p-container .c-flow-body::before {
        border-right: 25px solid #fff;
        border-top: 20px solid transparent;
        border-bottom: 20px solid transparent;
        top: calc((28px - 25px + 4px) + 126px / 2);
        left: -20px; } }

.p-container .c-flow-title {
  margin-bottom: .8em;
  padding-bottom: .6em;
  color: #0f4277;
  position: relative;
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  @media screen and (max-width: 520px) {
    .p-container .c-flow-title {
      font-size: 18px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-flow-title {
      font-size: 20px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-flow-title {
      font-size: 24px; } }
  .p-container .c-flow-title::before {
    content: '';
    width: 25px;
    height: 2px;
    background: #0f4277;
    position: absolute;
    left: 0;
    bottom: 0; }

.p-container .c-flow-text {
  padding-bottom: 2em; }
  @media screen and (max-width: 520px) {
    .p-container .c-flow-text {
      font-size: 14px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-flow-text {
      font-size: 15px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-flow-text {
      font-size: 16px; } }

.p-container .c-flow-subject .item:not(:last-of-type) {
  padding-bottom: 2em; }

.p-container .c-flow-subject .item-category {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  margin-bottom: .8em; }
  .p-container .c-flow-subject .item-category .name {
    margin-right: 1em;
    padding: .5em 1.5em;
    color: #828282;
    text-align: center;
    font-weight: bold; }
    @media screen and (max-width: 520px) {
      .p-container .c-flow-subject .item-category .name {
        min-width: 104px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-flow-subject .item-category .name {
        min-width: 112px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-flow-subject .item-category .name {
        min-width: 120px; } }
  @media screen and (max-width: 520px) {
    .p-container .c-flow-subject .item-category .title {
      font-size: 14px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-flow-subject .item-category .title {
      font-size: 16px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-flow-subject .item-category .title {
      font-size: 18px; } }
 
.p-container .c-flow-subject .courses-list {
	display: flex;
	flex-flow: row wrap;
	align-items: center;
	gap: .5rem 1rem;
}     
.p-container .c-flow-subject .courses-list .courses-item {
	list-style: disc;
	margin: 0 0 0 1.5rem;
}

@media screen and (max-width: 520px) {
  .p-container .c-flow-subject .item-text {
    font-size: 12px; } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container .c-flow-subject .item-text {
    font-size: 13px; } }

@media screen and (min-width: 1025px) {
  .p-container .c-flow-subject .item-text {
    font-size: 14px; } }

.p-container .c-flow-link {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-flow-link {
      max-width: 500px;
      margin: 0 auto; } }

.p-container .c-flow-btn {
  width: 100%; }
  @media screen and (min-width: 1025px) {
    .p-container .c-flow-btn {
      max-width: 380px; } }
  @media screen and (max-width: 520px) {
    .p-container .c-flow-btn:not(:last-of-type) {
      margin-bottom: 15px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-flow-btn:not(:last-of-type) {
      margin-bottom: 25px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-flow-btn:not(:last-of-type) {
      margin-right: 80px; } }
  .p-container .c-flow-btn-text {
    display: block;
    padding: 1em 1.5em;
    background: #fff;
    border-radius: 999px;
    text-align: center;
    line-height: 1.2;
    font-weight: bold;
    position: relative; }
    @media screen and (max-width: 520px) {
      .p-container .c-flow-btn-text {
        font-size: 16px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-flow-btn-text {
        font-size: 17px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-flow-btn-text {
        font-size: 18px; } }
    .p-container .c-flow-btn-text::before {
      content: '';
      width: 1.6em;
      height: 2px;
      position: absolute;
      top: 50%;
      right: 1em;
      transform: translate(-50%, -50%) skew(60deg); }

.p-container .c-certify-list {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-certify-list {
      max-width: 700px;
      margin-left: auto;
      margin-right: auto; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-certify-list {
      max-width: 1100px;
      margin-left: auto;
      margin-right: auto; } }
  .p-container .c-certify-list .item {
    padding: 1em;
    border-bottom: 1px dotted #c8c8c8;
    text-align: center;
    font-weight: bold;
    font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
    @media screen and (max-width: 520px) {
      .p-container .c-certify-list .item {
        font-size: 16px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-certify-list .item {
        font-size: 17px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-certify-list .item {
        font-size: 18px; } }
    @media screen and (max-width: 520px) {
      .p-container .c-certify-list .item {
        width: 100%; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-certify-list .item {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-flow: row wrap;
            flex-flow: row wrap;
        -ms-flex-align: center;
            align-items: center;
        -ms-flex-pack: center;
            justify-content: center;
        width: calc((100% - 20px) / 2); } }
    @media screen and (min-width: 1025px) {
      .p-container .c-certify-list .item {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-flow: row wrap;
            flex-flow: row wrap;
        -ms-flex-align: center;
            align-items: center;
        -ms-flex-pack: center;
            justify-content: center;
        width: calc((100% - 70px * 2) / 3); } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-certify-list .item:not(:nth-of-type(2n)) {
        margin-right: 20px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-certify-list .item:not(:nth-of-type(3n)) {
        margin-right: 70px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-certify-list .item:nth-child(n + 3) {
        margin-top: 20px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-certify-list .item:nth-child(n + 4) {
        margin-top: 20px; } }
    @media screen and (max-width: 520px) {
      .p-container .c-certify-list .item:not(:last-of-type) {
        margin-bottom: 10px; } }
    .p-container .c-certify-list .item .txt-small {
      display: inline-block;
      padding-left: .5em; }
      @media screen and (max-width: 520px) {
        .p-container .c-certify-list .item .txt-small {
          font-size: 12px; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .c-certify-list .item .txt-small {
          font-size: 13px; } }
      @media screen and (min-width: 1025px) {
        .p-container .c-certify-list .item .txt-small {
          font-size: 14px; } }
	.p-container .c-certify-list .item sub {
      display: inline-block;
      padding: 0 0 0 .5em;
      font-size: 12px; }	  

.p-container .c-certify-text {
    padding-top: 50px; }
  @media screen and (min-width: 1025px) {
        .p-container .c-certify-text {
          max-width: 1100px;
		  margin-left: auto;
		  margin-right: auto; } }

.p-container .c-certify-link {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  padding-top: 50px; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-certify-link {
      max-width: 500px;
      margin: 0 auto; } }
.p-container .c-certify-btn {
  width: 100%; }
  @media screen and (min-width: 1025px) {
    .p-container .c-certify-btn {
      max-width: 480px; } }
  @media screen and (max-width: 520px) {
    .p-container .c-certify-btn:not(:last-of-type) {
      margin-bottom: 15px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-certify-btn:not(:last-of-type) {
      margin-bottom: 25px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-certify-btn:not(:last-of-type) {
      margin-right: 80px; } }
  .p-container .c-certify-btn-text {
    display: block;
    padding: 1em 1.5em;
    background: #fff;
    border-radius: 999px;
    text-align: center;
    font-weight: bold;
    position: relative; }
    @media screen and (max-width: 520px) {
      .p-container .c-certify-btn-text {
        font-size: 16px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-certify-btn-text {
        font-size: 17px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-certify-btn-text {
        font-size: 18px; } }
    .p-container .c-certify-btn-text::before {
      content: '';
      width: 1.6em;
      height: 2px;
      position: absolute;
      top: 50%;
      right: 1em;
      transform: translate(-50%, -50%) skew(60deg); }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container .c-support-wrap {
    max-width: 700px;
    margin-left: auto;
    margin-right: auto; } }

@media screen and (min-width: 1025px) {
  .p-container .c-support-wrap {
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto; } }

@media screen and (max-width: 520px) {
  .p-container .c-support-wrap:not(:last-of-type) {
    padding-bottom: 60px; } }
@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container .c-support-wrap:not(:last-of-type) {
    padding-bottom: 70px; } }
@media screen and (min-width: 1025px) {
  .p-container .c-support-wrap:not(:last-of-type) {
    padding-bottom: 80px; } }

.p-container .c-support-title {
  margin-bottom: 1.2em;
  padding-bottom: .6em;
  color: #0f4277;
  position: relative;
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  @media screen and (max-width: 520px) {
    .p-container .c-support-title {
      font-size: 18px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-support-title {
      font-size: 20px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-support-title {
      font-size: 24px; } }
  .p-container .c-support-title::before {
    content: '';
    width: 25px;
    height: 2px;
    background: #0f4277;
    position: absolute;
    left: 0;
    bottom: 0; }
    
.p-container .c-support-subtitle {
  padding-bottom: 1em;
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  @media screen and (max-width: 520px) {
    .p-container .c-support-subtitle {
      font-size: 15px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-support-subtitle {
      text-align: center;
      font-size: 20px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-support-subtitle {
      text-align: center;
      font-size: 24px; } }

.p-container .c-support-text {
  padding-bottom: 2em;
  line-height: 1.8; }
  .p-container .c-support-text.w800 {
    max-width: 800px;
	margin: 1em auto 0;
	padding-bottom: 0; }
	.p-container .c-support-text.txt-large {
		font-weight: bold;
		font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
	@media screen and (max-width: 520px) {
    .p-container .c-support-text.txt-large {
      font-size: 16px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-support-text.txt-large {
      font-size: 17px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-support-text.txt-large {
      font-size: 18px; } }
    .p-container .c-support-text.pb1em {
      padding-bottom: 1em;  }
    .p-container .c-support-text a {
      text-decoration: underline;
      color: #0f4277;  }
      
 .p-container .c-support-subheading {
    margin-bottom: 1em;
    padding-bottom: 0.4em;
    border-bottom: 1px solid #0f4277;
    font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
    @media screen and (max-width: 520px) {
      .p-container .c-support-subheading {
        font-size: 16px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-support-subheading {
        font-size: 17px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-support-subheading {
        font-size: 18px; } }

.p-container .merit-list {
	margin-left: 1.5rem;
}
.p-container .merit-list-item {
	list-style: decimal;
}
.p-container .merit-list-item:not(:last-of-type) {
	margin: 0 0 .5rem;
}

.p-container .c-support-image {
  max-width: 600px;
  margin: 0 auto;
  text-align: center; }
  .p-container .c-support-image.w100 {
    max-width: 1000px; }
  .p-container .c-support-image.imageL {
    max-width: 100%;
    text-align: left; }
    .p-container .c-support-image.pb1em {
      padding-bottom: 1em;  }

.p-container .c-support-block {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between; }
  @media screen and (max-width: 520px) {
    .p-container .c-support-block:not(:last-of-type) {
      padding-bottom: 30px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-support-block:not(:last-of-type) {
      padding-bottom: 40px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-support-block:not(:last-of-type) {
      padding-bottom: 50px; } }
  .p-container .c-support-block .block-image-wrap {
    width: 100%;
    max-width: 460px; }
    @media screen and (max-width: 520px) {
      .p-container .c-support-block .block-image-wrap {
        -ms-flex-order: 2;
            order: 2;
        margin: 0 auto; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-support-block .block-image-wrap {
        -ms-flex-order: 2;
            order: 2;
        margin: 0 auto; } }
  @media screen and (max-width: 520px) {
    .p-container .c-support-block .block-text-wrap {
      -ms-flex-order: 1;
          order: 1;
      width: 100%;
      margin-bottom: 1em; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-support-block .block-text-wrap {
      -ms-flex-order: 1;
          order: 1;
      width: 100%;
      margin-bottom: 1em; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-support-block .block-text-wrap {
      width: calc(100% - (460px + 50px)); } }
  .p-container .c-support-block .block-title {
    margin-bottom: 1em;
    padding-bottom: 0.4em;
    border-bottom: 1px solid #0f4277;
    font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
    @media screen and (max-width: 520px) {
      .p-container .c-support-block .block-title {
        font-size: 16px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-support-block .block-title {
        font-size: 17px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-support-block .block-title {
        font-size: 18px; } }
  @media screen and (max-width: 520px) {
    .p-container .c-support-block .block-data {
      width: 100%;
      max-width: 460px;
      margin: 0 auto; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-support-block .block-data {
      width: 100%;
      max-width: 460px;
      margin: 0 auto; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-support-block .block-data {
      width: 48%; } }
  @media screen and (max-width: 520px) {
    .p-container .c-support-block .block-data:not(:last-of-type) {
      padding-bottom: 1em; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-support-block .block-data:not(:last-of-type) {
      padding-bottom: 1em; } }

.p-container .c-support-box {
  overflow: hidden; }
  @media screen and (max-width: 520px) {
    .p-container .c-support-box:not(:last-of-type) {
      padding-bottom: 30px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-support-box:not(:last-of-type) {
      padding-bottom: 40px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-support-box:not(:last-of-type) {
      padding-bottom: 50px; } }
  @media screen and (max-width: 520px) {
    .p-container .c-support-box .box-imageL {
      width: 100%;
      margin: 0 auto 1em;
      text-align: center; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-support-box .box-imageL {
      width: 100%;
      max-width: 460px;
      margin: 0 auto 1em;
      text-align: center; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-support-box .box-imageL {
      padding: 0 2em 2em 0;
      float: left; } }
  @media screen and (max-width: 520px) {
    .p-container .c-support-box .box-imageR {
      width: 100%;
      margin: 0 auto 1em;
      text-align: center; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-support-box .box-imageR {
      width: 100%;
      max-width: 460px;
      margin: 0 auto 1em;
      text-align: center; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-support-box .box-imageR {
      padding: 0 0 2em 2em;
      float: right; } }
  @media screen and (max-width: 520px) {
    .p-container .c-support-box .box-text {
      width: 100%; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-support-box .box-text {
      width: 100%; } }
      
 .p-container .c-support-step {
  display: -ms-flexbox;
  display: flex; }
  @media screen and (max-width: 520px) {
    .p-container .c-support-step {
      -ms-flex-flow: column wrap;
          flex-flow: column wrap; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-support-step {
      -ms-flex-flow: column wrap;
          flex-flow: column wrap; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-support-step {
      -ms-flex-flow: row nowrap;
          flex-flow: row nowrap; } }
  .p-container .c-support-step-item {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-flow: column wrap;
        flex-flow: column wrap;
    padding: 3em 2em 2em;
    position: relative; }
    @media screen and (max-width: 520px) {
      .p-container .c-support-step-item {
        width: 100%; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-support-step-item {
        width: 100%; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-support-step-item {
        width: 20%; } }
      @media screen and (max-width: 520px) {
        .p-container .c-support-step-item.step-1 {
          margin-top: 20px; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .c-support-step-item.step-1 {
          margin-top: 20px; } }
      @media screen and (min-width: 1025px) {
        .p-container .c-support-step-item.step-1 {
          margin-top: 200px; } }
      @media screen and (max-width: 520px) {
        .p-container .c-support-step-item.step-2 {
          margin-top: 30px; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .c-support-step-item.step-2 {
          margin-top: 30px; } }
      @media screen and (min-width: 1025px) {
        .p-container .c-support-step-item.step-2 {
          margin-top: 150px; } }
    .p-container .c-support-step-item.step-3 {
      color: #fff; }
      @media screen and (max-width: 520px) {
        .p-container .c-support-step-item.step-3 {
          margin-top: 30px; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .c-support-step-item.step-3 {
          margin-top: 30px; } }
      @media screen and (min-width: 1025px) {
        .p-container .c-support-step-item.step-3 {
          margin-top: 100px; } }
    .p-container .c-support-step-item.step-4 {
      margin-top: 50px;
      color: #fff; }
      @media screen and (max-width: 520px) {
        .p-container .c-support-step-item.step-4 {
          margin-top: 30px; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .c-support-step-item.step-4 {
          margin-top: 30px; } }
      @media screen and (min-width: 1025px) {
        .p-container .c-support-step-item.step-4 {
          margin-top: 50px; } }
    .p-container .c-support-step-item.step-5 {
      margin-top: 0;
      color: #fff; }
      @media screen and (max-width: 520px) {
        .p-container .c-support-step-item.step-5 {
          margin-top: 30px; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .c-support-step-item.step-5 {
          margin-top: 30px; } }
    .p-container .c-support-step-item div {
      position: absolute;
      width: 60%;
      left: 20%;
      margin: 0 auto;
      top: -15px;
      text-align: center;
      font-weight: bold;
      background: #fff;
      padding: .5em; }
      @media screen and (max-width: 520px) {
        .p-container .c-support-step-item div {
          font-size: 14px; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .c-support-step-item div {
          font-size: 15px; } }
      @media screen and (min-width: 1025px) {
        .p-container .c-support-step-item div {
          font-size: 16px; } }
    .p-container .c-support-step-item .step-title {
      font-weight: bold;
      margin-bottom: 1em;
      padding-bottom: 1em;
      letter-spacing: .08em; }
      @media screen and (max-width: 520px) {
        .p-container .c-support-step-item .step-title {
          font-size: 14px; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .c-support-step-item .step-title {
          font-size: 15px; } }
      @media screen and (min-width: 1025px) {
        .p-container .c-support-step-item .step-title {
          font-size: 16px; } }
      @media screen and (max-width: 520px) {
        .p-container .c-support-step-item .step-title {
          text-align: center; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .c-support-step-item .step-title {
          text-align: center; } }
    @media screen and (max-width: 520px) {
      .p-container .c-support-step-item .step-txt {
        font-size: 12px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-support-step-item .step-txt {
        font-size: 13px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-support-step-item .step-txt {
        font-size: 14px; } }  

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container .c-startWorking-wrap {
    max-width: 700px;
    margin-left: auto;
    margin-right: auto; } }

@media screen and (min-width: 1025px) {
  .p-container .c-startWorking-wrap {
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto; } }

.p-container .c-startWorking-wrap:not(:last-of-type) {
  padding-bottom: 50px; }
  
.p-container .c-startWorking-wrap .colorTbl {
  table-layout: fixed;
  border-spacing: 0;
  border-collapse: collapse;
  border-top: 1px solid #e6e7ec;
  border-bottom: 1px solid #e6e7ec;
  margin-bottom: 1em; }
  .p-container .c-startWorking-wrap .colorTbl tr:last-child th,
  .p-container .c-startWorking-wrap .colorTbl tr:last-child td {
    border-bottom: 0; }
  .p-container .c-startWorking-wrap .colorTbl th,
  .p-container .c-startWorking-wrap .colorTbl td {
    padding: 1em; }
    @media screen and (max-width: 520px) {
      .p-container .c-startWorking-wrap .colorTbl th,
      .p-container .c-startWorking-wrap .colorTbl td {
        display: block;
        width: 100%; } }
  .p-container .c-startWorking-wrap .colorTbl th {
    text-align: left;
    border-bottom: 1px solid #fff; }
    @media screen and (max-width: 520px) {
      .p-container .c-startWorking-wrap .colorTbl th {
        width: 100%; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-startWorking-wrap .colorTbl th {
        width: 30%; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-startWorking-wrap .colorTbl th {
        width: 30%; } }
  .p-container .c-startWorking-wrap .colorTbl td {
    border-bottom: 1px solid #e6e7ec;
    border-right: 1px solid #e6e7ec;
    background: #fff; }
    @media screen and (max-width: 520px) {
      .p-container .c-startWorking-wrap .colorTbl td {
        border: 0; } }

.p-container .c-startWorking-title {
  margin-bottom: .8em;
  padding-bottom: .6em;
  color: #0f4277;
  position: relative;
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-startWorking-title {
      max-width: 700px;
      margin-left: auto;
      margin-right: auto; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-startWorking-title {
      max-width: 1100px;
      margin-left: auto;
      margin-right: auto; } }
  @media screen and (max-width: 520px) {
    .p-container .c-startWorking-title {
      font-size: 18px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-startWorking-title {
      font-size: 20px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-startWorking-title {
      font-size: 24px; } }
  .p-container .c-startWorking-title::before {
    content: '';
    width: 25px;
    height: 2px;
    background: #0f4277;
    position: absolute;
    left: 0;
    bottom: 0; }

.p-container .c-startWorking-text {
  line-height: 1.8; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-startWorking-text {
      max-width: 700px;
      margin-left: auto;
      margin-right: auto; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-startWorking-text {
      max-width: 1100px;
      margin-left: auto;
      margin-right: auto; } }
  @media screen and (max-width: 520px) {
    .p-container .c-startWorking-text {
      font-size: 12px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-startWorking-text {
      font-size: 13px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-startWorking-text {
      font-size: 14px; } }

.p-container .c-startWorking-data {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center; }
  @media screen and (max-width: 520px) {
    .p-container .c-startWorking-data .data-image {
      width: 100%;
      text-align: center;
      margin: 1em auto; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-startWorking-data .data-image {
      width: 49%;
      margin-top: 2em;
      margin-bottom: 2em; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-startWorking-data .data-image {
      width: 49%;
      margin-top: 2em;
      margin-bottom: 2em; } }

.p-container .c-voice-wrap {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
  margin-bottom: 50px;
  position: relative; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-voice-wrap {
      max-width: 700px;
      margin-left: auto;
      margin-right: auto; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-voice-wrap {
      max-width: 1100px;
      margin-left: auto;
      margin-right: auto; } }

.p-container .c-voice-image-wrap {
  overflow: hidden;
  position: relative; }
  @media screen and (max-width: 520px) {
    .p-container .c-voice-image-wrap {
      min-width: 100vw;
      height: 170px;
      left: -20px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-voice-image-wrap {
      width: 100%;
      height: 240px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-voice-image-wrap {
      width: 620px;
      height: 300px; } }
  .p-container .c-voice-image-wrap img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); }

.p-container .c-voice-text-wrap {
  background: #fff;
  box-shadow: 0 0 20px rgba(204, 209, 193, 0.3);
  z-index: 1; }
  @media screen and (max-width: 520px) {
    .p-container .c-voice-text-wrap {
      width: 100%;
      margin-top: -40px;
      padding: 30px 30px 70px;
      position: relative; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-voice-text-wrap {
      width: calc(100% - 40px * 2);
      margin: -40px auto 0;
      padding: 40px 30px 70px;
      position: relative; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-voice-text-wrap {
      width: calc(100% - (620px - 120px));
      margin: 0 0 0 auto;
      padding: 30px 40px 60px;
      position: absolute;
      top: 50%;
      right: 0;
      transform: translate(0, -50%); } }

.p-container .c-voice-title {
  padding-bottom: 1em;
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  @media screen and (max-width: 520px) {
    .p-container .c-voice-title {
      font-size: 17px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-voice-title {
      font-size: 18px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-voice-title {
      font-size: 20px; } }

.p-container .c-voice-text .name {
  padding-bottom: .2em; }
  @media screen and (max-width: 520px) {
    .p-container .c-voice-text .name {
      font-size: 16px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-voice-text .name {
      font-size: 17px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-voice-text .name {
      font-size: 18px; } }

@media screen and (max-width: 520px) {
  .p-container .c-voice-text .graduate {
    font-size: 12px; } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container .c-voice-text .graduate {
    font-size: 13px; } }

@media screen and (min-width: 1025px) {
  .p-container .c-voice-text .graduate {
    font-size: 14px; } }

.p-container .c-voice-link-text {
  display: block;
  padding: .8em 2.5em .8em 3.5em;
  color: #fff;
  position: absolute;
  right: 0;
  bottom: 0; }
  .p-container .c-voice-link-text::before {
    content: '';
    width: .4em;
    height: .4em;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    position: absolute;
    top: 50%;
    left: 30px;
    transform: translate(0, -50%) rotate(45deg); }

.p-container .c-voice-page-link {
  width: 100%;
  margin: 0 auto; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-voice-page-link {
      max-width: 500px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-voice-page-link {
      max-width: 380px; } }
  .p-container .c-voice-page-link-text {
    display: block;
    padding: 1em 1.5em;
    background: #fff;
    border-radius: 999px;
    text-align: center;
    font-weight: bold;
    position: relative; }
    @media screen and (max-width: 520px) {
      .p-container .c-voice-page-link-text {
        font-size: 16px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-voice-page-link-text {
        font-size: 17px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-voice-page-link-text {
        font-size: 18px; } }
    .p-container .c-voice-page-link-text::before {
      content: '';
      width: 1.6em;
      height: 2px;
      position: absolute;
      top: 50%;
      right: 1em;
      transform: translate(-50%, -50%) skew(60deg); }

.p-container .c-future-wrap {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: column wrap;
      flex-flow: column wrap; }
  @media screen and (min-width: 1025px) {
    .p-container .c-future-wrap {
      max-width: 1100px;
      margin-left: auto;
      margin-right: auto; } }

.p-container .c-future-title {
  padding-bottom: 1em;
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  @media screen and (max-width: 520px) {
    .p-container .c-future-title {
      font-size: 15px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-future-title {
      text-align: center;
      font-size: 20px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-future-title {
      text-align: center;
      font-size: 24px; } }

.p-container .c-future-text {
  line-height: 2; }
  @media screen and (max-width: 520px) {
    .p-container .c-future-text {
      font-size: 16px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-future-text {
      font-size: 17px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-future-text {
      font-size: 18px; } }
  @media screen and (max-width: 520px) {
    .p-container .c-future-text {
      padding-top: 20px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-future-text {
      padding-top: 30px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-future-text {
      padding-top: 30px; } }
  .p-container .c-future-text.txt-C {
    text-align: center; }
 
.p-container .c-future-foot-text {
  padding-top: 2em;
  line-height: 2; }
      
.p-container .c-future-image {
  text-align: center; }

.p-container .c-future-course {
  background: #fff; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-future-course {
      max-width: 700px;
      margin-left: auto;
      margin-right: auto; } }
  @media screen and (max-width: 520px) {
    .p-container .c-future-course {
      width: 100%;
      padding: 20px 15px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-future-course {
      width: 100%;
      padding: 25px 20px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-future-course {
      width: 100%; /* 470px */
      padding: 20px 30px; } }
  .p-container .c-future-course .course-title {
    margin-bottom: 1em;
    padding-bottom: .4em;
    border-bottom: 1px solid #e6e7ec;
    font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
    @media screen and (max-width: 520px) {
      .p-container .c-future-course .course-title {
        font-size: 16px; } }
    @media print, screen and (min-width: 521px) and (max-width: 1024px) {
      .p-container .c-future-course .course-title {
        font-size: 17px; } }
    @media screen and (min-width: 1025px) {
      .p-container .c-future-course .course-title {
        font-size: 18px; } }
  .p-container .c-future-course .course-list {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-flow: row wrap;
        flex-flow: row wrap;
    -ms-flex-pack: start;
        justify-content: flex-start;
    -ms-flex-align: center;
        align-items: center; }
    .p-container .c-future-course .course-list-item {
      padding-left: 1em;
      position: relative;
      width: 50%; }
      @media screen and (max-width: 520px) {
        .p-container .c-future-course .course-list-item {
          width: calc((100% - 2px) / 2); } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .c-future-course .course-list-item {
          width: calc((100% - 10px) / 2); } }
      @media screen and (min-width: 1025px) {
        .p-container .c-future-course .course-list-item {
          width: calc((100% - 10px * 3) / 4); } }
      @media screen and (max-width: 520px) {
        .p-container .c-future-course .course-list-item:not(:nth-child(2n)) {
          margin-right: 2px; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .c-future-course .course-list-item:not(:nth-child(2n)) {
          margin-right: 10px; } }
      @media screen and (min-width: 1025px) {
        .p-container .c-future-course .course-list-item:not(:nth-child(4n)) {
          margin-right: 10px; } }
      @media screen and (max-width: 520px) {
        .p-container .c-future-course .course-list-item:nth-child(n + 3) {
          margin-top: 6px; } }
      @media print, screen and (min-width: 521px) and (max-width: 1024px) {
        .p-container .c-future-course .course-list-item:nth-child(n + 3) {
          margin-top: 6px; } }
      @media screen and (min-width: 1025px) {
        .p-container .c-future-course .course-list-item:nth-child(n + 5) {
          margin-top: 6px; } }
      .p-container .c-future-course .course-list-item::before {
        content: '';
        width: .6em;
        height: .6em;
        border-radius: 50%;
        position: absolute;
        top: 50%;
        left: 0;
        transform: translate(0, -50%); }

.p-container .c-future-text {
  line-height: 2; }
  @media screen and (max-width: 520px) {
    .p-container .c-future-text {
      font-size: 16px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-future-text {
      font-size: 17px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-future-text {
      font-size: 18px; } }
  @media screen and (max-width: 520px) {
    .p-container .c-future-text {
      padding-top: 20px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-future-text {
      padding-top: 30px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-future-text {
      padding-top: 30px; } }
  .p-container .c-future-text.txt-C {
    text-align: center; }

.p-container .c-greeting-wrap {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: justify;
      justify-content: space-between; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-greeting-wrap {
      max-width: 700px;
      margin-left: auto;
      margin-right: auto; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-greeting-wrap {
      max-width: 1100px;
      margin-left: auto;
      margin-right: auto; } }

.p-container .c-greeting-title {
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  text-align: center; }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-greeting-title {
      max-width: 700px;
      margin-left: auto;
      margin-right: auto; } }
  @media screen and (max-width: 520px) {
    .p-container .c-greeting-title {
      padding-bottom: 1em;
      font-size: 15px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-greeting-title {
      padding-bottom: 2em;
      font-size: 20px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-greeting-title {
      padding-bottom: 2em;
      font-size: 24px; } }

.p-container .c-greeting-text {
  line-height: 2; }
  @media screen and (max-width: 520px) {
    .p-container .c-greeting-text {
      font-size: 12px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-greeting-text {
      font-size: 13px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-greeting-text {
      font-size: 14px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-greeting-text {
      width: calc(100% - 250px);
      padding-left: 50px; } }

@media screen and (max-width: 520px) {
  .p-container .c-greeting-professor {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
        justify-content: center;
    -ms-flex-align: center;
        align-items: center;
    margin: 0 auto;
    padding-bottom: 30px; } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container .c-greeting-professor {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
        justify-content: center;
    -ms-flex-align: center;
        align-items: center;
    margin: 0 auto;
    padding-bottom: 40px; } }

@media screen and (min-width: 1025px) {
  .p-container .c-greeting-professor {
    width: 250px; } }

@media screen and (max-width: 520px) {
  .p-container .c-greeting-professor .professor-photo-wrap {
    width: 100%;
    max-width: 160px; } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container .c-greeting-professor .professor-photo-wrap {
    width: 100%;
    max-width: 200px; } }

@media screen and (min-width: 1025px) {
  .p-container .c-greeting-professor .professor-photo-wrap {
    width: 250px;
    margin-bottom: 1em; } }

@media screen and (max-width: 520px) {
  .p-container .c-greeting-professor .professor-text-wrap {
    padding-left: 20px; } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container .c-greeting-professor .professor-text-wrap {
    padding-left: 20px; } }

.p-container .c-greeting-professor .professor-faculty {
  padding-bottom: .1em;
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  @media screen and (max-width: 520px) {
    .p-container .c-greeting-professor .professor-faculty {
      font-size: 12px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-greeting-professor .professor-faculty {
      font-size: 13px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-greeting-professor .professor-faculty {
      font-size: 14px; } }

.p-container .c-greeting-professor .professor-name {
  font-weight: bold;
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  @media screen and (max-width: 520px) {
    .p-container .c-greeting-professor .professor-name {
      font-size: 16px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .c-greeting-professor .professor-name {
      font-size: 17px; } }
  @media screen and (min-width: 1025px) {
    .p-container .c-greeting-professor .professor-name {
      font-size: 18px; } }

@media screen and (max-width: 520px) {
  .p-container .c-related {
    margin: 10px 0 40px;
    padding: 0 20px; } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container .c-related {
    margin: 10px 0 40px;
    padding: 0 40px; } }

@media screen and (min-width: 1025px) {
  .p-container .c-related {
    margin: 20px 0 40px; } }

.p-container .c-related-wrap {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: row wrap;
      flex-flow: row wrap;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center; }

@media screen and (max-width: 520px) {
  .p-container .c-related-banner {
    width: 100%;
    height: 130px; } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container .c-related-banner {
    width: 100%;
    height: 130px; } }

@media screen and (min-width: 1025px) {
  .p-container .c-related-banner {
    width: calc((100% - 20px * 2) / 3);
    height: 250px; } }

@media screen and (max-width: 520px) {
  .p-container .c-related-banner:not(:last-of-type) {
    margin-bottom: 10px; } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-container .c-related-banner:not(:last-of-type) {
    margin-bottom: 15px; } }

@media screen and (min-width: 1025px) {
  .p-container .c-related-banner:not(:last-of-type) {
    margin-right: 20px; } }

.p-container .c-related-link {
  display: block;
  width: 100%;
  height: 100%;
  position: relative; }
  .p-container .c-related-link .link-image {
    width: 100%;
    height: 100%;
    position: relative;
    overflow: hidden; }
    .p-container .c-related-link .link-image img {
      width: 100%;
      max-width: inherit;
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%); }
  .p-container .c-related-link .link-title {
    color: #fff;
    white-space: nowrap;
    font-weight: bold;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
    font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, 'Noto Serif JP', "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
    @media screen and (min-width: 1025px) {
      .p-container .c-related-link .link-title {
        font-size: clamp(16px, 1vw, 18px); } }
    .p-container .c-related-link .link-title::before {
      content: '';
      width: 1.6em;
      height: 2px;
      border-bottom: 1px solid #fff;
      border-right: 2px solid #fff;
      position: absolute;
      top: 50%;
      right: calc(-1.6em * 2.5);
      transform: translate(-50%, -50%) skew(60deg); }

@media screen and (min-width: 1025px) {
.p-container .p-point-wrap {
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
}
}
.p-container .p-point-list {
  margin: 0 0 4em;
}
.p-container .p-point-list .p-point-list_item {
  padding-left: 1em;
  position: relative;
}
.p-container .p-point-list .p-point-list_item::before {
  content: '';
  display: block;
  width: .5em;
  height: .5em;
  background: #e9719b;
  position: absolute;
  top: calc(1em / 2 + .1em / 2);
  left: 0;
}
.p-container .p-point-list .p-point-list_item:not(:last-of-type) {
  margin: 0 0 1em;
}
.p-container .p-point-list .p-point-list_item .p-point-list_item-title {
  padding: 0 0 .2em;
}
  @media screen and (max-width: 520px) {
    .p-container .p-point-list .p-point-list_item .p-point-list_item-title {
      font-size: 14px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .p-point-list .p-point-list_item .p-point-list_item-title {
      font-size: 15px; } }
  @media screen and (min-width: 1025px) {
    .p-container .p-point-list .p-point-list_item .p-point-list_item-title {
      font-size: 16px; } }
  @media screen and (max-width: 520px) {
    .p-container .p-point-list .p-point-list_item .p-point-list_item-text {
      font-size: 12px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .p-point-list .p-point-list_item .p-point-list_item-text {
      font-size: 13px; } }
  @media screen and (min-width: 1025px) {
    .p-container .p-point-list .p-point-list_item .p-point-list_item-text {
      font-size: 14px; } }

.p-container .pickup {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1em;
	margin: 2em 0 0;
	padding: 1em;
	background: #fff;
}
@media screen and (max-width: 520px) {
    .p-container .pickup {
	    margin-bottom: 2em;
      grid-template-columns: 100%; } }

.p-container .pickup .pickup-item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  row-gap: 0;
}   

.p-container .pickup .pickup-item .pickup-item-title {
	padding: .2em;
	background: #e9719b;
	text-align: center;
	color: #fff;
}
.p-container .pickup .pickup-item .pickup-item-text {
	padding: .6em;
	background: #fbecf1;
}
@media screen and (max-width: 520px) {
    .p-container .pickup .pickup-item .pickup-item-title {
      font-size: 12px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .pickup .pickup-item .pickup-item-title {
      font-size: 13px; } }
  @media screen and (min-width: 1025px) {
    .p-container .pickup .pickup-item .pickup-item-title {
      font-size: 14px; } }
      
@media screen and (max-width: 520px) {
    .p-container .pickup .pickup-item .pickup-item-text {
      font-size: 10px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-container .pickup .pickup-item .pickup-item-text {
      font-size: 11px; } }
  @media screen and (min-width: 1025px) {
    .p-container .pickup .pickup-item .pickup-item-text {
      font-size: 12px; } }

.p-health .p-container-title {
  color: #79b424; }

.p-health .p-container-subtitle::after {
  background-image: linear-gradient(to right, #67ba5f 2px, transparent 2px); }

.p-health .p-container-nav {
  background: #eef4e2; }
  .p-health .p-container-nav .nav-link::before {
    border-left: 0.6em solid #79b424; }

@media screen and (max-width: 520px) {
  .p-health .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/health/gakka_hdr_health_sp.png); } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-health .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/health/gakka_hdr_health.png); } }

@media screen and (min-width: 1025px) {
  .p-health .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/health/gakka_hdr_health.png); } }
    
.p-health .p-container-wrap:nth-child(odd) {
  background: #eef4e2; }

.p-health .p-container-head .head-sub-text {
  color: #79b424; }

.p-health .table-of-contents {
  box-shadow: 0 0 10px rgba(115,177,115, .2); }
.p-health .table-of-contents-btn {
  background-color: #dae8c0; }
  .p-health .table-of-contents-btn .btn-text {
    color: #67ba5f; }
  .p-health .table-of-contents-btn .btn-close {
    background: #73b173; }
    
.p-health .dep-list .dep-list-item::before {
	background: #73b173; }

.p-health-bg {
  background: #eef4e2; }

.p-health .c-policy-btn-text {
  border: 1px solid #67ba5f;
  color: #67ba5f; }
  .p-health .c-policy-btn-text::before {
    border-bottom: 1px solid #67ba5f;
    border-right: 2px solid #67ba5f; }

.p-health .c-feature-item .item-text-wrap {
    box-shadow: 0 0 20px rgba(204, 209, 193, 0.3); }
.p-health .c-feature-item .item-num {
  color: #73b173; }

@media screen and (max-width: 520px) {
	.p-health .c-flow-block::before {
		background-image: linear-gradient(to bottom, #67ba5f, #67ba5f 2px, transparent 2px, transparent 10px); } }
@media print, screen and (min-width: 521px) and (max-width: 1024px) {
	.p-health .c-flow-block::before {
		background-image: linear-gradient(to bottom, #67ba5f, #67ba5f 2px, transparent 2px, transparent 10px); } }
@media screen and (min-width: 1025px) {
	.p-health .c-flow-block::before {
		background-image: linear-gradient(to bottom, #67ba5f, #67ba5f 2px, transparent 2px, transparent 14px); } }
.p-health .c-flow-annual {
  color: #72913d;
  border-style: solid;
  border-color: #d3e8ab; }
  @media screen and (max-width: 520px) {
    .p-health .c-flow-annual {
      border-width: 5px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-health .c-flow-annual {
      border-width: 8px; } }
  @media screen and (min-width: 1025px) {
    .p-health .c-flow-annual {
      border-width: 10px; } }
  .p-health .c-flow-annual.c-flow-annual-2 {
    border-color: #CCE59F; }
  .p-health .c-flow-annual.c-flow-annual-3 {
    border-color: #C4E08F; }
  .p-health .c-flow-annual.c-flow-annual-4 {
    border-color: #BBDC7F; }

.p-health .c-flow-subject .item-category .name {
  background: #f5f9f4; }

.p-health .c-flow-btn-text {
  border: 1px solid #67ba5f;
  color: #67ba5f; }
  .p-health .c-flow-btn-text::before {
    border-bottom: 1px solid #67ba5f;
    border-right: 2px solid #67ba5f; }

.p-health .c-voice-link-text {
  background: #67ba5f; }

.p-health .c-voice-page-link-text {
  border: 1px solid #67ba5f;
  color: #67ba5f; }
  .p-health .c-voice-page-link-text::before {
    border-bottom: 1px solid #67ba5f;
    border-right: 2px solid #67ba5f; }

.p-health .c-future-course .course-list-item::before {
  content: '';
  background: #73b173; }

.p-secondary .p-container-title {
  color: #e9719b; }

.p-secondary .p-container-subtitle::after {
  background-image: linear-gradient(to right, #e9719b 2px, transparent 2px); }

.p-secondary .p-container-nav {
  background: #fbecf1; }
  .p-secondary .p-container-nav .nav-link::before {
    border-left: 0.6em solid #e9719b; }

@media screen and (max-width: 520px) {
  .p-secondary .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/secondary/gakka_hdr_secondary_sp.png); } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-secondary .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/secondary/gakka_hdr_secondary.png); } }

@media screen and (min-width: 1025px) {
  .p-secondary .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/secondary/gakka_hdr_secondary.png); } }

.p-secondary .p-container-wrap:nth-child(odd) {
  background: #fbecf1; }

.p-secondary .p-container-head .head-sub-text {
  color: #de7a9b; }
  
.p-secondary .dep-list .dep-list-item::before {
	background: #e2746e; }

.p-secondary .table-of-contents {
  box-shadow: 0 0 10px rgba(222,122,155, .2); }
.p-secondary .table-of-contents-btn {
  background-color: #f5d7e1; }
  .p-secondary .table-of-contents-btn .btn-text {
    color: #e9719b; }
  .p-secondary .table-of-contents-btn .btn-close {
    background: #de7a9b; }

.p-secondary-bg {
  background: #fbecf1; }

.p-secondary .c-policy-btn-text {
  border: 1px solid #e9719b;
  color: #e9719b; }
  .p-secondary .c-policy-btn-text::before {
    border-bottom: 1px solid #e9719b;
    border-right: 2px solid #e9719b; }

.p-secondary .c-feature-item .item-text-wrap {
    box-shadow: 0 0 20px rgba(213, 200, 205, 0.3); }
.p-secondary .c-feature-item .item-num {
  color: #de7a9b; }

@media screen and (max-width: 520px) {
	.p-secondary .c-flow-block::before {
		background-image: linear-gradient(to bottom, #d68fa6, #d68fa6 2px, transparent 2px, transparent 10px); } }
@media print, screen and (min-width: 521px) and (max-width: 1024px) {
	.p-secondary .c-flow-block::before {
		background-image: linear-gradient(to bottom, #d68fa6, #d68fa6 2px, transparent 2px, transparent 10px); } }
@media screen and (min-width: 1025px) {
	.p-secondary .c-flow-block::before {
		background-image: linear-gradient(to bottom, #d68fa6, #d68fa6 2px, transparent 2px, transparent 14px); } }
.p-secondary .c-flow-annual {
  color: #d47e9a;
  border-style: solid;
  border-color: #efc5d3; }
  @media screen and (max-width: 520px) {
    .p-secondary .c-flow-annual {
      border-width: 5px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-secondary .c-flow-annual {
      border-width: 8px; } }
  @media screen and (min-width: 1025px) {
    .p-secondary .c-flow-annual {
      border-width: 10px; } }
  .p-secondary .c-flow-annual.c-flow-annual-2 {
    border-color: #EDBFCE; }
  .p-secondary .c-flow-annual.c-flow-annual-3 {
    border-color: #E9AFC2; }
  .p-secondary .c-flow-annual.c-flow-annual-4 {
    border-color: #E59FB6; }

.p-secondary .c-flow-subject .item-category .name {
  background: #f5ecef; }

.p-secondary .c-flow-btn-text {
  border: 1px solid #e9719b;
  color: #e9719b; }
  .p-secondary .c-flow-btn-text::before {
    border-bottom: 1px solid #e9719b;
    border-right: 2px solid #e9719b; }

.p-secondary .c-voice-link-text {
  background: #e9719b; }

.p-secondary .c-voice-page-link-text {
  border: 1px solid #e9719b;
  color: #e9719b; }
  .p-secondary .c-voice-page-link-text::before {
    border-bottom: 1px solid #e9719b;
    border-right: 2px solid #e9719b; }
    
.p-secondary .c-support-step-item.step-1 {
  background: #EFC5D3; }
.p-secondary .c-support-step-item.step-2 {
  background: #EDBFCE; }
.p-secondary .c-support-step-item.step-3 {
  background: #E9AFC2; }
.p-secondary .c-support-step-item.step-4 {
  background: #E59FB6; }
.p-secondary .c-support-step-item.step-5 {
  background: #E08FAA; }
.p-secondary .c-support-step-item div {
  color: #e9719b; }
.p-secondary .c-support-step-item .step-title {
  border-bottom: 1px solid #f5d7e1; }

.p-secondary .c-future-course .course-list-item::before {
  content: '';
  background: #de7a9b; }

.p-sociology .p-container-title {
  color: #3aa9df; }
.p-sociology.--sociology02 .p-container-title {
  color: var(--sociology02-color); }

.p-sociology .p-container-subtitle::after {
  background-image: linear-gradient(to right, #3aa9df 2px, transparent 2px); }
.p-sociology.--sociology02 .p-container-subtitle::after {
  background-image: linear-gradient(to right, var(--sociology02-color)c 2px, transparent 2px); }

.p-sociology .p-container-nav {
  background: #e1eef4; }
  .p-sociology .p-container-nav .nav-link::before {
    border-left: 0.6em solid #3aa9df; }

.p-sociology.--sociology02 .p-container-nav {
  background: color-mix(in srgb, var(--sociology02-bgcolor) 30%, white); }
  .p-sociology.--sociology02 .p-container-nav .nav-link::before {
    border-left: 0.6em solid var(--sociology02-color); }

@media screen and (max-width: 520px) {
  .p-sociology .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/sociology/gakka_hdr_sociology_sp.png); } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-sociology .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/sociology/gakka_hdr_sociology.png); } }

@media screen and (min-width: 1025px) {
  .p-sociology .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/sociology/gakka_hdr_sociology.png); } }
    
@media screen and (max-width: 520px) {
  .p-sociology.--sociology02 .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/sociology/gakka_hdr_sociology02_sp.png); } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-sociology.--sociology02 .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/sociology/gakka_hdr_sociology02.png); } }

@media screen and (min-width: 1025px) {
  .p-sociology.--sociology02 .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/sociology/gakka_hdr_sociology02.png); } }

.p-sociology .p-container-wrap:nth-child(odd) {
  background: #e1eef4; }
.p-sociology.--sociology02 .p-container-wrap:nth-child(odd) {
  background: color-mix(in srgb, #ffea00 10%, white); }

.p-sociology .p-container-head .head-sub-text {
  color: #3aa9df; }
  
.p-sociology .dep-list .dep-list-item::before {
	background: #3e98c8; }

.p-sociology .table-of-contents {
  box-shadow: 0 0 10px rgba(62,152,200, .2); }
.p-sociology.--sociology02 .table-of-contents {
  box-shadow: 0 0 10px rgba(255,244,61, .2); }
.p-sociology .table-of-contents-btn {
  background-color: #c8e1ec; }
  .p-sociology .table-of-contents-btn .btn-text {
    color: #3aa9df; }
  .p-sociology .table-of-contents-btn .btn-close {
    background: #3e98c8; }
.p-sociology.--sociology02 .table-of-contents-btn {
  background-color: color-mix(in srgb, var(--sociology02-bgcolor) 30%, white); }
  .p-sociology.--sociology02 .table-of-contents-btn .btn-text {
    color: var(--sociology02-color); }
  .p-sociology.--sociology02 .table-of-contents-btn .btn-close {
    background: var(--sociology02-color); }

.p-sociology-bg {
  background: #e1eef4; }
.p-sociology02-bg {
  background: color-mix(in srgb, #ffea00 10%, white); }

.c-future.p-sociology02-bg .c-future-course .course-list-item::before {
  content: '';
  background: var(--sociology02-bgcolor); }

.c-future.p-sociology02-bg .p-container-subtitle::after {
  background-image: linear-gradient(to right, var(--sociology02-color) 2px, transparent 2px); }
  

.p-sociology .c-policy-btn-text {
  border: 1px solid #3aa9df;
  color: #3aa9df; }
  .p-sociology .c-policy-btn-text::before {
    border-bottom: 1px solid #3aa9df;
    border-right: 2px solid #3aa9df; }
.p-sociology.--sociology02 .c-policy-btn-text {
  border: 1px solid var(--sociology02-color);
  color: var(--sociology02-color); }
  .p-sociology.--sociology02 .c-policy-btn-text::before {
    border-bottom: 1px solid var(--sociology02-color);
    border-right: 2px solid var(--sociology02-color); }

.p-sociology .c-feature-item .item-text-wrap {
    box-shadow: 0 0 20px rgba(188, 209, 218, 0.3); }
.p-sociology .c-feature-item .item-num {
  color: #3e98c8; }
.p-sociology.--sociology02 .c-feature-item .item-text-wrap {
    box-shadow: 0 0 20px rgba(204, 209, 193, 0.3); }
.p-sociology.--sociology02 .c-feature-item .item-num {
  color: var(--sociology02-bgcolor); }

@media screen and (max-width: 520px) {
	.p-sociology .c-flow-block::before {
		background-image: linear-gradient(to bottom, #8ec0cf, #8ec0cf 2px, transparent 2px, transparent 10px); } }
@media print, screen and (min-width: 521px) and (max-width: 1024px) {
	.p-sociology .c-flow-block::before {
		background-image: linear-gradient(to bottom, #8ec0cf, #8ec0cf 2px, transparent 2px, transparent 10px); } }
@media screen and (min-width: 1025px) {
	.p-sociology .c-flow-block::before {
		background-image: linear-gradient(to bottom, #8ec0cf, #8ec0cf 2px, transparent 2px, transparent 14px); } }
@media screen and (max-width: 520px) {
	.p-sociology.--sociology02 .c-flow-block::before {
		background-image: linear-gradient(to bottom, var(--sociology02-bgcolor), var(--sociology02-bgcolor) 2px, transparent 2px, transparent 10px); } }
@media print, screen and (min-width: 521px) and (max-width: 1024px) {
	.p-sociology.--sociology02 .c-flow-block::before {
		background-image: linear-gradient(to bottom, var(--sociology02-bgcolor), var(--sociology02-bgcolor) 2px, transparent 2px, transparent 10px); } }
@media screen and (min-width: 1025px) {
	.p-sociology.--sociology02 .c-flow-block::before {
		background-image: linear-gradient(to bottom, var(--sociology02-bgcolor), var(--sociology02-bgcolor) 2px, transparent 2px, transparent 14px); } }
.p-sociology .c-flow-annual {
  color: #50a4be;
  border-style: solid;
  border-color: #abdbe8; }
.p-sociology.--sociology02 .c-flow-annual {
  color: var(--sociology02-color);
  border-style: solid;
  border-color: var(--sociology02-bgcolor); }
  @media screen and (max-width: 520px) {
    .p-sociology .c-flow-annual {
      border-width: 5px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-sociology .c-flow-annual {
      border-width: 8px; } }
  @media screen and (min-width: 1025px) {
    .p-sociology .c-flow-annual {
      border-width: 10px; } }
  .p-sociology .c-flow-annual.c-flow-annual-2 {
    border-color: #9FD6E5; }
  .p-sociology.--sociology02 .c-flow-annual.c-flow-annual-2 {
    border-color: var(--sociology02-bgcolor); }
  .p-sociology .c-flow-annual.c-flow-annual-3 {
    border-color: #8FCFE0; }
  .p-sociology .c-flow-annual.c-flow-annual-4 {
    border-color: #7FC8DC; }
    
.p-sociology.--sociology02 .c-flow-annual-box {
	display: grid;
}
.p-sociology.--sociology02 .c-flow-annual .num {
	font-feature-settings: "palt";
    position: relative;
    left: 50%;
    translate: -50%;
}
.p-sociology.--sociology02 .c-flow-annual .annual {
	text-align: center;
}

.p-sociology .c-flow-subject .item-category .name {
  background: #edf4f5; }
.p-sociology.--sociology02 .c-flow-subject .item-category .name {
  background: var(--sociology02-bgcolor);color: var(--sociology02-color); }

.p-sociology .c-flow-btn-text {
  border: 1px solid #3aa9df;
  color: #3aa9df; }
  .p-sociology .c-flow-btn-text::before {
    border-bottom: 1px solid #3aa9df;
    border-right: 2px solid #3aa9df; }
    
.p-sociology .c-certify-btn-text {
  border: 1px solid #3aa9df;
  color: #3aa9df; }
  .p-sociology .c-certify-btn-text::before {
    border-bottom: 1px solid #3aa9df;
    border-right: 2px solid #3aa9df; }

.p-sociology .c-voice-link-text {
  background: #3aa9df; }

.p-sociology .c-voice-page-link-text {
  border: 1px solid #3aa9df;
  color: #3aa9df; }
  .p-sociology .c-voice-page-link-text::before {
    border-bottom: 1px solid #3aa9df;
    border-right: 2px solid #3aa9df; }

.p-sociology .c-future-course .course-list-item::before {
  content: '';
  background: #3e98c8; }

.p-infant .p-container-title {
  color: #ec726b; }

.p-infant .p-container-subtitle::after {
  background-image: linear-gradient(to right, #ec726b 2px, transparent 2px); }

.p-infant .p-container-nav {
  background: #fbe9e6; }
  .p-infant .p-container-nav .nav-link::before {
    border-left: 0.6em solid #ec726b; }

@media screen and (max-width: 520px) {
  .p-infant .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/infant/gakka_hdr_infant_sp.png); } }

@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .p-infant .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/infant/gakka_hdr_infant.png); } }

@media screen and (min-width: 1025px) {
  .p-infant .p-container-head {
    background-image: url(/univ/wp_univ/wp-content/themes/hgu/img/infant/gakka_hdr_infant.png); } }

.p-infant .p-container-wrap:nth-child(odd) {
  background: #fbe9e6; }

.p-infant .p-container-head .head-sub-text {
  color: #ec726b; }
  
.p-infant .dep-list .dep-list-item::before {
	background: #e2746e; }

.p-infant .table-of-contents {
  box-shadow: 0 0 10px rgba(226,116,110, .2); }
.p-infant .table-of-contents-btn {
  background-color: #f4d6d1; }
  .p-infant .table-of-contents-btn .btn-text {
    color: #ec726b; }
  .p-infant .table-of-contents-btn .btn-close {
    background: #e2746e; }

.p-infant-bg {
  background: #fbe9e6; }

.p-infant .c-policy-btn-text {
  border: 1px solid #ec726b;
  color: #ec726b; }
  .p-infant .c-policy-btn-text::before {
    border-bottom: 1px solid #ec726b;
    border-right: 2px solid #ec726b; }

.p-infant .c-feature-item .item-text-wrap {
    box-shadow: 0 0 20px rgba(212, 199, 197, 0.3); }
.p-infant .c-feature-item .item-num {
  color: #e2746e; }

@media screen and (max-width: 520px) {
	.p-infant .c-flow-block::before {
		background-image: linear-gradient(to bottom, #d6a18f, #d6a18f 2px, transparent 2px, transparent 10px); } }
@media print, screen and (min-width: 521px) and (max-width: 1024px) {
	.p-infant .c-flow-block::before {
		background-image: linear-gradient(to bottom, #d6a18f, #d6a18f 2px, transparent 2px, transparent 10px); } }
@media screen and (min-width: 1025px) {
	.p-infant .c-flow-block::before {
		background-image: linear-gradient(to bottom, #d6a18f, #d6a18f 2px, transparent 2px, transparent 14px); } }
.p-infant .c-flow-annual {
  color: #da846d;
  border-style: solid;
  border-color: #efcac5; }
  @media screen and (max-width: 520px) {
    .p-infant .c-flow-annual {
      border-width: 5px; } }
  @media print, screen and (min-width: 521px) and (max-width: 1024px) {
    .p-infant .c-flow-annual {
      border-width: 8px; } }
  @media screen and (min-width: 1025px) {
    .p-infant .c-flow-annual {
      border-width: 10px; } }
  .p-infant .c-flow-annual.c-flow-annual-2 {
	  border-color: #EEA096;
  }
  .p-infant .c-flow-annual.c-flow-annual-3 {
	  border-color: #EB9084;
  }
  .p-infant .c-flow-annual.c-flow-annual-4 {
	  border-color: #E88073;
  }

.p-infant .c-flow-subject .item-category .name {
  background: #f5ecef; }

.p-infant .c-flow-btn-text {
  border: 1px solid #ec726b;
  color: #ec726b; }
  .p-infant .c-flow-btn-text::before {
    border-bottom: 1px solid #ec726b;
    border-right: 2px solid #ec726b; }

.p-infant .c-voice-link-text {
  background: #ec726b; }

.p-infant .c-voice-page-link-text {
  border: 1px solid #ec726b;
  color: #ec726b; }
  .p-infant .c-voice-page-link-text::before {
    border-bottom: 1px solid #ec726b;
    border-right: 2px solid #ec726b; }
    
.p-infant .c-support-step-item.step-1 {
  background: #F4C0B9; }
.p-infant .c-support-step-item.step-2 {
  background: #EEA096; }
.p-infant .c-support-step-item.step-3 {
  background: #EB9084; }
.p-infant .c-support-step-item.step-4 {
  background: #E88073; }
.p-infant .c-support-step-item.step-5 {
  background: #E57161; }
.p-infant .c-support-step-item div {
  color: #ec726b; }
.p-infant .c-support-step-item .step-title {
  border-bottom: 1px solid #f4d6d1; }

.p-infant .c-future-course .course-list-item::before {
  content: '';
  background: #e2746e; }

.coming-text {
	padding: 2rem 0;
	font-feature-settings: "palt";
	text-align: center;
}
.coming-text .txt-large {
	font-weight: bold;
}
@media screen and (max-width: 520px) {
  .coming-text .txt-large {
    font-size: 24px; } }
@media print, screen and (min-width: 521px) and (max-width: 1024px) {
  .coming-text .txt-large {
    font-size: 28px; } }
@media screen and (min-width: 1025px) {
  .coming-text .txt-large {
    font-size: 32px; } }