@charset "utf-8";
body{
	background: var(--c-yellow-070);
}
:root{
	/* フォントベース */
	--ff-base: var(--ff-zenkaku);
}
/* ■■■■■■■■■■■■■■■■■■■■■■header■■■■■■■■■■■■■■■■■■■■■■ */

.fat-nav{
  top: 0;
  left: 0;
  z-index: 996;
  position: fixed;
  display: none;  
  width: 100%;
  height: 100%;
  background: var(--bg-c-yellow);
  transform: scale(1);
  transition-property: transform;
  transition-duration: 0.4s;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
}
.fat-nav__wrapper {
  height: 100%;
  max-width:1100px;
  box-sizing: border-box;
}
.fat-nav.active {
  transform: scale(1);
}
@media screen and (min-width: 768px){
	.hamburger{
		display: none;
	}
}
@media screen and (max-width: 767px){
		/* ハンバーガー */
	.hamburger{
		display: flex;
		justify-content: center;
		align-items: center;
		position: relative;
		position: fixed;
		right: 3.5%;
		width: 50px;
		height: 50px;
		padding: 10px 10px;
		z-index: 998;
		box-sizing: border-box;
		touch-action: manipulation;
		--hamburger-line-color: var(--theme-c-primary);
		--hamburger-line-ps: 8px;
		background-color: var(--c-white);
    box-shadow: var(--bxsd-default);
    border-radius: 50%;
	}
	.hamburger--menu{
		bottom: 30px;
	}
	.hamburger__icon {
		position: relative;
	}
	.hamburger__icon, .hamburger__icon:before, .hamburger__icon:after {
		display: block;
		width: 20px;
		height: 1px;
		background-color: var(--hamburger-line-color);
		transition-property: background-color, transform;
		transition-duration: 0.4s;
	}
	.hamburger .hamburger__icon:before{
		width: 100% !important;
	}
	.hamburger .hamburger__icon:after {
		width: 100% !important;
	}
	.hamburger__icon:before, .hamburger__icon:after {
		position: absolute;
		content: "";
	}
	.hamburger__icon:before {
		top: calc(0px - var(--hamburger-line-ps));
	}
	.hamburger__icon:after {
		top: var(--hamburger-line-ps);
	}
	.hamburger.active .hamburger__icon {
		background-color: transparent;
	}
	.hamburger.active .hamburger__icon:before, .hamburger.active .hamburger__icon:after {
		background-color: var(--hamburger-line-color);
	}
	.hamburger.active .hamburger__icon:before {
		transform: translateY(var(--hamburger-line-ps)) rotate(45deg);
		background-color: var(--hamburger-line-color);
	}
	.hamburger.active .hamburger__icon:after {
		transform: translateY(calc(0px - var(--hamburger-line-ps))) rotate(-45deg);
		background-color: var(--hamburger-line-color);
	}
}
.fn-logo{
	width: 93%;
	margin-inline: auto;
	padding-block: 18px;
}
.fn-logo img{
	width: 100px;
}
.fat-nav--menu .hd-nav{
	display: grid;
	margin-top: 30px;
}
.fat-nav--menu .hd-nav li{
	position: relative;
}
.fat-nav--menu .hd-nav li:not(:last-child){
	padding-bottom: 12px;
	margin-bottom: 12px;
}
.fat-nav--menu .hd-nav li:not(:last-child)::after{
	content: "";
	display: inline-block;
	background: var(--repeat-line-sm) repeat-x bottom left / 8px;
	width: 100%;
	height: 1px;
	position: absolute;
	bottom: 0;
	left: 0;
}
.fat-nav--menu .hd-nav__item{
	display: flex;
	flex-direction: column;
	gap: 3px;
	padding-left: 10px;
	position: relative;
}
.fat-nav--menu .hd-nav__item::after{
	content: "";
	display: inline-block;
	--this-mask: var(--data-icon-scrollhint) no-repeat center center / 100%;
	mask: var(--this-mask);
	-webkit-mask: var(--this-mask);
	background-color: var(--txt-c-base);
	aspect-ratio: 1;
	width: 10px;
	transform: translateY(-50%) rotate(-90deg);
	position: absolute;
	top: 50%;
	right: 15px;
}
.fat-nav--menu .hd-nav__item small{
	font-size: 12px;
	letter-spacing: 0.05em;
}
.fat-nav--menu .hd-nav__item span{
	font-size: 14px;
}
.fat-nav--menu .cp-ft-sns{
	padding-bottom: 50px;
}
.fat-nav--menu .cp-ft-sns li a{
	width: 30px;
}

/* ■■■■■■■■■■■■■■■■■■■■■■side■■■■■■■■■■■■■■■■■■■■■■ */

/* ■■■■■■■■■■■■■■■■■■■■■■footer■■■■■■■■■■■■■■■■■■■■■■ */
/* footerarea */
#footerarea{
	margin-top: var(--sec-spc);
	padding-top: var(--sec-spc);
	background-color: var(--c-white);
}
.cp-ft-copy{
	text-align: center;
	font-family: var(--ff-serif);
}
@media screen and (min-width: 768px){
	#footerarea{
		display: grid;
		grid-template-columns: 1fr auto;
		row-gap: var(--spc-80);
	}
	.cp-ft-box{
		display: flex;
		justify-content: space-between;
	}
	.cp-ft-logoContainer{
		width: 227px;
		display: flex;
		flex-direction: column;
	}
	.cp-ft-sns{
		flex: 1;
		align-items: flex-end;
		gap: var(--spc-20);
	}
	.cp-ft-sns li a{
		width: clamp( 20px, 2.2vw, 28px);
	}
	.cp-ft-nav{
		display: flex;
		align-items: flex-start;
		gap: var(--spc-80);
	}
	.cp-ft-menu{
		display: grid;
		row-gap: 10px;
	}
	.cp-ft-menu li a{
		font-size: var(--fz-14);
		font-family: var(--ff-serif);
		line-height: 1;
	}
	.cp-ft-topics{
		display: grid;
		align-items: center;
	}
	.cp-ft-topics__heading{
		font-size: var(--fz-14);
		font-family: var(--ff-serif);
	}
	.cp-ft-topics__list{
		display: grid;
		margin: 5px 0 0 10px;
	}
	.cp-ft-topics__list li a{
		font-size: var(--fz-12);
		font-family: var(--ff-serif);
		line-height: 1;
	}
	.cp-ft-contact{
		width: clamp( 150px, 20vw, 250px);
		display: flex;
		align-items: center;
	}
	.cp-ft-contact a{
		width: 100%;
	}
	.cp-ft-copy{
		grid-column: span 2;
		font-size: var(--fz-12);
		padding-bottom: var(--spc-20);
	}
}
@media screen and (max-width: 767px){
	#footerarea{
		display: block;
	}
	.cp-ft-logo{
		width: 200px;
		margin: 0 auto;
	}
	.cp-ft-sns{
		gap: 20px;
		margin-block: 30px;
	}
	.cp-ft-sns li a{
		width: 24px;
	}
	.cp-ft-contact{
		margin-inline: auto;
	}
	.cp-ft-copy{
		font-size: 10px;
		letter-spacing: 0;
		padding-block: 30px 20px;
	}
}


/* ■■■■■■■■■■■■■■■■■■■■■■全ページ共通部分■■■■■■■■■■■■■■■■■■■■■■ */


/* -------------------t-topics-------------------- */
.tab-wrap--topics .tab-btn{
  color: var(--txt-c-gray);
  font-family: var(--ff-serif);
  line-height: 1;
}
.tab-wrap--topics .tab-btn.show{
  color: var(--txt-c-base);
}
.tab-wrap--topics .tab-btn:not(:last-child){
  border-right: 1px solid var(--txt-c-gray);
}
.cp-g-topics__list{
  --grid-cols-pc: 4;
  --grid-cols-sp: 2;
}
.cp-g-topics__list__thumb{
	position: relative;
}
.cp-g-topics__list__thumb img{
  aspect-ratio: 1;
  object-fit: cover;
}
.cp-g-topics__list__thumb__pinned{
	aspect-ratio: 1;
	width: clamp(23px, 2vw, 30px);
	background-color: var(--c-white);
	border-radius: 50%;
	position: absolute;
	transform: rotate(45deg);
	top: 5px;
	right: 5px;
}
.cp-g-topics__list__thumb__pinned span{
	content: "";
	display: inline-block;
	--this-mask: var(--data-icon-pinned) no-repeat center center / 100%;
	mask: var(--this-mask);
	-webkit-mask: var(--this-mask);
	background-color: var(--theme-c-secondary);
	aspect-ratio: 1;
	width: clamp(15px, 1.7vw, 20px);
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
@media screen and (min-width: 768px){
	.cp-g-topics__list+.g-btnContainer{
		margin-top: var(--spc-70);
	}
  .tab-wrap--topics .tab-nav{
    justify-content: center;
    margin-bottom: var(--spc-70);
  }
  .tab-wrap--topics .tab-btn{
    flex: unset;
    font-size: var(--fz-18);
    padding-inline: var(--spc-40);
  }
  .cp-g-topics__list{
    gap: var(--spc-70) var(--spc-20);
  }
  .cp-g-topics__list__ttl{
    margin-block: 10px -2px;
    font-size: var(--fz-14);
  }
  .cp-g-topics__list__date{
    font-size: var(--fz-12);
  }
}
@media screen and (max-width: 767px){
  .tab-wrap--topics .tab-nav{
    overflow-x: scroll;
    overflow-y: hidden;
    padding-left: var(--sp-scroll-padding-left);
    -ms-overflow-style: none;
    scrollbar-width: none;
    white-space: nowrap;
    margin-bottom: 30px;
  }
  .tab-wrap--topics .tab-nav::-webkit-scrollbar{
    display: none;
  }
  .tab-wrap--topics .tab-btn{
    flex: 0 0 auto;
    padding-inline: 20px;
  }
  .tab-wrap--topics .tab-btn:first-child{
    padding-left: 0;
  }
  .cp-g-topics__list{
    gap: 18px 15px;
  }
  .cp-g-topics__list__ttl{
    margin-block: 10px -2px;
    font-size: 14px;
  }
  .cp-g-topics__list__date{
    font-size: 12px;
  }
}



.pagetop a{
	background-color: var(--c-blue-700);
}