/*
Theme Name:Astra-child
Template:astra
Version:4.11.2
*/

body {
	font-family: 'Zen Old Mincho', serif !important;
	color:#4c4c4c;
	background:#f1ebd5;
	letter-spacing:0.03rem;
	line-height:2;
}
h1,h2,h3,h4,h5{
	font-family: 'Zen Old Mincho', serif !important;
}
.ast-page-builder-template{
	background-image:block;
}
.mt-4{
	margin-top:4rem;
}
.mb-4{
	margin-bottom:4rem;
}
.mb-1{
	margin-bottom:1rem;
}
img{
	object-fit:cover;
}

.site-content .ast-container{
	display:block;
	padding:0;
	margin-top:1.5rem;
	position:relative;
}

/* PCのみ表示 スマホのみ表示 */
.SPonly{
	display:none;
}
.PConly{
	display:block;
}
@media (max-width: 599px) {
	.SPonly{
		display:block;
	}
	.PConly{
		display:none;
	}
}

.container{
	max-width:1200px;
	margin:0 auto;
}
@media (max-width: 599px) {
	.container{
		max-width:90%;
		margin:0 auto;
	}
}

/*TOPページ バナ一覧*/
.original_bnr{
	margin-top:6rem;
}
.original_bnr div{
	text-align:center;
}
.original_bnr .wp-block-group-is-layout-grid{
	gap:0;
}
@media (max-width: 599px) {
	.original_bnr{
		width:90%;
		margin:6rem auto 0 auto;
	}
}

/* フェードイン */
.fadein {
    opacity: 0;
    transform: translate(0,0);
    transition: all 1.5s;
  &.fadein-left{
      transform: translate(-30px,0);
  }
  &.fadein-right{
      transform: translate(30px,0);
  }
  &.fadein-up{
      transform: translate(0,-30px);
  }
  &.fadein-bottom{
      transform: translate(0,30px);
  }
  &.scrollin{
    opacity: 1 !important;
    transform: translate(0, 0) !important;
  }
}

/* お問い合わせフォーム */
.contact-form input[type="submit"]{
	background-color:#4c4c4c;
	color:#f1ebd5;
	display:block;
	margin:0 auto;
}

/* 投稿ページ */
.ast-single-entry-banner{
	background:none;
}
.ast-separate-container .ast-article-post, .ast-separate-container .ast-article-single:not(.ast-related-post){
	background-color:#f1ebd5;
}

/* 投稿アーカイブ */
#original-page article{
	width:100%;
}
.ast-blog-layout-4-grid .ast-article-inner{
	box-shadow:0 0;
	background:#f1ebd5;
}
.site-content section.ast-archive-description{
	padding:0 !important;
	margin:0;
}

/* ページ次へ */
.pagination{
	text-align:center;
}
.pagination span{
	border:1px solid #4c4c4c;
	padding:0.3rem 0.6rem;
}
.pagination a{
	border:1px solid #4c4c4c;
	padding:0.3rem 0.6rem;
}

/* 投稿一覧 */
#original-list{
	max-width:1200px;
	margin:0 auto;
}
#original-list .card-grid{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-column-gap: 4rem;
	grid-row-gap: 4rem;
}
#original-list .card-grid .card{
	position:relative;
}
#original-list .card-grid .card::before {
	content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 212px;
  height: 266px;
  border-top: 2px solid #4c4c4c;
  border-left: 2px solid #4c4c4c;
  clip-path: polygon(0 0, 100% 0, 0 40%);
  z-index: 2;
}
#original-list .saki .card::before{
  background: linear-gradient(135deg, #8eb9c0 0%, #8eb9c0 49.9%, transparent 50%, transparent 100%);
}
#original-list .hito .card::before{
  background: linear-gradient(135deg, #d1968b 0%, #d1968b 49.9%, transparent 50%, transparent 100%);
}
#original-list .sumu .card::before{
  background: linear-gradient(135deg, #dba246 0%, #dba246 49.9%, transparent 50%, transparent 100%);
}
.card.saki::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(135deg, #8eb9c0 0%, #8eb9c0 49.9%, transparent 50%, transparent 100%);
    z-index: -1;
  }
  .card.hito::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(135deg, #d1968b 0%, #d1968b 49.9%, transparent 50%, transparent 100%);
    z-index: -1;
  }
  .card.sumu::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(135deg, #dba246 0%, #dba246 49.9%, transparent 50%, transparent 100%);
    z-index: -1;
  }
#original-list .card-grid .card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 210px;
  height: 40%;
  background: url('/wp-content/uploads/list_deco.png') no-repeat top left;
  background-size: contain;
  pointer-events: none;
  z-index: 2;
}
#original-list .card-grid .card-image{
	border:2px solid #4c4c4c;
	height: auto;
	overflow:hidden;
}
#original-list .card-grid .card-image img{
	width:100%;
	transition: transform .6s ease;
}
#original-list .card-grid .card-image:hover img{
	transform: scale(1.1);
}
#original-list .card-grid p{
	margin-bottom:0;
	margin-top:1rem;
	line-height:1.4;
}
.card-content{
	border:2px solid #4c4c4c;
	border-top:0;
	padding:2rem;
}
.post-index{
	position:absolute;
	left:0;
	top:0;
	z-index:10;
	padding:1rem;
	color:#fff;
	font-size:3rem;
	line-height:1;
}
#original-list .container{
	max-width:1200px;
	margin:4rem auto 0;
}
/* スマホ用メニュー */
@media (max-width: 599px) {
	#original-list .card-grid{
		display:block;
		width:90%;
		margin:0 auto;
	}
	#original-list .container{
		margin:2rem auto 0;
	}
	#original-list .card{
		margin-bottom:2rem;
	}
	#original-list .card-grid .card::after{
		width:160px;
		height:30%;
	}
	#original-list .card-grid .card::before{
		width:160px;
		height:200px;
	}
	.post-index{
		font-size:2rem;
	}
}


/* よくある質問 */
.faq-wrap{
	margin-bottom:3rem;
	border-bottom:1px solid #4c4c4c;
	padding-left:4rem;
}
.faq-wrap .Q,
.faq-wrap .A{
	position:relative;
	margin-bottom:1rem;
}
.faq-wrap .A{
	margin-bottom:3rem;
}
.faq-wrap .Q::before{
	position:absolute;
	left:-3.5rem;
	top:0;
	content:'質問：';
	font-weight:700;
}
.faq-wrap .A::before{
	position:absolute;
	left:-3.5rem;
	top:0;
	content:'答え：';
	font-weight:700;
}
/* スマホ用 */
@media (max-width: 599px) {
	.faq-wrap{
		margin-bottom:2rem;
	}
	.faq-wrap .A{
		margin-bottom:2rem;
	}
}

/* 固定ページ オリジナル */
#original-page h1{
	position:absolute;
	top:-130px;
	right:20px;
	background:#f1ebd5;
	border:2px solid #4c4c4c;
	writing-mode:vertical-rl;
	padding:2rem 1rem;
	margin:0;
	font-size:3rem;
	letter-spacing:0.2em;
	opacity: 0;
  transform: translateY(30px);
  transition: all 1s ease;
}
#original-page h1.show{
	opacity: 1;
  transform: translateY(0);
}
#original-page{
	width:70%;
	margin:0 auto;
}
#original-page h2{
	opacity: 0;
  transform: translateY(30px);
  transition: all 1s ease;
}
#original-page h2.show{
	opacity: 1;
  transform: translateY(0);
}
#original-page p{
	opacity: 0;
  transform: translateY(30px);
  transition: all 1s ease;
}
#original-page p.show{
	opacity: 1;
  transform: translateY(0);
}
.ast-plain-container.ast-no-sidebar #primary{
	margin:0;
}
h2.first{
		margin-bottom:1rem;
}
/* スマホ用 */
@media (max-width: 599px) {
	#original-page h1{
		top:-70px;
		font-size:2rem;
		z-index:10;
	}
	#original-page{
		width:90%;
	}
	#original-page h2{
		font-size:1.5rem;
	}
	h2.first{
		margin-bottom:1rem;
		padding-top:2rem;
	}
}

/* 固定ページ テーブルデザイン */
.original-table,
.original-table th,
.original-table td{
	border:0;
}
.original-table th,
.original-table td{
	border-bottom:1px solid #4c4c4c;
	padding:2rem;
}
.original-table th{
	width:20%;
}
.original-table ul{
	margin:0;
}
/* スマホ用 */
@media (max-width: 599px) {
	.original-table th,
	.original-table td{
		padding: 2rem 1rem;
	}
}

/* ボタンデザイン */
.original-button{
	text-align:center;
}
.original-button a {
  display: inline-block;
  padding: 1rem 2rem;
  border: 2px solid #4c4c4c;
  color: #4c4c4c;
	font-weight:700;
	background:#f1ebd5;
	overflow: hidden;
	position: relative;
	text-decoration:none !important;
}
.original-button a span {
  position: relative;
  z-index: 2;
}
/* 波ホバー */
.original-button a::before {
  content: "";
  position: absolute;
  bottom: -110%;
  left: 0;
  width: 160%;
  height: 210%;
  z-index: 1;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath d='M0,100 V50 Q5,47 10,50 T20,50 T30,50 T40,50 T50,50 T60,50 T70,50 T80,50 T90,50 T100,50 V100 Z' fill='%238eb9c0'/%3E%3C/svg%3E") no-repeat bottom;
  background-size: cover;
  transition: bottom 0.5s ease-in-out;
}
.original-button a:hover::before {
  bottom: 0;
}


/* カスタム投稿テンプレート */
.custom-post{
	max-width:70%;
	margin:0 auto 5rem;
}
.custom-post h2{
	margin:2rem 0;
	font-size:2rem;
}
.custom-post-back{
	width:100%;
	text-align:center;
	margin-top:5rem;
}
.custom-post-back a{
	text-decoration:underline;
}
/* タイトル */
.custom-post-title h1{
	position:absolute;
	top:-13%;
	right:20px;
	background:#f1ebd5;
	border:2px solid #4c4c4c;
	writing-mode:vertical-rl;
	padding:2rem 1rem;
	margin:0;
	font-size:3rem;
	letter-spacing:0.2em;
}
/* カスタム投稿アーカイブ */
.ast-separate-container{
	background-color:#f1ebd5;
}
.ast-separate-container .ast-archive-description{
	background-color:#f1ebd5;
}
.ast-separate-container .entry-header{
	display:none;
}
.ast-separate-container #primary{
	margin:0;
}
/* スマホ用 */
@media (max-width: 599px) {
	.custom-post-title h1{
		top:-70px;
		font-size:2rem;
		z-index:10;
	}
	.custom-post{
		max-width:85%;
	}
	.custom-post h2{
		font-size:1.5rem;
	}
}
/*メニュー*/
.main-navigation ul{
	display:flex;
	justify-content:space-evenly;
	width:100%;
}
.ast-main-header-bar-alignment,
.site-header-section .ast-builder-menu ,
.ast-builder-menu .main-navigation{
	width:100%;
}
.main-header-bar{
	background:none;
}
.main-header-bar .ast-container{
	padding:0;
}
/*スクロールで出てくる*/
.main-header-bar-wrap.fixed {
	display:block;
  position: fixed;
  top: 0;
  width: 100%;
  background: white;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
  z-index: 1000;
  padding:1rem 0;
	background:#f1ebd5;
	margin-top:0;
}
.ast-mobile-header-wrap.fixed {
	display:block;
  position: fixed;
  top: 0;
  width: 100%;
	height:60px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
  z-index: 1000;
  padding:0;
	background:#f1ebd5;
	margin-top:0;
}
.ast-mobile-header-wrap.fixed .ast-builder-grid-row>.site-header-section{
	height:60px;
}
.ast-mobile-header-wrap.fixed .ast-button-wrap .menu-toggle{
	margin-top:0;
}
.ast-mobile-header-wrap.fixed .custom-logo-link img,
.ast-mobile-header-wrap.fixed .ast-header-break-point .site-branding img,
.ast-mobile-header-wrap.fixed .ast-header-break-point .custom-logo-link img{
	max-width:60px;
}
.ast-header-break-point .main-navigation .stack-on-mobile li{
	height:110px;
}

/* オリジナルデザイン */
.main-header-bar-wrap{
	margin-top:2rem;
}
.ast-builder-menu-1 .menu-item > .menu-link{
	border:2px solid #4c4c4c;
	font-weight:700;
	z-index:10;
}
.ast-primary-header-bar .site-primary-header-wrap{
	max-width:100% !important;
}
.current-menu-item > a {
  background: #8eb9c0 !important;
	display:block;
}
.main-header-menu li{
	overflow:hidden;
	background:#f1ebd5;
}
.main-header-menu {
	position:relative;
}
.main-header-menu::before{
  content: "";
  position: absolute;
  top: 50%;
  width: 100%;
  height: 2px;
  background: #4c4c4c;
}
/* 波ホバー */
.main-header-menu li::before {
  content: "";
  position: absolute;
  bottom: -110%;
  left: 0;
  width: 160%;
  height: 210%;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath d='M0,100 V50 Q5,47 10,50 T20,50 T30,50 T40,50 T50,50 T60,50 T70,50 T80,50 T90,50 T100,50 V100 Z' fill='%238eb9c0'/%3E%3C/svg%3E") no-repeat bottom;
  background-size: cover;
  transition: bottom 0.5s ease-in-out;
}
.main-header-menu li:hover::before {
  bottom: 0;
}

/* トップ メニュー */
.menu-top .menu{
	position:relative;opacity: 0;
  transform: translateY(30px);
  transition: all 1s ease;
}
.menu-top .menu.show {
  opacity: 1;
  transform: translateY(0);
}
.menu-top .menu::before{
  content: "";
  position: absolute;
  top: 43%;
  width: 100%;
  height: 2px;
  background: #4c4c4c;
}
.menu-top .menu ul {
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}
.menu-top .menu li {
	z-index:10;
}
.menu-top .menu li:first-child::before,
.menu-top .menu li:last-child::after {
  content: none;
}
.menu-top .menu a {
  display: inline-block;
  padding: 0 1em;
  border: 2px solid #4c4c4c;
  color: #4c4c4c;
	font-weight:700;
	background:#f1ebd5;
	overflow: hidden;
	position: relative;
}
.menu-top .menu li a span {
  position: relative;
  z-index: 2;
}
/* 波ホバー */
.menu-top .menu li a::before {
  content: "";
  position: absolute;
  bottom: -110%;
  left: 0;
  width: 160%;
  height: 210%;
  z-index: 1;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath d='M0,100 V50 Q5,47 10,50 T20,50 T30,50 T40,50 T50,50 T60,50 T70,50 T80,50 T90,50 T100,50 V100 Z' fill='%238eb9c0'/%3E%3C/svg%3E") no-repeat bottom;
  background-size: cover;
  transition: bottom 0.5s ease-in-out;
}
.menu-top .menu li a:hover::before {
  bottom: 0;
}
/* スマホ用 */
@media (max-width: 599px) {
	.menu-top{
		display:none;
	}
}
/* スマホ用メニュー */
@media (max-width: 599px) {
	.ast-mobile-header-content{
		top:0;
		z-index:-1;
		padding:8rem 0;
		background:#f1ebd5;
	}
	.ast-header-break-point .main-navigation .stack-on-mobile li{
		width:auto;
		writing-mode: vertical-rl;
		letter-spacing:0.6em;
		line-height:1;
		text-align:center;
		border:solid 2px #4c4c4c;
		font-weight:700;
	}
	.menu-link{
		z-index:5;
	}
}

/*TOPページ*/
#content-top{
	margin-top:40px;
	width:100%;
}
/* スマホ用 */
@media (max-width: 599px) {
	#content-top{
		margin-top:60px;
		overflow:hidden;
	}
}
/*TOPページ スライダー*/
.mv-top{
	position:relative;
	max-width:1200px;
	margin:0 auto;
}
.mv-top::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 320px;
  height: 50%;
  background: url('/wp-content/uploads/list_deco.png') no-repeat;
  background-size: contain;
  pointer-events: none;
  z-index: 2;
}
.mv-top .slick-slide{
	overflow: hidden;
	clip-path: polygon(320px 0, 100% 0, 100% 100%, 0 100%, 0 160px);
	overflow: hidden;
	height:600px;
	border:3px solid #4c4c4c;
}
.mv-title{
	position:absolute;
	top:0;
	right:0;
	background:#f1ebd5;
	border:2px solid #4c4c4c;
	writing-mode:vertical-rl;
	padding:2rem 1rem;
	margin:3rem 2rem;
	opacity: 0;
  transform: translateY(50px);
  transition: all 1.2s ease;
}
.mv-title.show {
  opacity: 1;
  transform: translateY(0);
}
.mv-title h1{
	font-size:2.5rem;
}
.mv-title p{
	padding:3rem 0 0 0;
	margin-bottom:0;
	font-size:0.9rem;
	line-height:1.4;
	opacity: 0;
  transform: translateY(30px);
  transition: all 1s ease;
}
.mv-title.show p {
  opacity: 1;
  transform: translateY(0);
}
.site-branding{
	opacity: 0;
  transform: translateY(50px);
  transition: all 1.2s ease;
}
.site-branding.show{
  opacity: 1;
  transform: translateY(0);
}
/* 文字単位アニメーション */
.mv-title span {
  opacity: 0;
  display: inline-block;
  transform: translateY(20px);
  animation: fadeUp 0.6s ease forwards;
}

@keyframes fadeUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* スマホ用 */
@media (max-width: 599px) {
	.mv-top{
		max-width:90%;
	}
	.mv-top .slick-slide{
		height:70vh;
	}
	.mv-top .slick-track{
		border-bottom:3px solid #4c4c4c;
	}
	.slick-slide img{
		height:100%;
		object-fit:cover;
	}
	.mv-top .slick-slide{
		border-bottom:none;
	}
	.mv-top::before{
		width:160px;
	}
	.mv-top .slick-slide{
		clip-path:polygon(160px 0, 100% 0, 100% 100%, 0 100%, 0 80px);
	}
	.mv-title{
		margin:2rem 1rem 5rem 0;
		
	}
	.mv-title h1{
		font-size:1.5rem;
	}
	.mv-title p{
		font-size:0.8rem;
		padding:1rem 0 0 0;
	}
}

/* スライダーデザイン */
.dots-wrap{
	position:absolute;
	bottom:1rem;
	left:1rem;
	width:18%;
	background:#f1ebd5;
	border:2px solid #4c4c4c;
	margin:0;
	padding:0.5rem;
	height:60px;
}
.dots-wrap {
    display: flex;
    justify-content: center;
}
.dots-wrap li {
    width: 30px;
    height: 10px;
    margin: 0 5px;
    background: #f1ebd5;
    cursor: pointer;
	border:1px solid #4c4c4c;
	list-style:none;
}
.dots-wrap li:hover,
.dots-wrap li.slick-active {
    background: #d1968b;
	border:1px solid #d1968b;
}
.dots-wrap button {
    display: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: none;
    padding: 0;
    border: none;
    background-color: transparent;
}
.dots-wrap .caption-label {
  display: none;
	position:absolute;
	left:0;
	bottom:0.5rem;
}
.dots-wrap .slick-active .caption-label {
  display: block;
	width:200px;
	position:absolute;
	left:1rem;
	bottom:0.5rem;
}
.caption-label{
	font-size:0.8rem;
}
/* スマホ用 */
@media (max-width: 599px) {
	.dots-wrap{
		left:0;
		bottom:-4.5rem;
		width:60%;
	}
}

/* トップページ テキストエリア */
.text-top{
	position:relative;
	margin:3rem 0 0;
}
.text-top .container{
	max-width:1200px;
	margin:0 auto;
}
.center{
	text-align:center;
}
.text-top h2{
	font-size:1.5rem;
	margin-bottom:2rem;
}
.text-top p{
	font-weight:600;
}
.text-top::before{
	content:'';
	position: absolute;
	top: 10%;
	left:-5%;
	width: 45%;
	height: 45%;
	background: url('/wp-content/uploads/top_deco_1.png') no-repeat;
	background-size: contain !important;
	z-index:-1;
}
.text-top::after{
	content:'';
	position: absolute;
	bottom: 0;
	right:-10%;
	width: 45%;
	height: 45%;
	background: url('/wp-content/uploads/top_deco_2.png') no-repeat;
	background-size: contain !important;
	z-index:-1;
}
/* スマホ用メニュー */
@media (max-width: 599px) {
	.text-top{
		margin:7rem auto 0;
		width:90%;
	}
	.text-top h2{
		font-size:1.2rem;
		line-height:1.8em;
	}
	.text-top p{
		width:90%;
		margin:0 auto 1rem auto;
	}
	.text-top::before{
		top:20%;
		left:-60%;
		width:600px;
	}
	.text-top::after{
		right:-80%;
		width:600px;
		height:30%;
	}
}

/*TOPページ お知らせ*/
.news-top{
	margin-top:3rem;
}
.news-top .latest-posts-wrap{
	width:50%;
	margin:0 auto;
	font-size:0.9rem;
	border:2px solid #4c4c4c;
}
.latest-posts-wrap{
	padding:2rem 3rem;
}
.latest-posts-wrap h2{
	text-align:center;
	font-size:2rem;
	margin-bottom:1rem;
}
.news-top .latest-posts{
	margin:0;
}
.news-top .latest-posts li{
	display:grid;
	margin-bottom:1rem;
}
.news-top .latest-posts li a{
	text-decoration:underline;
}
.news-top .latest-posts{
	font-size:0.9rem;
}
.news-top .latest-posts .post-date{
	font-size:0.75rem;
}
.news-top .more{
	text-align:right;
}
.news-top .more a{
	background:#4c4c4c;
	color:#f1ebd5;
	font-size:0.8rem;
	padding:5px 15px;
	border-radius:100px;
}
/* スマホ用メニュー */
@media (max-width: 599px) {
	.news-top .latest-posts-wrap{
		width:80%;
		padding:1rem 1.5rem;
	}
}

/* TOPページ 掲示板 */
.keijiban-top{
	margin-top:3rem;
}
.keijiban-top h2{
	width:30%;
	margin:0 auto 2rem auto;
}
/* スマホ用メニュー */
@media (max-width: 599px) {
	.keijiban-top h2{
		width:70%;
	}
}

/* TOPページ バナー一覧 */
#bnr-top .original-bnr{
	place-items:center;
	grid-template-columns: repeat(4, 1fr);
	gap:5rem;
}
#bnr-top .original-bnr p{
	font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;
}

/* スマホ用メニュー */
@media (max-width: 599px) {
	#bnr-top .original-bnr{
		grid-template-columns: repeat(2, 1fr);
	}
}

/* フッター */
.site-above-footer-wrap[data-section="section-above-footer-builder"] .ast-builder-grid-row{
	padding:0;
}
.site-footer-section-2 .wp-block-image img{
	max-width:160px;
}
.footer-bnr{
	grid-template-columns:repeat(2, 1fr) !important;
	margin:3rem auto;
	gap:0;
}
.footer-bnr img{
	max-width:100px;
}
/* メニュー */
.footer-nav-wrap .astra-footer-horizontal-menu li:first-child a,
.footer-nav-wrap .astra-footer-horizontal-menu li:last-child a{
	padding:0 1em;
}
#astra-footer-menu{
	display:flex;
	justify-content:space-evenly;
	position:relative;
	align-items:center;
}
#astra-footer-menu::before{
  content: "";
  position: absolute;
  top: 50%;
  width: 100%;
  height: 2px;
  background: #4c4c4c;
	z-index:-1;
}
#astra-footer-menu li a{
	border:2px solid #4c4c4c;
	font-weight:700;
	z-index:10;
	padding:0 1em;
}
#astra-footer-menu li{
	overflow:hidden;
	background:#f1ebd5;
	position:relative;
}
/* 波ホバー */
#astra-footer-menu li::before {
  content: "";
  position: absolute;
  bottom: -110%;
  left: 0;
  width: 160%;
  height: 210%;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cpath d='M0,100 V50 Q5,47 10,50 T20,50 T30,50 T40,50 T50,50 T60,50 T70,50 T80,50 T90,50 T100,50 V100 Z' fill='%238eb9c0'/%3E%3C/svg%3E") no-repeat bottom;
  background-size: cover;
  transition: bottom 0.5s ease-in-out;
}
#astra-footer-menu li:hover::before {
  bottom: 0;
}
/* メニューリンク */
#nav_menu-3 ul li{
	position:relative;
	font-weight:700;
}
#nav_menu-3 ul li::before{
    position: absolute;
    content:'';
    top: 50%;
    width: 7px;
    height: 2px;
    left: -1rem;
	background:#4c4c4c;
}
#block-13{
	font-size:0.75rem;
}
/* スマホ用メニュー */
@media (max-width: 599px) {
	#astra-footer-menu li{
		writing-mode: vertical-rl;
		line-height:0;
		text-align:center;
		height:100px;
		letter-spacing:0.3em;
	}
	#astra-footer-menu > .menu-item > .menu-link{
		display:block;
	}
}