@charset "utf-8";
/* -----------------------------------------------
= common
----------------------------------------------- */
body {
	position: relative;
	opacity: 0;
	transition: opacity .8s;
}
body.visible {
	opacity: 1;
}
body::before,
body::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -4;
	width: 100%;
	height: 100%;
	background: #fafaef;
}
/* -----------------------------------------------
= main_contents
----------------------------------------------- */
.main_contents {
	position: relative;
	margin-bottom: -14rem;
	padding-bottom: 14rem;
}
.main_contents::before,
.main_contents::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.main_contents::before {
	z-index: -2;
	background: url(../../img/nanimono/interview_bg01.png) repeat-y 50% 0;
}
.main_contents::after {
	z-index: -1;
	background: url(../../img/shared/bg01.png?230130);
	mix-blend-mode: multiply;
}
@media print, screen and (min-width: 768px) {/* PC */
.main_contents {
	margin-bottom: -28.6rem;
	padding-bottom: 28.6rem;
}
}/* @media */
/* -----------------------------------------------
= pagetitle
----------------------------------------------- */
.pagetitle {
	position: relative;
	height: 20.7rem;
	padding: 8rem 0 0;
	color: #fff;
	text-align: center;
	letter-spacing: .06em;
	overflow: hidden;
}
.pagetitle::before {
	content: '';
	position: absolute;
	top: 9.3rem;
	right: -14.5rem;
	border: solid transparent;
	border-width: 22.5rem 12.4rem;
	border-top-color: rgba(216,208,189,.3);
}
.pagetitle .inner::before,
.pagetitle .inner::after {
	content: '';
	position: absolute;
	background: url(../../img/recruit/event_pagetitle.jpg) no-repeat 50% / cover;
}
.pagetitle .inner::before {
	top: 8.1rem;
	right: 50%;
	width: calc(50% + 4rem);
	height: 14.4rem;
	margin-right: -4rem;
	clip-path: polygon(0 100%, 0 0, 100% 0, 64.3% 100%);
}
.pagetitle .inner::after {
	top: 11.5rem;
	left: 2.5rem;
	width: calc(100% - 2.5rem);
	height: 14.6rem;
	clip-path: polygon(0 100%, 22.6% 0, 100% 0, 100% 100%);
}
.pagetitle h1 .en {
	display: block;
	position: relative;
	z-index: 1;
	padding: 7.5rem 0 1.8rem;
	font-family: 'Montserrat', sans-serif;
	font-size: 2.4rem;
}
.pagetitle h1 .jp {
	display: block;
	position: relative;
	z-index: 1;
	padding: 0 0 1.2rem;
	font-size: 1.4rem;
}
.pagetitle p {
	position: relative;
	z-index: 1;
	font-size: 1.2rem;
}
@media print, screen and (min-width: 768px) {/* PC */
.pagetitle {
	height: 59.2rem;
	padding: 11.3rem 0 0;
}
.pagetitle::before {
	top: 14.2rem;
	right: -9.6rem;
	border-width: 53.5rem 29.5rem;
}
.pagetitle .inner::before {
	top: 11.3rem;
	width: calc(50% + 8.5rem);
	height: 51.2rem;
	margin-right: -8.5rem;
}
.pagetitle .inner::after {
	top: auto;
	bottom: 0;
	left: 50%;
	width: calc(50% + 65rem);
	height: 52rem;
	margin-left: -65rem;
	background-position: 12% 50%;
}
.pagetitle h1 .en {
	padding: 25rem 0 2.8rem;
	font-size: 5.7rem;
}
.pagetitle h1 .jp {
	padding: 0 0 1.8rem;
	font-size: 1.8rem;
}
.pagetitle p {
	font-size: 1.4rem;
}
}/* @media */
@media print, screen and (max-width: 1440px) and (min-width: 768px) {/* TABLET */
.pagetitle .inner::after {
	left: 7rem;
	width: calc(100% - 7rem);
	margin-left: 0;
}
}/* @media */
/* -----------------------------------------------
= bnr
----------------------------------------------- */
.bnr {
	padding: 3rem .8rem 3.2rem;
	opacity: 0;
	transform: translateY(4rem);
	transition: .8s .4s;
}
.bnr.visible {
	opacity: 1;
	transform: translateY(0);
}
.bnr a {
	display: block;
	position: relative;
	padding-bottom: 3.8rem;
	color: #fff;
	text-align: center;
}
.bnr .en {
	position: absolute;
	top: 1.3rem;
	left: 0;
	width: 100%;
	font-family: 'Montserrat', sans-serif;
	font-size: 1.2rem;
	text-align: center;
	letter-spacing: .06em;
}
.bnr .jp {
	position: absolute;
	top: 10rem;
	left: 0;
	width: 100%;
	font-family: 'Shippori Mincho B1', serif;
	font-size: 3.4rem;
	line-height: 6rem;
	text-align: center;
	letter-spacing: .2em;
}
.bnr .jp span {
	border-bottom: .16rem solid #fff;
}
.bnr .text {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	background: linear-gradient(20deg,#A0A36C,#757949);
	font-size: 1.5rem;
	line-height: 3.8rem;
	text-align: center;
	letter-spacing: .02em;
}
.bnr .text::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../../img/shared/bg01.png?230130);
	mix-blend-mode: multiply;
}
@media print, screen and (min-width: 768px) {/* PC */
.bnr {
	max-width: 115.6rem;
	margin: 0 auto;
	padding: 10rem 2rem 8.8rem;
}
.bnr a {
	padding-bottom: 0;
	overflow: hidden;
}
.bnr a img {
	transition: transform .3s;
}
.bnr a:hover img {
	transform: scale(1.05);
}
.bnr .en {
	top: 2.4rem;
	font-size: 2.1rem;
}
.bnr .jp {
	top: 22.4rem;
	font-size: 4.9rem;
	letter-spacing: .3em;
}
.bnr .jp span {
	padding-bottom: 1.4rem;
	border-bottom-width: .2rem;
}
.bnr .text {
	font-size: 1.9rem;
	line-height: 5.2rem;
	letter-spacing: .06em;
}
}/* @media */
/* -----------------------------------------------
= calendar
----------------------------------------------- */
.calendar_wrap .side {
	opacity: 0;
	transform: translateY(4rem);
	transition: .8s .4s;
}
.calendar_wrap .side.visible {
	opacity: 1;
	transform: translateY(0);
}
.calendar {
	background: #fff;
	margin: 0 .8rem;
	padding: 1.9rem 2.4rem;
}
.calendar-nav {
	position: relative;
	width: 100%;
	min-height: 3.2rem;
	margin-bottom: 2.4rem;
}
.calendar-nav strong {
	display: block;
	padding: .8rem 0;
	font-family: 'Montserrat', sans-serif;
	font-size: 2rem;
	letter-spacing: .03em;
}
.calendar-nav button {
	position: absolute;
	top: 0;
	width: 3.2rem;
	height: 3.2rem;
	color: #fff;
	background: #80794A;
	border-radius: 2px;
	font-size: 2rem;
}
.calendar-nav button:first-child {
	right: 3.6rem;
}
.calendar-nav button:last-child {
	right: 0;
}
.calendar-nav button::before {
	content: '';
	position: absolute;
	top: 50%;
	width: 1rem;
	height: 1rem;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
}
.calendar-nav button:first-child::before {
	left: calc(50% - .3rem);
	transform: translateY(-50%) rotate(-135deg);
}
.calendar-nav button:last-child::before {
	left: calc(50% - .8rem);
	transform: translateY(-50%) rotate(45deg);
}
.calendar-grid {
	display: grid;
	grid-template-columns:
	repeat(7, 1fr);
	font-size: 1.5rem;
	text-align: center;
}
.calendar .weekday {
	margin-bottom: 1rem;
}
.calendar .day {
	width: 4rem;
	height: 4rem;
	margin: 2px;
	border-radius: 50%;
	font-family: 'Montserrat', sans-serif;
	font-size: 1.6rem;
	line-height: 4rem;
	text-align: center;
	letter-spacing: .02em;
	cursor: pointer;
	transition: opacity .3s;
	pointer-events: none;
}
.calendar .day:hover {
	opacity: .8;
}
.calendar .day.has-event {
	background-color: rgba(128,121,74,.25);
	pointer-events: auto;
}
.calendar .day.selected {
	background-color: rgba(128,121,74,.5);
}
@media print, screen and (min-width: 768px) {/* PC */
.calendar_wrap {
	display: flex;
	max-width: 144rem;
	margin: 0 auto 16rem;
	padding: 0 2rem;
}
.calendar_wrap .side {
	width: 37rem;
	margin-right: 6.7rem;
}
.calendar_wrap .event-list {
	flex: 1;
}
.calendar-nav strong {
	padding: .2rem 0;
	font-size: 2.8rem;
}
.calendar-nav button {
	transition: opacity .3s;
}
.calendar-nav button:hover {
	opacity: .8;
}
.calendar-grid {
	font-size: 2rem;
}
.calendar .day {
	font-size: 2rem;
}
}/* @media */
/* -----------------------------------------------
= filters
----------------------------------------------- */
.filters {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0 3rem;
	margin: 0 .8rem 4.9rem;
	padding: 2rem 3rem;
	color: #fff;
	background: linear-gradient(90deg, #969964,#757949 70%);
}
.filters .accordion-toggle {
	position: relative;
	width: 100%;
	color: #fff;
	border-bottom: 1px solid #fff;
	font-family: 'Montserrat', sans-serif;
	font-size: 1.3rem;
	line-height: 2;
	text-align: left;
	letter-spacing: .06em;
}
.filters .accordion-toggle::before {
	content: '';
	position: absolute;
	top: 1rem;
	right: .2rem;
	width: .5rem;
	height: .5rem;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
	transform: rotate(45deg);
}
.filters .accordion-toggle.is-open::before {
	top: 1.4rem;
	transform: rotate(-135deg);
}
.filters ul {
	margin: 1.5rem 0 0;
	height: 0;
	opacity: 0;
	pointer-events: none;
	transition: .4s;
}
.filters ul.is-open {
	height: 10rem;
	opacity: 1;
	pointer-events: auto;
}
.filters li {
	margin: .7rem 0;
}
.filters li button {
	width: 100%;
	padding: .3rem 0;
	color: #fff;
	font-size: 1.3rem;
	line-height: 1.5;
	text-align: left;
	letter-spacing: .03em;
}
.filter-btn.active {
	padding: .3rem .5rem;
	color: #80794A;
	background: rgba(255,255,255,.8);
}
@media print, screen and (min-width: 768px) {/* PC */
.filters .accordion-toggle {
	font-size: 1.5rem;
}
.filters li {
	margin: .5rem 0;
}
.filters li button {
	font-size: 1.4rem;
}
}/* @media */
/* -----------------------------------------------
= event_list
----------------------------------------------- */
.event_list {
	margin: 0 3.2rem 6rem;
	border-top: 1px solid #80794A;
	opacity: 0;
	transform: translateY(4rem);
	transition: .8s .4s;
}
.event_list.visible {
	opacity: 1;
	transform: translateY(0);
}
.event_list .event {
	padding: 2.4rem 0;
	border-bottom: 1px solid #80794A;
}
.event_list .event.past {
	opacity: 0.5;
}
.event_list .event.past a {
	pointer-events: none;
}
.event_list .tag {
	display: flex;
	gap: .4rem;
	margin-bottom: 1.4rem;
}
.event_list .tag span {
	padding: .8rem 1.2rem;
	color: #80794A;
	border: 1px solid #80794A;
	border-radius: 4px;
	font-size: 1.2rem;
	letter-spacing: .03em;
}
.event_list .date {
	margin-bottom: 1.6rem;
	font-family: 'Montserrat', sans-serif;
	font-size: 1.6rem;
	line-height: 1.5;
	letter-spacing: .03em;
}
.event_list .title {
	margin-bottom: 2rem;
	font-size: 2rem;
	line-height: 1.5;
	letter-spacing: .03em;
}
.event_list .organizer {
	margin-bottom: 3.2rem;
	color: #80794A;
	font-size: 1.5rem;
	line-height: 1.5;
	letter-spacing: .03em;
}
.event_list .btn {
	display: block;
	position: relative;
	padding: 2.5rem 5rem 2.5rem 3.2rem;
	color: #fff;
	background: #80794A;
	font-family: 'Montserrat', sans-serif;
	font-size: 1.5rem;
	line-height: 1.5;
	letter-spacing: .06em;
}
.event_list .btn::after {
	content: '';
	position: absolute;
	top: calc(50% - .7rem);
	right: 3rem;
	width: 1.7rem;
	height: 1.3rem;
	background: url(../../img/recruit/event_icon_external.svg) no-repeat 50% / cover;
}
.event_list .note {
	margin-top: 1rem;
	font-size: 1.2rem;
	line-height: 1.5;
}
.event_list .note a {
	text-decoration: underline;
}
.nodata {
	margin: 3rem 0;
	font-size: 1.5rem;
	line-height: 1.5;
	letter-spacing: .06em;
}
.comingsoon {
	margin: 3rem 0;
	font-size: 1.2rem;
	line-height: 1.5;
	letter-spacing: .06em;
}
.comingsoon span {
	display: block;
	margin-bottom: 2rem;
	font-family: 'Montserrat', sans-serif;
	font-size: 1.5rem;
}
.comingsoon a {
	text-decoration: underline;
}
.comingsoon a:hover {
	text-decoration: none;
}
@media print, screen and (min-width: 768px) {/* PC */
.event_list {
	width: 86.2rem;
	margin: 0;
}
.event_list .event {
	position: relative;
	padding: 4.2rem 0 4.8rem;
}
.event_list .tag {
	float: left;
	margin: 0 1.6rem 1.6rem 0;
}
.event_list .tag span {
	padding: .8rem 1.2rem;
	font-size: 1.4rem;
	letter-spacing: .06em;
}
.event_list .date {
	float: left;
	margin: .5rem 0 2.1rem;
	letter-spacing: .06em;
}
.event_list .title {
	clear: left;
	margin-bottom: 2.4rem;
	padding-right: 30rem;
	font-size: 2.4rem;
	line-height: 1.58;
	letter-spacing: .06em;
}
.event_list .organizer {
	margin-bottom: 0;
	padding-right: 30rem;
	font-size: 1.6rem;
	letter-spacing: .06em;
}
.event_list .btn {
	position: absolute;
	top: calc(50% - 3.9rem);
	right: 0;
	width: 29rem;
	padding: 2.8rem 5rem 2.8rem 3.7rem;
	box-sizing: border-box;
	transition: opacity .3s;
}
.event_list .btn:hover {
	opacity: .8;
}
.event_list .btn::after {
	right: 2rem;
}
.event_list .note {
	position: absolute;
	top: calc(50% + 4.9rem);
	right: 2.7rem;
	margin: 0;
}
.event_list .note a:hover {
	text-decoration: none;
}
}/* @media */
/* -----------------------------------------------
= recommended
----------------------------------------------- */
.recommended {
	position: relative;
	padding: 6rem 2rem;
}
.recommended::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	width: 100%;
	height: 100%;
	background: #f0f0f0;
	mix-blend-mode: multiply;
}
.recommended .inner {
	opacity: 0;
	transform: translateY(4rem);
	transition: .8s .4s;
}
.recommended .inner.visible {
	opacity: 1;
	transform: translateY(0);
}
.recommended h3 .en {
	display: block;
	margin: 0 -1rem 2rem;
	font-family: 'Montserrat', sans-serif;
	font-size: 2.4rem;
	text-align: center;
}
.recommended h3 .jp {
	display: block;
	margin-bottom: 3rem;
	font-size: 1.4rem;
	text-align: center;
	letter-spacing: .02em;
}
.recommended .item {
	opacity: 0;
	transform: translateY(4rem);
	transition: .8s .4s;
}
.recommended .item.visible {
	opacity: 1;
	transform: translateY(0);
}
.recommended .item a {
	color: #fff;
	font-family: 'Montserrat', 'Noto Sans JP', sans-serif;
}
.recommended .item a img {
	width: 100%;
	filter: grayscale(100%);
	transition: filter .5s;
}
.recommended .item a:hover img {
	filter: grayscale(0);
}
.recommended p {
	padding: .5rem 1rem;
	background: linear-gradient(45deg, rgba(139,144,78,.8), rgba(87,93,30,.8));
	font-size: 1.2rem;
	font-weight: 300;
	line-height: 1.5;
	letter-spacing: .02em;
}
@media print, screen and (min-width: 768px) {/* PC */
.recommended {
	padding: 10rem 4rem;
}
.recommended h3 .en {
	margin-bottom: 3rem;
	font-size: 3.4rem;
}
.recommended h3 .jp {
	margin-bottom: 5rem;
	font-size: 1.6rem;
}
.recommended .item {
	max-width: 50.8rem;
	margin: 0 auto;
}
.recommended p {
	font-size: 1.4rem;
}
}/* @media */
/* -----------------------------------------------
= print
----------------------------------------------- */
@media print {
body,
.bnr,
.calendar_wrap .side,
.event_list,
.recommended .inner,
.recommended .item {
	opacity: 1;
	transform: translateY(0);
}
}/* @media */

