@charset "UTF-8";
/*==========================================================================
  変数
==========================================================================*/
/*==========================================================================
  共通
==========================================================================*/
h2 {
  color: #001A43; }
  h2.border_bottom_dotted_center {
    text-align: center; }
    h2.border_bottom_dotted_center:after {
      content: "";
      display: block;
      width: 8rem;
      height: 7px;
      margin: .5em auto .5em;
      background-image: linear-gradient(to right, #EC6955, #EC6955 6px, transparent 6.5px, transparent 14px);
      background-size: 14px 7px;
      background-position: top left;
      background-repeat: repeat-x;
      background-color: transparent; }
    h2.border_bottom_dotted_center .j_icon {
      position: relative;
      display: flex;
      align-items: center;
      justify-content: center; }
      h2.border_bottom_dotted_center .j_icon::before {
        content: "";
        display: inline-block;
        background-image: url(../img/icon_book.svg);
        background-size: cover;
        background-repeat: no-repeat;
        width: 1.3em;
        height: 1em;
        margin-right: 0.5em; }
    h2.border_bottom_dotted_center .m_icon {
      position: relative;
      display: flex;
      align-items: center;
      justify-content: center; }
      h2.border_bottom_dotted_center .m_icon::before {
        content: "";
        display: inline-block;
        background-image: url(../img/icon_sem.svg);
        background-size: cover;
        background-repeat: no-repeat;
        width: 1.3em;
        height: 1em;
        margin-right: 0.5em; }

button {
  background-color: #001A43;
  color: #fff;
  border: none;
  padding: 1.5rem;
  max-width: 30rem;
  width: 100%;
  display: block;
  font-size: 1.4rem;
  text-align: center;
  margin: 0 auto;
  transition: all 0.3s ease;
  text-decoration: none;
  border-radius: 0.3rem;
  transition: all 0.3s ease;
  position: relative; }
  button::after {
    content: "";
    display: inline-block;
    background-image: url("../img/icon_link_arrow.svg");
    background-size: cover;
    background-repeat: no-repeat;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 1.5rem;
    width: 1.2em;
    height: 0.7em;
    margin-top: 0;
    margin-left: 0.5em;
    z-index: 3;
    filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%); }
  button:hover {
    cursor: pointer;
    opacity: 0.6;
    transition: all 0.3s ease; }
  button:hover {
    cursor: pointer;
    opacity: 0.6;
    transition: all 0.3s ease; }

.btn_wrap a {
  background-color: #001A43;
  color: #fff;
  border: none;
  padding: 1.5rem;
  max-width: 30rem;
  width: 100%;
  display: block;
  font-size: 1.4rem;
  text-align: center;
  margin: 0 auto;
  transition: all 0.3s ease;
  text-decoration: none;
  border-radius: 0.3rem;
  transition: all 0.3s ease; }
  .btn_wrap a:hover {
    cursor: pointer;
    opacity: 0.6;
    transition: all 0.3s ease; }
.btn_wrap.icon_link a {
  position: relative; }
  .btn_wrap.icon_link a::after {
    content: "";
    display: inline-block;
    background-image: url("../img/icon_link_arrow.svg");
    background-size: cover;
    background-repeat: no-repeat;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 1.5rem;
    width: 1.2em;
    height: 0.7em;
    margin-top: 0;
    margin-left: 0.5em;
    z-index: 3;
    filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%); }
.btn_wrap.icon_link.pdf a::after {
  background-image: url("../img/icon_pdf.svg");
  width: 1em;
  height: 1.2em;
  filter: invert(9%) sepia(75%) saturate(2120%) hue-rotate(200deg) brightness(93%) contrast(107%); }
.btn_wrap.icon_link.external_link a::after {
  background-image: url("../img/icon_external_link.svg"); }

.border_link a {
  text-decoration: underline; }
  .border_link a.back_arrow {
    position: relative;
    padding-left: 1em; }
    .border_link a.back_arrow::before {
      content: '';
      width: 6px;
      height: 6px;
      border: 0;
      border-top: solid 2px #001A43;
      border-left: solid 2px #001A43;
      transform: rotate(-45deg);
      position: absolute;
      top: 0;
      left: 0;
      bottom: 0;
      margin: auto; }

a.icon_link {
  position: relative; }
  a.icon_link::after {
    content: "";
    display: inline-block;
    background-image: url("../img/icon_pdf.svg");
    background-size: cover;
    background-repeat: no-repeat;
    width: 1em;
    height: 1.2em;
    margin-top: 0;
    margin-left: 0.5em;
    margin-right: 0.5em;
    filter: invert(9%) sepia(75%) saturate(2120%) hue-rotate(200deg) brightness(93%) contrast(107%); }
  a.icon_link.external_link::after {
    background-image: url("../img/icon_external_link.svg");
    width: 0.9em;
    height: 0.9em; }

.movie iframe {
  width: 100%;
  aspect-ratio: 16 / 9;
  max-width: 100%;
  border: 3px solid #F0F3F5; }

.section_wrap {
  width: 100%; }
  .section_wrap .section_inner {
    max-width: 1140px;
    width: 100%;
    margin: 0 auto; }

header {
  position: relative; }

nav .nav_inner {
  max-width: 1140px;
  width: 100%;
  margin: 0 auto; }
  nav .nav_inner .nav_box {
    display: flex;
    align-items: center;
    justify-content: space-between; }
    nav .nav_inner .nav_box .nav_logo {
      position: fixed;
      z-index: 3;
      left: 3%;
      top: 3rem; }
    nav .nav_inner .nav_box .log_out_btn {
      position: fixed;
      z-index: 3;
      right: 3%;
      top: 4rem;
      border: 2px solid #001A43;
      color: #001A43;
      border-radius: 100rem;
      padding: 1rem 3rem;
      font-size: 1.4rem;
      text-decoration: none; }
      nav .nav_inner .nav_box .log_out_btn span {
        position: relative;
        display: flex;
        align-items: center; }
        nav .nav_inner .nav_box .log_out_btn span::before {
          content: "";
          display: inline-block;
          background-image: url("../img/icon_user.svg");
          background-size: cover;
          background-repeat: no-repeat;
          width: 0.8em;
          height: 1.1em;
          margin-right: 0.5em;
          filter: invert(9%) sepia(62%) saturate(2436%) hue-rotate(201deg) brightness(96%) contrast(105%); }
  nav .nav_inner ul.nav-links {
    display: flex;
    column-gap: 1.5rem; }
    nav .nav_inner ul.nav-links li {
      list-style-type: none; }

footer .footer_inner {
  max-width: 1140px;
  width: 100%;
  border-top: 2px solid #001A43;
  margin: 0 auto;
  padding: 3rem 0 5rem; }
  footer .footer_inner .copyright p {
    color: #001A43;
    font-size: 1.2rem;
    letter-spacing: 2px; }

/*==========================================================================
  個別
==========================================================================*/
/*ログインページ*/
#member_login {
  background-color: #F0F3F5; }
  #member_login article#wrap {
    padding: 0 1.5rem; }
    #member_login article#wrap main {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: center; }
      #member_login article#wrap main #index_login_box.section_wrap {
        margin: 8rem auto; }
        #member_login article#wrap main #index_login_box.section_wrap .section_inner {
          background-color: #fff;
          padding: 5rem 10%;
          border-radius: 1.5rem; }
          #member_login article#wrap main #index_login_box.section_wrap .section_inner figure.user_img {
            max-width: 8rem;
            margin: 0 auto 2rem; }
          #member_login article#wrap main #index_login_box.section_wrap .section_inner .login_form_box {
            display: flex;
            flex-direction: column;
            align-items: center;
            margin: 3rem 0 1rem; }
            #member_login article#wrap main #index_login_box.section_wrap .section_inner .login_form_box form {
              display: block;
              font-size: 1.6rem;
              width: 100%; }
              #member_login article#wrap main #index_login_box.section_wrap .section_inner .login_form_box form input[type="password"] {
                width: 100%;
                padding: 1.5rem;
                border-radius: .5rem;
                border: 1px solid #001a43; }
            #member_login article#wrap main #index_login_box.section_wrap .section_inner .login_form_box button {
              margin: 2rem auto 0; }
            #member_login article#wrap main #index_login_box.section_wrap .section_inner .login_form_box .error {
              color: #EC6955;
              font-size: 1.4rem;
              margin-top: 1.5rem; }
          #member_login article#wrap main #index_login_box.section_wrap .section_inner .back_wrap {
            text-align: center; }
            #member_login article#wrap main #index_login_box.section_wrap .section_inner .back_wrap p {
              font-size: 1.4rem;
              letter-spacing: 1px; }

/*ログイン後*/
.member_template {
  background-color: #F0F3F5; }
  .member_template main {
    padding: 16rem 0 8rem;
    max-width: 1140px;
    width: 100%;
    margin: 0 auto; }
    .member_template main .main_inner {
      width: 100%;
      display: flex;
      flex-direction: row-reverse;
      align-items: flex-start;
      gap: 3%; }
    .member_template main .side_nav_box {
      width: 20%;
      height: auto;
      position: relative;
      align-self: flex-start;
      position: sticky;
      top: 15%;
      height: 100%;
      overflow-y: auto; }
      .member_template main .side_nav_box ul.nav-links {
        display: flex;
        flex-direction: column;
        grid-row-gap: 1rem;
        width: 100%;
        padding-left: 0;
        margin: 0; }
        .member_template main .side_nav_box ul.nav-links li {
          list-style-type: none; }
          .member_template main .side_nav_box ul.nav-links li a {
            background-color: #fff;
            color: #001A43;
            border-left: 3px solid #001A43;
            padding: 1.5rem;
            margin: 0;
            text-decoration: none;
            display: block;
            position: relative;
            display: flex;
            align-items: center; }
            .member_template main .side_nav_box ul.nav-links li a::before {
              content: "";
              display: inline-block;
              background-image: url("");
              background-size: cover;
              background-repeat: no-repeat;
              width: 1.3em;
              height: 1em;
              margin-right: 0.5em; }
          .member_template main .side_nav_box ul.nav-links li.h_icon a::before {
            background-image: url("../img/icon_home.svg");
            width: 1.1em;
            height: 1em; }
          .member_template main .side_nav_box ul.nav-links li.j_icon a::before {
            background-image: url("../img/icon_book.svg"); }
          .member_template main .side_nav_box ul.nav-links li.m_icon a::before {
            background-image: url("../img/icon_sem.svg"); }
          .member_template main .side_nav_box ul.nav-links li.active {
            display: none; }
    .member_template main .main_box {
      width: calc(100% - 20%); }
      .member_template main .main_box .section_wrap {
        background-color: #fff;
        margin-bottom: 5rem;
        padding: 5%;
        border-radius: 1.5rem; }
        .member_template main .main_box .section_wrap:last-child {
          margin-bottom: 0; }
      .member_template main .main_box .read_text {
        margin-bottom: 3rem;
        text-align: center; }
  .member_template#member_top_page main .main_box .btn_wrap {
    margin-top: 3rem; }
  .member_template #journal .contents_wrap .contents_head {
    margin: 0 0 3rem;
    width: 100%; }
    .member_template #journal .contents_wrap .contents_head .update {
      width: fit-content;
      margin: 0 auto;
      font-size: 1.4rem; }
      .member_template #journal .contents_wrap .contents_head .update label {
        background-color: #F0F3F5;
        color: #001A43;
        padding: 0.5em;
        border-radius: 0.5rem;
        margin-right: 1em; }
      .member_template #journal .contents_wrap .contents_head .update span {
        letter-spacing: 1px;
        font-size: 110%; }
  .member_template #journal .contents_wrap .contents_main {
    border: 1px solid #b0b9b9;
    padding: 3rem;
    margin-bottom: 3rem;
    border-radius: 1.5rem;
    display: flex;
    align-items: center;
    gap: 1.5rem; }
    .member_template #journal .contents_wrap .contents_main .journal {
      width: 50%; }
      .member_template #journal .contents_wrap .contents_main .journal .journal_inner .text_wrap {
        text-align: center;
        width: 100%; }
        .member_template #journal .contents_wrap .contents_main .journal .journal_inner .text_wrap p.journal_title {
          font-weight: bold;
          letter-spacing: 3px;
          font-size: 1.8rem;
          margin-bottom: 3rem; }
        .member_template #journal .contents_wrap .contents_main .journal .journal_inner .text_wrap .btn_wrap a {
          border: 1px solid;
          color: #001A43;
          background-color: transparent;
          padding: 1rem; }
    .member_template #journal .contents_wrap .contents_main .journal_list_wrap {
      background-color: #F0F3F5;
      padding: 1.5rem;
      border-radius: 1.5rem;
      width: 50%; }
      .member_template #journal .contents_wrap .contents_main .journal_list_wrap h5 {
        font-size: 1.8rem; }
      .member_template #journal .contents_wrap .contents_main .journal_list_wrap dl.right_border {
        margin-bottom: 0;
        padding: 0 !important;
        font-size: 1.4rem; }
        .member_template #journal .contents_wrap .contents_main .journal_list_wrap dl.right_border dt {
          width: 15%;
          padding-left: 0;
          padding-bottom: 0; }
          .member_template #journal .contents_wrap .contents_main .journal_list_wrap dl.right_border dt:last-child {
            padding-bottom: 1em; }
        .member_template #journal .contents_wrap .contents_main .journal_list_wrap dl.right_border dd {
          width: 85%;
          padding: 1em 1em 0 1em; }
          .member_template #journal .contents_wrap .contents_main .journal_list_wrap dl.right_border dd:last-child {
            padding-bottom: 1em; }
          .member_template #journal .contents_wrap .contents_main .journal_list_wrap dl.right_border dd label {
            display: block;
            width: fit-content;
            font-size: 75%;
            border: 1px solid;
            padding: 0.2em 1em;
            line-height: 1;
            border-radius: 1em; }
          .member_template #journal .contents_wrap .contents_main .journal_list_wrap dl.right_border dd ul {
            padding-left: 1em;
            margin-bottom: 0;
            font-size: 1.4rem; }
  .member_template #movie .contents_wrap .contents_head {
    margin: 0 0 3rem;
    width: 100%; }
    .member_template #movie .contents_wrap .contents_head .update {
      width: fit-content;
      margin: 0 auto;
      font-size: 1.4rem; }
      .member_template #movie .contents_wrap .contents_head .update label {
        background-color: #F0F3F5;
        color: #001A43;
        padding: 0.5em;
        border-radius: 0.5rem;
        margin-right: 1em; }
      .member_template #movie .contents_wrap .contents_head .update span {
        letter-spacing: 1px;
        font-size: 110%; }
  .member_template #movie .contents_wrap .contents_main {
    border: 1px solid #b0b9b9;
    padding: 3rem;
    margin-bottom: 3rem;
    border-radius: 1.5rem; }
    .member_template #movie .contents_wrap .contents_main .title h3 {
      font-size: 1.8rem;
      text-align: center;
      letter-spacing: 1px; }
    .member_template #movie .contents_wrap .contents_main .flex_box {
      display: flex;
      flex-direction: column;
      width: 100%;
      gap: 1.5rem; }
      .member_template #movie .contents_wrap .contents_main .flex_box .movie {
        width: 100%; }
      .member_template #movie .contents_wrap .contents_main .flex_box .list_wrap {
        width: 100%; }
    .member_template #movie .contents_wrap .contents_main:last-child {
      margin-bottom: 0; }
    .member_template #movie .contents_wrap .contents_main ul.note_list {
      margin: 1.5rem 0 0; }
  .member_template #movie .contents_wrap .list_wrap {
    background-color: #F0F3F5;
    padding: 1.5rem;
    border-radius: 1.5rem;
    width: 50%; }
    .member_template #movie .contents_wrap .list_wrap h5 {
      font-size: 1.8rem; }
    .member_template #movie .contents_wrap .list_wrap dl.right_border {
      margin-bottom: 0;
      padding: 0 !important;
      font-size: 1.4rem; }
      .member_template #movie .contents_wrap .list_wrap dl.right_border dt {
        width: 15%;
        padding-bottom: 0; }
        .member_template #movie .contents_wrap .list_wrap dl.right_border dt:last-child {
          padding-bottom: 1em; }
      .member_template #movie .contents_wrap .list_wrap dl.right_border dd {
        width: 85%;
        padding: 1em 1em 0 1em; }
        .member_template #movie .contents_wrap .list_wrap dl.right_border dd:last-child {
          padding-bottom: 1em; }
        .member_template #movie .contents_wrap .list_wrap dl.right_border dd label {
          display: block;
          width: fit-content;
          font-size: 75%;
          border: 1px solid;
          padding: 0.2em 1em;
          line-height: 1;
          border-radius: 1em; }
        .member_template #movie .contents_wrap .list_wrap dl.right_border dd ul {
          padding-left: 1em;
          margin-bottom: 0;
          font-size: 1.4rem; }
  .member_template.member_journal #journal .contents_wrap p.none_text {
    text-align: center;
    font-weight: bold;
    font-size: 1.6rem;
    color: #EC6955;
    margin: 3rem 0;
    background: #ffeeee;
    border-radius: 1.5rem;
    padding: 3rem; }
  .member_template.member_journal #journal .contents_wrap ul.note_list {
    text-align: center; }

.for_PC,
.forPC {
  display: block; }

.for_SP,
.forSP {
  display: none; }

/*==========================================================================
  レスポンシブ設定
==========================================================================*/
/*for SP*/
@media (max-width: 768px) {
  h2.border_bottom_dotted_center {
    font-size: 2.2rem; }
    h2.border_bottom_dotted_center:after {
      margin: .25em auto .5em; }

  #member_login article#wrap main #index_login_box.section_wrap {
    margin: 3rem auto 3rem; }
    #member_login article#wrap main #index_login_box.section_wrap .section_inner {
      padding: 3rem 5%; }
  #member_login footer {
    padding: 0; }
    #member_login footer .footer_inner {
      padding: 3rem 0 3rem; }

  nav .nav_inner {
    padding: 0;
    left: 0;
    position: fixed;
    z-index: 3;
    background: #F0F3F5;
    padding: 1.5rem; }
    nav .nav_inner .nav_box .nav_logo {
      position: static;
      width: 16rem; }
    nav .nav_inner .nav_box .log_out_btn {
      padding: 0.5rem 1.5rem;
      font-size: 1.2rem;
      position: static; }

  footer {
    padding: 0 5%; }
    footer .footer_inner {
      padding: 3rem 0 10rem; }
      footer .footer_inner .copyright {
        margin-top: 1.5rem; }
        footer .footer_inner .copyright p {
          font-size: 1rem;
          letter-spacing: 1px; }
      footer .footer_inner .footer_logo {
        width: 20rem; }
        footer .footer_inner .footer_logo a {
          margin: 0; }

  .member_template main {
    padding: 10rem 5% 3rem; }
    .member_template main .main_inner {
      display: block; }
    .member_template main .main_box {
      width: 100%; }
      .member_template main .main_box .section_wrap {
        margin-bottom: 3rem;
        padding: 3rem 5%; }
      .member_template main .main_box .read_text {
        text-align: left; }
    .member_template main .side_nav_box {
      position: fixed;
      z-index: 5;
      bottom: 0;
      top: auto !important;
      width: 100%;
      height: auto;
      left: 0;
      box-shadow: 5px 5px 5px 10px rgba(0, 0, 0, 0.1); }
      .member_template main .side_nav_box ul.nav-links {
        display: flex;
        flex-direction: row;
        gap: 1rem;
        background: #F0F3F5;
        padding: 1.5rem; }
        .member_template main .side_nav_box ul.nav-links li {
          width: fit-content; }
          .member_template main .side_nav_box ul.nav-links li a {
            width: fit-content;
            border-radius: 0.3rem;
            border: none;
            text-align: center;
            padding: 1rem;
            box-shadow: 2px 2px 0px 0px #001A43; }
  .member_template #journal .contents_wrap .contents_main {
    flex-direction: column;
    padding: 3rem 5% 1.5rem;
    gap: 3rem; }
    .member_template #journal .contents_wrap .contents_main .journal {
      width: 100%; }
      .member_template #journal .contents_wrap .contents_main .journal .journal_inner .text_wrap p.journal_title {
        margin: 0 0 1.5rem;
        font-size: 1.6rem; }
      .member_template #journal .contents_wrap .contents_main .journal .journal_inner .text_wrap .btn_wrap a {
        width: 20rem; }
    .member_template #journal .contents_wrap .contents_main .journal_list_wrap {
      width: 100%; }
      .member_template #journal .contents_wrap .contents_main .journal_list_wrap dl.right_border {
        flex-direction: column; }
        .member_template #journal .contents_wrap .contents_main .journal_list_wrap dl.right_border dt {
          width: 100%;
          padding: 0 0 0.5rem;
          border-right: none;
          border-bottom: 1px solid #b0b9b9; }
        .member_template #journal .contents_wrap .contents_main .journal_list_wrap dl.right_border dd {
          width: 100%;
          padding: 0.5rem 0 0 !important; }
  .member_template #movie .contents_wrap .contents_main {
    flex-direction: column;
    padding: 3rem 5%;
    gap: 3rem; }
    .member_template #movie .contents_wrap .contents_main .title h3 {
      font-size: 1.6rem;
      text-align: left;
      letter-spacing: 0px; }
    .member_template #movie .contents_wrap .contents_main .flex_box {
      flex-direction: column; }
      .member_template #movie .contents_wrap .contents_main .flex_box .movie {
        width: 100%; }
      .member_template #movie .contents_wrap .contents_main .flex_box .list_wrap {
        width: 100%; }
        .member_template #movie .contents_wrap .contents_main .flex_box .list_wrap dl.right_border {
          flex-direction: column; }
          .member_template #movie .contents_wrap .contents_main .flex_box .list_wrap dl.right_border dt {
            width: 100%;
            padding: 0 0 0.5rem;
            border-right: none;
            border-bottom: 1px solid #b0b9b9; }
          .member_template #movie .contents_wrap .contents_main .flex_box .list_wrap dl.right_border dd {
            width: 100%;
            padding: 0.5rem 0 0 !important; }
  .member_template.member_journal #journal .contents_wrap ul.note_list {
    text-align: left; }

  .for_PC,
  .forPC {
    display: none; }

  .for_SP,
  .forSP {
    display: block; } }
