@charset "UTF-8";
/*
Author: c.nz
Version: 1.0
*/
/* ---------------------------------------------------
	acms リセット
------------------------------------------------------ */
.acms-entry .entry-container {
  margin: 0; }

.entry {
  border: none;
  width: 100%;
  max-width: 100%;
  margin: 0 auto 50px; }

.entry-title {
  text-align: center;
  font-size: 30px;
  line-height: 1.2;
  font-weight: 500; }

.acms-grid, .acms-grid-r {
  margin: 0; }

.entry-column tr:nth-child(odd) {
  background: none; }

.acms-admin-form .acms-admin-form-select, .acms-admin-form select {
  -moz-appearance: none;
  -webkit-appearance: none; }

/* メディアユニットの調整 */
.acms-entry [class*=column-eximage], .acms-entry [class*=column-media], .acms-entry [class*=column-video], .acms-entry [class*=column-youtube] {
  padding-left: 0;
  padding-right: 0; }

.acms-entry [class*=column-media].img-full {
  width: 100%;
  max-width: 100%; }

.acms-entry [class*=column-media].acms-col-sm-12,
.acms-entry [class*=column-media].acms-col-sm-10,
.acms-entry [class*=column-media].acms-col-sm-8,
.acms-entry [class*=column-media].acms-col-sm-6,
.acms-entry [class*=column-media].acms-col-sm-4 {
  width: 100%; }

.acms-entry [class*=column-media-auto],
.acms-entry [class*=column-media-left],
.acms-entry [class*=column-media-center],
.acms-entry [class*=column-media-right] {
  float: none; }

.acms-entry [class*=column-media-auto] > * {
  margin-right: auto; }

.acms-entry [class*=column-media-left] > * {
  margin-right: auto; }

.acms-entry [class*=column-media-center] > * {
  margin: auto; }

.acms-entry [class*=column-media-right] > * {
  margin-left: auto; }

.acms-entry [class*=column-media-auto] > a,
.acms-entry [class*=column-media-left] > a,
.acms-entry [class*=column-media-center] > a,
.acms-entry [class*=column-media-right] > a {
  display: inline-block; }

.acms-entry [class*=column-media].img-full > * {
  max-width: 100%; }

.acms-entry [class*=column-media].img-full > img,
.acms-entry [class*=column-media].img-full > a,
.acms-entry [class*=column-media].img-full > a > img {
  width: 100%; }

.acms-entry [class*=column-media].acms-col-sm-12 > * {
  width: 100%;
  max-width: 1200px; }

.acms-entry [class*=column-media].acms-col-sm-10 > * {
  width: 100%;
  max-width: 1000px; }

.acms-entry [class*=column-media].acms-col-sm-8 > * {
  width: 100%;
  max-width: 800px; }

.acms-entry [class*=column-media].acms-col-sm-6 > * {
  width: 100%;
  max-width: 600px; }

.acms-entry [class*=column-media].acms-col-sm-4 > * {
  width: 100%;
  max-width: 400px; }

.entry-column em {
  /*font-style: italic;*/
  font-style: normal;
  font-weight: bold;
  text-decoration: underline; }

.message-back-link {
  display: inline-block;
  margin: 50px auto;
  text-align: center;
  border: none;
  padding: 10px 20px; }

/* ---------------------------------------------------
	ダイレクト編集用調整
------------------------------------------------------ */
.js-edit_inplace-hovering {
  width: 100% !important;
  max-width: 100%; }

.acms-admin-table-admin-edit th {
  width: auto; }

/* ---------------------------------------------------
	グループ用調整
------------------------------------------------------ */
.acms-grid > * {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto; }

@media screen and (max-width: 1024px) {
  .acms-grid > * {
    max-width: 960px; } }
@media print {
  .acms-grid > * {
    max-width: 960px; } }
/* yahBGカラー */
[class*=group-bg-] {
  max-width: 100%;
  padding: 100px 0; }
  [class*=group-bg-] > * {
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto; }

@media screen and (max-width: 1024px) {
  [class*=group-bg-] > * {
    max-width: 960px; } }
@media print {
  [class*=group-bg-] > * {
    max-width: 960px; } }
.group-bg-gray {
  background: #eee; }

.group-bg-blue {
  background: #F0F9FD; }

/* カラム */
.l-2col-l {
  width: 590px;
  max-width: 590px;
  margin-left: calc((100% - 1200px) / 2);
  margin-right: 10px; }

.l-2col-r {
  width: 590px;
  max-width: 590px;
  margin-right: calc((100% - 1200px) / 2);
  margin-left: 10px; }

.l-3col-l {
  float: left;
  width: 384px;
  max-width: 384px;
  margin-left: calc((100% - 1200px) / 2); }

.l-3col-c {
  float: left;
  width: 384px;
  max-width: 384px;
  margin: 0 24px; }

.l-3col-r {
  float: left;
  width: 384px;
  max-width: 384px;
  margin-right: calc((100% - 1200px) / 2); }

@media screen and (max-width: 1280px) {
  /* カラム */
  .l-2col-l {
    width: calc(100vw * (590 / 1280));
    margin-left: calc((100% - (100vw * (1200 / 1280))) / 2);
    margin-right: calc(100vw * (10 / 1280)); }

  .l-2col-r {
    width: calc(100vw * (590 / 1280));
    margin-right: calc((100% - (100vw * (1200 / 1280))) / 2);
    margin-left: calc(100vw * (10 / 1280)); }

  .l-3col-l {
    float: left;
    width: calc(100vw * (384 / 1280));
    max-width: 384px;
    margin-left: calc((100% - (100vw * (1200 / 1280))) / 2); }

  .l-3col-c {
    float: left;
    width: calc(100vw * (384 / 1280));
    max-width: 384px;
    margin: 0 calc(100vw * (24 / 1280)); }

  .l-3col-r {
    float: left;
    width: calc(100vw * (384 / 1280));
    max-width: 384px;
    margin-right: calc((100% - (100vw * (1200 / 1280))) / 2); } }
@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .acms-grid > * {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;}

  /* yahBGカラー */
  [class*=group-bg-] {
    max-width: 100%;
    padding: 50px 0; }
    [class*=group-bg-] > * {
      max-width: 100%; }

  /* カラム */
  .l-2col-l {
    width: 100%;
    max-width: 100%;
    margin-left: 0; }

  .l-2col-r {
    width: 100%;
    max-width: 100%;
    margin-right: 0; }

  .l-3col-l {
    float: none;
    width: 100%;
    max-width: 100%;
    margin-left: 0; }

  .l-3col-c {
    float: left;
    width: 100%;
    max-width: 100%;
    margin: 0; }

  .l-3col-r {
    float: left;
    width: 100%;
    max-width: 100%;
    margin-right: 0; } }
@media print {
  .l-2col-l {
    width: 480px;
    margin-left: 10px;
    margin-right: 10px; }

  .l-2col-r {
    width: 480px;
    margin-right: 10px;
    margin-left: 10px; }

  .l-3col-l {
    float: left;
    width: 320px;
    max-width: 320px;
    margin-left: 10px; }

  .l-3col-c {
    float: left;
    width: 320px;
    max-width: 320px;
    margin: 0 10px; }

  .l-3col-r {
    float: left;
    width: 320px;
    max-width: 320px;
    margin-right: 10px; } }
/* ---------------------------------------------------
	汎用ユニット
------------------------------------------------------ */
.entry-column {
  counter-reset: flow;
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; }
  .entry-column h2 {
    /* 見出し大 */
    font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-weight: 600;
    font-style: normal;
    font-size: 3.6rem;
    line-height: 1.4;
    color: #222;
    margin: 0 auto 50px;
    padding: 0;
    border-left: none;
    letter-spacing: 0.1em; }
  .entry-column h3 {
    /* 見出し中 */
    font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-weight: 500;
    font-style: normal;
    font-size: 3.2rem;
    line-height: 1.4;
    color: #24ABE8;
    margin: 0 auto 30px;
    padding: 0;
    background: none;
    letter-spacing: 0.05em; }
    .entry-column h3.tit-flow {
      padding-left: 50px;
      font-size: 2.8rem;
      text-align: left;
      position: relative;
      color: #24ABE8; }
      .entry-column h3.tit-flow::before {
        content: counter(flow);
        counter-increment: flow 1;
        position: absolute;
        top: 0;
        left: 0;
        margin-top: 0;
        letter-spacing: 0;
        font-size: 2.4rem;
        font-weight: 400;
        line-height: 1; }
  .entry-column h4 {
    /* 見出し小 */
    font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    position: relative;
    font-weight: 500;
    font-style: normal;
    font-size: 2.6rem;
    line-height: 1.4;
    color: #222;
    padding: 0;
    padding-bottom: 12px;
    margin: 0 auto 30px; }
    .entry-column h4::before {
      content: "";
      display: inline-block;
      width: 100px;
      height: 2px;
      background: #C2A33C;
      position: absolute;
      left: 0;
      bottom: 0; }
    .entry-column h4.taC {
      text-align: center; }
      .entry-column h4.taC::before {
        left: 50%;
        transform: translateX(-50%); }


  .entry-column .contact-box h3 {
    /* 見出し小 */
    font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    position: relative;
    font-weight: 500;
    font-style: normal;
    font-size: 2.6rem;
    line-height: 1.4;
    color: #222;
    padding: 0;
    padding-bottom: 12px;
    margin: 0 auto 30px;
    letter-spacing: 0;}
    .entry-column .contact-box h3::before {
      content: "";
      display: inline-block;
      width: 100px;
      height: 2px;
      background: #C2A33C;
      position: absolute;
      left: 0;
      bottom: 0; }


  .entry-column h5 {
    /* 小見出し */
    font-weight: 700;
    font-style: normal;
    font-size: 2rem;
    line-height: 1.4;
    padding: 0;
    margin: 0 auto 20px; }

    .entry-column .contact-box h4.sub-tit {
    font-weight: 700;
    font-style: normal;
    font-size: 2rem;
    line-height: 1.4;
    padding: 0;
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    color: #333;
    margin: 50px auto 20px;}
    .entry-column .contact-box h4.sub-tit::before {
    display: none;}
    
  .entry-column p {
    /* 本文 */
    font-size: 1.7rem;
    line-height: 2;
    margin: 0 auto 40px;
    padding: 0; }
    .entry-column p span.taL {
      display: block; }
    .entry-column p span.taC {
      display: block; }
    .entry-column p span.taR {
      display: block; }
    .entry-column p.flow-txt {
      margin: 0; }
  .entry-column ul, .entry-column ol {
    /* リスト */
    padding: 0;
    margin: 0 auto; }
    .entry-column ul li, .entry-column ol li {
      padding: 0;
      margin: 0;
      font-size: 1.7rem;
      line-height: 2; }
  .entry-column ul {
    margin-bottom: 40px;
    list-style: none; }
    .entry-column ul li {
      padding-left: 25px;
      background: url(../images/common/ico-li@2x.png) no-repeat 0 5px;
      background-size: 20px 20px;
      margin-bottom: 5px; }
  .entry-column ol {
    counter-reset: oldef;
    margin-bottom: 40px;
    list-style: none; }
    .entry-column ol li {
      padding-left: 30px;
      position: relative;
      margin-bottom: 5px; }
      .entry-column ol li::before {
        counter-increment: oldef;
        content: counter(oldef);
        color: #222;
        font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
        font-style: normal;
        font-weight: 500;
        font-size: 1.8rem;
        display: block;
        width: 20px;
        position: absolute;
        top: 0;
        left: 0;
        text-align: center;
        line-height: 1.5; }

.column-map-auto, .column-map-left {
  margin-bottom: 40px; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  h2.entry-title {
    font-size: 2.4rem;
    margin: 0 auto 20px;
    padding: 0 10px; }

  .entry-column h2 {
    font-size: 2.4rem;
    margin: 0 auto 20px;
    padding: 0 10px; }
  .entry-column h3 {
    font-size: 2.2rem;
    margin: 0 auto 20px;
    padding: 0 10px; }
  .entry-column h4 {
    font-size: 2rem;
    width: calc(100% - 20px);
    margin: auto;
    margin-bottom: 20px;
    padding: 0 0 13px; }
    .entry-column h4::after {
      width: 100px; }
    
    .entry-column .contact-box h3 {
    font-size: 2rem;
    width: calc(100% - 20px);
    margin: auto;
    margin-bottom: 20px;
    padding: 0 0 13px; }
    .entry-column .contact-box h3::after {
      width: 100px; }
    
    
  .entry-column h5 {
    font-size: 1.8rem;
    padding: 0 10px;
    margin: 0 auto 10px; }
    .entry-column .contact-box h4.sub-tit {
    font-size: 1.8rem;
    padding: 0 10px;
    margin: 50px auto 10px;
    width: 100%;}
  .entry-column p {
    font-size: 1.6rem;
    padding: 0 10px;
    margin-bottom: 20px; }
    .entry-column p.taC {
      text-align: left; }
    .entry-column p iframe {
      width: 100%; }
  .entry-column ul, .entry-column ol {
    margin-bottom: 40px;
    padding: 0 10px; }

  .column-map-auto, .column-map-left {
    margin-bottom: 20px; }

  .gmap iframe {
    width: 100%; } }
/* ---------------------------------------------------
	テキストリンク
------------------------------------------------------ */
.txt-link {
  justify-content: flex-start;
  margin-bottom: 40px; }
  .txt-link .row_col {
    display: inline-block;
    margin-right: 60px;
    margin-bottom: 20px; }
    .txt-link .row_col a {
      position: relative;
      display: inline-block;
      padding: 0;
      color: #24ABE8;
      line-height: 2;
      text-align: left;
      text-decoration: underline; }
      .txt-link .row_col a:hover {
        color: #222;
        text-decoration: none;
        opacity: 1; }
      .txt-link .row_col a[href^="#"]::after {
        content: "";
        display: inline-block;
        width: 14px;
        height: 8px;
        background: url("../images/common/ico-arrow-bottom.svg") no-repeat center/contain;
        margin-left: 8px;
        vertical-align: middle; }
    .txt-link .row_col.blank a::after {
      content: "";
      display: inline-block;
      width: 16px;
      height: 16px;
      vertical-align: middle;
      margin-left: 10px;
      background: url(../images/common/ico-blank@2x.png) no-repeat center;
      background-size: cover; }
  .txt-link.row-l {
    justify-content: flex-start; }
    .txt-link.row-l .row_col {
      text-align: left; }
  .txt-link.row-c {
    justify-content: center; }
    .txt-link.row-c .row_col {
      text-align: center; }
  .txt-link.row-r {
    justify-content: flex-end; }
    .txt-link.row-r .row_col {
      text-align: right; }
  .txt-link.num-1 .row_col {
    display: inline-block;
    width: 100%;
    margin-right: 0; }
  .txt-link.num-2 .row_col {
    display: inline-block;
    width: 49%;
    margin-right: 2%; }
    .txt-link.num-2 .row_col:nth-child(2n) {
      margin-right: 0; }
    .txt-link.num-2 .row_col:last-child {
      margin-right: 0; }
  .txt-link.num-3 .row_col {
    display: inline-block;
    width: 32%;
    margin-right: 2%; }
    .txt-link.num-3 .row_col:nth-child(3n) {
      margin-right: 0; }
    .txt-link.num-3 .row_col:last-child {
      margin-right: 0; }
  .txt-link.num-4 .row_col {
    display: inline-block;
    width: 23.5%;
    margin-right: 2%; }
    .txt-link.num-4 .row_col:nth-child(4n) {
      margin-right: 0; }
    .txt-link.num-4 .row_col:last-child {
      margin-right: 0; }

p a.txtlink {
  position: relative;
  display: inline-block;
  padding: 0;
  color: #24ABE8;
  line-height: 2;
  text-align: left; }
  p a.txtlink:link {
    text-decoration: underline; }
  p a.txtlink:hover {
    color: #222;
    text-decoration: none;
    opacity: 1; }
  p a.txtlink:visited {
    color: #24ABE8; }
  p a.txtlink[href^="#"]::after {
    content: "";
    display: inline-block;
    width: 16px;
    height: 16px;
    vertical-align: middle;
    margin-left: 10px;
    background: url(../images/common/ico-blank@2x.png) no-repeat center;
    background-size: cover; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .txt-link {
    padding: 0 10px;
    margin-bottom: 20px; }
    .txt-link .row_col {
      margin-right: 0; }
    .txt-link.num-2 .row_col {
      width: 100%;
      margin-right: 0; }
    .txt-link.num-3 .row_col {
      width: 100%;
      margin-right: 0; }
    .txt-link.num-4 .row_col {
      width: 100%;
      margin-right: 0; } }
@media screen and (max-width: 896px) and (orientation: landscape) {
  .txt-link {
    padding: 0 10px; } }
/* ---------------------------------------------------
	ボタンリンク
------------------------------------------------------ */
a.btn-link, .btn-link, .btnlink .row_col a {
  font-family: "Noto Serif JP";
  position: relative;
  display: inline-block;
  min-width: 0;
  width: 100%;
  max-width: 100%;
  padding: 15px 50px 16px;
  border: none;
  color: #222;
  font-size: 2rem;
  font-weight: 500;
  text-align: center;
  text-decoration: none;
  background-color: #FFF;
  border-radius: 100px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25); }

.btn-link::after {
  content: "";
  position: absolute;
  right: 30px;
  display: block;
  width: 9px;
  height: 15px;
  top: 50%;
  transform: translateY(-50%);
  background: url("../images/common/ico-arrow-right.svg") no-repeat center;
  background-size: 100%; }

.btnlink .row_col a.icon-pdf, .btnlink .row_col a.icon-doc, .btnlink .row_col a.icon-xls, .btnlink .row_col a.icon-ppt, .btnlink .row_col a.icon-file {
  border-radius: 0;
  box-shadow: none;
  color: #FFF;
  background: #C2A33C; }

.btn-link[target="_blank"]::after, .btnlink .row_col.blank a::after {
  content: "";
  position: absolute;
  right: 30px;
  display: block;
  width: 16px;
  height: 16px;
  top: 50%;
  transform: translateY(-50%);
  background: url("../images/common/ico-blank.svg") no-repeat center;
  background-size: 100%; }

.btnlink .row_col a.icon-pdf::before, .btnlink .row_col.blank a[href$=".pdf"]::before {
  content: "";
  position: absolute;
  top: 62%;
  left: 30px;
  display: block;
  width: 18px;
  height: 24px;
  margin-top: auto;
  top: 50%;
  transform: translateY(-50%);
  background: url("../images/common/ico-pdf.svg") no-repeat center;
  background-size: 100%; }

.btnlink .row_col a.icon-doc::before, .btnlink .row_col.blank a[href$=".doc"]::before, .btnlink .row_col.blank a[href$=".docx"]::before {
  content: "";
  position: absolute;
  top: 62%;
  left: 30px;
  display: block;
  width: 18px;
  height: 24px;
  margin-top: auto;
  top: 50%;
  transform: translateY(-50%);
  background: url("../images/common/ico-word.svg") no-repeat center;
  background-size: 100%; }

.btnlink .row_col a.icon-xls::before, .btnlink .row_col.blank a[href$=".xls"]::before, .btnlink .row_col.blank a[href$=".xlsx"]::before {
  content: "";
  position: absolute;
  top: 62%;
  left: 30px;
  display: block;
  width: 18px;
  height: 24px;
  margin-top: auto;
  top: 50%;
  transform: translateY(-50%);
  background: url("../images/common/ico-xlxs.svg") no-repeat center;
  background-size: 100%; }

.btnlink .row_col a.icon-ppt::before, .btnlink .row_col.blank a[href$=".ppt"]::before, .btnlink .row_col.blank a[href$=".pptx"]::before {
  content: "";
  position: absolute;
  top: 62%;
  left: 30px;
  display: block;
  width: 18px;
  height: 24px;
  margin-top: auto;
  top: 50%;
  transform: translateY(-50%);
  background: url("../images/common/ico-ppt.svg") no-repeat center;
  background-size: 100%; }

.btnlink .row_col a.icon-file::before {
  content: "";
  position: absolute;
  top: 62%;
  left: 30px;
  display: block;
  width: 18px;
  height: 24px;
  margin-top: auto;
  top: 50%;
  transform: translateY(-50%);
  background: url("../images/common/ico-folder.svg") no-repeat center;
  background-size: 100%;
  width: 20px;
  height: 15px; }

.btnlink .row_col a.icon-pdf, .btnlink .row_col a.icon-doc, .btnlink .row_col a.icon-xls, .btnlink .row_col a.icon-ppt, .btnlink .row_col a.icon-file, .btnlink .row_col.blank a[href$=".pdf"], .btnlink .row_col.blank a[href$=".doc"], .btnlink .row_col.blank a[href$=".docx"], .btnlink .row_col.blank a[href$=".xls"], .btnlink .row_col.blank a[href$=".xlsx"], .btnlink .row_col.blank a[href$=".ppt"], .btnlink .row_col.blank a[href$=".pptx"] {
  padding: 25px 50px 25px 70px;
  text-align: left; }
  .btnlink .row_col a.icon-pdf:hover, .btnlink .row_col a.icon-doc:hover, .btnlink .row_col a.icon-xls:hover, .btnlink .row_col a.icon-ppt:hover, .btnlink .row_col a.icon-file:hover, .btnlink .row_col.blank a[href$=".pdf"]:hover, .btnlink .row_col.blank a[href$=".doc"]:hover, .btnlink .row_col.blank a[href$=".docx"]:hover, .btnlink .row_col.blank a[href$=".xls"]:hover, .btnlink .row_col.blank a[href$=".xlsx"]:hover, .btnlink .row_col.blank a[href$=".ppt"]:hover, .btnlink .row_col.blank a[href$=".pptx"]:hover {
    background: #C2A33C; }

.btnlink {
  justify-content: flex-start;
  margin-bottom: 60px;
  font-feature-settings: "palt"; }
  .btnlink .row_col {
    width: auto;
    max-width: 100%;
    margin-bottom: 20px; }
  .btnlink.row-l {
    justify-content: flex-start;
    text-align: left; }
    .btnlink.row-l .row_col {
      margin-right: auto; }
  .btnlink.row-c {
    justify-content: center;
    text-align: center; }
    .btnlink.row-c .row_col {
      margin-right: auto;
      margin-left: initial; }
  .btnlink.row-r {
    justify-content: flex-end;
    text-align: right; }
    .btnlink.row-r .row_col {
      margin-left: auto; }
  .btnlink.num-1 {
    display: block;
    width: 100%; }
    .btnlink.num-1 .row_col {
      max-width: fit-content; }
  .btnlink.num-2 .row_col {
    width: 49%;
    max-width: 49%;
    margin-right: 2%; }
    .btnlink.num-2 .row_col:nth-child(2n), .btnlink.num-2 .row_col:last-child {
      margin-right: 0; }
  .btnlink.num-3 .row_col {
    width: 30%;
    max-width: 30%;
    margin-right: 5%; }
    .btnlink.num-3 .row_col:nth-child(3n), .btnlink.num-3 .row_col:last-child {
      margin-right: 0; }
  .btnlink.num-4 .row_col {
    width: 23.5%;
    max-width: 23.5%;
    margin-right: 2%; }
    .btnlink.num-4 .row_col:nth-child(4n), .btnlink.num-4 .row_col:last-child {
      margin-right: 0; }

a.btn-link {
  width: auto;
  margin-bottom: 10px; }
  a.btn-link::after {
    content: none; }
  a.btn-link:hover {
    text-decoration: none;
    background: #F6F6F6;
    border-radius: 100px; }
  a.btn-link[target="_blank"]::after {
    margin-top: 0; }

.btn-link {
  width: auto;
  margin-right: 10px;
  line-height: 1.2;
  padding: 0; }
  .btn-link::after:hover {
    content: none; }
  .btn-link a {
    display: block;
    padding: 15px 50px 16px; }
    .btn-link a:hover {
      text-decoration: none;
      background: #F6F6F6;
      border-radius: 100px; }

.btnlink .row_col a:hover {
  background: #F6F6F6; }
.btnlink .row_col a::after {
  content: none; }
.btnlink .row_col a[href^="#"] {
  padding: 20px 20px 30px;
  text-align: center;
  border: 1px solid #C2A33C; }
  .btnlink .row_col a[href^="#"]::after {
    content: "";
    position: absolute;
    top: auto;
    right: auto;
    left: 50%;
    bottom: 12px;
    display: block;
    width: 20px;
    height: 10px;
    margin-left: -10px;
    background: url("../images/common/ico-arrow-bottom.svg") no-repeat center;
    background-size: 100%;
    transition: transform .2s; }
  .btnlink .row_col a[href^="#"]:hover {
    opacity: 1; }
    .btnlink .row_col a[href^="#"]:hover::after {
      transform: translateY(2px); }
.btnlink .row_col.blank a::after {
  margin-top: auto; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .btnlink {
    display: block;
    margin-bottom: 30px;
    padding: 0 10px; }

  .btnlink .row_col {
    width: 100%;
    max-width: 100%;
    margin-right: 0;
    margin-bottom: 10px; }

  .btnlink .row_col:last-of-type {
    margin-bottom: 0; }

  .btnlink.num-2 .row_col {
    width: 100%;
    max-width: 100%;
    margin-right: 0; }

  .btnlink.num-3 .row_col {
    width: 100%;
    max-width: 100%;
    margin-right: 0; }

  .btnlink.num-4 .row_col {
    width: 100%;
    max-width: 100%;
    margin-right: 0; }

  .btn-link::after,
  .btnlink .row_col a::after {
    right: 30px; }

  a[target="_blank"].btn-link::after,
  .btnlink .row_col.blank a::after {
    right: 25px; }

  .btn-link {
    margin-right: 0;
    margin-top: 10px; } }
@media screen and (max-width: 896px) and (orientation: landscape) {
  .btnlink {
    padding: 0 10px; }

  .btn-link,
  .btnlink .row_col a {
    padding: 25px; }

  .btn-link::after,
  .btnlink .row_col a::after {
    right: 10px; }

  a[target="_blank"].btn-link::after,
  .btnlink .row_col.blank a::after {
    right: 10px; }

  /* ファイルアイコン */
  .btnlink .row_col a.icon-pdf, .btnlink .row_col.blank a[href$=".pdf"], .btnlink .row_col a.icon-doc, .btnlink .row_col.blank a[href$=".doc"], .btnlink .row_col.blank a[href$=".docx"], .btnlink .row_col a.icon-xls, .btnlink .row_col.blank a[href$=".xls"], .btnlink .row_col.blank a[href$=".xlsx"], .btnlink .row_col a.icon-ppt, .btnlink .row_col.blank a[href$=".ppt"], .btnlink .row_col.blank a[href$=".pptx"], .btnlink .row_col a.icon-file {
    padding: 25px 36px 25px 40px; }

  /* ー＊ー＊ー＊ー＊ー */
  .btnlink .row_col a.icon-pdf::before, .btnlink .row_col.blank a[href$=".pdf"]::before {
    left: 10px; }

  .btnlink .row_col a.icon-doc::before, .btnlink .row_col.blank a[href$=".doc"]::before, .btnlink .row_col.blank a[href$=".docx"]::before {
    left: 10px; }

  .btnlink .row_col a.icon-xls::before, .btnlink .row_col.blank a[href$=".xls"]::before, .btnlink .row_col.blank a[href$=".xlsx"]::before {
    left: 10px; }

  .btnlink .row_col.blank a::after {
    right: 10px; }

  .btnlink .row_col a.icon-ppt::before, .btnlink .row_col.blank a[href$=".ppt"]::before, .btnlink .row_col.blank a[href$=".pptx"]::before {
    left: 10px; }

  .btnlink .row_col a.icon-file::before {
    left: 10px; } }
/* ---------------------------------------------------
	コラム
------------------------------------------------------ */
.column_unit {
  width: 100%;
  margin: 0 auto 60px; }
  .column_unit > .box {
    width: 100%;
    border: 10px solid #F0F9FD;
    padding: 28px;
    box-sizing: border-box;
    background: #FFF;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: nowrap; }
    .column_unit > .box .txt {
      width: 100%; }
      .column_unit > .box .txt p {
        margin-bottom: 0; }
    .column_unit > .box .img {
      width: 30%;
      max-width: 360px;
      margin-left: 40px; }
  .column_unit.column_important {
    /* 重要なコラムの設定 */ }
    .column_unit.column_important > .box {
      border: 4px solid #B10404; }
      .column_unit.column_important > .box .txt h2, .column_unit.column_important > .box .txt h3, .column_unit.column_important > .box .txt h4 {
        color: #B10404; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .column_unit {
    width: calc(100% - 20px);
    margin: 0 auto 30px; }
    .column_unit h2, .column_unit h3, .column_unit h4, .column_unit h5 {
      padding: 0;
      width: 100%; }
    .column_unit h4 {
      padding-bottom: 10px; }
    .column_unit > .box {
      display: block;
      width: 100%;
      padding: 20px; }
      .column_unit > .box .txt {
        margin-bottom: 20px; }
        .column_unit > .box .txt p {
          padding: 0;
          margin-bottom: 0; }
      .column_unit > .box .img {
        width: 100%;
        max-width: 100%;
        margin-left: 0; } }
/* ---------------------------------------------------
	画像＋テキスト（左右配置）
------------------------------------------------------ */
.pic_txt {
  margin-bottom: 60px; }
  .pic_txt .row_pic {
    width: 50%;
    max-width: 600px; }
    .pic_txt .row_pic.row_pic_w30 {
      width: 30%;
      max-width: 360px; }
    .pic_txt .row_pic.row_pic_w40 {
      width: 40%;
      max-width: 480px; }
    .pic_txt .row_pic.row_pic_w60 {
      width: 60%;
      max-width: 720px; }
    .pic_txt .row_pic.row_pic_w70 {
      width: 70%;
      max-width: 840px; }
  .pic_txt.pic_right .row_pic {
    width: 50%;
    max-width: 600px;
    order: 10; }
    .pic_txt.pic_right .row_pic.row_pic_w30 {
      width: 30%;
      max-width: 360px;
      order: 10; }
    .pic_txt.pic_right .row_pic.row_pic_w40 {
      width: 40%;
      max-width: 480px;
      order: 10; }
    .pic_txt.pic_right .row_pic.row_pic_w60 {
      width: 60%;
      max-width: 720px;
      order: 10; }
    .pic_txt.pic_right .row_pic.row_pic_w70 {
      width: 70%;
      max-width: 840px;
      order: 10; }
    .pic_txt.pic_right .row_pic img + img {
      margin-top: 20px; }
  .pic_txt .row_txt {
    width: 46.667%;
    max-width: 560px; }
    .pic_txt .row_txt.row_txt_w66 {
      width: 66.667%;
      max-width: 790px; }
    .pic_txt .row_txt.row_txt_w56 {
      width: 56.667%;
      max-width: 670px; }
    .pic_txt .row_txt.row_txt_w36 {
      width: 36.667%;
      max-width: 440px; }
    .pic_txt .row_txt.row_txt_w26 {
      width: 26.667%;
      max-width: 320px; }
    .pic_txt .row_txt p {
      margin-bottom: 0; }
      .pic_txt .row_txt p + .btn-link {
        margin-top: 40px; }
    .pic_txt .row_txt .btn-link.btnL {
      margin-left: 0;
      margin-right: auto; }
    .pic_txt .row_txt .btn-link.btnR {
      margin-left: auto;
      margin-right: 0; }
    .pic_txt .row_txt .btn-link.btnC {
      margin-left: auto;
      margin-right: auto; }
    .pic_txt .row_txt .btn-link::after {
      content: none; }

.border-caution {
  width: 100%;
  border: 4px solid #B10404;
  padding: 40px;
  box-sizing: border-box;
  margin: 0 auto 60px; }
  .border-caution .pic_txt {
    margin-bottom: 0; }

.border-standard {
  width: 100%;
  border: 10px solid #F0F9FD;
  padding: 40px;
  box-sizing: border-box;
  margin: 0 auto 60px;
  background: #FFF; }
  .border-standard .pic_txt {
    margin-bottom: 0; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .pic_txt {
    margin-bottom: 30px; }
    .pic_txt h3 {
      padding: 0; }
    .pic_txt .row_pic {
      width: 100%;
      max-width: 100%;
      margin-bottom: 20px;
      text-align: center; }
      .pic_txt .row_pic.row_pic_w30, .pic_txt .row_pic.row_pic_w40, .pic_txt .row_pic.row_pic_w60, .pic_txt .row_pic.row_pic_w70 {
        width: 100%;
        max-width: 100%; }
    .pic_txt.pic_right .row_pic {
      width: 100%;
      max-width: 100%;
      order: 0; }
      .pic_txt.pic_right .row_pic.row_pic_w30, .pic_txt.pic_right .row_pic.row_pic_w40, .pic_txt.pic_right .row_pic.row_pic_w60, .pic_txt.pic_right .row_pic.row_pic_w70 {
        width: 100%;
        max-width: 100%;
        order: 0; }
    .pic_txt .row_txt {
      width: 100%;
      max-width: 100%;
      padding: 0 10px; }
      .pic_txt .row_txt.row_txt_w66, .pic_txt .row_txt.row_txt_w56, .pic_txt .row_txt.row_txt_w36, .pic_txt .row_txt.row_txt_w26 {
        width: 100%;
        max-width: 100%; }
      .pic_txt .row_txt p {
        padding: 0; }
        .pic_txt .row_txt p + .btn-link {
          margin-top: 20px; }
        .pic_txt .row_txt p .btn-link.btnL, .pic_txt .row_txt p .btn-link.btnC, .pic_txt .row_txt p .btn-link.btnR {
          margin-right: auto;
          margin-left: auto; }

  .border-caution {
    padding: 10px;
    margin: 0 auto 30px;
    width: calc(100% - 20px); }
    .border-caution .pic_txt .row_txt {
      padding: 0; }

  .border-standard {
    padding: 10px;
    margin: 0 auto 30px;
    width: calc(100% - 20px); }
    .border-standard .pic_txt .row_txt {
      padding: 0; } }
@media screen and (max-width: 896px) and (orientation: landscape) {
  .pic_txt .row_txt {
    padding: 0; }
  .pic_txt .row_txt_w26 .txt_btn a {
    padding: 25px 16px; }
    .pic_txt .row_txt_w26 .txt_btn a::after {
      right: 20px; }

  .entry-column .content_row {
    padding: 0 40px; }
    .entry-column .content_row h2 {
      padding: 0;
      font-size: 30px; }
    .entry-column .content_row h3 {
      padding: 0;
      font-size: 28px; }
    .entry-column .content_row h4 {
      width: 100%; }
    .entry-column .content_row h5 {
      padding: 0; }
    .entry-column .content_row p {
      padding: 0;
      font-size: 16px; }

  .border-caution {
    width: calc(100% - 80px);
    padding: 20px; }
    .border-caution .content_row {
      padding: 0; }

  .border-standard {
    width: calc(100% - 80px);
    padding: 20px; }
    .border-standard .content_row {
      padding: 0; } }
/* ---------------------------------------------------
	画像＋テキスト（画像に重ねて配置）
------------------------------------------------------ */
.pic-ontxt {
  margin-bottom: 40px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap; }
  .pic-ontxt .img {
    position: relative;
    z-index: 100;
    order: 1; }
  .pic-ontxt .txt {
    background: #FFF;
    padding: 50px;
    position: relative;
    z-index: 200;
    order: 2; }
    .pic-ontxt .txt p {
      margin-bottom: 0; }
  .pic-ontxt.ontxt-top .img {
    width: 100%;
    order: 10; }
  .pic-ontxt.ontxt-top .txt {
    width: calc(100% - 100px);
    margin: 0 auto -150px; }
  .pic-ontxt.ontxt-bottom .img {
    width: 100%; }
  .pic-ontxt.ontxt-bottom .txt {
    width: calc(100% - 100px);
    margin: -150px auto 0; }
  .pic-ontxt.ontxt-left {
    flex-wrap: nowrap; }
    .pic-ontxt.ontxt-left .img {
      width: 70%;
      margin-left: auto;
      order: 10; }
    .pic-ontxt.ontxt-left .txt {
      width: 50%;
      margin: 50px -20% 50px 0; }
  .pic-ontxt.ontxt-right {
    flex-wrap: nowrap; }
    .pic-ontxt.ontxt-right .img {
      width: 70%;
      margin-right: auto; }
    .pic-ontxt.ontxt-right .txt {
      width: 50%;
      margin: 50px 0 50px -20%; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .pic-ontxt {
    margin-bottom: 20px; }
    .pic-ontxt.ontxt-left, .pic-ontxt.ontxt-right {
      flex-wrap: wrap; }
    .pic-ontxt.ontxt-top .img, .pic-ontxt.ontxt-bottom .img, .pic-ontxt.ontxt-left .img, .pic-ontxt.ontxt-right .img {
      width: 100%;
      order: 1; }
    .pic-ontxt.ontxt-top .txt, .pic-ontxt.ontxt-bottom .txt, .pic-ontxt.ontxt-left .txt, .pic-ontxt.ontxt-right .txt {
      width: calc(100% - 20px);
      margin: -50px auto 0;
      padding: 20px;
      order: 2; } }
/* ---------------------------------------------------
	画像＋テキスト（縦：2分割）※センターから表示する
------------------------------------------------------ */
.box_row2 {
  justify-content: space-between;
  margin-bottom: 40px; }
  .box_row2 h4 {
    margin-bottom: 10px; }
  .box_row2 .row_col {
    width: 580px;
    max-width: 48.333%;
    margin-bottom: 40px; }
    .box_row2 .row_col .col_pic {
      margin-bottom: 20px;
      text-align: center; }
    .box_row2 .row_col .col_txt p {
      padding: 0; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .box_row2 h4 {
    width: 100%;
    margin-bottom: 10px;
    padding: 0; }
  .box_row2 .row_col {
    width: 100%;
    max-width: 100%;
    margin-bottom: 20px; }
    .box_row2 .row_col .col_pic {
      margin-bottom: 15px; }
    .box_row2 .row_col + .row_col {
      margin-top: 30px; }
    .box_row2 .row_col .col_txt {
      padding: 0 10px; } }
@media screen and (max-width: 896px) and (orientation: landscape) {
  .box_row2 .row_col .col_txt {
    padding: 0; } }
/* ---------------------------------------------------
	画像＋テキスト（縦：3分割）※センターから表示する
------------------------------------------------------ */
.box_row3 {
  justify-content: center;
  margin-bottom: 40px; }
  .box_row3 h4 {
    margin-bottom: 10px; }
  .box_row3 .row_col {
    width: 373px;
    max-width: 31.084%;
    margin-right: 3.37%;
    margin-bottom: 40px; }
    .box_row3 .row_col:nth-of-type(3n) {
      margin-right: 0; }
    .box_row3 .row_col:last-of-type {
      margin-right: 0; }
    .box_row3 .row_col .col_pic {
      margin-bottom: 20px;
      text-align: center; }
    .box_row3 .row_col .col_txt p {
      margin: 0; }
    .box_row3 .row_col .col_btn {
      margin-top: 20px;
      text-align: left; }
      .box_row3 .row_col .col_btn a {
        display: inline-block;
        border: 1px solid #0EA7AC;
        padding: 20px 20px;
        text-decoration: none;
        width: 100%;
        min-width: 360px; }
        .box_row3 .row_col .col_btn a::before {
          content: url(../images/common/ico-arrow-cr.png);
          margin-right: 10px; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .box_row3 {
    margin-bottom: 50px; }
    .box_row3 h4 {
      width: calc(100% - 20px);
      margin-bottom: 10px;
      padding: 0; }
    .box_row3 .row_col {
      width: 100%;
      max-width: 100%;
      margin-right: 0; }
      .box_row3 .row_col:last-of-type {
        margin-bottom: 0; }
      .box_row3 .row_col .col_pic {
        margin-bottom: 15px; }
      .box_row3 .row_col .col_txt {
        padding: 0; } }
@media screen and (max-width: 896px) and (orientation: landscape) {
  .box_row3 h4 {
    width: 100%; }
  .box_row3 .row_col .col_txt {
    padding: 0; } }
/* ---------------------------------------------------
	画像＋テキスト（縦：4分割）※センターから表示する
------------------------------------------------------ */
.box_row4 {
  justify-content: center;
  margin-bottom: 40px; }
  .box_row4 h5 {
    margin-bottom: 20px; }
  .box_row4 .row_col {
    width: 22.5%;
    margin-right: 3.33%;
    margin-bottom: 40px; }
    .box_row4 .row_col:nth-of-type(4n) {
      margin-right: 0; }
    .box_row4 .row_col:last-of-type {
      margin-right: 0; }
    .box_row4 .row_col .col_pic {
      margin-bottom: 20px;
      text-align: center; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .box_row4 {
    margin-bottom: 50px;
    justify-content: space-between; }
    .box_row4 h4 {
      padding: 0; }
    .box_row4 h5 {
      font-size: 20px;
      margin-bottom: 10px;
      margin-left: 0;
      margin-right: 0;
      text-align: left;
      padding: 0 10px; }
    .box_row4 .row_col {
      width: 100%;
      max-width: 100%;
      margin-right: 0; }
      .box_row4 .row_col:last-of-type {
        margin-bottom: 0; }
      .box_row4 .row_col .col_pic {
        margin-bottom: 15px; } }
@media screen and (max-width: 896px) and (orientation: landscape) {
  .box_row4 .row_col .col_txt h5 {
    padding: 0; } }
.bg-on-txt {
  max-width: 100%;
  padding: 100px 0; }

/* ---------------------------------------------------
	タイトル＋テキスト（左右配置）
------------------------------------------------------ */
.tit-and-txt-wrap {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap; }
  .tit-and-txt-wrap .text-wrap {
    width: 47%; }
  .tit-and-txt-wrap .tit-wrap {
    width: 50%; }
    .tit-and-txt-wrap .tit-wrap.w70 {
      width: 70%; }
      .tit-and-txt-wrap .tit-wrap.w70 + .text-wrap {
        width: 27%; }
    .tit-and-txt-wrap .tit-wrap.w60 {
      width: 60%; }
      .tit-and-txt-wrap .tit-wrap.w60 + .text-wrap {
        width: 37%; }
    .tit-and-txt-wrap .tit-wrap.w50 {
      width: 50%; }
      .tit-and-txt-wrap .tit-wrap.w50 + .text-wrap {
        width: 47%; }
    .tit-and-txt-wrap .tit-wrap.w40 {
      width: 40%; }
      .tit-and-txt-wrap .tit-wrap.w40 + .text-wrap {
        width: 57%; }
    .tit-and-txt-wrap .tit-wrap.w30 {
      width: 30%; }
      .tit-and-txt-wrap .tit-wrap.w30 + .text-wrap {
        width: 67%; }
  .tit-and-txt-wrap.pos-top {
    align-items: flex-start; }
  .tit-and-txt-wrap.pos-middle {
    align-items: center; }
  .tit-and-txt-wrap.pos-under {
    align-items: flex-end; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .tit-and-txt-wrap .tit-wrap {
    width: 100% !important; }
  .tit-and-txt-wrap .text-wrap {
    width: 100% !important; } }
/* ---------------------------------------------------
	Q&A
------------------------------------------------------ */
.faq-group {
  max-width: 1200px;
  margin: 0 auto 40px; }
  .faq-group h2 {
    width: 100%;
    text-align: center;
    background: rgba(42, 24, 0, 0.05);
    padding: 5px 0;
    cursor: pointer; }
    .faq-group h2::after {
      content: "";
      display: inline-block;
      width: 29px;
      height: 17px;
      background: url("../images/common/ico-arrow-bb@2x.png") no-repeat center/cover;
      transition: all 0.4s ease-in-out;
      -webkit-transform: rotate(0deg);
      transform: rotate(0deg);
      margin: 0 0 3px 20px; }
    .faq-group h2.open::after {
      -webkit-transform: rotate(180deg);
      transform: rotate(180deg); }

.faq-group-contents {
  display: none; }
  .faq-group-contents .faq-content {
    border-bottom: none;
    margin: 0 auto 40px; }
    .faq-group-contents .faq-content .faq-q {
      position: relative;
      padding-left: 40px;
      padding-bottom: 13px;
      text-align: left;
      font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
      font-size: 2.6rem;
      margin-bottom: 20px;
      border-bottom: 1px solid #C2A33C;
      color: #222; }
      .faq-group-contents .faq-content .faq-q::before {
        font-family: Lora;
        content: 'Q';
        position: absolute;
        left: 0;
        top: -10px;
        color: #222;
        font-size: 3.4rem;
        font-weight: 400; }
    .faq-group-contents .faq-content .faq-a {
      position: relative;
      padding-left: 40px; }
      .faq-group-contents .faq-content .faq-a::before {
        font-family: Lora;
        content: 'A';
        margin-right: 10px;
        position: absolute;
        top: 5px;
        left: 0;
        color: #C2A33C;
        font-size: 3.4rem;
        font-weight: 400;
        line-height: 1; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .faq-group {
    max-width: 100%;
    margin: 0 auto 40px;
    padding: 0 10px; }
    .faq-group .faq-content .faq-q {
      font-size: 1.8rem; }
      .faq-group .faq-content .faq-q::before {
        font-size: 30px; }
    .faq-group .faq-content .faq-a::before {
      top: 0;
      margin: 0;
      font-size: 34px; } }
/* ---------------------------------------------------
	流れ・手順用
------------------------------------------------------ */
.custom-flow {
  counter-reset: flownum; }

.flow-box {
  position: relative;
  padding: 40px 10px; }
  .flow-box:nth-child(2n) {
    background: rgba(42, 24, 0, 0.05); }
  .flow-box h3 {
    padding-left: 50px;
    position: relative;
    margin-bottom: 20px; }
    .flow-box h3.tit-flow::before {
      counter-increment: flownum;
      content: counter(flownum);
      position: absolute;
      top: 0;
      left: 0;
      margin-top: 0;
      letter-spacing: 0.1em;
      font-size: 4rem;
      font-family: "Times New Roman", Times, "serif";
      font-weight: bold; }

.flow-content {
  display: flex;
  justify-content: space-between;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto; }
  .flow-content::before, .flow-content::after {
    content: "";
    display: none; }
  .flow-content .flow-img {
    width: 28.334%;
    max-width: 340px; }
  .flow-content .flow-txt {
    width: 68.334%;
    max-width: 820px; }
  .flow-content.no-img .flow-img {
    display: none; }
  .flow-content.no-img .flow-txt {
    width: 100%;
    max-width: 100%; }
    .flow-content.no-img .flow-txt strong {
      font-weight: bold; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .flow-box {
    position: relative;
    padding: 40px 0; }
    .flow-box .flow-content {
      display: block;
      width: 100%;
      max-width: 1200px; }
      .flow-box .flow-content .flow-img {
        width: 100%;
        max-width: 100%;
        text-align: center;
        margin-bottom: 10px; }
      .flow-box .flow-content .flow-txt {
        width: 100%;
        max-width: 100%; } }
/* ---------------------------------------------------
	テーブル
------------------------------------------------------ */
.column-table- {
  width: 100%;
  margin: 0 auto 40px; }
  .column-table- table tr {
    width: 100%;
    border-spacing: 0;
    border-collapse: collapse;
    empty-cells: show;
    table-layout: fixed;
    background: #FFF; }
    .column-table- table tr th, .column-table- table tr td {
      padding: 20px;
      border: 1px solid #CCC;
      vertical-align: middle;
      font-size: 1.7rem;
      font-weight: 500;
      color: #222222; }
      .column-table- table tr th p, .column-table- table tr td p {
        margin-bottom: 0;
        line-height: 1; }
    .column-table- table tr th {
      background: #C2A33C;
      border-bottom: 1px solid #FFF;
      border-right: 1px solid #FFF;
      font-family: "Noto Serif JP";
      font-weight: 500;
      font-size: 2.2rem;
      letter-spacing: 0.05em;
      line-height: 1;
      color: #fff; }
    .column-table- table tr:nth-of-type(odd) td {
      background: #F9F8F2; }
    .column-table- table tr:last-child th {
      border-bottom: 1px solid #CCC; }
  .column-table- table.blue-table tr th, .column-table- table.blue-table tr td {
    border: 1px solid #24ABE8; }
  .column-table- table.blue-table tr th {
    background: #24ABE8;
    border-bottom: 1px solid #FFF; }
  .column-table- table.blue-table tr td {
    background: #F0F9FD; }
  .column-table- table.pink-table tr th, .column-table- table.pink-table tr td {
    border: 1px solid #EC427C; }
  .column-table- table.pink-table tr th {
    background: #EC427C;
    border-right: 1px solid #FFF;
    border-bottom: 1px solid #FFF; }
  .column-table- table.pink-table tr td {
    background: #FCF5F7; }
  .column-table-.price-table {
    margin-bottom: 20px; }
    .column-table-.price-table table tr th, .column-table-.price-table table tr td {
      line-height: 1;
      padding: 5px 0 9px;
      font-size: 18px; }
    .column-table-.price-table table tr th {
      font-family: "Noto Serif JP";
      font-weight: 700;
      font-size: 18px;
      letter-spacing: 0.05em; }
      .column-table-.price-table table tr th:first-of-type {
        font-family: "Noto Serif JP";
        width: 300px;
        font-size: 22px;
        letter-spacing: .05em;
        line-height: 1.52727; }
    .column-table-.price-table table tr td {
      font-family: Arial;
      font-weight: 400;
      font-size: 25px;
      text-align: center;
      color: #222;
      line-height: 1; }
      .column-table-.price-table table tr td small {
        font-size: 18px;
        font-family: "Yu Gothic";
        font-weight: 600; }
      .column-table-.price-table table tr td.discount .before {
        font-family: Arial;
        font-weight: normal;
        font-size: 14px;
        text-align: center;
        color: #999;
        text-decoration: line-through; }
        .column-table-.price-table table tr td.discount .before small {
          font-family: "Yu Gothic";
          font-weight: bold;
          font-size: 10px; }
      .column-table-.price-table table tr td.discount .after {
        font-family: Arial;
        font-weight: bold;
        font-size: 25px;
        text-align: center;
        color: #24abe8; }
        .column-table-.price-table table tr td.discount .after small {
          font-family: "Yu Gothic";
          font-weight: bold;
          font-size: 18px; }
    .column-table-.price-table.woman tr td.discount .after {
      color: #EC427C; }
  .column-table-.course-table table tr th, .column-table-.course-table table tr td {
    line-height: 1;
    padding: 5px 0 9px; }
  .column-table-.course-table table tr th {
    font-weight: 700;
    font-size: 18px;
    letter-spacing: 0.05em;
    padding: 10px 0 7px; }
    .column-table-.course-table table tr th:first-of-type {
      font-family: "Noto Serif JP";
      font-size: 22px;
      padding: 5px 0 4px; }
  .column-table-.course-table table tr td {
    font-family: Arial;
    font-weight: normal;
    font-size: 25px;
    text-align: center;
    color: #222; }
    .column-table-.course-table table tr td small {
      font-size: 18px; }
    .column-table-.course-table table tr td:first-of-type {
      font-size: 20px;
      font-family: "Noto Serif JP";
      font-weight: 500;
      color: #24ABE8;
      background: #F0F9FD; }
    .column-table-.course-table table tr td.discount .before {
      font-family: Arial;
      font-weight: normal;
      font-size: 14px;
      text-align: center;
      color: #999;
      text-decoration: line-through; }
      .column-table-.course-table table tr td.discount .before small {
        font-family: "Yu Gothic";
        font-weight: bold;
        font-size: 10px; }
    .column-table-.course-table table tr td.discount .after {
      font-family: Arial;
      font-weight: bold;
      font-size: 25px;
      text-align: center;
      color: #24abe8; }
      .column-table-.course-table table tr td.discount .after small {
        font-family: "Yu Gothic";
        font-weight: bold;
        font-size: 18px; }
  .column-table-.course-table.woman table tr td:first-of-type {
    color: #EC427C;
    background: #F7EBEF; }
  .column-table-.man table tr th {
    background: #24ABE8;
    border-bottom: 1px solid #24ABE8;
    border-left: 1px solid #24ABE8;
    font-family: "Yu Gothic";
    padding: 10px 0 7px; }
    .column-table-.man table tr th:last-child {
      border-right: 1px solid #24ABE8; }
  .column-table-.woman table tr th {
    background: #EC427C;
    border-bottom: 1px solid #EC427C;
    border-left: 1px solid #EC427C;
    font-family: "Yu Gothic";
    padding: 10px 0 7px; }
    .column-table-.woman table tr th:last-child {
      border-right: 1px solid #EC427C; }
  .column-table-.woman table tr td.discount .after {
    color: #EC427C; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .column-table- {
    margin: 0 auto 20px;
    padding: 0 10px; }
    .column-table- table tr th, .column-table- table tr td {
      padding: 10px;
      font-size: 1.6rem;
      display: block; }
    .column-table- table tr th {
      width: 100%; }
    .column-table- table.js-table-unit-scroll-hint {
      table-layout: auto; }
    .column-table- table.acms-table-scrollable {
      table-layout: auto; }
    .column-table-.man table tr th {
      padding: 10px 30px 8px; }
    .column-table-.woman table tr th {
      padding: 10px 30px 8px; } }
@media screen and (max-width: 896px) and (orientation: landscape) {
  .column-table- {
    padding: 0 40px; }
    .column-table- table.js-table-unit-scroll-hint {
      table-layout: auto; }
      .column-table- table.js-table-unit-scroll-hint th, .column-table- table.js-table-unit-scroll-hint td {
        display: table-cell !important;
        white-space: nowrap; }
    .column-table- table.acms-table-scrollable {
      table-layout: auto; }
      .column-table- table.acms-table-scrollable th, .column-table- table.acms-table-scrollable td {
        display: table-cell !important;
        white-space: nowrap; } }
.scroll-hint-icon {
  top: calc(50% - 40px) !important;
  height: 70px !important;
  padding: 6px 10px 10px !important; }

/* ---------------------------------------------------
	罫線
------------------------------------------------------ */
.entry-column hr.hr-line {
  margin: 0 auto;
  border-bottom: 1px dotted #C2A33C; }

/* ---------------------------------------------------
	余白
------------------------------------------------------ */
.hr_margin {
  margin: 0 auto;
  border: none !important; }

.margin-s {
  margin-bottom: 20px; }

.margin-m {
  margin-bottom: 40px; }

.margin-l {
  margin-bottom: 60px; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .margin-s {
    margin-bottom: 10px; }

  .margin-m {
    margin-bottom: 20px; }

  .margin-l {
    margin-bottom: 30px; } }
/* ------------------------------
　　sdgs
------------------------------ */
.sdgs-unit-wrap {
  width: 100%;
  max-width: 1200px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: auto;
  margin-bottom: 60px; }
  .sdgs-unit-wrap img {
    display: block;
    width: 260px;
    height: 260px;
    object-fit: cover;
    margin-right: 40px; }
  .sdgs-unit-wrap .text {
    width: 900px; }
  .sdgs-unit-wrap > *:last-child {
    margin-bottom: 0; }
  @media screen and (max-width: 1240px) {
    .sdgs-unit-wrap {
      width: 120rem;
      margin: auto;
      margin-bottom: 6rem; }
      .sdgs-unit-wrap img {
        width: 26rem;
        height: 26rem;
        margin-right: 4rem; }
      .sdgs-unit-wrap .text {
        width: 90rem; } }
  @media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
    .sdgs-unit-wrap {
      width: 100%; }
      .sdgs-unit-wrap img {
        margin-right: auto;
        margin: auto;
        margin-bottom: 20px; }
      .sdgs-unit-wrap .text {
        width: 100%; } }

/* ---------------------------------------------------
	slider 共通
------------------------------------------------------ */
.slick-prev, .slick-next {
  background: none; }
  .slick-prev::before, .slick-next::before {
    content: "";
    display: none; }

.slide-inft {
  max-width: 1000px;
  margin: 0 auto;
  display: none; }
  .slide-inft.slick-initialized {
    display: block; }
  .slide-inft .slick-next, .slide-inft .slick-prev {
    width: 30px;
    height: 54px;
    margin-top: -27px; }
  .slide-inft .slick-prev {
    background: url("../images/common/ico-slider-prev@2x.png") no-repeat;
    left: -50px; }
  .slide-inft .slick-next {
    background: url("../images/common/ico-slider-next@2x.png") no-repeat;
    right: -50px; }
  .slide-inft .slick-slide img {
    max-width: 1000px;
    max-height: 660px; }

.slide-inft-thumb {
  max-width: 880px;
  margin: 0 auto 40px;
  display: none; }
  .slide-inft-thumb.slick-initialized {
    display: block; }
  .slide-inft-thumb .slick-track {
    display: flex;
    justify-content: space-between; }
    .slide-inft-thumb .slick-track::before, .slide-inft-thumb .slick-track::after {
      display: none; }
  .slide-inft-thumb .slick-slide {
    max-width: 170px; }
  .slide-inft-thumb .slick-next, .slide-inft-thumb .slick-prev {
    width: 15px;
    height: 27px;
    top: 50%;
    margin-top: -14px; }
  .slide-inft-thumb .slick-prev {
    background: url("../images/common/ico-slider-prev.png") no-repeat;
    left: -30px; }
  .slide-inft-thumb .slick-next {
    background: url("../images/common/ico-slider-next.png") no-repeat;
    right: -30px; }

.slide-inf {
  max-width: 1000px;
  margin: 0 auto 40px;
  display: none; }
  .slide-inf.slick-initialized {
    display: block; }
  .slide-inf .slick-next, .slide-inf .slick-prev {
    width: 30px;
    height: 54px;
    margin-top: -27px; }
  .slide-inf .slick-prev {
    background: url("../images/common/ico-slider-prev@2x.png") no-repeat;
    left: -50px; }
  .slide-inf .slick-next {
    background: url("../images/common/ico-slider-next@2x.png") no-repeat;
    right: -50px; }
  .slide-inf .slick-slide img {
    max-width: 1000px;
    max-height: 660px; }

.slick-list:focus::before {
  border: none; }

.slick-slide .slide-img-cap {
  margin-bottom: 20px; }

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .slide-inft {
    max-width: 100%;
    margin: 0 auto; }
    .slide-inft .slick-next, .slide-inft .slick-prev {
      display: none !important;
      width: 80px;
      height: 15px;
      margin-top: -7px;
      top: 110px; }
    .slide-inft .slick-prev {
      background: url("../img/common/ico_slide_arrow_left.png") no-repeat;
      left: 0; }
    .slide-inft .slick-next {
      background: url("../img/common/ico_slide_arrow_right.png") no-repeat;
      right: 0; }
    .slide-inft .slick-slide img {
      max-width: 100%;
      max-height: 250px; }

  .slide-inft-thumb {
    max-width: 100%;
    margin: 0 auto 40px; }
    .slide-inft-thumb .slick-track {
      display: flex;
      justify-content: space-between;
      margin-bottom: 20px; }
      .slide-inft-thumb .slick-track::before, .slide-inft-thumb .slick-track::after {
        display: none; }
    .slide-inft-thumb .slick-slide {
      max-width: 170px; }
    .slide-inft-thumb .slick-next, .slide-inft-thumb .slick-prev {
      top: 40%; }

  .slide-inf {
    max-width: 100%;
    margin: 0 auto 40px; }
    .slide-inf .slick-next, .slide-inf .slick-prev {
      display: none !important;
      width: 80px;
      height: 15px;
      margin-top: -7px;
      top: 110px; }
    .slide-inf .slick-prev {
      background: url("../img/common/ico_slide_arrow_left.png") no-repeat;
      left: 0; }
    .slide-inf .slick-next {
      background: url("../img/common/ico_slide_arrow_right.png") no-repeat;
      right: 0; }
    .slide-inf .slick-slide img {
      max-width: 100%;
      max-height: 250px; }

  .slick-slide .slide-img-cap {
    margin-bottom: 10px;
    line-height: 1.6; } }
/* ---------------------------------------------------
	社長あいさつ
------------------------------------------------------ */
.president_greeting .president_greeting_title {
  margin: 10px 0 40px;
  text-align: center;
  font-family: "Noto Serif JP";
  font-weight: 500; }
.president_greeting .president_greeting_movie {
  width: 100%;
  margin: 0;
  position: relative;
  height: 0;
  padding-top: 160px;
  margin-bottom: 10px; }
  .president_greeting .president_greeting_movie iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }
.president_greeting .president_greeting_program {
  display: flex;
  justify-content: space-between; }
  .president_greeting .president_greeting_program p {
    font-size: 16px;
    line-height: 1.4;
    text-align: left;
    max-width: 280px;
    margin: 0 0 0 auto; }
.president_greeting .president_greeting_link p {
  margin: 0; }
  .president_greeting .president_greeting_link p + p {
    margin-top: 10px; }
  .president_greeting .president_greeting_link p a {
    background-color: #412001;
    padding: 2px 0;
    color: #FFF;
    font-weight: bold;
    text-align: center;
    font-size: 13px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none; }
    .president_greeting .president_greeting_link p a::after {
      content: "";
      display: inline-block;
      background: url(../images/common/arrow-president_greeting_link.png) no-repeat center;
      background-size: 100%;
      margin-left: 5px;
      transform: translateY(-10%);
      width: 11px;
      height: 14px; }
    .president_greeting .president_greeting_link p a:hover {
      text-decoration: none; }
.president_greeting .row_txt h4 {
  margin: 40px 0 30px; }
  .president_greeting .row_txt h4::before {
    width: 220px; }
  .president_greeting .row_txt h4 + p {
    margin-bottom: 44px; }

@media screen and (max-width: 767px) {
  .president_greeting .president_greeting_program {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center; }

  .president_greeting .president_greeting_program p {
    max-width: 80%;
    margin-bottom: 0; }

  #company .entry-column .president_greeting .president_greeting_program p {
    font-size: 13px; } }
/* ---------------------------------------------------
	参加資格
------------------------------------------------------ */
.qualifications {
  margin-bottom: 60px; }
  .qualifications h2 {
    font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-weight: 500;
    font-size: 3.2rem;
    letter-spacing: 0.05em;
    text-align: center;
    color: #fff;
    width: 100%;
    background: #C2A33C;
    padding: 2px 0; }
  .qualifications .wrap {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap; }
    .qualifications .wrap img {
      display: block;
      width: 200px;
      margin-right: 40px; }
    .qualifications .wrap dl {
      width: 460px;
      margin: 0; }
      .qualifications .wrap dl:last-of-type {
        margin-left: 40px; }
      .qualifications .wrap dl dt {
        font-family: "Noto Sans JP";
        font-weight: 700;
        font-size: 20px;
        line-height: 1.4;
        text-align: left;
        color: #222;
        margin-bottom: 22px; }
      .qualifications .wrap dl dd {
        font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
        font-weight: 500;
        font-size: 17px;
        line-height: 2;
        text-align: left;
        color: #222; }
    .qualifications .wrap .btn-link {
      font-family: "Noto Serif JP";
      font-weight: 500;
      font-size: 17px;
      letter-spacing: 0.05em;
      text-align: center;
      color: #222;
      margin: 3px 0 0 auto;
      padding: 8px 32px 7px; }
      .qualifications .wrap .btn-link::after {
        content: none; }
      .qualifications .wrap .btn-link a:hover {
        text-decoration: none; }
    .qualifications .wrap.man {
      padding-bottom: 50px;
      margin-bottom: 50px;
      border-bottom: 1px dotted #C2A33C; }
    .qualifications .wrap.woman {
      margin-bottom: 50px; }
  .qualifications .credit-card {
    background: #EEEEEE;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 10px; }
    .qualifications .credit-card p {
      font-family: "Yu Gothic";
      font-weight: 500;
      font-size: 17px;
      color: #222;
      margin-bottom: 0;
      margin-right: 17.2px; }
    .qualifications .credit-card img {
      display: inline-block; }
  @media screen and (max-width: 767px) {
    .qualifications h2 {
      margin-bottom: 30px; }
    .qualifications .wrap {
      padding: 0 10px; }
      .qualifications .wrap img {
        margin: auto;
        margin-bottom: 20px; }
      .qualifications .wrap dl {
        width: 100%; }
        .qualifications .wrap dl:last-of-type {
          width: 100%;
          margin-left: 0; }
        .qualifications .wrap dl dd {
          margin-bottom: 20px; }
    .qualifications .credit-card {
      display: block; } }

/* ---------------------------------------------------
	スタッフ紹介
------------------------------------------------------ */
.staff_introduction .l p {
  font-size: 100%;
  margin: 0; }

.staff_introduction .staff_introduction_link a {
  background-color: #412001;
  margin-top: 10px;
  padding: 2px 0;
  color: #FFF;
  font-weight: bold;
  text-align: center;
  font-size: 12px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  max-width: 180px;
  text-decoration: none; }

.staff_introduction .staff_introduction_link a::after {
  content: "";
  display: inline-block;
  background: url(../images/common/arrow-staff_introduction_link.png) no-repeat center;
  background-size: 100%;
  margin-left: 5px;
  transform: translateY(-10%);
  width: 8px;
  height: 11px; }

.staff_introduction .staff_introduction_link a:hover {
  text-decoration: none; }

@media screen and (max-width: 767px) {
  .staff_introduction .staff_introduction_link a {
    margin: 10px auto 0; } }
/* ---------------------------------------------------
	提携講師紹介（スペシャルサポーターズ）
------------------------------------------------------ */
.special_supporters {
  border: 10px solid #F0F9FD;
  display: flex;
  align-items: flex-start;
  padding: 30px;
  margin-bottom: 40px; }
  .special_supporters .img-wrap {
    width: 240px;
    margin-right: 40px; }
    .special_supporters .img-wrap p {
      text-align: center; }
  .special_supporters .txt-wrap {
    width: calc(100% - 280px); }
    .special_supporters .txt-wrap ul {
      margin-bottom: 0; }
  @media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
    .special_supporters {
      flex-direction: column;
      padding: 20px; }
      .special_supporters .img-wrap {
        width: 100%;
        margin-right: 0;
        margin-bottom: 20px; }
      .special_supporters .txt-wrap {
        width: 100%; } }

/* ---------------------------------------------------
	★ページ上にもどるボタン
------------------------------------------------------ */
#btn_up {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end; }

@media screen and (max-width: 767px) {
  #btn_up {
    display: none; } }
/* ---------------------------------------------------
	各コース料金表
------------------------------------------------------ */
.course_price {
  margin-bottom: 40px; }

.course_price .course_price_list table {
  border: 1px solid #666;
  margin-bottom: 10px; }

.course_price .course_price_list table tr th,
.course_price .course_price_list table tr td {
  text-align: center;
  vertical-align: middle;
  border: none;
  padding: 10px 2px;
  line-height: 1;
  color: #000; }

.course_price .course_price_list table tr th {
  color: #FFF;
  font-size: 14px; }

.course_price .course_price_list table.price-list-man tr th {
  background-color: #004266; }

.course_price .course_price_list table.price-list-woman tr th {
  background-color: #F27183; }

.course_price .course_price_list table tr td {
  background-color: #FFF;
  font-weight: bold;
  border-right: 1px solid #000; }

.course_price .course_price_list table tr td .bg-annual-fee {
  color: #FFF;
  font-size: 14px;
  font-weight: bold;
  padding: 0 8px; }

.course_price .course_price_list table.price-list-man tr td .bg-annual-fee {
  background-color: #008BD7; }

.course_price .course_price_list table.price-list-woman tr td .bg-annual-fee {
  background-color: #EF4B64; }

.course_price .course_price_list table tr.price-row td {
  /*vertical-align: inherit;*/
  /* border-bottom: 1px solid #000;*/ }

.course_price .course_price_list table tr.price-row td.annual-fee {
  vertical-align: middle;
  min-width: 70px; }

.course_price .course_price_list table tr .total-price {
  font-size: 24px;
  color: #F00; }

.course_price .course_price_list table tr.remarks-row td,
.course_price .course_price_list table tr td.great-value {
  font-size: 14px;
  font-weight: normal; }

.course_price .course_price_list table tr td.great-value {
  color: #F00; }

.course_price .course_price_list table tr td.discount-text {
  font-size: 14px;
  color: #F00; }

.course_price .course_price_list table tr td del {
  background-image: linear-gradient(#F00, #F00);
  background-position: 0 calc(50% - 1px);
  background-size: 100% 2px;
  background-repeat: repeat-x;
  padding: 0 4px;
  text-decoration: none; }

.course_price .course_price_list table tr td del .color-reset {
  color: initial;
  font-size: initial; }

.course_price .course_price_list table tr.campaign-row td,
.course_price .course_price_list table tr.great-value-row td,
.course_price .course_price_list table tr.remarks-row td {
  padding-top: 0; }

.course_price .price-list-benefits table {
  border: 1px solid #412100;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  margin-bottom: 10px;
  font-feature-settings: "palt"; }

.course_price .price-list-benefits table thead tr th {
  background-color: #D3BA85;
  text-align: center;
  font-size: 17px;
  font-weight: bold;
  padding: 4px;
  border-top: 1px solid #412100;
  border-bottom: 1px solid #412100;
  color: #000; }

.course_price .price-list-benefits table tbody tr th,
.course_price .price-list-benefits table tbody tr td {
  background-color: #FFF;
  border-top: none;
  border-bottom: 1px dashed #412100;
  vertical-align: middle;
  padding: 4px 10px;
  color: #000; }

.course_price .price-list-benefits table tbody tr th {
  border-right: 1px solid #412100; }

.course_price .price-list-benefits table tbody tr th .price-list-benefits-remarks {
  font-size: 13px; }

.course_price .price-list-benefits table tbody tr td {
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  min-width: 150px; }

/* 210621 */
.course_price .course_price_list table tr.price-row td .admission-discount {
  font-size: 19px;
  color: #F00; }

.course_price .course_price_list table tr.price-row td .registration-fee-supplement {
  font-size: 12px; }

@media screen and (max-width: 767px) {
  .course_price {
    margin-bottom: 20px; } }
/* 220816 */
.entry-column td.sp-only, .entry-column th.sp-only {
  display: none !important; }

.course_price .course_price_list table.js-table-unit-scroll-hint tr .sp-only {
  display: none !important; }

@media screen and (max-width: 767px) {
  .acms-entry .course_price .course_price_list .entry-container, .acms-entry .course_price .price-list-benefits .entry-container {
    padding: 0; }

  .course_price .course_price_list table.js-table-unit-scroll-hint tr .pc-only {
    display: none !important; }

  .course_price .course_price_list table.js-table-unit-scroll-hint tr .sp-only {
    display: block !important;
    line-height: 1.2;
    width: 100%; }

  .course_price .course_price_list table tr.item-row {
    width: 40%;
    display: inline-block; }

  .course_price .course_price_list table tr.price-row {
    width: 60%;
    display: inline-block; }

  .course_price .course_price_list table tr.item-row th, .course_price .course_price_list table tr.price-row td, .course_price .course_price_list table tr.remarks-row td {
    display: flex !important;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    padding: 10px; }

  .course_price .course_price_list table tr.price-row td {
    /*border-right: none; */
    border-bottom: 1px solid #000; }

  .course_price .course_price_list table tr.price-row td.annual-fee {
    border-top: 1px solid #000; }

  .course_price .course_price_list table tr:nth-of-type(2) td.annual-fee {
    border-top: none; }

  .course_price .course_price_list table tr.item-row th, .course_price .course_price_list table tr.price-row td {
    height: 44px; }

  .course_price .course_price_list table tr.item-row th:first-of-type {
    /*height: 45px;*/ }

  .course_price .course_price_list table tr.item-row th.campaign_existence, .course_price .course_price_list table tr.price-row td.campaign_existence {
    height: 60px; }

  .course_price .course_price_list table tr td {
    border-right: 1px solid #000; }

  .course_price .course_price_list table tr td .bg-annual-fee {
    padding: 4px 8px; }

  .course_price .course_price_list table tr.remarks-row td {
    padding: 0 2px 10px;
    /* border-right: none;*/ }

  .course_price .course_price_list table tr.remarks-row td:first-of-type {
    padding-top: 10px; }

  .course_price .course_price_list table tr.campaign-row + tr.remarks-row td:first-of-type,
  .course_price .course_price_list table tr.great-value-row + tr.campaign-row td:first-of-type {
    padding-top: 0; }

  .course_price .course_price_list table tr.remarks-row td:last-of-type {
    display: none !important; }

  .course_price .course_price_list table tr.great-value-row .total-price, .course_price .course_price_list table tr td.nbsp {
    display: none !important; }

  .course_price .course_price_list table tr.great-value-row td, .course_price .course_price_list table tr.campaign-row td {
    padding-top: 10px; }

  .course_price .course_price_list table tr.remarks-row td {
    /*border-bottom: 1px solid #000;*/ }

  .course_price .course_price_list table tr td.nbsp {
    display: none !important; }

  /* .course_price .course_price_list table tr:last-of-type.tr-partition {display: none !important;}
  .course_price .course_price_list table tr.tr-partition td {height: 10px; padding: 0; width: 100vw;} */
  .course_price .price-list-benefits table tbody tr th, .course_price .price-list-benefits table tbody tr td {
    padding: 4px 8px; }

  .course_price .price-list-benefits table tbody tr th {
    font-size: 14px; }

  .course_price .price-list-benefits table tbody tr td {
    font-size: 16px;
    min-width: 105px; } }
/* /220816 */
/* ---------------------------------------------------
	各コース料金/プラン料金
------------------------------------------------------ */
.course_plan_list {
  margin-bottom: 20px; }

.course_plan_list table {
  border-top: 1px solid #412100;
  border-bottom: 1px solid #412100; }

.course_plan_list table tr th,
.course_plan_list table tr td {
  text-align: center;
  vertical-align: middle;
  border-top: none;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  padding: 10px 5px 5px;
  color: #000;
  line-height: 1; }

.course_plan_list table tr th {
  font-size: 14px;
  border-bottom: 1px solid #412100; }

.course_plan_list table tr:first-of-type th {
  padding: 5px; }

.course_plan_list table tr:not([class^="plan_list-item-row"]) th {
  text-align: left;
  font-size: 18px;
  letter-spacing: -0.15em; }

.course_plan_list table tr th:first-of-type {
  width: 21%;
  border-right: 1px solid #412100; }

.course_plan_list table tr th:last-of-type {
  letter-spacing: -0.2em; }

.course_plan_list table tr.tr-gender th:last-of-type {
  letter-spacing: 0; }

.course_plan_list table tr td {
  background-color: #FFF;
  font-weight: bold;
  font-size: 18px;
  border-right: 1px solid #000; }

.course_plan_list table tr th.plan-list-gender,
.course_plan_list table tr td.annual-fee .bg-annual-fee,
.course_plan_list table tr.remarks-row td,
.course_plan_list table tr td.discount-text {
  font-family: "Noto Sans JP", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; }

.course_plan_list table tr th.plan-list-gender {
  text-align: left;
  font-size: 20px;
  font-weight: normal;
  color: #FFF; }

.course_plan_list table tr td.annual-fee .bg-annual-fee {
  color: #FFF;
  font-size: 12px;
  font-weight: normal;
  padding: 0 4px; }

.course_plan_list table tr .total-price {
  font-size: 24px;
  color: #F00; }

.course_plan_list table tr.remarks-row td,
.course_plan_list table tr.campaign-row td {
  padding-top: 0; }

.course_plan_list table tr.remarks-row {
  border-bottom: 1px dotted #412100; }

.course_plan_list table tr.remarks-row td {
  font-size: 12px;
  font-weight: normal; }

.course_plan_list table tr.course-begin-row {
  border-top: 1px solid #412100; }

.course_plan_list table tr td.discount-text {
  font-size: 14px;
  color: #F00; }

.course_plan_list table tr td del {
  background-image: linear-gradient(#F00, #F00);
  background-position: 0 calc(50% - 0px);
  background-size: 100% 2px;
  background-repeat: repeat-x;
  padding: 0 4px;
  text-decoration: none; }

.course_plan_list table tr td del .color-reset {
  color: initial;
  font-size: initial; }

/* 男性 */
.course_plan_list table.plan-list-man tr th {
  background-color: rgba(0, 66, 112, 0.1); }

.course_plan_list table.plan-list-man tr th.plan-list-gender {
  background-color: #004270; }

.course_plan_list table.plan-list-man tr td.annual-fee .bg-annual-fee {
  background-color: #008BD7; }

/* 女性 */
.course_plan_list table.plan-list-woman tr th {
  background-color: rgba(242, 113, 132, 0.1); }

.course_plan_list table.plan-list-woman tr th.plan-list-gender {
  background-color: #f27184; }

.course_plan_list table.plan-list-woman tr td.annual-fee .bg-annual-fee {
  background-color: #EF4B64; }

/* 210621 */
.course_plan_list table tr td .admission-discount {
  font-size: 18px;
  color: #F00; }

.course_plan_list table tr td.annual-fee {
  min-width: 55px; }

/* 220816 */
.course_plan_list table.js-table-unit-scroll-hint tr .total-price.sp-only {
  display: none !important; }

.course_plan_list table tr.plan_list-item-row.pc-only {
  display: table-row; }

@media screen and (max-width: 767px) {
  .course_plan_list table.js-table-unit-scroll-hint tr .total-price.pc-only {
    display: none !important; }

  .acms-table-scrollable td.pc-only, .acms-table-scrollable th.pc-only, .js-table-unit-scroll-hint td.pc-only, .js-table-unit-scroll-hint th.pc-only {
    display: none !important; }

  .course_plan_list table.js-table-unit-scroll-hint tr .total-price.sp-only {
    display: block !important;
    line-height: 1.2;
    width: 100%; }

  .acms-entry .course_plan_list .entry-container {
    padding: 0; }

  .course_plan_list table tr.plan_list-item-row {
    width: 40%;
    display: inline-block; }

  .course_plan_list table tr.plan_list-item-row.pc-only {
    display: none; }

  .course_plan_list table tr.course-begin-row, .course_plan_list table tr.course-end-row {
    width: 60%;
    display: inline-block; }

  .course_plan_list table tr.course-begin-row {
    border-top: 0; }

  .course_plan_list table tr.plan_list-item-row th, .course_plan_list table tr.course-begin-row td, .course_plan_list table tr.course-end-row td {
    display: flex !important;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    padding: 10px;
    height: 44px; }

  .course_plan_list table tr.plan_list-item-row th.pc-only, .course_plan_list table tr.course-begin-row td.pc-only, .course_plan_list table tr.course-end-row td.pc-only {
    display: none !important; }

  .course_plan_list table tr.plan_list-item-row th.campaign_existence, .course_plan_list table tr.course-begin-row td.campaign_existence, .course_plan_list table tr.course-end-row td.campaign_existence {
    height: 60px; }

  .course_plan_list table tr.plan_list-item-row th {
    padding-bottom: 9px; }

  .course_plan_list table tr th:first-of-type {
    width: 100%;
    border-right: none; }

  .course_plan_list table tr.tr-gender th, .course_plan_list table tr.tr-course th {
    width: 100vw;
    border-right: none; }

  .course_plan_list table tr th.th-course {
    font-size: 1.125em; }

  .course_plan_list table tr td {
    border-right: none;
    border-bottom: 1px solid #000; }

  .course_plan_list table tr td.annual-fee .bg-annual-fee {
    padding: 4px 8px; }

  .course_plan_list table tr.remarks-row td {
    padding: 10px 2px;
    font-size: 14px; }

  .course_plan_list table tr.campaign-row + tr.remarks-row td {
    padding-top: 0; }

  .course_plan_list table tr td.discount-text {
    padding: 10px 2px;
    border-bottom: none; }

  .course_plan_list table tr:not(:last-of-type) td.discount-text {
    /*padding-bottom: 0;*/ }

  .course_plan_list table tr:last-of-type.tr-partition {
    display: none !important; }

  .course_plan_list table tr.tr-partition td {
    height: 10px;
    padding: 0;
    width: 100vw; }

  .course_plan_list table tr td.nbsp {
    display: none !important; } }
/* /220816 */
/* 220819 */
/* ---------------------------------------------------
	入会案内の表（テーブル）
------------------------------------------------------ */
.price-table- table.js-table-unit-scroll-hint tr .total-price.sp-only {
  display: none !important; }

.price-table- table tr td {
  border-right: 1px solid #000; }

.price-table- .price-table-item-row:not(:nth-of-type(2)) {
  display: none; }

@media screen and (max-width: 767px) {
  .price-table- table.js-table-unit-scroll-hint tr .total-price.pc-only {
    display: none !important; }

  .acms-table-scrollable td.pc-only, .acms-table-scrollable th.pc-only, .js-table-unit-scroll-hint td.pc-only, .js-table-unit-scroll-hint th.pc-only {
    display: none !important; }

  .price-table- table.js-table-unit-scroll-hint tr .total-price.sp-only {
    display: block !important;
    line-height: 1.2;
    width: 100%; }

  .acms-entry .price-table- .entry-container {
    padding: 0; }

  #price .price-table- table tbody {
    display: flex;
    flex-wrap: wrap; }

  #price .price-table- table tr {
    border-bottom: none; }

  #price .column-table- table tr:first-of-type th {
    border-bottom: none; }

  #price .price-table- table tr.tr-course th {
    text-align: center !important;
    font-size: 1.25em;
    border-bottom: 1px solid #000; }

  #price .price-table- table tr.tr-course:not(:first-of-type) th {
    border-top: 1px solid #000; }

  .price-table- table tr.price-table-item-row, .price-table- .price-table-item-row:not(:nth-of-type(2)) {
    width: 40%;
    display: inline-block; }

  .price-table- table tr.course-row {
    width: 60%;
    display: inline-block; }

  .price-table- table tr.price-table-item-row th, .price-table- table tr.course-row td {
    display: flex !important;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    padding: 10px;
    height: 68px; }

  #price .price-table- table tr.price-table-item-row th {
    width: 100%; }

  .price-table- table tr.price-table-item-row th.pc-only, .price-table- table tr.course-row td.pc-only {
    display: none !important; }

  .price-table- table tr th:first-of-type {
    width: 100%;
    border-right: none; }

  #price .price-table- table tr:first-of-type th:first-of-type {
    width: 100vw; }

  .price-table- table tr.tr-course th, #price .price-table- table tr.tr-course th {
    width: 100vw;
    border-right: none; }

  .price-table- table tr th.th-course {
    font-size: 1.125em; }

  .price-table- table tr.price-table-item-row th div {
    width: 100%; }

  #price .price-table- table tr:not(:first-of-type) th {
    border-bottom: 1px solid #000; }

  #price .price-table- table tr:not(:first-of-type) th:last-of-type {
    border-bottom: none; }

  #price .price-table- table tr:not(:first-of-type) th:first-of-type {
    border-bottom: 1px solid #000; }

  .price-table- table tr td {
    border-right: none;
    border-bottom: 1px solid #000; }

  .price-table- table tr td:last-of-type {
    border-bottom: 0; }

  .price-table- table tr td.nbsp {
    display: none !important; } }
/* /220819 */
/* ---------------------------------------------------
	入会後の流れ
------------------------------------------------------ */
.flow {
  padding: 0; }
  .flow ol {
    max-width: 1200px;
    margin: auto;
    margin-bottom: 70px; }
    .flow ol li {
      display: flex;
      align-items: center;
      margin-bottom: 40px; }
      .flow ol li::before {
        content: none; }
      .flow ol li .img-wrap {
        position: relative;
        width: 355px;
        margin-right: 76px; }
        .flow ol li .img-wrap img {
          display: inline-block;
          width: 100%; }
        .flow ol li .img-wrap p {
          position: absolute;
          top: 0;
          right: -50px;
          font-family: Lora;
          font-weight: normal;
          font-style: italic;
          font-size: 24px;
          line-height: 1;
          text-align: right;
          color: #24abe8;
          text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); }
          .flow ol li .img-wrap p span {
            font-family: Lora;
            font-weight: normal;
            font-style: italic;
            font-size: 65px;
            line-height: 1;
            text-align: right;
            color: #24abe8;
            text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); }
      .flow ol li .txt-wrap {
        width: 769px; }
        .flow ol li .txt-wrap h3 {
          font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
          font-weight: 500;
          font-size: 24px;
          line-height: 1.4;
          text-align: left;
          color: #222;
          margin-bottom: 10px; }
        .flow ol li .txt-wrap p {
          font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
          font-weight: 500;
          font-size: 17px;
          line-height: 1.6;
          text-align: left;
          color: #222; }
          .flow ol li .txt-wrap p.red {
            color: #EC427C;
            font-weight: 700; }
  .flow .movie h3 {
    width: 1200px;
    margin: auto;
    margin-bottom: 30px;
    font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-weight: 600;
    font-size: 28px;
    letter-spacing: 0.1em;
    line-height: 1.5;
    text-align: center;
    white-space: nowrap;
    color: #222;
    display: flex;
    align-items: center;
    justify-content: space-between; }
    .flow .movie h3::before {
      content: "";
      display: inline-block;
      width: 100%;
      height: 1px;
      margin-right: 32px !important;
      background: #222; }
    .flow .movie h3::after {
      content: "";
      display: inline-block;
      width: 100%;
      height: 1px;
      margin-left: 32px !important;
      background: #222; }
  .flow .movie .movie-wrap {
    position: relative;
    width: 1000px;
    margin: auto;
    padding-bottom: 563px;
    height: 0;
    overflow: hidden; }
    .flow .movie .movie-wrap iframe {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }
  @media screen and (max-width: 1366px) {
    .flow h2 {
      font-size: calc(100vw * (40 /1366));
      margin-bottom: calc(100vw * (47 /1366)); }
      .flow h2 small {
        font-size: calc(100vw * (17 /1366));
        margin-top: calc(100vw * (20 /1366)); }
      .flow h2::before {
        top: calc(100vw * (-94 /1366));
        z-index: 1;
        font-size: calc(100vw * (100 /1366)); }
    .flow ol {
      max-width: calc(100vw * (1200 /1366)); }
      .flow ol li {
        margin-bottom: calc(100vw * (40 /1366)); }
        .flow ol li .img-wrap {
          width: calc(100vw * (354 /1366));
          margin-right: calc(100vw * (76 /1366)); }
          .flow ol li .img-wrap p {
            font-size: calc(100vw * (24 /1366));
            text-shadow: 0px calc(100vw * (3 /1366)) calc(100vw * (6 /1366)) rgba(0, 0, 0, 0.16); }
            .flow ol li .img-wrap p span {
              font-size: calc(100vw * (65 /1366));
              text-shadow: 0px calc(100vw * (3 /1366)) calc(100vw * (6 /1366)) rgba(0, 0, 0, 0.16); }
        .flow ol li .txt-wrap {
          width: calc(100vw * (770 /1366)); }
          .flow ol li .txt-wrap h3 {
            font-size: calc(100vw * (24 /1366));
            margin-bottom: calc(100vw * (10 /1366)); }
          .flow ol li .txt-wrap p {
            font-size: calc(100vw * (17 /1366)); } }
  @media screen and (max-width: 767px) {
    .flow {
      padding: 0 10px; }
      .flow h2 {
        font-size: 40px;
        margin-bottom: 47px; }
        .flow h2 small {
          font-size: 17px;
          margin-top: 20px; }
        .flow h2::before {
          top: -94px;
          font-size: 100px; }
      .flow ol {
        max-width: 1200px;
        margin-bottom: 0; }
        .flow ol li {
          margin-bottom: 40px;
          padding-left: 0;
          display: block; }
          .flow ol li .img-wrap {
            width: 100%;
            margin-right: 0;
            margin-bottom: 10px; }
            .flow ol li .img-wrap p {
              font-size: 24px;
              text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
              right: auto;
              right: 10px; }
              .flow ol li .img-wrap p span {
                font-size: 65px;
                text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); }
          .flow ol li .txt-wrap {
            width: 100%; }
            .flow ol li .txt-wrap h3 {
              font-size: 24px;
              margin-bottom: 10px;
              text-align: center; }
            .flow ol li .txt-wrap p {
              font-size: 17px; } }
  @media screen and (max-width: 896px) and (orientation: landscape) {
    .flow ol li .img-wrap p {
      right: -30px; } }

/* ---------------------------------------------------
	チェックリスト
------------------------------------------------------ */
.check-list ul li {
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 28px;
  letter-spacing: 0.05em;
  line-height: 1.5;
  background: none;
  padding-left: 0;
  margin-bottom: 20px; }
  .check-list ul li::before {
    content: "";
    display: inline-block;
    width: 34px;
    height: 34px;
    margin-right: 10px;
    background: url(../images/common/check-icon.svg) no-repeat center/contain;
    transform: translateY(8px); }
@media screen and (max-width: 767px) {
  .check-list ul li {
    font-size: 22px; } }

/* ---------------------------------------------------
	ピンク色ボタン
------------------------------------------------------ */
.btn_pink {
  width: 100%;
  max-width: 1000px;
  font-size: 1.35em;
  text-align: center;
  display: block;
  margin: 15px auto 20px auto; }

.entry-column .btn_pink a,
#footer_tuika .btn_pink a {
  text-decoration: none;
  padding: 23px 0;
  display: block;
  background: #EA4E82;
  border-radius: 100px;
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 26px;
  letter-spacing: 0.05em;
  text-align: center;
  color: #fff;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25); }

#footer_tuika .btn_pink {
  margin: 40px auto 20px auto; }

@media screen and (max-width: 767px) {
  .btn_pink {
    width: auto;
    font-size: 1em;
    margin-left: 10px;
    margin-right: 10px; }

  .entry-column .btn_pink a,
  #footer_tuika .btn_pink a {
    padding: 15px;
    font-size: 22px; }

  #footer_tuika .btn_pink {
    font-size: 1em;
    margin-left: 0;
    margin-right: 0; } }


/* 240305 */
/* 子ブログのサイドバー関連 */
.koblog-flex {
  display: flex;
  justify-content: space-between;
}

.category_marriage {
  width: 100%;
  /*max-width: 253.52px;*/
  margin-top: 40px;
}
.category_marriage h2 {
  margin-bottom: 20px;
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 1;
  color: #222;
}
.category_marriage ul li {
  padding: 0.5em 0.25em;
  border-bottom: 1px solid #CCC;
  background: none;
}
.category_marriage ul li:first-of-type {
  border-top: 1px solid #CCC;
}
.category_marriage ul li .acms-list-group-item {
  border: none;
  line-height: 1.15;
}
.category_marriage ul li .acms-list-group-item:hover {
  background: none;
}

.blog-right h2 {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-size: 24px;
  margin-bottom: 20px;
}

/* 新着記事一覧 */
.new_articles_marriage {
}
.new_articles_marriage ul li {
  margin-bottom: 15px;
  padding: 0;
  background: none;
}
.new_articles_marriage ul li a {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.new_articles_marriage ul li a:hover {
  text-decoration: none;
}
.new_articles_marriage ul li a img {
  width: 30%;
  object-fit: cover;
  aspect-ratio: 1;
}
.new_articles_marriage ul li a .txt-wrap {
  width: 65%;
}
.new_articles_marriage ul li a .txt-wrap .date {
  line-height: 1;
}
.new_articles_marriage ul li a .txt-wrap h3 {
  margin: 5px 0 0;
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 16px;
  font-weight: 500;
  color: #222;
  line-height: 1.4;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .koblog-flex {
    flex-direction: column;
  }
  
  .category_marriage {
    max-width: 100%;
  }
}

/* 子ブログのエントリー */
.koblog-flex .blog-left {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top: 30px;
  width: 100%;
  max-width: 880px;
}
.koblog-flex .blog-left .blog-image {
  margin: 0 auto 40px;
}
.koblog-flex .blog-left p {
  /*margin-right: 0;*/
}
.koblog-flex .blog-right {
  width: 100%;
  max-width: 280px;
  margin-top: 30px;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .koblog-flex .blog-left {
    max-width: 100%;
  }
  .koblog-flex .blog-right {
    max-width: 100%;
  }
}
/* /240305 */

/* ---------------------------------------------------
	無料相談ボタン
------------------------------------------------------ */
.entry-column .more-btn_spe {
    width: 348px;
    margin: auto;
    text-align: center;
    margin-bottom: 30px;
    margin-top: 50px;
}

.entry-column .more-btn_spe a {
    display: block;
    width: 100%;
    padding: 16px 0 15px;
    font-family: "Noto Serif JP";
    font-weight: 500;
    font-size: 20px;
    letter-spacing: 0.05em;
    line-height: 1.4;
    text-align: center;
    color: #fff;
    background: linear-gradient(135deg, #C2A33C, #e6cc63);
    border-radius: 100px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease-in-out;
    opacity: 1;
    text-decoration: none;
}

.entry-column .more-btn_spe a::before {
    content: '';
    position: absolute;
    top: 0;
    left: -75%;
    width: 50%;
    height: 100%;
    background: linear-gradient(
        120deg,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0.6) 50%,
        rgba(255, 255, 255, 0) 100%
    );
    transform: skewX(-25deg);
}

.entry-column .more-btn_spe a:hover::before {
    animation: shine 1s forwards;
}

/* ---------------------------------------------------
	FQAアコーディオン
------------------------------------------------------ */
.faq .main small , .wedding .main small , .free-form .main small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 17px;
  text-align: center;
  color: #222;
  margin-top: 20px;
  display: block;
}
.faq-accordion-group {
  max-width: 1200px;
  margin: 0 auto;
}
.faq-accordion-group .faq-content .faq-q {
  cursor: pointer;
}
.faq-accordion-group .faq-content .faq-q span.ui-accordion-header {
  display: block;
  cursor: inherit;
  position: inherit;
  margin: 0;
  padding: 0;
  font-size: inherit;
  border: inherit;
  background: inherit;
  color: inherit;
  border: none;
}
.faq-accordion-group .faq-content .faq-q span.ui-accordion-header span {
  display: none;
}
.faq-accordion-group .faq-content .faq-q span.ui-accordion-header::before, .faq-accordion-group .faq-content .faq-q span.ui-accordion-header::after {
  content: "";
  position: absolute;
  width: 15px;
  height: 2px;
  top: 50%;
  right: 15px;
  left: auto;
  background: #C2A33C;
  transition: all .4s ease-in-out;
}
.faq-accordion-group .faq-content .faq-q span.ui-accordion-header::before {
  transform: rotate(90deg);
}
.faq-accordion-group .faq-content .faq-q.open span.ui-accordion-header::before {
  transform: rotate(180deg);
}
.faq-accordion-group .faq-content .faq-a {
  display: none;
  line-height: 2;
}
.faq-accordion-group .faq-content .faq-a a {
  text-decoration: underline;
}
.faq-accordion-group .faq-content .faq-a a:hover {
  text-decoration: none;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
 
  .faq-accordion-group .faq-content {
    margin-bottom: 30px;
    padding: 0 10px;
  }
  .faq-accordion-group .faq-content .faq-q {
    font-size: 1.8rem;
  }
  .faq-accordion-group .faq-content .faq-q span.ui-accordion-header {
    padding-right: 40px;
  }
}

/* ---------------------------------------------------
	入会案内/コース・料金ページ　キャッチコピー
------------------------------------------------------ */
.entry-column .proven-and-trusted {
  width: 850px;
  margin: 0 auto;
  text-align: center;
}
.entry-column .proven-and-trusted p {
  font-weight: 500;
  font-size: 1.2vw;
  line-height: 1.6;
  margin: 0;
}
.entry-column .proven-and-trusted p.proven-and-trusted-heading {
  font-weight: 700;
  font-size: 1.4vw;
}
.entry-column .icon-heart {
  color: #E91E63;
}
.entry-column .no-joining-fee {
  color: #d32f2f;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .entry-column .proven-and-trusted {
    width: 100%;
    margin-bottom: 10px;
  }
  .entry-column .proven-and-trusted p {
    font-size: 16px;
  }
  .entry-column .proven-and-trusted p.proven-and-trusted-heading {
    font-size: 18px;
  }
}