@charset "UTF-8";

/*  pege common
--------------------------------------------- */
.page-main-contents{
  position: relative;
}
.page-main-contents::before{
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 30.0rem;
  height: 30.0rem;
  background: url('/assets/img/page/ornament-bg-grd.svg') no-repeat top right / contain;
}
.page-main-contents section:first-child .ttl-wrapper{
  margin-top: var(--mg-20);
  margin-bottom: var(--mg-60);
}
@media  only screen and (max-width: 767px){
  .page-main-contents::before{
    width: 32vw;
    height: 32vw;
  }
}

.breadcrumb-list{
  margin-top: var(--mg-30);
}
.breadcrumb-list ol{
  display: flex;
  overflow-x: scroll;
  overflow-y: hidden;
  scrollbar-width: none;
  word-break: keep-all;
  white-space: nowrap;
}
.breadcrumb-list ol li,
.breadcrumb-list ol li a{
  color: #555555;
  font-size: var(--fs-14);
}
.breadcrumb-list ol li a{
  transition: 0.3s ease-in-out;
}
.breadcrumb-list ol li:not(:first-child) {
  position: relative;
  padding-left: 2.5rem;
}
.breadcrumb-list ol li:not(:first-child)::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 1.0rem;
  transform: translateY(-50%);
  width: 5px;
  height: 5px;
  background-color: #707070;
  border-radius: 50%;
}
@media (hover: hover) and (pointer: fine) {
  .breadcrumb-list ol li a:hover{
    transition: 0.3s ease-in-out;
    opacity: .6;
  }
}
@media screen and (max-width: 767px) {
  .breadcrumb-list{
    margin-top: var(--mg-20);
  }
  .breadcrumb-list ol li,
  .breadcrumb-list ol li a{
    font-size: var(--fs-11);
  }
  .breadcrumb-list ol li:not(:first-child) {
    padding-left: 2.4rem;
  }
  .breadcrumb-list ol li:not(:first-child)::before {
    width: 4px;
    height: 4px;
  }
}

/*  pege article
--------------------------------------------- */
.page-category-search{
  margin-bottom: var(--mg-70);
}
.page-category-flex:not(:first-child){
  margin-top: var(--mg-40);
}
.page-search-ttl{
  font-size: var(--fs-14);
  font-weight: var(--fw-600);
  color: var(--main-color);
}
.page-category-search .category-list,
.page-category-search .tag-list{
  margin-top: var(--mg-15);
  width: 100%;
}
.page-category-search .category-list ul li{
  width: calc((100% - 3rem)/4);
}
@media  only screen and (max-width: 1199px){
  .page-category-search .category-list ul li{
    width: calc((100% - 2rem)/3);
  }
}
@media  only screen and (max-width: 959px){
  .category-list ul li a{
    font-size: var(--fs-13);
  }
}
@media  only screen and (max-width: 767px){
  .js-accordion {
    cursor: pointer;
    position: relative;
    padding-right: 1.5em;
  }
  .js-accordion::after {
    content: "";
    position: absolute;
    right: 0.5em;
    top: 50%;
    width: 8px;
    height: 8px;
    border-right: 1px solid var(--main-color);
    border-bottom: 1px solid var(--main-color);
    transform: translateY(-50%) rotate(45deg); /* ▼下向き */
    transition: transform 0.3s ease;
  }
  .js-accordion.open::after {
    transform: translateY(-50%) rotate(-135deg); /* ▲上向き */
  }
  .js-accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease, opacity 0.4s ease;
    opacity: 0;
  }
  .js-accordion.open + .js-accordion-content {
    max-height: 1000px;
    opacity: 1;
  }
  .page-main-contents section:first-child .ttl-wrapper{
    margin-top: var(--mg-30);
    margin-bottom: var(--mg-40);
  }
  .page-category-search{
    margin-bottom: var(--mg-50);
  }
  .page-search-ttl{
    padding: 1.6rem 0;
    border-bottom: 1px solid #DDD6DE;
  }
  .page-category-search .category-list,
  .page-category-search .tag-list{
    margin-top: 0;
  }
  .page-category-search .category-list ul,
  .page-category-search .tag-list ul{
    margin-top: var(--mg-25);
  }
  .js-accordion.open + .js-accordion-content{
    margin-bottom: var(--mg-20);
  }
  .page-category-search .category-list ul{
    gap:  1.0rem 2%;
  }
  .page-category-search .category-list ul li{
    width: 49%;
  }
  .page-category-flex:not(:first-child){
    margin-top: 0;
  }
}

/*  page book-review archive
--------------------------------------------- */
.article-item.book-review-arc-img .article-img{
  background: var(--white-color);
}
.article-item.book-review-arc-img .article-img img{
  width: unset;
  max-width: 100%;
  max-height: 100%;
  /* height: unset; */
  text-align: center;
  margin: 0 auto;
}

/*  page info archive
--------------------------------------------- */
.info-list{
  width: 100%;
}
.info-item a{
  display: flex;
  align-items: baseline;
  gap: 2.0rem;
  border-bottom: 1px solid #CBCBCB;
  padding: 2.5rem 0;
}
.info-item:first-child a{
  border-top: 1px solid #CBCBCB;
}
.info-time{
  color: var(--black-color);
  font-size: var(--fs-14);
  font-weight: normal;
  display: inline-block;
  padding: 0.6rem 1.5rem;
  background: #F8F8F8;
  border-radius: 3.0rem;
}
.info-item .key{
  width: 2.6rem;
  height: auto;
}
.info-item .key img{
  vertical-align: text-top;
  width: 2.6rem;
  height: auto;
}
.info-ttl{
  color: var(--main-color);
  font-weight: var(--fw-500);
  word-break: break-word;
  transition: 0.3s ease-in-out;
}
@media (hover: hover) and (pointer: fine) {
  .info-item a:hover .info-ttl{ opacity: .6; transition: 0.3s ease-in-out;}
}

@media screen and (max-width: 1199px) {
  .info-item a{ padding: 2.2rem 0;}
  .info-time{ font-size: var(--fs-13);}
}
@media screen and (max-width: 767px) {
  .info-item a{
    flex-wrap: wrap;
    align-items: center;
    gap: 1.0rem;
    padding: 2.0rem 0;
  }
  .info-time{ 
    padding: 0.4rem 1.3rem;
    font-size: var(--fs-11);  
  }
  .info-item .key,
  .info-item .key img{
    width: 2.2rem;
    height: auto;
  }
  .info-ttl{
    width: 100%;
  }
}

/*  pege article pagenavi
--------------------------------------------- */
.pagination{
  margin-top: var(--mg-60);
}
.pagination .nav-links {
  display: flex;
  gap: 1.0rem;
  justify-content: center;
  align-items: center;
}
/* 数字・前へ・次への共通デザイン */
.pagination .page-numbers {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid var(--main-color);
  color: var(--main-color);
  text-decoration: none;
  font-size: 14px;
  transition: 0.2s;
}
.pagination .page-numbers.current {
  background: var(--main-color);
  color: var(--white-color);
}
.pagination .page-numbers img {
  width: 12px;
  height: 12px;
}
@media (hover: hover) and (pointer: fine) {
  .pagination .page-numbers:hover {
    background: var(--main-color);
    color: var(--white-color);
  }
  .pagination .page-numbers:hover img{
    filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(7490%) hue-rotate(145deg) brightness(101%) contrast(98%);
  }
}
@media screen and (max-width: 767px) {
  .pagination{
    margin-top: var(--mg-40);
  }
  .pagination .nav-links{
    gap: 0.7rem;
  }
  .pagination .page-numbers {
    width: 30px;
    height: 30px;
    font-size: 10px;
  }
  .pagination .page-numbers img {
    width: 8px;
    height: 8px;
  }
}


/*  single common
--------------------------------------------- */
.single-main-contents{
  position: relative;
  overflow-x: hidden;
}
.single-main-contents::before{
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 30.0rem;
  height: 30.0rem;
  background: url('/assets/img/page/ornament-bg-grd.svg') no-repeat top right / contain;
  z-index: 0;
}
.single-main-contents section:first-child .single-wrapper{
  margin-top: var(--mg-20);
}
@media  only screen and (max-width: 767px){
  .single-main-contents::before{
    width: 32vw;
    height: 32vw;
  }
}

/*  single temp
--------------------------------------------- */
.single-main-container{
  display: flex;
  align-items: center;
  gap: 5%;
}
.single-main-container .single-img{
  flex: 1;
  object-fit: cover;
  height: 100%; 
  width: 100%;
  margin-left: calc(50% - 50vw);
  border-radius: 0 30px 0 0;
  overflow: hidden;
  z-index: 1;
}
.single-main-container .single-block{
   width: 50%;
   padding-bottom: 3.0rem;
}
.single-catkey{
  display: flex;
  gap: 1.0rem;
}
.single-cat a{
  display: block;
  border: 1px solid var(--main-color);
  border-radius: 2.0rem;
  font-size: var(--fs-14);
  font-weight: var(--fw-500);
  padding: 0.7rem 1.6rem;
  line-height: 100%;
}
@media (hover: hover) and (pointer: fine) {
  .single-cat a:hover{
    background: var(--main-color);
    color: var(--white-color);
  }
}
.single-ttl{
  color: var(--main-color);
  font-size: var(--fs-30);
  font-weight: var(--fw-500);
  margin-top: var(--mg-30);
}
.single-txt{
  margin-top: var(--mg-20);
  font-size: var(--fs-18);
  font-weight: var(--fw-500);
}
.single-txt2{
  margin-top: var(--mg-10);
  font-size: 90%;
}
.single-subtxt{
  margin-top: var(--mg-15);
  display: flex;
  flex-wrap: wrap;
  gap: 2.0rem;
  color: var(--gray-color);
  font-size: var(--fs-12);
  font-weight: normal;
}
.single-tag-container{
  display: flex;
  flex-wrap: wrap;
  gap: 1.0rem;
}
.single-tag-container span:before{
  content: "#";
}
.single-fav{
  margin-top: var(--mg-15);
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  align-items: center;
}
.single-overview-container {
  max-width: 120.0rem;
  width:100%;
  margin: 0 auto;
}
.single-overview-bg.over-right{
  width: 100vw;
  margin-top: -5.0rem;
  margin-right: calc(50% - 50vw);
  background: linear-gradient(to right, #E0DCE9 0%, #E0DCE9 50%, transparent 100%);
  border-radius: 1.5rem 0 0 1.5rem;
  padding: 14rem 0 9rem;
}
.single-overview-txt{
  max-width: 1200px;
  width: 100%;
  padding-inline: 200px;
  line-height: 2.0em;
  color: var(--main-color);
}
.no-img .single-main-container .single-block{
  width: 100%;
  padding-bottom: 0;
}
.no-img .single-overview-bg.over-right{
  padding: 9rem 0;
  margin-top: 3.0rem;
}
.book-review-single-img .single-main-container{
  align-items: flex-start;
}
.book-review-single-img .single-main-container .single-img{
  width: 30%;
  margin-left: unset;
  object-fit: unset;
  flex: unset;
  border-radius: 0;
}
.book-review-single-img .single-main-container .single-block{
  width: 70%;
}
.book-review-single-img .single-main-container .single-img-inner{
  height: 300px;
  max-width: 200px;
  border-radius: 0;
  overflow: unset;
  margin: 0 auto;
  padding-bottom: 5px;
}
.book-review-single-img .single-main-container .single-img img{
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  box-shadow: 5px 5px 0px 0px rgba(107, 27, 126, 1);
}
@media  only screen and (max-width: 1199px){
  .single-main-container .single-img{
    border-radius: 0 20px 0 0;
  }
  .single-cat a{
    font-size: var(--fs-13);
    padding: 0.6rem 1.5rem;
  }
  .single-ttl{
    font-size: var(--fs-24);
    margin-top: var(--mg-20);
  }
  .single-txt{
    margin-top: var(--mg-15);
    font-size: var(--fs-14);
  }
  .single-subtxt{
    margin-top: var(--mg-15);
  }
  .single-key img{
    width: 2.7rem;
    height: 2.7rem;
  }
  .single-overview-container{
    margin-top: 3.0rem;
  }
  .single-overview-bg.over-right{
    padding: 6rem 0;
    margin-top: 0;
    margin-left: 4%;
  }
  .no-img .single-overview-bg.over-right{
    padding: 6rem 0;
  }
  .single-overview-txt{
    max-width: 100%;
    padding-inline: max(4.0rem);
  }
  .book-review-single-img .single-main-container .single-img-inner{
    height: 280px;
    max-width: 195px;
    padding-right: 5px;
    padding-bottom: 5px;
  }
}
@media  only screen and (max-width: 767px){
  .single-main-container{
    display: flex;
    flex-wrap: wrap;
    gap: 3.0rem;
  }
  .single-main-container{
    align-items: flex-start;
  }
  .single-main-container .single-block{
    width: 100%;
  }
  .single-main-container .single-img{
    flex: auto;
  }
  .single-cat a{
    font-size: var(--fs-12);
    padding: 0.6rem 1.5rem;
  }
  .single-ttl{
    font-size: var(--fs-20);
  }
  .single-subtxt{
    gap: 1.5rem;
    font-size: var(--fs-13);
  }
  .single-fav{
    margin-top: var(--mg-15);
  }
  .single-overview-container{
    margin-top: 0;
  }
  .single-overview-bg.over-right{
    margin-top: 0;
    margin-left: 4%;
    padding: 4rem 0 4rem;
  }
  .no-img .single-overview-bg.over-right{
    padding: 4rem 0;
    margin-top: 3.0rem;
  }
  .single-overview-txt{
    max-width: 96%;
    padding-inline: 4%;
  }
  .book-review-single-img .single-main-container .single-img,
  .book-review-single-img .single-main-container .single-block{
    width: 100%;
  }
  .book-review-single-img .single-main-container .single-block{
    padding-bottom: 0;
  }
  .book-review-single-img .single-main-container .single-img-inner{
    height: 190px;
    max-width: 130px;
  }
}

/*  single-block-container
--------------------------------------------- */
.single-block-container{
  padding: 8.0rem 0 0;
}
.toc-container{
  margin-bottom: 6.0rem;
}
.single-block-contents{
  margin-bottom: 12.0rem;
}
.single-block-contents h2,
.single-block-contents h3,
.single-block-contents h4,
.single-block-contents h5,
.single-block-contents p,
.single-block-contents .wp-block-image,
.single-block-contents .wp-block-table,
.single-block-contents .wp-block-button,
.single-block-contents .wp-block-media-text,
.single-block-contents .wp-block-gallery{
  margin-bottom: var(--mg-40);
}
.single-block-contents .wp-block-button{
  margin-bottom: var(--mg-60) !important;
}
.single-block-contents h2 span{
  display: inline-block;
  background: var(--main-color);
  border-radius: 0.5rem;
  color: var(--white-color);
  font-size: var(--fs-24);
  font-weight: var(--fw-500);
  padding: 0.5rem 1.5rem;
}
.single-block-contents > * + h2,
.single-block-contents * + h2{
  margin-top: var(--mg-70);
}
.single-block-contents h3 span{
  display: inline; 
  font-size: var(--fs-20);
  font-weight: var(--fw-500);
  background: linear-gradient(0deg, #E2DCF2 35%, transparent 35%);
  box-decoration-break: clone; 
  -webkit-box-decoration-break: clone;
  line-height: 1.8em;
}
.single-block-contents h4{
  font-size: var(--fs-18);
  font-weight: var(--fw-500);
  border-bottom: 1px solid #707070;
  padding: 1.0rem 0;
}
.single-block-contents h5{
  font-size: var(--fs-18);
  font-weight: var(--fw-500);
}
.single-block-contents strong{
  font-weight: var(--fw-600);
}
.single-block-contents .single-fontimg{
  width: auto !important;
  vertical-align: text-top !important;
}
.single-block-contents p{
  line-height: 2.0em;
}
.single-block-contents a{
  color: var(--main-color);
  border-bottom: 1px solid var(--main-color);
  word-break: break-all;
}
@media (hover: hover) and (pointer: fine) {
  .single-block-contents a:hover{
    opacity: .6;
  }
}
.single-block-contents .wp-block-image{
  width: 100%;
  height: auto;
  line-height: 2.0em;
}
.single-block-contents .wp-block-gallery{
  display: grid;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 15px !important;
}
.wp-block-gallery.has-nested-images figure.wp-block-image figcaption,
.wp-block-gallery.has-nested-images figure.wp-block-image:has(figcaption):before{
  position: unset !important;
}
.wp-block-gallery.has-nested-images figure.wp-block-image figcaption{
  color: #333 !important;
  overflow: auto !important;
  text-shadow: unset !important;
  background: unset !important;
  padding: 0.5em 0 1em !important;
  line-height: normal !important;
  text-align: left !important;
}
.wp-block-gallery.has-nested-images.is-cropped figure.wp-block-image:not(#individual-image){
  align-self: flex-start !important;
}
@media  only screen and (min-width: 768px){
  .wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image){
    width: 100% !important;
  }
}
@media  only screen and (max-width: 767px){
  .single-block-contents .wp-block-gallery{
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }
  .wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image){
    width: 100% !important;
  }
  :where(.wp-block-columns.is-layout-flex){
    gap: 0 !important;
  }
}
.single-block-contents .wp-block-gallery .wp-block-image img{
  width: 100%;
  height: auto;
  display: block;
}
.single-block-contents .wp-block-list{
  padding:0;
  list-style :none;
}
.single-block-contents .wp-block-list li {
  position:relative;
  padding-left:15px;
}
.single-block-contents .wp-block-list li:not(:first-child){
  margin-top: 5px;
}
.single-block-contents .wp-block-list li:before {
  content:"";
  width: 5px;
  height: 5px;
  background:#333333;
  border-radius: 5px;
  position:absolute;
  left:0px;
  top: 10px;
}
.single-block-contents .wp-block-table table{
  width: 100%;
  border-collapse: collapse;
}
.wp-block-table td, .wp-block-table th{
  border-left: unset !important;
  border-right: unset !important;
}
.single-block-contents .wp-block-table table ,
.single-block-contents .wp-block-table table td{
  border-top: solid 1px #CBCBCB;
  border-bottom: solid 1px #CBCBCB;
  padding: 20px;
  text-align: left;
  font-weight: normal;
}
.single-block-contents .wp-block-table table td:first-child{
  color: var(--main-color);
  font-weight: var(--fw-500);
  background: #EFEDF4;
  mix-blend-mode: multiply;
  width: 25%;
}
.single-block-contents .wp-block-table table td{
  width: 75%;
}
.single-block-contents .wp-block-button a{
  position: relative;
  background: var(--main-color);
  border-radius: 999px;
  color: var(--white-color);
  display: flex; 
  align-items: center; 
  justify-content: center;
  font-size: var(--fs-14);
  font-weight: var(--fw-400);
  padding: 1.6rem 4.8rem 1.6rem 3.6rem;
  min-width: auto;
  max-width: 50.0rem;
  margin: 0 auto;
  transition: 0.3s ease-in-out;
}
.single-block-contents .wp-block-media-text .wp-block-button{
  margin-bottom: 0 !important;
}
.single-block-contents .wp-block-media-text .wp-block-buttons{
  margin-top: 2.0rem;
}
.single-block-contents .wp-block-media-text .wp-block-button a{
  padding: 1.4rem 4.8rem 1.4rem 3.6rem;
}
.single-block-contents .wp-block-button .wp-block-button__link:after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  right: var(--mg-20);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 12px;
  height: 10px;
  background: url(/assets/img/common/icon_arrowlink-wht.svg) no-repeat center / contain;
  transition: none; 
  animation: none; 
  pointer-events: none;
}
@media (hover: hover) and (pointer: fine) {
  .single-block-contents .wp-block-button a:hover{ background-color: var(--main-color-hover); opacity: 1;}
  .single-block-contents .wp-block-button .wp-block-button__link:hover::after{ animation: arrowSlide 0.3s ease-in-out forwards; }
}
.single-block-contents .wp-block-separator{
  border-top: 1px solid #CECECE !important;
  margin: 4.0rem 0;
}
.wp-block-image .aligncenter>figcaption{
  line-height: 1.4em;
}
.wp-caption,
.wp-caption-text,
figcaption {
  display: block;
  font-size: 14px;
  color: #666;
  text-align: left;
  margin-top: 6px;
}
.wp-caption-text {
  display: block !important;
}
.wp-block-media-text .wp-block-media-text__content p{
  margin-bottom: 1.0rem !important;
}
.wp-block-media-text .wp-block-media-text__content p:last-child{
  margin-bottom: 0rem !important;
}
.wp-block-media-text .wp-block-media-text__content .has-medium-font-size{
  line-height: 1.5em;
}
.wp-block-media-text>.wp-block-media-text__content{
  padding: 0 0 0 6% !important;
}
.wp-block-media-text.has-media-on-the-right>.wp-block-media-text__content{
  padding: 0 6% 0 0 !important;
}

@media  only screen and (max-width: 1199px){
  .single-block-container{
    padding: 8.0rem 0 0;
  }
  .single-block-contents{
    margin-bottom: 10.0rem;
  }
  .single-block-contents h2 span{
    font-size: var(--fs-20);
    padding: 0.7rem 1.3rem;
  }
  .single-block-contents h3 span{
    font-size: var(--fs-20);
  }
  /* 
  .wp-block-media-text {
    align-items: start !important;
  }
  .wp-block-media-text__content,
  .wp-block-media-text__media {
    align-self: start !important;
  }
  */
}
@media  only screen and (max-width: 767px){
  .single-block-container{
    padding: 4.0rem 0 0;
  }
  .toc-container{
    margin-bottom: 4.0rem;
  }
  .single-block-contents{
    margin-bottom: 8.0rem;
  }
  .single-block-container .wrap-min{
    padding-inline: 4%;
  }
  .single-block-contents h2,
  .single-block-contents h3,
  .single-block-contents h4,
  .single-block-contents h5,
  .single-block-contents p,
  .single-block-contents .wp-block-image,
  .single-block-contents .wp-block-table,
  .single-block-contents .wp-block-button,
  .single-block-contents .wp-block-media-text,
  .single-block-contents .wp-block-gallery{
    margin-bottom: var(--mg-30);
  }
  .single-block-contents .wp-block-button{
    margin-bottom: var(--mg-50) !important;
  }
  .single-block-contents h2 span{
    font-size: var(--fs-17);
  }
  .single-block-contents > * + h2,
  .single-block-contents * + h2{
    margin-top: var(--mg-50);
  }
  .single-block-contents h3 span{
    font-size: var(--fs-16);
  }
  .single-block-contents h4{
    font-size: var(--fs-15);
  }
  .single-block-contents h5{
    font-size: var(--fs-15);
  }
  .single-block-contents .gallery2 .wp-block-image{
    width: 100%;
  }
  .single-block-contents .gallery3 .wp-block-image{
    width: 48%;
    max-width: 48%;
  }
  .single-block-contents .wp-block-list li {
    padding-left:10px;
  }
  .single-block-contents .wp-block-list li:before {
    top: 8px;
  }
  .single-block-contents .wp-block-table table ,
  .single-block-contents .wp-block-table table td{
    padding: 15px;
  }
  .single-block-contents .wp-block-table table td:first-child{
    width: 100%;
    border-top: unset;
  }
  .single-block-contents .wp-block-table table td{
    width: 100%;
    display: block;
    border-bottom: unset;
  }
  .single-block-contents .wp-block-button a{
    padding: 1.3rem 4.8rem 1.3rem 3.6rem;
    max-width: 28.0rem;
    font-size: var(--fs-13);
  }
  .single-block-contents .wp-block-media-text .wp-block-button a{
    padding: 1.7vw 4rem 1.7vw 3.0rem;
  }
  .single-block-contents .wp-block-button .wp-block-button__link:after{
    width: 1.0rem;
    height: 0.8rem;
  }
  .single-block-contents .wp-block-separator{
    margin: 3.0rem 0;
  }
  .wp-caption,
  .wp-caption-text,
  figcaption {
    font-size: 12px;
    margin-top: 4px;
  }
  .wp-block-media-text .wp-block-media-text__content .has-medium-font-size{
    font-size: 120% !important;
  }
  .wp-block-media-text{
    grid-template-columns: 100% !important;
  }
  .wp-block-media-text>.wp-block-media-text__content{
    padding: 2.0rem 0 0 0 !important;
    grid-column: unset !important;
    grid-row: unset !important;
  }
  .wp-block-media-text.has-media-on-the-right>.wp-block-media-text__media{
    grid-column: unset !important; 
  }
  .wp-block-media-text.has-media-on-the-right>.wp-block-media-text__content{
    padding: 2.0rem 0 0 0 !important;
  }
  .wp-block-media-text[style*="grid-template-columns"],
  .wp-block-media-text.is-stacked-on-mobile[style*="grid-template-columns"]{
    grid-template-columns: 30% auto !important;
  }
  .wp-block-media-text[style*="grid-template-columns"] .wp-block-media-text__content{
    padding-top: 0 !important;
    padding-left: 5% !important;
  }
  .wp-block-media-text[style*="grid-template-columns"] .wp-block-media-text__content p{
    line-height: 1.7em;
  }

  .wp-block-columns .wp-block-column[style*="66.66"] {
      order: 2 !important;
  }
  .wp-block-columns .wp-block-column[style*="33.33"] figure {
      order: 1 !important;
  }
}

.custom-flex{
  display: flex;
  gap: 15px;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: baseline;
}

/*  single-share
--------------------------------------------- */
.single-share-container{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4.0rem;
}
.single-share-list{
  display: flex;
  gap: 2.0rem; 
}
.single-share-list .single-share-item a img{
  width: 2.8rem;
  height: 2.8rem;
  transition: 0.3s ease-in-out;
  filter: brightness(0) saturate(100%) invert(19%) sepia(0%) saturate(671%) hue-rotate(295deg) brightness(96%) contrast(85%);
}
@media (hover: hover) and (pointer: fine) {
  .single-share-list .single-share-item a:hover img{
    opacity: .6;
  }
}
@media  only screen and (max-width: 767px){
  .single-share-container{
    flex-wrap: wrap;
    gap: 1.5rem;
  }
  .single-share-container p{
    width: 100%;
    text-align: center;
  }
  .single-share-list{
    width: 100%;
    gap: 2.0rem; 
  }
  .single-share-list .single-share-item a img{
    width: 2.5rem;
    height: 2.5rem;
  }
}

/*  single-backlist
--------------------------------------------- */
.single-backlist-wrapper{
  position: relative;
  margin-top: 6.0rem;
  padding-top: 6.0rem;
}  
.single-backlist-wrapper::before{
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #BEBEBE;
}
.single-backlist-wrapper::before {
  top: 0;
  box-shadow: 0 5px 0 #BEBEBE;
}
.single-backlist-container{
  display: flex;
  justify-content: space-between;
}
/*  button txttype */
.button-prevnext a{
  position: relative;
  display: inline-block; 
  font-weight: var(--fw-600);
  transition: 0.3s ease-in-out;
}
.button-prevnext .link-prev{
  padding-left: var(--mg-40);
}
.button-prevnext .link-next{
  padding-right: var(--mg-40);
}
.button-prevnext .link-prev:before,
.button-prevnext .link-next:before {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  width: 2.4rem;
  height: 2.4rem;
  background: var(--main-color);
  border-radius: 999px;
  color: var(--white-color);
}
.button-prevnext .link-prev:before{
  left: 0;
}
.button-prevnext .link-next:before {
  right: 0;
}
.button-prevnext .link-prev:after,
.button-prevnext .link-next:after{
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 10px;
  height: 8px;
  transition: none; 
  animation: none; 
  pointer-events: none;
}
.button-prevnext .link-prev:after{
  left: 0.8rem;
  background: url(/assets/img/common/icon_arrowlink-wht-prev.svg) no-repeat center / contain;
}
.button-prevnext .link-next:after {
  right: 0.8rem;
  background: url(/assets/img/common/icon_arrowlink-wht.svg) no-repeat center / contain;
}
@media (hover: hover) and (pointer: fine) {
  .button-prevnext .link-prev:hover::before,
  .button-prevnext .link-next:hover::before{ background: var(--main-color-hover);}
  .button-prevnext .link-next:hover::after,
  .button-prevnext .link-prev:hover::after{ animation: arrowSlide 0.3s ease-in-out forwards; }
}

.button-backlist a{
  position: relative;
  display: inline-block; 
  font-weight: var(--fw-600);
  transition: 0.3s ease-in-out;
  padding-left: var(--mg-40);
}
.button-backlist .link-backlist:before{
  position: absolute;
  content: "";
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 2.0rem;
  height: 2.0rem;
  background: url(/assets/img/common/icon_backklist.svg) no-repeat center / contain;
  pointer-events: none;
}
@media (hover: hover) and (pointer: fine) {
  .button-prevnext a:hover,
  .button-backlist a:hover{
    color: var(--main-color-hover);
  }
}
@media  only screen and (max-width: 767px){
  .single-backlist-wrapper{
    margin-top: 4.0rem;
    padding-top: 4.0rem;
  }  
  /*  button txttype */
  .single-backlist-container{
    justify-content: center;
    margin-top: var(--mg-30);
  }
  .button-prevnext:first-child{
    margin-right: 25px;
    padding-right: 25px;
    border-right: 1px solid var(--main-color);
  }
  .button-backlist a{
    position: unset;
    display: flex; 
    justify-content: center;
    flex-direction: column;
    padding-left: 0;
    text-align: center;
  }
  .button-backlist a img{
    width: 2.0rem;
    margin: 0 auto 5px;
  }
  .button-backlist .link-backlist:before{
    display: none;
  }
}

/*  single-related
--------------------------------------------- */
.single-related .section-inner{
  background: #DFDCE8;
  mix-blend-mode: multiply;
}
.single-related .main-ttl .jp{
  font-size: var(--fs-24);
  color: var(--main-color);  
}
@media  only screen and (max-width: 1199px){
  .single-related .main-ttl .jp{
    font-size: var(--fs-20);
  }
}
@media  only screen and (max-width: 767px){
  .single-related .main-ttl .jp{
    font-size: var(--fs-18);
  }
  .single-related .article-wrapper{
    margin-right: calc(50% - 50vw);
    margin-top: 1.5rem;
  }
  .sp-slide{
    display:-webkit-box;
    display:-ms-flexbox;
    display: flex;
    gap: 6%;
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding:0 0 1em;
    scroll-behavior: smooth;
  }
  .sp-slide .article-item{
    flex: 0 0 70%;
    height:100%;
    scroll-snap-align:center;
  }
  .sp-slide .article-item:last-child{
    margin-right: 4%;
  }
}

/*  single password
--------------------------------------------- */
.password-form-wrapper{
  width: 100%;
  text-align: center;
}
.password-form-wrapper input[type="password"] {
  max-width: 100%;
  margin: 20px auto;
  background: #fff;
  width: 100%;
  max-width: 100%;
  padding: 15px;
  border: 1px solid #BEBEBE;
  box-sizing: border-box;
  outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.password-submit-wrapper {
  position: relative;
  display: inline-block; /* 横幅をボタンに合わせる */
  margin-top: 20px;
}
.password-submit-wrapper input[type="submit"] {
  z-index: 1; /* 矢印より上に */
  position: relative;
  background: var(--main-color);
  border-radius: 999px;
  color: var(--white-color);
  display: flex; 
  align-items: center; 
  justify-content: center;
  font-size: var(--fs-14);
  font-weight: var(--fw-400);
  padding: 1.8rem 0;
  min-width: 26.0rem;
  max-width: 26.0rem;
  margin: 0 auto;
  transition: 0.3s ease-in-out;
}
/* ★ 親に after を付ける */
.password-submit-wrapper::after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  right: var(--mg-20);
  width: 12px;
  height: 10px;
  background: url(/assets/img/common/icon_arrowlink-wht.svg) no-repeat center / contain;
  pointer-events: none;
  z-index: 2;
}
@media (hover: hover) and (pointer: fine) {
  .password-submit-wrapper input[type="submit"]:hover{ background-color: var(--main-color-hover);}
}
@media  only screen and (max-width: 767px){
  .password-form-wrapper input[type="password"]{
    margin: 10px auto;
    padding: 12px 15px;
  }
  .password-submit-wrapper input[type="submit"] {
    font-size: var(--fs-13);
    padding: 1.6rem 0;
  }
}

/*  single toc plugin
--------------------------------------------- */
div#ez-toc-container{
  border: 1px dotted #6b1b7e !important;
  border-radius: 5px !important;
}
#ez-toc-container{
  padding: 20px 30px !important;
  margin-bottom: 5.0rem !important;
}
span.ez-toc-section,
span.ez-toc-section-end{
  padding: 0 !important;
}
#ez-toc-container a {
  text-decoration: none !important;
  border-bottom: none !important;
}
.ez-toc-title-container {
  margin-bottom: 5px;
}
.ez-toc-counter nav ul li a::before{
  margin-right: 0.5rem !important;
}
@media (hover: hover) and (pointer: fine) {
  .ez-toc-counter nav ul li a:hover{
    opacity: 1 !important;
  }
}
@media  only screen and (max-width: 767px){
  #ez-toc-container{
    padding: 15px !important;
    margin-bottom: 4.0rem !important;
  }
}


/*  archive / single heart
--------------------------------------------- */
.heart-button {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  user-select: none;
  transition: 0.2s;
  color: var(--main-color);
  font-size: var(--fs-14);
}
.heart-icon {
  width: 35px;
  height: 35px;
  display: inline-flex;
}
.heart-after {
  display: none;
}
/* 押した後（.hearted）でアイコンを切り替え */
.heart-button.hearted .heart-before {
  display: none;
}
.heart-button.hearted .heart-after {
  display: inline-flex;
}
@media  only screen and (max-width: 767px){
  .heart-icon {
    width: 30px;
    height: 30px;
  }
}
.article-fav .heart-icon {
  width: 26px;
  height: 26px;
}
@media  only screen and (max-width: 1199px){
  .article-fav .heart-icon {
    width: 22px;
    height: 22px;
  }
}
@media  only screen and (max-width: 767px){
  .article-fav .heart-button{
    gap: 0.4rem;
  }
  .article-fav .heart-count{
    font-size: var(--fs-11);
  }
}