@charset 'UTF-8';



/***************************************
基本設定
***************************************/
.e_font2 {
  font-family: "utile-display", sans-serif;
  font-weight: 200;
  font-style: normal;
}

.e_font {
  font-family: "utile-display", sans-serif;
  font-weight: 300;
  font-style: normal;
}



.j_font {
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  font-style: normal;
}

/* .j_font {
  font-family: "Noto Serif JP", serif;
  font-weight: 200;
  font-style: normal;
} */

body {
  margin: 0;
  /* font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif; */
  font-family: "Zen Kaku Gothic New", serif;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.7;
  color: #000;
  background-color: #fff;
  letter-spacing: 0.04em;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

html {
  font-size: 14px;
}

@media screen and (min-width: 1200px) {
  html {
    font-size: 16px;
  }
}

.fwb {
  font-weight: bold;
}

.mb0 {
  margin-bottom: 0;
}

.img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  max-width: 100%;
  max-height: 100%;
}

/***************************************
タイトル
***************************************/
.section_title_box {
  margin-bottom: 2.5rem;
}

.section_title_center {
  text-align: center;
}

.section_title span {
  display: block;
  font-size: 2.8rem;
  line-height: 1;
  margin-bottom: 0.7rem;
}

.section_title {
  display: block;
  font-size: 1rem;
  font-size: 0.928rem;
}

@media screen and (min-width: 768px) {
  .section_title_box {
    margin-bottom: 3.5rem;
  }
}

@media screen and (min-width: 992px) {
  .section_title span {
    font-size: 3.3rem;
  }
}

@media screen and (min-width: 1200px) {
  .section_title_box {
    margin-bottom: 4rem;
  }

  .section_title span {
    font-size: 3.75rem;
    margin-bottom: 1rem;
  }

  .section_title {
    font-size: 0.875rem;
    font-size: 0.9375rem;
    font-size: 1.0625rem;
  }
}

/***************************************
ボタン
***************************************/
.section_btn_center .section_btn {
  margin: 0 auto;
}

.section_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 150px;
  height: 40px;
  font-size: 0.9rem;
  border-radius: 60px;
  transition: all 0.5s 0s ease;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.5);

  z-index: 0;
  transition: .5s all;
}

.section_btn:hover {
  transition: .5s all;
}


/*白色ボタン*/
.section_btn_white {
  color: #171717;
  border: solid 1px rgba(0, 0, 0, 0.5);
  background-color: #fff;
}



/*グレーボタン*/
.section_btn_gray {
  color: #fff;
  border: solid 1px rgba(0, 0, 0, 0.5);
  background-color: #171717;
}




@media screen and (min-width: 1200px) {
  .section_btn {
    font-size: 0.9375rem;
    width: 200px;
    height: 50px;

  }



}

/***************************************
フォーム
***************************************/
#form {
  max-width: 1000px;
  margin: 0 auto;
}

.form-txt {
  font-size: 0.928rem;
  margin-bottom: 3rem;
}

@media screen and (min-width: 768px) {
  .form-txt {
    width: 70%;
    margin-left: 30%;

  }
}

@media screen and (min-width: 992px) {
  .form-txt {
    width: 76%;
    margin-left: 24%;
    margin-bottom: 5rem;

  }
}

/**====|基本設定====**/
select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
}

input[type="button"], input[type="text"], input[type="submit"], input[type="image"], textarea {
  -webkit-appearance: none;
  border-radius: 0;
}

input, textarea, select {
  padding: 15px;
  background-color: #f5f5f5;
  outline: none;
  resize: none;
  font-weight: 500;
  font-size: 1rem;
  margin: 0;
  border-radius: 0;
  border: none;
  width: 100%;
}

input[type="checkbox"], input[type="radio"] {
  display: inline-block;
}

input[type="date"] {
  min-width: 100%;
  display: block;
  width: 100%;
  height: 100%;
  outline: none;
}

@media screen and (min-width: 992px) {
  input, textarea, select {
    padding: 27px;
  }
}

/**====||フォーム====**/
.form-item {
  border-bottom: 1px solid rgba(200, 200, 200, 0.25);
  margin-bottom: 1rem;
  padding-bottom: 1.5rem;
}

.form-item.form-item--bottom {
  border: none;
  margin-bottom: 0.7rem;
}

.form-required {
  font-weight: 500;
  font-size: 0.8rem;
  background-color: #cc0033;
  padding: 4px 13px;
  color: #fff;
  border-radius: 12px;
  margin-left: 0.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  white-space: nowrap;
}

.form-item .form-label {
  font-size: 1rem;
  margin-bottom: 0.7rem;
  display: flex;
  align-items: center;
  cursor: inherit;
}

.form-item--bottom span.wpcf7-list-item {
  text-align: center;
  margin: 0;
}

@media screen and (min-width: 768px) {
  .form-item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    padding-bottom: 1.2rem;
    margin-bottom: 1.2rem;
  }

  .form-item .form-label {
    width: 30%;
    display: flex;
    margin-bottom: 0;
    padding-right: 1.8rem;
    justify-content: space-between;
  }

  .form-required {
    padding: 5px 20px;
  }

  .form-item--bottom {
    align-items: flex-start;
  }

  .form-item--bottom .form-label {
    padding-top: 1.7rem;
  }

  .form-item .wpcf7-form-control-wrap {
    width: 70%;
    margin-left: auto;
  }
}

@media screen and (min-width: 992px) {
  .form-item .form-label {
    width: 24%;
  }

  .form-item .wpcf7-form-control-wrap {
    width: 76%;
  }
}

/**====|||チェックボックス====**/
.form-input__checkbox {
  margin-bottom: 0;
}

.form-input__checkbox label {
  cursor: pointer;
  margin-bottom: 0;
}

.form-input__checkbox input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}

.form-input__checkbox .wpcf7-form-control {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
}

.form-input__checkbox .wpcf7-list-item {
  margin-right: 1.5rem;
  margin-left: 0;
}

.form-input__checkbox .wpcf7-list-item-label {
  font-size: 1rem;
  display: flex;
  align-items: center;
  position: relative;
  padding-left: 38px;
  line-height: 40px;
  padding-top: 0;
  top: 0;
  border-radius: 50%;
}

.form-input__checkbox .wpcf7-list-item-label::before, .form-input__checkbox .wpcf7-list-item-label::after {
  content: "";
  position: absolute;
  border-radius: inherit;
  transition: 0.2s;
}

.form-input__checkbox .wpcf7-list-item-label::before {
  display: block;
  top: 50%;
  left: 0;
  transform: translate(0%, -50%);
  height: 22px;
  width: 22px;
  margin-right: 10px;
  border: none;
  background-color: #f5f5f5;
}

.form-input__checkbox .wpcf7-list-item-label::after {
  top: 50%;
  left: 6px;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  opacity: 0;
  background-color: #171717;
}

.form-input__checkbox input:checked~.wpcf7-list-item-label::after {
  opacity: 1;
}

@media screen and (min-width: 768px) {
  .form-input__checkbox {
    width: 70%;
  }
}

@media screen and (min-width: 1200px) {
  .form-input__checkbox .wpcf7-list-item {
    margin-right: 1.5rem;
    margin-bottom: 0.2rem;
  }
}

/**====||||ラジオボタン====**/
.form-input__checkbox.form-input__radio .wpcf7-list-item-label {
  padding-left: 30px;
}

.form-input__radio .wpcf7-list-item-label::before {
  border-radius: 50%;
}

.form-input__radio .wpcf7-list-item-label::after {
  border-radius: 50%;
}

/**====|||||個人情報の取り扱いに同意する====**/
.form-item--agree {
  margin-bottom: 3rem;
}

@media screen and (min-width: 768px) {
  .form-item--agree {
    width: 70%;
    margin-left: auto;
    text-align: left !important;
    margin-bottom: 4.2rem;
  }
}

@media screen and (min-width: 992px) {
  .form-item--agree {
    width: 76%;
  }
}

/**====||||||個人情報の取り扱いに同意する-CHECKBOX====**/
.form-input__checkbox--round .wpcf7-form-control {
  justify-content: center;
}

.form-input__checkbox--round .wpcf7-list-item-label {
  position: relative;
  padding-left: 50px;
}

.form-input__checkbox--round .wpcf7-list-item-label::before, .form-input__checkbox--round .wpcf7-list-item-label::after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  -webkit-transition: 0.2s;
  -o-transition: 0.2s;
  transition: 0.2s;
}

.form-input__checkbox--round .wpcf7-list-item-label::before {
  left: 0;
  display: block;
  background-color: #f5f5f5;
  width: 35px;
  height: 35px;
  border-radius: 50%;
  border: none;
}

.form-input__checkbox--round .wpcf7-list-item-label::after {
  left: 12.5px;
  width: 10px;
  height: 10px;
  opacity: 0;
  background-color: #171717;
  border-radius: 50%;
}

.form-input__checkbox--round .wpcf7-list-item-label {
  border-radius: 50%;
  padding-left: 75px;
  line-height: 35px;
  padding-top: 0;
  font-size: 0.9375rem;
}

.form-input__checkbox--round .wpcf7-list-item-label::before {
  width: 50px;
  height: 50px;
  top: 50%;
  left: 0;
  transform: translate(0%, -50%);
}

.form-input__checkbox--round .wpcf7-list-item-label::after {
  left: 19.5px;
  top: 50%;
}

@media screen and (min-width: 768px) {
  .form-input__checkbox--round .wpcf7-form-control {
    justify-content: flex-start;
  }
}

@media screen and (min-width: 1200px) {
  .form-input__checkbox--round .wpcf7-list-item-label {
    font-size: 1rem;
  }
}

/**====|||||||プライバシーポリシーリンクテキスト====**/
.form-policy {
  text-align: center;
  margin-top: 2rem;
}

.form-policy a {
  color: #000;
  text-decoration: underline;
  transition: all 0.5s;
}

.form-policy a:hover {
  color: #828282;
  transition: all 0.5s;
  text-decoration: underline;
}

@media screen and (min-width: 768px) {
  .form-policy {
    text-align: left;
  }
}

@media screen and (min-width: 1200px) {
  .form-policy {
    font-size: 0.875rem;
  }
}

/**====||||||||その他-選択====**/
.form-item.form-item_other_block {
  margin-bottom: 2.5rem;
  position: relative;
  z-index: 10;
}

.form-item .form-label.form-label_other_text {
  font-size: 0.857rem;
}

@media screen and (min-width: 768px) {
  .form-item.form-item_other_block {
    flex-direction: column;
    margin-left: auto;
    width: 70%;
  }

  .form-item.form-item_other_block .form-label {
    width: 100%;
    justify-content: flex-start;
    margin-bottom: 1rem;
  }

  .form-item.form-item_other_block .wpcf7-form-control-wrap {
    width: 100%;
  }
}

@media screen and (min-width: 992px) {
  .form-item.form-item_other_block {
    width: 76%;
  }
}

/**====||||||||送信ボタン====**/
.form-item--submit {
  width: 88%;
  margin: 0 auto;
  text-align: center;
}

input[type="submit"] {
  display: block;
  background-color: #171717;
  color: #fff;
  height: 60px;
  width: 100%;
  max-width: 420px;
  font-weight: 400;
  font-size: 1rem;
  border: none;
  border-radius: 42px;
  letter-spacing: 0.08em;
}

@media screen and (min-width: 768px) {
  .form-item--submit {
    width: 70%;
    margin-left: 30%;

  }
}

@media screen and (min-width: 992px) {
  .form-item--submit {
    width: 76%;
    margin-left: 24%;

  }

  input[type="submit"] {
    font-size: 1.0625rem;
    padding: 0;
    height: 80px;
  }
}

/***************************************
パンクズ
***************************************/
.breadcrumb {
  width: 100%;
  font-size: 0.85rem;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

/*
.search_bred_outer .breadcrumb {
  max-width: 1280px;
  margin-right: auto;
  margin-left: auto;
} */



.breadcrumb span {
  display: block;
}

.breadcrumb a {
  color: #171717;
  vertical-align: middle;
}

.pagenation_line {
  margin: 0 3px;
}

/* .breadcrumb_arrow {
  font-size: 10px;
  margin: 0 4px 0 6px;
  padding-bottom: 2px;
} */

@media screen and (min-width: 569px) {
  .breadcrumb {
    font-size: 0.875rem;
  }
}

/***************************************
ページネーション
***************************************/
.pagination {
  margin: 4rem auto;
  font-family: "Outfit", serif;
  font-weight: 400;
  color: #ccc;
  font-size: 1rem;
}

.nav-links {
  display: flex;
  justify-content: center;
}

.pagination .page-numbers {
  display: inline-block;
  margin-right: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;

  /* font-size: 0.875rem; */
}

.pagination .page-numbers:last-child {
  margin-right: 0;
}

.pagination .current {
  color: #171717;
}

.pagination .current::before {
  content: '';
  display: block;
  width: 10px;
  height: 1px;
  background-color: #171717;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 0%);
}



@media screen and (min-width: 768px) {
  .pagination {
    margin: 5rem auto 7rem;
  }

  .pagination .page-numbers {
    margin-right: 1.5rem;
  }
}

/***************************************
固定ページ
***************************************/
.page_container {
  width: 84%;
  margin: 0 auto;
  max-width: 1000px;
}


/*----------------------------
サンクスページ
----------------------------*/
.pg_thanks_container {
  max-width: 1000px;
  margin: 2rem auto 4rem;
}

.pg_thanks_txt1 span {
  color: #afafb0;
  margin-bottom: 1rem;
  font-size: 1rem;
  display: block;
}

.pg_thanks_txt1 {
  font-size: 1.3rem;
  text-align: center;
  margin-bottom: 2rem;
}

.pg_thanks_txt2 {
  font-size: 1rem;
  margin-bottom: 1rem;
}

@media screen and (min-width: 768px) {
  .pg_thanks_container {
    text-align: center;
    margin: 4rem auto 8rem;
  }

  .pg_thanks_txt1 {
    font-size: 1.8rem;
    margin-bottom: 3rem;
    letter-spacing: 0.1rem;
  }

  .pg_thanks_txt2 {
    font-size: 1.2rem;
    margin-bottom: 2rem;
  }
}

/*----------------------------

----------------------------*/


/*----------------------------

----------------------------*/


/*----------------------------

----------------------------*/
/*----------------------------
投稿一覧
----------------------------*/
.archive_container {
  width: 84%;
  margin: 2rem auto;
  max-width: 1000px;
}

.archive_container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.archive_img_box {
  width: 100%;
  height: 200px;
}

.archive_img_box img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.archive_block {
  margin-bottom: 3rem;
}

.archive_block>ul>li {
  border-bottom: 1px solid #a8a8a8;
}

.archive_block>ul>li:first-child {
  border-top: 1px solid #a8a8a8;
}

.archive_box {
  display: flex;
  padding: 1rem 0;
  position: relative;
}

.archive_block ul li:last-child .archive_box {
  border-top: none;
}

.archive_imgbox {
  width: 25%;
  /* height: 100px; */
}

.archive_imgbox img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.archive_txtbox {
  width: 65%;
  margin-left: 10%;
}

.archive_date {
  font-size: 0.8rem;
  margin-bottom: 0.3rem;
  font-weight: 500;
}

.archive_txt1 {
  font-weight: 500;
  line-height: 1.4;
}

.archive_txt2 {
  display: none;
}

@media screen and (min-width: 768px) {
  .archive_container {
    margin: 2rem auto 4rem;
    display: flex;
  }

  .archive_block {
    width: 100%;
  }


  .archive_txt2 {
    display: block;
    font-size: 0.6rem;
  }
}

@media screen and (min-width: 992px) {
  .archive_imgbox {
    /* height: 200px; */
  }
}

@media screen and (min-width: 1200px) {
  .archive_container {
    margin: 2rem auto 6rem;
  }

  .archive_date {
    font-size: 0.9rem;
    margin-bottom: 1.5rem;
  }

  .archive_txt1 {
    font-size: 1.4em;
    margin-bottom: 1rem;
  }

  .archive_txt2 {
    font-size: 0.9rem;
  }
}

/*----------------------------
公開日
----------------------------*/
.single_date_block {
  margin-bottom: 2rem;
}

.single_datebox_outer {
  display: flex;
}

.single_datebox_outer .single_datebox:first-child {
  margin-right: 24px;
}

.single_datebox {
  font-size: 0.8rem;
  color: #7b7b7b;
}

.single_datebox time {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", "Hiragino Kaku Gothic ProN", "メイリオ", meiryo, sans-serif;
  letter-spacing: 0.05em;
}

@media screen and (min-width: 1200px) {
  .single_date_block {
    margin-bottom: 4rem;
  }

  .single_datebox {
    font-size: 0.95rem;
  }
}

/*----------------------------
投稿ページ
----------------------------*/
.single_container {
  width: 84%;
  margin: 2rem auto;
  max-width: 1000px;
}

.single_container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.single_block {
  margin-bottom: 3rem;
}


.single_thumbnail img {
  margin-bottom: 2rem;
}

/*見出し*/
.single_main h1 {
  font-size: 1.3rem;
  color: #333;

  margin-bottom: 2rem;
  line-height: 1.4;
  border-bottom: 1px solid rgba(204, 204, 204, 0.5);
  position: relative;
  padding-bottom: 0.8rem;
}

/* .single_main h1::before {
  content: '';
  display: block;
  width: 3px;
  height: 20px;
  background-color: #0c2b4a;
  position: absolute;
  top: 50%;
  left: 5px;
  transform: translate(0%, -50%);
} */
.single_main h2 {
  font-size: 1.2rem;
  margin-top: 3rem;
  margin-bottom: 2rem;
  background: #f2f2f2;
  padding: 0.5rem 1rem;
  color: #000;
  border-left: 4px solid #0c2b4a;
  line-height: 1.4;
  font-weight: 600;
  box-shadow: 1px 1px 1px 1px rgba(0, 0, 0, 0.1);
}

.single_main h3 {
  font-size: 1.1rem;
  margin-top: 2.5rem;
  margin-bottom: 1.5rem;
  padding: 0.5rem 1rem;
  color: #000;
  border-left: 3px solid #0c2b4a;
  line-height: 1.4;
  font-weight: 500;
  box-shadow: 1px 1px 1px 1px rgba(0, 0, 0, 0.1);
}

.single_main h4 {
  font-size: 1.1rem;
  margin-top: 2rem;
  margin-bottom: 1.2rem;
  font-weight: 600;
  color: #0c2b4a;
  padding: 0 15px;
  border-left: 2px solid #0c2b4a;
  font-weight: 500;
}

.single_main p {
  font-size: 0.96rem;
  letter-spacing: 0.02em;
  line-height: 1.8;
  text-align: justify;
}

.single_marker {
  background: linear-gradient(transparent 70%, #fff789 0%);
  font-weight: bold;
}

.single_listbox {
  background-color: #f2f2f2;
  padding: 1rem;
  border-radius: 10px;
}

.single_stepbox {
  margin-bottom: 2rem;
}

.single_stepbox>ul>li {
  position: relative;
  width: 95%;
  margin-right: 0;
  margin-left: auto;
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px dashed #afafb0;
}

.single_stepbox>ul>li::before {
  background: #afafb0;
  bottom: 0;
  content: "";
  display: block;
  left: -5%;
  position: absolute;
  top: 21px;
  width: 1px;
}

.single_stepbox>ul>li::after {
  background: #afafb0;
  bottom: 0;
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
  display: block;
  position: absolute;
  top: 12px;
  /* left: -6%; */
  left: calc(-5% - 4px);
}

.single_stepbox {
  counter-reset: number 0;
}

.single_step_number {
  font-size: 0.9rem;
  font-family: 'Montserrat', sans-serif;
  /* position: relative;
  left: 0; */
  display: inline-block;
  color: #afafb0;
  font-weight: 600;
  /* border: solid 1px #afafb0; */
  background-color: #fff;
  letter-spacing: 0.04em;
  margin-bottom: 0.1rem;
}

.single_step_number::before {
  counter-increment: number 1;
  content: "STEP. 0"counter(number);
}

.single_main .single_step_txt {
  font-size: 0.9rem;
  line-height: 1.5;
  margin-bottom: 1rem;
}

.fw6 {
  font-weight: 600;
}

@media screen and (min-width: 768px) {
  .single_container {
    margin: 2rem auto 4rem;
  }
}

@media screen and (min-width: 992px) {


  .single_block {
    width: 100%;
  }

  .sideber_block {
    width: 25%;
  }
}

@media screen and (min-width: 1200px) {
  .single_container {
    margin: 2rem auto 6rem;
  }

  .single_thumbnail img {
    margin-bottom: 4rem;
  }

  /*見出し*/
  .single_main h1 {
    font-size: 1.7rem;
  }

  .single_main h2 {
    font-size: 1.5rem;
    padding: 0.9rem 1rem;
  }

  .single_main h3 {
    font-size: 1.4rem;
  }

  .single_main h4 {
    font-size: 1.2rem;
  }

  .single_main p {
    font-size: 1rem;
    line-height: 1.8;
    letter-spacing: 0.03em;
  }
}

/*----------------------------
関連記事表示
----------------------------*/
.connection_block {
  border: solid rgba(0, 0, 0, .075);
  padding: 1rem;
  border-radius: 3px;
  display: flex;
  transition: all 0.5s;
}

.connection_block:hover {
  background-color: #f2f2f2;
  transition: all 0.5s;
}

.single_main p.connection_name {
  background-color: #000;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1px 8px;
  font-size: 0.7rem;
  margin-bottom: 1rem;
  width: 100%;
}

.connection_unit01 {
  height: 100px;
  width: 100px;
}

.connection_unit02 {
  width: calc(100% - 100px);
  padding-left: 5%;
}

.single_main p.connection_title {
  font-size: 1rem;
  margin-bottom: 0;
  line-height: 1.3;
}

.single_main p.connection_txt {
  display: none;
}

@media screen and (min-width: 1200px) {
  .connection_block {
    padding: 1.5rem;
    border-radius: 5px;
  }

  .connection_unit01 {
    height: 150px;
    width: 150px;
  }

  .connection_unit02 {
    width: calc(100% - 150px);
    padding-left: 5%;
  }

  .single_main p.connection_name {
    font-size: 0.9rem;
    max-width: 150px;
    letter-spacing: 0.1em;
  }

  .single_main p.connection_title {
    font-size: 1.3rem;
    margin-bottom: 0.6rem;
  }

  .single_main p.connection_txt {
    display: block;
    font-size: 0.8rem;
    margin-bottom: 0;
  }
}

/*----------------------------
固定ページ1000px用
----------------------------*/
.page_1000_container {
  width: 84%;
  margin: 2rem auto;
  max-width: 1000px;
}

.page_1000_container .breadcrumb {
  width: 100%;
}

@media screen and (min-width: 768px) {
  .page_1000_container {
    margin: 2rem auto 4rem;
  }
}

/*----------------------------
無料デザイン
----------------------------*/
.free_design_block h2 {
  background-color: inherit;
  padding: 0 1rem;
  font-size: 1.2rem;
  border-left: 4px solid #0c2b4a;
  margin-bottom: 2rem;
}

.list_style_block {
  background-color: #f2f2f2;
  padding: 1rem;
  margin-bottom: 2rem;
}

.list_style_block>ul>li {
  margin-bottom: 0.5rem;
}

.list_style_block>ul>li:last-child {
  margin-bottom: 0.5rem;
}

.list_style_block>ul>li {
  font-size: 0.9rem;
  text-indent: -1em;
  padding-left: 1em;
}

.free_design_block h3 {
  background-color: #0c2b4a;
  padding: 0.5rem;
  color: #fff;
  margin-bottom: 1rem;
  font-size: 1.2rem;
}

.free_design_block #form_contact-box {
  width: 100%;
}

@media screen and (min-width: 1200px) {
  .free_design_block h2 {
    font-size: 1.8rem;
  }

  .list_style_block>ul>li {
    font-size: 1rem;
  }

  .free_design_block h3 {
    padding: 0.8rem;
    font-size: 1.6rem;
  }
}



/*----------------------------
検索結果タイトル
----------------------------*/
.search_results_title {
  margin-bottom: 2rem;
}

@media screen and (min-width: 1200px) {
  .search_results_title {
    font-size: 1.8rem;
  }
}

/*----------------------------
投稿詳細ページ
----------------------------*/
.toc_box {
  margin-bottom: 30px;
  border: 2px solid #afafb0;
  border-radius: 3px;
}

.toc_box div {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 10px 0;
  background-color: #afafb0;
  color: #fff;
  font-weight: 600;
  font-size: 1.1em;
}

.toc_box div::before {
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-right: 5px;
  background-image:
    url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22M3.8%2017.2h-3c-.5%200-.8.4-.8.8v3c0%20.4.3.8.8.8h3c.4%200%20.8-.3.8-.8v-3c-.1-.4-.4-.8-.8-.8zm0-15h-3c-.5%200-.8.4-.8.8v3c0%20.4.3.8.8.8h3c.4%200%20.8-.3.8-.8V3c-.1-.4-.4-.8-.8-.8zm0%207.6h-3c-.5%200-.8.3-.8.7v3c0%20.4.3.8.8.8h3c.4%200%20.8-.3.8-.8v-3c-.1-.4-.4-.7-.8-.7zM23.2%2018h-15c-.4%200-.8.3-.8.8v1.5c0%20.4.3.8.8.8h15c.4%200%20.8-.3.8-.8v-1.5c0-.5-.3-.8-.8-.8zm0-15h-15c-.4%200-.7.3-.7.8v1.5c0%20.4.3.7.7.7h15c.5%200%20.8-.3.8-.8V3.8c0-.5-.3-.8-.8-.8zm0%207.5h-15c-.4%200-.8.3-.8.8v1.5c0%20.4.3.8.8.8h15c.4%200%20.8-.3.8-.8v-1.5c0-.5-.3-.8-.8-.8z%22%2F%3E%3C%2Fsvg%3E');
  content: '';
}

.toc_box ol {
  list-style-type: decimal;
  margin: 0;
  overflow: hidden;
}

.toc_box>ol {
  padding: 1em 1em 1em 3em;
}

.toc_box ol ol {
  margin-top: 5px;
  padding-left: 1.3em;
}

.toc_box li {
  padding: 5px 0;
  font-weight: 600;
}

.toc_box ol ol li {
  font-weight: 500;
  font-size: .9em;
}

.toc_box a {
  color: #333;
  text-decoration: none;
}

.img_600 {
  text-align: center;
}

.img_600 img {
  max-width: 600px;
  margin-right: auto;
  margin-left: auto;
}

/*----------------------------
マージン
----------------------------*/
.mb1 {
  margin-bottom: 1rem;
}

.mb2 {
  margin-bottom: 2rem;
}

.mb3 {
  margin-bottom: 3rem;
}

.mb4 {
  margin-bottom: 4rem;
}

.mb5 {
  margin-bottom: 5rem;
}

.mb6 {
  margin-bottom: 6rem;
}

.mb7 {
  margin-bottom: 7rem;
}

.mb8 {
  margin-bottom: 8rem;
}

.mb9 {
  margin-bottom: 9rem;
}

.mb10 {
  margin-bottom: 10rem;
}

/*----------------------------
br
----------------------------*/
.br_sp5 {
  display: block;
}

.br_pc5 {
  display: none;
}

@media screen and (min-width: 569px) {
  .br_sp5 {
    display: none;
  }

  .br_pc5 {
    display: block;
  }
}

.br_sp7 {
  display: block !important;
}

.br_pc7 {
  display: none !important;
}

@media screen and (min-width: 768px) {
  .br_sp7 {
    display: none !important;
  }

  .br_pc7 {
    display: block !important;
  }
}

.br_sp9 {
  display: block;
}

.br_pc9 {
  display: none;
}

@media screen and (min-width: 992px) {
  .br_sp9 {
    display: none;
  }

  .br_pc9 {
    display: block;
  }
}

.br_sp12 {
  display: block;
}

.br_pc12 {
  display: none;
}

@media screen and (min-width: 1200px) {
  .br_sp12 {
    display: none;
  }

  .br_pc12 {
    display: block;
  }
}

.br_sp15 {
  display: block;
}

.br_pc15 {
  display: none;
}

@media screen and (min-width: 1500px) {
  .br_sp15 {
    display: none;
  }

  .br_pc15 {
    display: block;
  }
}
