@import url('https://fonts.googleapis.com/css2?family=Cormorant+Infant:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600;1,700&display=swap');

:root {
  --main-font: "Cormorant Infant", serif;
}

body {
	font-family: var(--main-font);
	font-weight: 300;
}

.ark-block-heading .ark-block-heading__main {
	font-size: min(70px, 14vw);
	font-weight: 300 !important;
	line-height: 1.2;
	background: linear-gradient(-135deg, var(--ark-color--main), var(--ark-color--text));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
}
.ark-block-heading .ark-block-heading__sub {
	font-size: min(16px, 4vw);
}

/* ===== ドロワー ===== */
.p-drawer__logo {
	text-align: center;
	padding-bottom: 1rem;
}
.p-drawer__logo img {
	width: 16rem;
}


/* ヘッダーボタン */
.c-gnav .ark-block-buttons .ark-block-button__link {
	padding: 0.95em 1.25em;
}
.c-gnav .ark-block-button__link .ark-block-button__text {
	font-size: min(16px, 4vw);
}
.c-gnav .ark-block-buttons[data-orientation=horizontal] .ark-block-button {
    margin-left: calc(var(--arkb-gap--x) + 0.75rem);
    margin-right: 0;
}

/* ボタン装飾 */
.ark-block-button.-gw_btn .ark-block-button__link {
    box-shadow: inset 0 0 0 1px var(--ark-color--main);
}

/* フッター */
.l-footer__foot {
    padding-bottom: 2rem;
    padding-top: 2rem;
}

.p-fixBtnWrap {
	display: none;
}


/************************************
　ローディングアニメーション
************************************/
/* 画面全体 */
#loader_wrap {
	z-index: 999;
	position: fixed;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100vw;
	height: 100vh;
	top: 0;
	background: var(--ark-color--text);
	pointer-events: none;
	transition: all 0.3s;
}
/* ローディングアニメーション */
.loader {
	width: 14%;
	height: 100vh;
	background: url("https://vietoile.com/wp/wp-content/uploads/2025/06/logo.png") var(--ark-color--text);
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: contain;
	opacity: 0;
	animation: blinkAnime 3s infinite linear;
}
@keyframes blinkAnime {
	0% {opacity: 0;}
	30% {opacity: 1; }
	100% {opacity: 1; }
}
@media screen and (max-width:768px) { 
	.loader {
		width: 30%;
	}
}
/* ************************************
  ************************************ */



/************************************
** Contact form 7 CSSカスタマイズ
************************************/
/* 入力欄全体の設定 */
input[type="text"],input[type="password"],input[type="datetime"],input[type="date"],input[type="month"],input[type="time"],input[type="week"],
input[type="number"],input[type="email"],input[type="url"],input[type="search"],input[type="tel"],input[type="color"],select,textarea {
    display: block;
    width: 100%;
    height: 45px;
    margin-bottom: 0;
    padding: 0 12px;
    border: 0;
    box-shadow: none;
    background-color: #F6F8F8;
    color: #5c6b80;
    font-size: 1em;
    vertical-align: middle;
    line-height: 45px;
    transition: background-color 0.24s ease-in-out;
}
/* テキストエリアの設定 */
table.CF7_table textarea {
    resize: vertical;
    max-width: 100%;
    min-height: 300px;
    line-height: 1.5em;
    padding: 0.5em;
    overflow: auto;
}
/* 入力欄とテキストエリア共通 */
.CF7_table input, .CF7_table select, .CF7_table textarea {
	border: 1px solid #d8d8d8;
}
/* table */
table.CF7_table {
	width: 100%;
	margin: 0 auto;
	border: none !important
}
table.CF7_table tr {
	border-top: 1px solid #e5e5e5;
}
table.CF7_table th {
  width: 30%;
  background-color: #F6F8F8;
	font-size: 15px;
	vertical-align: middle;
}
/* 背景を削除 */
table.CF7_table tr,
table.CF7_table th,
table.CF7_table td {
	padding: 0.75rem 0.75rem !important;
	background: none !important;
	border: none !important;
}

table.CF7_table td.fl-all p {
	display: flex;
	flex-direction: row;
    flex-wrap: wrap;
	align-items: center;
	gap: 10px;
}
table.CF7_table td.fl-all [data-name="reserve-date"] {
	min-width: 300px;
}
@media screen and (max-width: 768px){
	table.CF7_table td.fl-all [data-name="reserve-date"] {
		min-width: 100%;
	}
}

.single .entry-content table.CF7_table,
.page .entry-content table.CF7_table {
	display: table;
}
.CF7_table ::placeholder {
	color: #797979;
}

/*「必須」文字*/
.CF7_req{
	font-size: .9em;
	padding: 4px 7px;
	background: var(--ark-color--main);
	color: #fff;
	margin-right:1em;
}

/*「任意」文字*/
.CF7_unreq{
	font-size: .9em;
	padding: 4px 7px;
	background: #bdbdbd;
	color: #fff;
	margin-right:1em;
}

/* レスポンシブ */
@media screen and (max-width: 768px){
	table.CF7_table{
	    width: 90%;
	}
	.CF7_table tr, .CF7_table td, .CF7_table th{
        display: block;
        width: 100% !important;
        line-height: 2.5em;
	}
	.CF7_table th{
	    background-color: #F6F8F8;
	}
}

/* 「送信する」ボタン */
.wpcf7 input.wpcf7-submit {
	background-color: var(--ark-color--main);
	border: 2px solid  var(--ark-color--main);
	color:#fff;
	font-size:1.2em;
	font-weight: bold;
	margin: 0 auto;
	padding: 15px 30px;
	transition: all 0.5s 0s ease;
}
.wpcf7 input.wpcf7-submit:hover {
  background: #fff;
	color:  var(--ark-color--main);
}
.CF7_btn{
	text-align: center;
	margin: 20px;
}
.wpcf7-spinner{
	width:0;
	margin:0;
}
/* ************************************
  ************************************ */

/* reCaptha 非表示 */
.grecaptcha-badge { visibility: hidden; }
