@charset "UTF-8";
/*
Theme Name: sane
Version: 2.0
Author: sane - https://saneyoshi.com
-------------------------------------------------*/

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin:0;
  padding:0;
  border:0;
  outline:0;
	font-size:100%;
	/*baseline→middleにアレンジ*/
  vertical-align:middle;
  /*background:transparent;*/
}
*:where(:not(html, iframe, canvas, img, svg, video, audio):not(svg *, symbol *)) {
 all: unset;
 display: revert;
 box-sizing: border-box;
}
body {
  word-break: normal;
  overflow-wrap: break-word;
}
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
  display:block;
}
ul,ol {
  list-style:none;
}
blockquote, q {
  quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
  content:'';
  content:none;
}
a {
  margin:0;
  padding:0;
  font-size:100%;
  vertical-align:baseline;
  background:transparent;
  text-decoration: none;
}
del {
  text-decoration: line-through;
}
table {
  width:100%;
  border-collapse:collapse;
  border-spacing:0;
}
input, select {
  vertical-align:middle;
}
/*img*/
img {
  overflow: hidden;
  vertical-align: bottom;
  margin: 0;
  padding: 0;
  border: none;
  width: 100%;
  max-width: 100%;
  min-height: 1px;
  height: auto;
  line-height: 1em;
}
iframe {
  width: 100%;
  aspect-ratio: 16/9;
}
strong,b{
  vertical-align: baseline;
}
button{
  border: none;
  outline: none;
  background: transparent;
  cursor: pointer;
}
/*========================================
*	fonts.css
*---------------------------------------*/
:root {
font-size: 62.5%;
/*メインカラー*/
--main-color: #541b86;
--main-color: #00713e;
--light-main-color: #f3e5ff;
/*アクセントカラー*/
--accent-color-yellow: #fff300;
--accent-color-red: #ea554b;
/*テキストカラー*/
--text-color:#231815;
/*基本カラー*/
--white-color:#fff;
--black-color:#003;
/*ページ幅*/
--widthMax : 700px;
/*フォントサイズ*/
--fontsize-3l: 4.0rem;
--fontsize-2l: 3.0rem;
--fontsize-l: 2.5rem;
--fontsize-m: 1.8rem;
--fontsize-s: 1.5rem;
}

body {
  font-size:var(--fontsize-m);
  color: var(--text-color);
	background-color: var(--white-color);
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  line-height:1.6;
  letter-spacing: 0.08em;
}
/*========================================

*	ヘッダー

*---------------------------------------*/
#header-inner{
  width: 100%;
}
#header-inner .logo{
	width: 250px;
  position: relative;
  top: 30px;
  left: 30px;
  z-index: 999;
}
/*========================================

*	フッター

*---------------------------------------*/
.footer__content {
	width: 100%;
	padding: 12px;
	padding-bottom: 12px;
	padding-left: 4%;
	padding-right: 4%;
	background-color: var(--main-color);
}
.footer__content-text {
	font-size: var(--fontsize-m);
	color: var(--white-color);
  font-weight: 800;
	text-align: center;
}
/*========================================

*	小技

*---------------------------------------*/
.pc_none {
	display: none;
}
@media screen and (max-width: 768px) {
.sp_none {
	display: none;
}
.pc_none {
	display: block;
}
}
/*========================================

*	Layout

*---------------------------------------*/
.wrap {
	width: 100%;
	overflow: hidden;
	background: url(/assets/images/hs/common/bg.jpg) no-repeat center center / cover;
	background-attachment: fixed;
}
.inner {
	width: min(800px,92%);
	margin: auto;
}
.content {
	width: min(740px,100%);
	margin: auto;
	padding-top: clamp(50px,10vw,80px);
	padding-bottom: clamp(80px,17.5vw,140px);
	background: #f5e8cb;
	position: relative;
	z-index: 5;
}
.content_inner {
	padding-left: 5%;
	padding-right: 5%;
}
.content_inner .content_area:not(:last-child) {
	margin-bottom: clamp(48px,6.25vw,80px);
}
.content_area {
	padding-top: clamp(28px,7.75vw,62px);
	position: relative;
}
.content_box {
	padding-top: clamp(24px,7.5vw,60px);
	padding-bottom: clamp(24px,7.5vw,60px);
	padding-left: 6%;
	padding-right: 6%;
	background-color: var(--white-color);
	border-radius: clamp(20px,3.75vw,30px);
	position: relative;
	z-index: 6;
}
/*========================================

*	お知らせ：info_list

*---------------------------------------*/
.info_list {
	display: grid;
	row-gap: clamp(20px,5.25vw,42px);
}
.info_list-date {
	width: fit-content;
	margin-bottom: 0.4em;
	padding-left: 0.5em;
	padding-right: 0.5em;
	background-color: var(--main-color);
	color: var(--white-color);
  font-size:var(--fontsize-l);
  font-weight: 800;
  border-radius: 5px;
}
/*========================================

*	タイトルとテキスト

*---------------------------------------*/
.common_text {
  font-size:var(--fontsize-l);
	font-weight: 500;
}
/*========================================

*	日時と場所

*---------------------------------------*/
.reception_area:nth-child(n + 2) {
	margin-top: clamp(20px,5.25vw,42px);
}
.reception_area-title {
	margin-bottom: 0.5em;
	margin-left: clamp(12px,2.5vw,20px);
	margin-right: clamp(12px,2.5vw,20px);
  font-size:var(--fontsize-2l);
	font-weight: 800;
	text-align: center;
	color: var(--white-color);
	background-color: var(--main-color);
	position: relative;
}
.reception_area-title::before,
.reception_area-title::after {
	content: "";
	display: block;
	width: clamp(12px,2.5vw,20px);
	height: 100%;
	background-color: var(--main-color);
	clip-path: polygon(100% 50%, 0 0, 0 100%);
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
.reception_area-title::before {
	right: 99.9%;
	transform: translateY(-50%) scale(-1, 1);
}
.reception_area-title::after {
	left: 99.9%;
}
.reception_area-date {
	line-height: 1.2;
}
.reception_area-date-year {
  font-size:var(--fontsize-m);
  font-weight: 800;
}
.reception_area-date-time {
	display: block;
  font-size:var(--fontsize-l);
  font-weight: 800;
	letter-spacing: 0.15em;
}
.reception_area-place {
  font-size:var(--fontsize-l);
  font-weight: 800;
	text-decoration: underline;
}
.reception_area-place-icon {
	padding-left: 0.3em;
}
@media (hover: hover) and (pointer: fine) {
.reception_area-place:hover {
	text-decoration: none;
  opacity: 0.75;
  transition: all 0.2s ease-in-out;
}
}
/*========================================

*	イベント概要（アコーディオン）

*---------------------------------------*/
.toggle {
	display: none;
	transition: all 0.3s;
}
.checkbox_list-item {
	position: relative;
}
.checkbox_list-item:not(:last-child) {
	margin-bottom: clamp(12px,3vw,24px);
}
.checkbox_list-title,
.checkbox_list-content {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
}
.checkbox_list-title {
	display: block;
	padding-top: 0.5em;
	padding-bottom: 0.5em;
	padding-left: 0.7em;
	padding-right: 2em;
	border: solid 1px var(--main-color);
	background-color: var(--main-color);
  font-size:var(--fontsize-l);
	font-weight: 800;
	line-height: 1.25;
	color: var(--white-color);
	cursor: pointer;
}
.checkbox_list-title span {
  font-size:var(--fontsize-l);
}
.checkbox_list-title::after,
.checkbox_list-title::before {
	content: "";
	position: absolute;
	right: 1em;
	top: 0.6em;
	width: 6px;
	height: 0.75em;
	background-color: var(--white-color);
	transition: all 0.3s;
}
.checkbox_list-title::after {
	transform: rotate(90deg);
}
.checkbox_list-content {
	max-height: 0;
	overflow: hidden;
}
.checkbox_list-inner {
	margin: 0;
	padding-top: 1em;
	padding-bottom: 1em;
	padding-left: 4%;
	padding-right: 4%;
	border: 1px solid var(--main-color);
	clear: both;
}
.checkbox_list-image {
	display: block;
	width: 40%;
	margin-left: clamp(12px,2.25vw,18px);
	float: right;
}
.checkbox_list-text > *:not(:last-child) {
	margin-bottom: clamp(16px,3vw,24px);
}
.checkbox_list-shop {
  font-size:var(--fontsize-l);
  color: var(--main-color);
	font-weight: 800;
}
.toggle:checked + .checkbox_list-title + .checkbox_list-content {
	max-height: 3500px;
	transition: all 1.5s;
}
.toggle:checked + .checkbox_list-title::before {
	transform: rotate(90deg) !important;
}
/*========================================

*	イベント概要（タイムリスト）

*---------------------------------------*/
.time__list-item {
	display: grid;
	grid-template-columns: clamp(80px,27vw,220px) 1fr;
	align-items: center;
	border-top: 1px solid var(--main-color);
	border-left: 1px solid var(--main-color);
	border-right: 1px solid var(--main-color);
}
.time__list-item:last-child {
	border-bottom: 1px solid var(--main-color);
}
div.time__list-item {
	border-bottom: 1px solid var(--main-color);
}
.time__list-time {
	display: flex;
	align-items: baseline;
	justify-content: center;
	height: 100%;
	margin-right: 0.5em;
	padding-top: 0.2em;
	padding-bottom: 0.2em;
  font-size:var(--fontsize-l);
  font-weight: 800;
	text-align: center;
	background-color: var(--light-main-color);
	border-right: 1px solid var(--main-color);
  color: var(--main-color);
}
/*========================================

*	イベント概要（ボタン）

*---------------------------------------*/
.buton_area {
	margin-top: 20px;
	margin-bottom: 20px;
	display: grid;
}
.buton_area > .button:nth-child(2) {
	margin-top: clamp(16px,3.75vw,30px);
}
.button {
	display: grid;
	transition: all 0.2s ease-in;
}
.button__note-text {
	margin-top: 10px;
  font-size:var(--fontsize-l);
	text-align: center;
}
.button::before {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	grid-column: 1/2;
	grid-row: 1/2;
	background-color: var(--white-color);
	border: 4px solid var(--main-color);
	border-radius: 13px;
	position: relative;
	z-index: 1;
	transform: translate(6px, 6px);
	transition: all 0.2s ease-in;
}
.button span {
	display: grid;
	grid-template-columns: auto auto;
	align-items: center;
	justify-content: center;
	gap: 0.5em;
	padding-top: 0.5em;
	padding-bottom: 0.5em;
	padding-left: 2%;
	padding-right: 2%;
	min-height: 2.67em;
	grid-column: 1/2;
	grid-row: 1/2;
  font-size:var(--fontsize-l);
	font-weight: 800;
	color: var(--white-color);
	background-color: var(--main-color);
	border: 4px solid var(--main-color);
	border-radius: 10px;
	position: relative;
	z-index: 2;
	transition: transform 0.2s ease-in;
}
.button span::after {
	content: "";
	display: block;
	width: 0.85em;
	height: 0.85em;
	background: url(/assets/images/hs/common/icon-arr.png) no-repeat center center / contain;
}
@media (hover: hover) and (pointer: fine) {
.button:hover {
	transform: translate(6px, 6px);
	transition: transform 0.2s ease-in;
}
.button:hover::before {
	transform: translate(0, 0);
	transition: transform 0.2s ease-in;
	z-index: 1;
}
.button:hover span {
	color: var(--main-color);
	background-color: var(--white-color);
	transition: transform 0.2s ease-in;
	z-index: 2;
}
.button:hover span::after {
	background-image: url(/assets/images/hs/common/icon-arr-hover.png);
}
}
/*========================================

*	注意事項

*---------------------------------------*/
.event_list {
	display: grid;
}
.event_list-item {
	display: grid;
	grid-template-columns: clamp(14px,3vw,24px) 1fr;
	gap: clamp(6px,1.25vw,10px);
	align-items: baseline;
	justify-content: flex-start;
	padding-top: 1em;
	padding-bottom: 1em;
}
.event_list-item:not(:last-child) {
	border-bottom: 1px dotted var(--main-color);
}
.event_list-item:first-child {
	padding-top: 0;
}
.event_list-item:last-child {
	padding-bottom: 0;
}
.event_list-item::before {
	content: "";
	display: block;
	width: clamp(14px,3vw,24px);
	height: clamp(14px,3vw,24px);
	background-color: var(--main-color);
}
.event__ol-text {
  font-size:var(--fontsize-l);
	font-weight: 800;
}
.event__box-text {
	display: inline-block;
	margin-left: 0.4em;
	margin-right: 0.4em;
	padding-left: 0.4em;
	padding-right: 0.4em;
  font-size:var(--fontsize-l);
	color: var(--white-color);
	line-height: 1.3;
	background-color: var(--main-color);
	border-radius: 5px;
}
/*========================================

*	イベントについて

*---------------------------------------*/
.about__area-title {
  color: var(--main-color);
  font-size:var(--fontsize-l);
  font-weight: 800;
	line-height: 1.2;
	margin-bottom: 0.5em;
}
.about__image-area {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: clamp(14px,3vw,24px);
	margin-top: clamp(14px,3vw,24px);
}
/*========================================

*	アクセス情報

*---------------------------------------*/
.access_box {
	background-color: var(--white-color);
	border-radius: 30px;
	position: relative;
	z-index: 6;
}
.access_inner {
	padding-top: clamp(24px,7.5vw,60px);
	padding-bottom: 18px;
	padding-left: 6%;
	padding-right: 6%;
	background-color: var(--white-color);
	border-radius: 30px;
}
.access_intro-text {
	padding-bottom: 10px;
	font-size:var(--fontsize-l);
	font-weight: 800;
	text-align: center;
	color: var(--accent-color-red);
}
.access_intro-text-note {
	padding-bottom: 1.6em;
	font-size:var(--fontsize-l);
	font-weight: 800;
	text-align: center;
	color: #140700;
}
.access__image-sp {
	position: relative;
	padding-right: 1.5em;
}
.access__image-sp::after {
	content: "";
	display: block;
	width: 1em;
	height: 1em;
	background: url(/assets/images/hs/common/icon-plus.png) no-repeat center center / contain;
	position: absolute;
	top: 0;
	right: 0;
}
.access__info {
	padding-top: clamp(20px,4vw,32px);
	padding-bottom: clamp(24px,7.5vw,60px);
	padding-left: 6%;
	padding-right: 6%;
	background-color: var(--accent-color-red);
	border-radius: 0 0 30px 30px;
	text-align: center;
}
.access__info-text {
	padding-bottom: 0.8em;
	font-size:var(--fontsize-l);
	color: var(--white-color);
}
.access__info-text span {
	color: var(--accent-color-yellow);
}
.access__info-text-note {
  font-size:var(--fontsize-l);
	color: var(--accent-color-yellow);
}
/*赤字*/
.font_note {
	color: var(--accent-color-red);
}
/*========================================

*	お問い合わせ

*---------------------------------------*/
.contact_text {
  font-size:var(--fontsize-l);
	font-weight: 800;
	text-align: center;
}
/*========================================

*	言語

*---------------------------------------*/
.language_area {
	width: min(800px,92%);
	position: fixed;
	top: 10px;
	z-index: 10;
}
.language_list {
	width: fit-content;
	margin-left: auto;
	padding-right: 6%;
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: clamp(10px,2vw,16px);
}
.language_list-button {
	display: grid;
	color: var(--white-color);
	line-height: 1.2;
	transition: all 0.2s ease-in;
}
.language_list-button::before {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	grid-column: 1/2;
	grid-row: 1/2;
	background-color: var(--white-color);
	border: 2px solid var(--accent-color-red);
	border-radius: 30px;
	position: relative;
	z-index: 9;
	transform: translate(3px, 4px);
	transition: all 0.2s ease-in;
}
.language_list-button-text {
	display: grid;
	grid-column: 1/2;
	grid-row: 1/2;
	padding-top: 0.2em;
	padding-bottom: 0.2em;
	padding-left: 0.8em;
	padding-right: 0.8em;
	background-color: var(--accent-color-red);
	border: 2px solid var(--accent-color-red);
	border-radius: 30px;
  font-size:var(--fontsize-m);
	font-weight: 800;
	text-align: center;
	position: relative;
	z-index: 10;
	transition: transform 0.2s ease-in;
}
.language_list-button-reason {
  font-size:var(--fontsize-s);
}
@media (hover: hover) and (pointer: fine) {
.language_list-button:hover {
	transform: translate(3px, 4px);
	transition: transform 0.2s ease-in;
}
.language_list-button:hover::before {
	transform: translate(0, 0);
	transition: transform 0.2s ease-in;
	z-index: 1;
}
.language_list-button:hover .language_list-button-text {
	color: var(--accent-color-red);
	background-color: var(--white-color);
	transition: transform 0.2s ease-in;
	z-index: 2;
}
}
/*========================================

* TOP固定バージョン

*---------------------------------------*/
.mv {
	width: 100%;
	background: url(/assets/images/hs/bg/mv-bg.jpg) no-repeat center center / cover;
}
.mv_inner {
	position: relative;
}
.mv_image-title {
	padding-top: 56px;
	padding-bottom: 48%;
	padding-right: 2%;
	padding-left: 2%;
	position: inherit;
	z-index: 3;
}
.mv_image-free {
	display: block;
	width: min(218px,26%);
	position: absolute;
	top: 43%;
	left: 2%;
	z-index: 2;
}
.mv_image-model {
	display: block;
	width: 100%;
	position: absolute;
	top: 36%;
	left: 0;
	z-index: 1;
}
.mv_image-text {
	display: block;
	width: min(515px,92%);
	position: absolute;
	bottom: 2%;
	right: 4%;
	z-index: 2;
}
@media screen and (max-width: 768px) {
.inner {
	width: 100%;
}
.language_area {
	width: 100%;
}
.language_list {
	padding-right: 4%;
}
.mv_image-title {
	padding-bottom: 68%;
}
.about__image-area {
	grid-template-columns: 1fr;
}
.button span {
	border-radius: 8px;
}
.button::before {
	border-radius: 10px;
	border-width: 2px;
	transform: translate(4px, 4px);
}
.cht .mv_image-title {
	width:80%;
	padding-top: 56px;
	padding-bottom: 80%;
}
}
@media screen and (max-width: 320px) {
.content_area {
	padding-top: 26px;
}
.event__ol-text {
  font-size:var(--fontsize-m);
}
.button span {
	grid-template-columns: 1fr;
  font-size:var(--fontsize-m);
	text-align: center;
}
.button span::after {
	content: none;
}
}
/*========================================

* TOPスライドバージョン

*---------------------------------------*/
.top-main-spacer {
  height: 90vh;
}
.top-main {
  position: absolute;
  top: -50px;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 6;
  background-color: var(--black-color);
}
.top-main figure {
  position: relative;
  overflow: hidden;
  z-index: 0;
  height: 100%;
}
.top-main figure img{
  height: 100vh;
  object-fit: cover;
}
.top-main figure:after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(24,24,24,0.35);
  z-index: 1;
}
/*コピー部分*/
.top-main-copy-type1 {
  color: var(--white-color);
  font-size: var(--fontsize-3l);
  position: absolute;
  bottom: 100px;
  left: 8vw;
  z-index: 1;
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: .01em;
  white-space: nowrap;
}
.top-main-copy-type1 span{
  display: block;
}
.top-main-copy-type1 .indent1 {
  margin-left: 0;
}
.top-main-copy-type1 .indent2 {
  margin-left: 0.4em;
}
.top-main-copy-type1 .indent3 {
  margin-left: 0.8em;
}
.top-main-copy-type1 .indent4{
  font-size: var(--fontsize-s);
  text-align: right;
  margin-top: 10px;
  letter-spacing: -.01em;
}
.top-main-copy-type2 {
  width: 620px;
  position: absolute;
  bottom: 160px;
  right: 6.8vw;
  z-index: 1;
}
.top-main-copy-type2 .wrap {
  width: 100%;
}
.top-main-copy-type2 h2 {
  font-size: var(--fontsize-3l);
  color: var(--white-color);
  display: block;
  line-height: 1.15;
  letter-spacing: 0em;
  margin-bottom: 22px;
}
.top-main-copy-type2 .subttl {
  font-size: var(--fontsize-xl);
  color: var(--white-color);
  display: block;
  line-height: 1;
  letter-spacing: 0em;
  margin-bottom: 22px;
}
.top-main-copy-type2 .name {
  font-size: var(--fontsize-m);
  color: var(--white-color);
  display: block;
  line-height: 1.3;
  letter-spacing: .03em;
  margin-top: 20px;
}
.top-main-copy-type2 .cat {
  font-size: var(--fontsize-s);
  color: var(--white-color);
  display: inline-block;
  line-height: 1;
  letter-spacing: .03em;
  padding: 3.5px 12px;
  margin-left: 18px;
  border: 1px solid var(--white-color);
  border-radius: 12px;
}
/*========================================

*	タイトル

*---------------------------------------*/
.title {
	color: var(--main-color);
  font-size: var(--fontsize-2l);
  font-weight: 800;
	width: fit-content;
	margin-inline: auto;
	text-align: center;
	white-space: nowrap;
	position: absolute;
	z-index: 0;
	top: -15px;
	left: 50%;
	transform: translateX(-50%);
}
/*========================================

*	Figcaption

*---------------------------------------*/
figcaption {
  font-size: var(--fontsize-m);
  color: var(--white-color);
  background: var(--black-color);
  font-weight: 500;
  padding: 0px 5px;
  text-align: center;
}
/*========================================

*	カスタマイズ

*---------------------------------------*/
.reception_area-title.before-non::before {
  display: none;
}
.reception_area-title.after-non::after {
  display: none;
}
.button.audio span::after {
  background: url(/assets/images/hs/common/audio-play.png) no-repeat center center / contain;
  width: 1.5em;
  height: 1.5em;
}
.button.audio.playing span::after {
  background: url(/assets/images/hs/common/audio-stop.png) no-repeat center center / contain;
}
/*========================================

*	Contact form 7

*---------------------------------------*/
:root {
/*フォーム*/
--form-input-color:#fffeee;
--form-error-color:#00B36B;
--form-border-color:#c9c9c9;
--form-required-color:#f1c846;
--form-submit-color:#f1c846;
}
.grecaptcha-badge {
  visibility: hidden;
}
.wpcf7 label{
  font-size:var(--fontsize-m);
  padding-top: 30px;
  display: block;
}
input[type="text"],
input[type="email"],
input[type="tel"],
select{
  font-size:var(--fontsize-m);
	font-family: inherit;
	-webkit-appearance: none;
	appearance: none;
	border-radius: 3px;
	border: 1px solid var(--form-border-color);
	height:44px;
	width: 100%;
	padding-left: 5px;
	margin-top: 10px;
}
textarea {
  font-size:var(--fontsize-m);
  border: 1px solid var(--form-border-color);
  width: 100%;
  height: 200px;
  overflow: scroll;
  padding: 5px;
  font-family: inherit;
	padding-left: 5px;
	margin-top: 10px;
}
.wpcf7-list-item {
    display: block!important;
}
.wpcf7 input[type="submit"] {
	-webkit-appearance: none;
  appearance: none;
  border: none;
  cursor: pointer;
  border-radius: 99px;
  padding: 30px 10px;
	width: 100%;
	max-width: 100%;
	font-family: inherit;
  font-size:var(--fontsize-m);
	font-weight: 700;
  background-color: var(--form-submit-color);
	color: var(--text-color);
	margin: 0 auto;
	line-height: 1;
	height: 80px;
  margin-top: 50px;
  text-align: center;
}
.wpcf7-validates-as-required{
	background: var(--form-input-color);
}
/* 必須項目 */
.wpcf7 .required {
  font-size:var(--fontsize-s);
  color: var(--text-color);
  background: var(--form-required-color);
  font-weight: bold;
  padding: 1px 6px 3px;
  border-radius: 1px;
	display: inline-block;
	margin-left: 10px;
	vertical-align: bottom;
}
/* 送信後のメッセージ */
.wpcf7 form .wpcf7-response-output {
  margin: 0!important;
  border: none!important;
  font-size: var(--fontsize-l);
  color:var(--form-error-color);
  font-weight: 800;
}

/* Scroll Animations */
.js-fade {
  opacity: 0;
  transition: opacity 1.2s cubic-bezier(0.22, 1, 0.36, 1), transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}

.js-fade-up {
  transform: translateY(50px);
}

.is-visible {
  opacity: 1 !important;
  transform: translate(0, 0) !important;
}
