@charset "utf-8";

/* Column カバー写真 */
.kv-news .kv_img {
	background:  linear-gradient(to right, #0f3dd7 0%, #06cad1 100%);
}
.kv_inner {
    max-width: 1440px;
}
.news_bg{
	background-color: #F5F7FA;
}

/* column 一覧ページ */
.column-b .card {
  display: flex;
  flex-wrap: wrap;
  margin: 6.0rem 0 0;
}
.column-b .card .item {
	position: relative;
  width: 33.333%;
	margin-bottom: 12.0rem;
  padding: 10px;
  box-sizing: border-box;
}
.column-b .card .item .img-wrapper{
	overflow: hidden;
  border-radius: 5px;
}
.column-b .card .item img{
	width: 100%;
	border: 1px solid #ddd;
  transition-duration: 0.5s;
	display: block;
}
.column-b .card .item img:hover{
	transform: scale(1.2);
  	transition-duration: 0.5s;
}
.column-b .card .item a {
  color: #000;
}
.column-b .card .item:nth-child(n+4) {
  margin-top: 0;
}
.column-b .card .item:not(:nth-child(3n)) {
  margin-right: 0;
}
.column_text{
  position: absolute;
  top: 90%;
  left: 50%;
  width: 90%;
  transform: translate(-50%,-50%);
  color: #fff;
  background-color: rgba(0, 0, 0, .6);
  border-radius: 10px;
}
.column-b .card .ttl {
  margin: 5px 0 0;
  padding: 10px;
  flex-grow: 1;
}
.column-b .card .ttl span {
  display: inline-block;
  border-radius: 5px;
  padding: 0 8px;
  text-align: center;
  width: 120px;
  color: #000;
  border: 1px solid #33b3ee;
}
.column-b .card .ttl i {
  padding-right: 5px;
}

.column-b .card .txt {
  font-weight: bold;
  margin: 5px 0;
  padding: 10px;
  flex-grow: 1;
}

/* writer */
.column-b .card .writer{
	display: flex;
}
.column-b .card .writer_item1{
	display: flex;
	align-items: center;
	padding-left: 10px;
}
.column-b .card .writer_item2{
	display: block;
}
.column-b .card .writer_item2 .writer_title{
	font-size: 1.2rem;
  margin-bottom: 6px;
  text-align: center;
	padding: 2px 6px;
	color: #fff;
	background: rgba(0, 0, 0, .6);
	border-radius: 20px;
}
.column-b .card .writer_item2 .writer_name{
	font-size: 1.2rem;
  text-align: center;
	padding: 2px 6px;
	color: #fff;
	background: rgba(0, 0, 0, .6);
	border-radius: 20px;
}
.column-b .card .writer_item1 img{
	display: block;
	margin: 0 auto;
	border-radius: 50%;
  margin-right: 10px;
	width: 42px;
	height: 42px;
}
h4.post{
	position: relative;
	justify-content: right;
	text-align: right;
  line-height: 4.0;
  font-size: 1.5rem;
  font-weight: bold;
  letter-spacing: 0.075em;
}
h4.post a{
	color: #000;
}
h4.post a:hover{
	color: #64CCBF;
}

/* Newマーク */
.new_column {
  position: absolute;
  top: 17%;
  right: 0;
  width: 40px;
  height: 40px;
  background-color: brown;
  border-radius: 50%;
  padding: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.new_column p {
  color: #fff;
  margin: 0;
  text-align: center;
  font-style: italic;
}

/* Volマーク */
.vol_number {
  position: absolute;
  top: 22%;
  left: 4%;
  margin: 0;
  background: rgba(255, 255, 255, .6);
  border-radius: 20px;
  padding: 0 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.vol_number p {
  color: #000;
  margin: 0;
  text-align: center;
  padding-top: 3px;
}

/* End column 一覧ページ */

/* 一覧へ戻る */
.return_btn,
.return_btn_top{
	text-align: center;
}
.return_btn_top {
    margin-top: 10.0rem;
    padding-bottom: 6.0rem;
}
.return_btn a,
.return_btn_top a{
	font-size: 1.6rem;
	color: #000;
	border: 1px solid #000;
    display: inline-block;
    font-weight: bold;
    margin: 0 auto;
    padding: 1rem 4rem;
}
.return_btn a:hover,
.return_btn_top a:hover{
	color: #fff;
	border: 1px solid #000;
	background-color: #000;
}
.return_btn i{
	padding-right: 5px;
}
/* End 一覧へ戻る */

/* Pagenation */
.page_list li {
  display: none !important; /* 初期は非表示 */
}
.page_list li.on {
  display: block !important;
}
.pagination .number > a.active {
  background-color: #000;
  color: #fff;
}
.page_list {
  display: flex;
  flex-wrap: wrap; /* 折り返しを許可する場合 */
}
.pagination {
  width: 70%;
  margin: 50px auto;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content:center;
  gap: 5px;
}
.pagination .number {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 5px;
}
.pagination a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  color: #000;
  background-color: #ffffff;
  border: solid 1px #333;
  border-radius: 50%;
}
/* End Pagenation */

/* filter-buttons */
.filter-buttons {
  margin-top: 6.0rem;
  text-align: center;
}
.filter-buttons button {
  display: inline-block;
  width: 120px;
  margin: 10px;
  padding: 10px 5px;
  font-weight: bold;
  cursor: pointer;
  border: 1px solid #1597CC;
  background-color: #fff;
  border-radius: 5px;
}
.filter-buttons button:hover {
  background-color: #1597CC;
  color: #fff;
}
/* End filter-buttons */

/* column 記事ページ */
.column_article{
	margin-top: 10.0rem;
}
.column_page{
  position: relative;
  margin-top: 6.0rem;
}
.column_page_inner{
  max-width: 1200px;
  margin: 0 auto;
}
.column_page_kv{
  position: relative;
  width: 100%;
  height: auto;
}
.column_page_kv img{
  width: 100%;
}
.column_date {
  font-size: 2.0rem;
  padding: 10px;
}
.column_date i{
  padding-right: 5px;
}
.column_ttl {
  font-size: 2.6rem;
  font-weight: bold;
  padding: 10px;
}
.column_date span {
  display: inline-block;
  border-radius: 5px;
  padding: 0 8px;
  text-align: center;
  /* width: 120px; */
  color: #000;
  border: 1px solid #33b3ee;
}
.writer_bg{
	display: flex;
  justify-content: flex-end;
  padding: 10px;
}
.writer_profile{
	display: flex;
	align-items: center;
	padding-left: 10px;
}
.writer_item .writer_title{
	font-size: 1.2rem;
  margin-bottom: 6px;
}
.writer_item .writer_name{
	font-size: 1.2rem;
  font-weight: bold;
}
.writer_profile img{
	display: block;
	margin: 0 auto;
	border-radius: 50%;
  margin-right: 10px;
	width: 42px;
	height: 42px;
}
.column_page_article{
  width: 100%;
  margin-top: 3.0rem;
  margin-bottom: 10.0rem;
}
.column_page_heading {
  border-bottom: 3px solid #f2f2f2;
  line-height: 1.5;
}
.column_page_heading span {
  display: inline-block;
  position: relative;
  padding: 0 .4em .2em;
  font-weight: bold;
  color: #333333;
  font-size: 2.4rem;
}
.column_page_heading span::before {
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 100%;
  height: 3px;
  background-color: #2589d0;
  content: '';
}
.column_page_text{
  color: #333333;
  font-size: 1.8rem;
  padding: 10px;
  font-weight: bold;
  margin-top: 2.0rem;
}

/* column 記事ページ 「インタビュー」*/
.column_page_heading_interview {
  font-weight: bold;
  font-size: 2.2rem;
  padding: .5em .7em;
  border-left: 10px solid !important;
  border-image: linear-gradient(to bottom, #54d389, #fabf49) 1 !important;
  margin: 5.0rem 0 3.0rem;
  margin-left: 10px;
  line-height: 1.5;
}
.column_page_text span{
  color: #222;
}
.column_page_photo_bg{
  display: flex;
}
.column_page_photo_item{
  position: relative;
  display: inline-block;
  width: 50%;
  height: auto;
  margin: 1.0rem;
}
.column_page_photo_item img{
  display: block;
  width: 100%;
  height: auto;
}
.overlay {
  position: absolute;
  bottom: 0; /* 下に配置 */
  left: 0;
  width: 100%;
  background: rgba(0, 0, 0, 0.4); /* 半透明の黒 */
  color: #fff;
  text-align: center;
  padding: 10px;
  box-sizing: border-box;
}
p.caption{
  font-size: 1.8rem;
}
p.caption_left{
  font-size: 1.4rem;
  text-align: left;
  font-weight: bold;
}
.column_page_text2{
  color: #333333;
  font-size: 1.8rem;
  font-weight: bold;
}
.bg_mg{
  margin-top: 3.0rem;
}

/* パンくずリスト*/
.breadcrumb {
  display: flex;
  gap: 0 15px;
  list-style: none;
  padding: 10px;
  font-size: .9em;
  margin-bottom: 6.0rem;
  border-top: 1px solid #ddd;
}
.breadcrumb li {
  display: flex;
  align-items: center;
}
.breadcrumb li:first-child::before {
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-right: 4px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 20C20 20.5523 19.5523 21 19 21H5C4.44772 21 4 20.5523 4 20V11L1 11L11.3273 1.6115C11.7087 1.26475 12.2913 1.26475 12.6727 1.6115L23 11L20 11V20ZM11 13V19H13V13H11Z' fill='%23333333'%3E%3C/path%3E%3C/svg%3E");
  background-repeat: no-repeat;
  content: '';
}
.breadcrumb li:not(:last-child)::after {
  display: inline-block;
  margin-left: 15px;
  color: #333333;
  content: '/';
}
.breadcrumb a {
  color: #333333;
  text-decoration: none;
}
.breadcrumb a:hover {
  color: #64CCBF;
}
/* End column1~ 記事ページ */

/* レスポンシブ */

@media screen and (max-width: 1024px) {

	.column_text {
		top: 100%;
	}
  .column-b .card .item {
    margin-bottom: 20.0rem;
  }
  .vol_number {
		top: 75px;
    left: 20px;
	}
  .new_column {
    top: 23%;
  }

}

@media screen and (max-width:767px) {
	.kv_inner_breadcrumbs ul {
    	display: none;
	}
	.return_btn_top {
		margin-top: 6.0rem;
		padding-bottom: 6.0rem;
	}
}

@media screen and (max-width: 768px) {

  .column-b .card .item {
    width: 50%;
    margin-bottom: 12.0rem;
  }
  .filter-buttons {
    margin-top: 10.0rem;
  }
  .filter-buttons button {
    padding: 5px 1px;
    margin: 3px;
  }
  .column-b .card .ttl span {
    padding: 0;
  }
  .new_column {
    top: 19%;
    width: 32px;
    height: 32px;
  }
  .vol_number {
		top: 65px;
    left: 16px;
	}
}

@media screen and (max-width: 576px) {

  .contents {
    padding-top: 0;
  }
	.column-b .card {
		display: block;
	}
  .column-b .card .item {
		width: 100%;
		margin-bottom: 12.0rem;
	}
  .column-b .card {
    margin: 2.0rem 0 0;
  }
  .filter-buttons {
    margin-top: 3.0rem;
  }

  /* Columnページ */
  .inner-m {
    padding: 0;
  }
  .column_article {
    margin-top: 4.0rem;
  }
  .column_date {
    font-size: 1.6rem;
  }
  .column_ttl {
    font-size: 2.0rem;
  }
  .breadcrumb {
    display: none;
  }
  .column_page_heading span {
    font-size: 2.0rem;
  }
  .column_page_text {
    font-size: 1.6rem;
  }
  .column_text {
    top: 90%;
  }
  .new_column {
    width: 40px;
    height: 40px;
  }
  .vol_number {
		top: 70px;
    left: 18px;
  }

  /* column「インタビュー」 */
  .column_page_heading_interview {
    font-size: 2.0rem;
  }
  .column_page_photo_bg{
    display: block;
  }
  .column_page_photo_item{
    width: 100%;
    margin: 0;
  }
  .column_page_text2{
    font-size: 1.6rem;
    padding: 10px;
  }
  p.caption {
    font-size: 1.6rem;
  }

}
/* End レスポンシブ */