@charset "utf-8";
/* CSS Document */

/*
* BASE
******************************************************/
* {
	word-wrap:break-word;
	background-repeat:no-repeat;
	overflow-wrap:break-word
}
html {
	scroll-behavior:smooth;
	font-family:'Lato', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "MS Pゴシック", "MS PGothic", sans-serif;
	font-weight: 400;
	font-size: 62.5%;
}
body {
	font-size: 1.6rem;
	line-height: 1.75;
	letter-spacing: 0.05em;
	overflow-wrap: break-word;
	word-break: normal;
}

/* LINK */
body, body a {
	color: var(--color-primary);
}
body a,
body a:hover,
body a:visited {
	text-decoration:none;
}
a {
	transition:.2s ease-in-out;
}

/* svg set */
.svg-symbol {
	display:none;
}

/* IE */
main {
	display:block;
}

/*
* FOOTER FIXED
******************************************************/
.footer-fix {
	display:flex;
	flex-direction:column;
   	min-height: 100vh;
}

/*
* HEADER
******************************************************/
.global-header {
    width: 100%;
	height: 0;
    overflow-x: hidden;
	top: 0;
	left: 0;
	z-index: 9;
	text-align: center;
	color: var(--color-complementary);
}
.global-page-header,
.global-header.is-fixed {
    position: fixed;
	width: 100%;
    height: 54px;
	background-color: var(--color-primary);
    top: 0;
    left: 0;
    z-index: 999;
    -webkit-transition: all .6s ease 0s,background .6s ease .4s;
    transition: all .6s ease 0s,background .6s ease .4s;
    -webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
    overflow: hidden;
}
.global-header-inner {
	padding: 0 54px;
    display: flex;
    justify-content: space-between;
	position: relative;
}
.global-header_logo{
	z-index:9;
    position: fixed;
    top: 26px;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}
.global-header_logo h1 {
    font-size: 2rem;
    letter-spacing: .35em;
}
.global-header_logo h1 a {
	color: var(--color-complementary);
}
.global-header_button {
	display: block;
	position: fixed;
	left: 24px;
    top: 5px;
	cursor: pointer;
	transition: .5s;
	z-index:39;
}
.global-header-sns-nav {
	display: flex;
	position: fixed;
	right: 46px;
	top: 14px;
	z-index: 9;
}
.global-header-sns-nav ul {
	display: flex;
}
.global-header-sns-nav li {
	display: flex;
    justify-content: flex-end;
    align-items: baseline;
}
.wp-block-social-links,
.wp-block-social-links.has-normal-icon-size {
    font-size: 18px!important;
}
.wp-block-social-link a {
    display: inline-block!important;
	margin: 0 8px 0 0;
}
.wp-block-social-links:not(.is-style-logos-only) .wp-social-link {
    background-color: transparent!important;
    color: #fff!important
}
@media screen and (max-width:744px) {
	.global-header_button {
		left: 16px;
	}
	.global-header_logo h1 {
		display:none;
	}
}
/*
* HEADER MENU BUTTON
******************************************************/
.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
	cursor: pointer
}
.menu-trigger {
	position: relative;
	width: 24px;
	height: 24px;
	color: var(--color-complementary);
	border-radius: 4px;
	z-index: 7
}
.menu-trigger span {
	position: absolute;
	background: var(--color-complementary);
	width: 24px;
	height: 2px;
	left: 0;
	right: 0;
	margin: auto
}
.menu-trigger span:nth-of-type(1) {
    top: 13px
}
.menu-trigger span:nth-of-type(2) {
    top: 17px;
    bottom: 0
}
.menu-trigger span:nth-of-type(3) {
    bottom: -5px
}
.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(7px) rotate(-45deg);
	transform: translateY(7px) rotate(-45deg)
}  
.menu-trigger.active span:nth-of-type(2) {
	opacity: 0
}  
.menu-trigger.active span:nth-of-type(3) {
	-webkit-transform: translateY(-7px) rotate(45deg);
	transform: translateY(-7px) rotate(45deg)
}
#menu-text {
	font-size: 1.2rem;
	letter-spacing: .2em;
	text-align: center;
	color: var(--color-complementary);
    position: fixed;
    left: 60px;
    top: 16px;
}
@media screen and (max-width:744px) {
	#menu-text {
		left: 50px;
	}
}
/*
* HEADER NAV
******************************************************/
.global-header_nav {
	display:none;
	position: fixed;
	top: 0;
	left: 0;
	width: auto;
	height: 100%;
	z-index: 9;
	background-color: var(--bg--color-menu);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	overflow: auto;
	-webkit-overflow-scrolling: touch;
}
.global-header_nav-inner {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    width: 100%;
    height: 100%;
    margin: 60px 0 60px 0;
}
.global-header_nav ul {
	width: 100%;
	max-width: 1180px;
	overflow: hidden;
}
.global-header_nav li {
	font-size: 1.6rem;
	letter-spacing: .3em;
	font-weight: 400;
	text-align:left;
	color: var(--color-secondary);
	padding: 0 40px;
	margin: 30px 0;
	display: block;
	margin-left: -100%;
	transition: 0.4s;
}
.global-header_nav li a {
	font-size: 1.5rem;
	display: inline-block;
	color: var(--color-secondary);
	transition: .3s;
	text-decoration: solid;
	padding: 0.25rem 0;
}
.global-header_nav li.active {
	margin-left: 0;
}
/*
* HEADER SEARCH
******************************************************/
.search-keyword {
	text-align: center;
	margin: 0 0 80px 0;
	position: relative;
}
.search-keyword_input-area {
	width: 266px;
	height: 20px;
	line-height: 20px;
	display: inline-table;
	vertical-align: middle;
	font-size: 1.3rem;
	color:  var(--color-secondary);
	padding: 8px 16px;
	background: var(--bg--color-tertiary);
	border-bottom: 1px solid var(--bg--color-quaternary);
    border-left: 1px solid var(--bg--color-quaternary);
    border-right: 1px solid var(--bg--color-quaternary);
}
.search-keyword_input-area::placeholder {
	color: var(--color-secondary);
}
.search-keyword_submit {
    position: absolute;
    right: 10px;
    top: 7px;
}
.search-keyword_submit img {
	width: 90%;
}
@media screen and (max-width:980px) {
	.search-keyword {
		text-align: left;
		display: flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 100%;
	}
}
.search-toggle-list {
  display: none;
}
#search-toggle {
  background-image: url(../img/common/search-open.png);
}
#search-toggle.is_close {
  background-image: url(../img/common/search-close.png);
}
.global-header_search-button {
  width: 20px;
  height: 20px;
  margin: 0 auto;
  z-index:99;
  position: fixed;
  right: 20px;
  top: 18px;
}
.global-header_search {
	position: fixed;
    z-index: 12;
    width: 100%;
    height: 100vh;
    left: 0;
    top: 0;
}
.global-header_search.is-fixed {
	background-color: var(--bg--color-menu);
	position: fixed;
	z-index: 999998;
	width: 100%;
	height: 100vh;
	margin-top: 90px;
	padding: 0;
}
.global-header_search-content {
	background-color: var(--bg--color-menu);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	position: fixed;
	z-index: 9995;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}
.global-header_search-content_inner {
	max-width: 740px;
	margin: 114px 0 auto;
}
.global-header_search-title {
  font-size: 1.6rem;
  letter-spacing: .3em;
  font-weight: 400;
  line-height: 1;
  text-align: center;
  color: var(--color-complementary);
  margin-bottom: 20px;
}
.global-header_search-tags ul {
	display:inline-block;
}
.global-header_search-tags li {
  font-size: 1.1rem;
  display: inline-block;
  margin: 0;
  line-height: 1.7;
  transition: .3s;
}
.global-header_search-tags li a {
	color:  var(--bg--color-page);
	padding: 2px 8px;
}
.global-header_search-tags li a:hover {
	color: var(--color-complementary);
  }
@media screen and (max-width:744px) {
	.global-header_search {
		height: 100%;
		overflow: scroll;
	}	
	.global-header_search.is-fixed {
		height: 100%;
		overflow: scroll;
	}
	.global-header_search-content {
		overflow: scroll;
		padding: 55px 0 100px;
	}
	.global-header_search {
		left: 0;
		top: 0;
	}
	.global-header_search-button {
		right: 16px;
	}
}
/*
* CONNTENT
******************************************************/
.global-main-content {
	margin: 54px 0 0 0;
	flex: 1;
	position: relative;
}
.page-content {
	max-width: 1080px;
	margin: auto;
}
/*
* POST LIST CONTENTS
******************************************************/
.ge-4col-list {
	margin: auto;
}
.ge-4col-list ul {
	display: flex;
    flex-wrap: wrap;
	justify-content: flex-start;
    margin: 0 auto;
}
.ge-4col-list li {
    width: calc(25% - (40px * 3) / 4);
	height: 100%;
	margin: 0 0 40px 40px;
}
.ge-4col-list li:nth-child(4n+1) {
    margin-left: 0
}
.ge-4col-list-thumb {
    position: relative;
    box-sizing: border-box;
    width: 240px;
    height: 240px;
    overflow: hidden
}
.ge-4col-list-thumb img {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 50%;
    left: 50%;
    min-height: 100%;
    min-width: 100%;
}
@supports (object-fit: cover) {
	.ge-4col-list-thumb img {
        position:static;
        height: 100%;
        width: 100%;
        left: 0;
        -o-object-fit: cover;
        object-fit: cover;
        top: 0
    }
}
.ge-4col-list-desc {
	max-width: 140px;
    margin: auto;
	margin: 1em auto;
}
.ge-4col-list-desc h3 {
	text-align: left;
    font-size: 1.3rem;
    font-weight: 400;
	line-height: 1.4;
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
}
.ge-4col-list-desc h3 span {
	display: block;
	text-align: left;
    font-size: 1.3rem;
    font-weight: 400;
	color:  var(--color-secondary);
}
@media screen and (min-width:714px) and (max-width:1180px) {
	.ge-4col-list {
		max-width: calc(100vw - 40px);
		padding: 0 20px;
	}
	.ge-4col-list-thumb {
		width: calc(24vw - (30px * 3) / 4);
		height: calc(24vw - (30px * 3) / 4);
	}
	.ge-4col-list-desc h3 {
		font-size: 1.3rem;
	}
}
@media screen and (max-width:714px) {
	.ge-4col-list {
		max-width: calc(100vw - 40px);
		padding: 0 20px;
	}
	.ge-4col-list li {
		width: calc(50% - 20px / 2);
		margin: 0 0 30px 0;
	}
	.ge-4col-list li:nth-child(2n+1) {
		margin-right: 20px;
	}
	.ge-4col-list-thumb {
		width: calc(48vw - (20px * 2) / 2);
		height: calc(48vw - (20px * 2) / 2);
	}
	.ge-4col-list-desc {
	max-width: 120px;
	}
	.ge-4col-list-desc h3 {
		font-size: 1.3rem;
		-webkit-line-clamp: 4;
	}
}

/*
* BUTTON
******************************************************/
.ge-button {
	max-width: 200px;
	margin: auto;;
	font-size: 1.2rem;
	line-height: 1;
	letter-spacing: 0.2em;
}
.ge-button a {
	text-align: center;
	color: var(--color-secondary);
	display: block;
	border: 1px solid var(--color-secondary);
	padding: 20px 10px;
	transition: .5s;
}
.ge-button a:hover {
	text-align: center;
	color: var(--color-complementary);
	display: block;
	border: 1px solid var(--color-primary);
	background:  var(--color-primary);
	padding: 20px 10px;
}
/*
* MENU TEXT LINK
******************************************************/
.text-link a {
	position: relative;
	z-index: 1;
}
.text-link a::after {
  	content: '';
	position: absolute;
	left: 0;
	bottom: -4px;
	width: 0%;
	height: 1px;
	background: var(--color-secondary);
	z-index: -1;
	transition: all 0.4s;
}
.text-link a:hover::after {
	  width: 100%;
}
/*
* BREADCRUMBS
******************************************************/
.breadcrumbs {
	width: 100%;
	height: 40px;
	position: absolute;
    bottom: 0;
}  
.breadcrumbs__box {
	max-width: 1180px;
	line-height: 40px;
	margin: auto;
	color: var(--color-secondary);
}  
.breadcrumbs__box ul {
	display: flex;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}
.breadcrumbs__box li {
	padding-right: 20px;
	font-size: 1.1rem;
}
.breadcrumbs__box li:not(:last-child) {
	padding-right: 1em;
}  
.breadcrumbs__box li:not(:last-child)::after {
	content: "";
	top: 0;
	right: 0;
	box-sizing: border-box;
	display: inline-block;
	width: 7px;
	height: 7px;
	border-style: solid;
	border-width: 1px 1px 0 0;
	border-color: var(--color-secondary);
	transform: rotate(45deg);
}  
.breadcrumbs__box li a, .breadcrumbs__box li a:visited {
	color: var(--color-secondary);
}
@media screen and (min-width:814px) and (max-width:1080px) {
	.breadcrumbs__box {
		max-width: inherit;
		padding: 0 60px;
	}  
}
@media screen and (max-width:814px) {
	.breadcrumbs__box {
		max-width: inherit;
		padding: 0 20px;
	}
	.breadcrumbs__box ul {
	  display: block;
	  overflow-x: auto;
	  overflow-y: hidden;
	  -webkit-overflow-scrolling: touch;
	  overflow: auto;
	  white-space: nowrap;
	}
	.breadcrumbs__box li {
	  display: inline;
	  padding-right: 20px;
	  flex: 0 0 40%;
	}
}
/*
* SEARCH RESULT
******************************************************/
.search-result {
	background: var(--bg--color-primary);
	width: 100%;
	padding: 60px 0;
}
.search-result-heading {
	text-align: center;
	font-size: 1.8rem;
	font-weight: 600;
	letter-spacing: .2em;
	position: relative;
	margin: 0 0 80px 0;
	color:var(--color-primary);
}
.search-result-heading::after {
	content: '';
    width: 40px;
    height: 2px;
    display: inline-block;
    background-color: var(--color-primary);
    position: absolute;
    bottom: -5px;
    left: calc(50% - 20px);
}
.search-result-count {
	display: block;
	font-size: 1.2rem;
	padding: 1.55em 0;
	text-align: left;
}
.search-notice {
	text-align: center;
	font-size: 1.3rem;
}
.search-notice p {
	margin: 0 0 40px 0;;
}
/*
* SEARCH
******************************************************/
.search {
	background: var(--bg--color-primary);
	width: 100%;
	padding: 60px 0;
}
.search-content {
	position: relative;
}
.search-content ul {
	display: block;
}
.search-content li {
	display: block;
	margin: 0;
}
.index-search-content {
	max-width: 300px;
	margin: auto;
}
.index-search-lists {
	display: flex;
	justify-content: baseline;
	border-top: 1px solid var(--bg--color-quaternary);
    border-left: 1px solid var(--bg--color-quaternary);
}
.index-search-list {
	width: 50%;
	max-width: 150px;
	margin: auto;
}
/*
* CATEGORY
******************************************************/
summary {
	display: block;
}
summary::-webkit-details-marker {
	display: none;
}
.summary_content {
	border-bottom: 1px solid var(--bg--color-quaternary);
	border-right: 1px solid var(--bg--color-quaternary);
    padding: 5px 12px;
	cursor: pointer;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	color: var(--color-secondary);
	font-size: 1.2rem;
	font-weight: 400;
}
.details_content {
    padding: 14px;
    width: 120px;
    font-size: 1.5rem;
    line-height: 2;
    letter-spacing: 0.05em;
    border: 1px solid var(--bg--color-quaternary);
	position: absolute;
    background: var(--bg--color-tertiary);
	z-index: 3;
}
details[open] .details_content {
	animation: fadeIn 0.85s ease;
}
  @keyframes fadeIn {
	0% {
	  opacity: 0;
	  transform: translateY(-12px);
	}
	100% {
	  opacity: 1;
	  transform: none;
	}
}
.toggle_button {
	display: block;
	position: relative;
	width: 13px;
	margin-left: 8px;
	flex-shrink: 0;
	transform-origin: center 45%;
	transition: transform 0.75s;
}
.toggle_button::before,
.toggle_button::after {
	content: "";
	position: absolute;
	display: block;
	width: 7px;
	height: 1px;
	background-color: var(--color-secondary);
}
.toggle_button::before {
	left: 2px;
	transform: rotate(45deg);
}
.toggle_button::after {
	right: 0;
	transform: rotate(-45deg);
}
details[open] .toggle_button {
	transform: rotate(180deg);
}
@media screen and (min-width:714px) and (max-width:1180px) {
	.post-list-category {
		margin: 20px;
	}
}
@media screen and (max-width:714px) {
	.post-list-category {
		margin: 20px 20px 60px 20px;
	}
	.summary_content {
		font-size: 1.2rem;
	}
}
/*
* FOOTER
******************************************************/
.global-footer {
    height: 54px;
	line-height: 54px;
    width: 100%;
    background-color:  var(--color-primary);
}
.global-footer-copyright {
	text-align: center;
	color:  var(--bg--color-quaternary);
	font-weight: 400;
	font-size: 1.2rem;
	letter-spacing: .2em;
}