/****共通カスタマイズ****/

.hsm-original-alert {
	background-color: #f8f8f3;
	border-color:#f3f3f3;

}
.hsm-original-alert .svg-inline--fa {
	color: #758c40;
}

.fade-in-up {
    opacity: 0;
    transform: translateY(50px);
    transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
.fade-in-delay {
    opacity: 0;
    transform: translateY(100px);
    transition: opacity 1s ease-out 0.2s, transform 1s ease-out 0.2s;
}
.fade-in-big {
    opacity: 0;
    transform: translateY(100px);
	transform:scale(0);
    transition: opacity 1s ease-out 0.2s, transform 1s ease-out 0.2s, scale 1s ease-out 0.2s;
}
.fade-in-up.visible, .fade-in-delay.visible  {
    opacity: 1;
    transform: translateY(0);
}
.fade-in-big.visible {
    opacity: 1;
    transform: translateY(0);
	transform:scale(1);
}
.l-header{
	background-color: rgba(255,255,255,0.8);
	backdrop-filter: blur(20px) saturate(180%);
	-webkit-backdrop-filter: blur(20px) saturate(180%);
	
}
@media (max-width: 768px) {
.l-header{
	background-color: rgba(255,255,255,0.8);
	backdrop-filter: blur(20px) saturate(180%);
	-webkit-backdrop-filter: blur(20px) saturate(180%);
}
}
.page-id-113 .c-entry__header {
  	display:none;
	}
.page-id-76 .c-entry__header {
  	display:none;
	}
.page-id-403 .c-entry__header {
  	display:none;
	}
.page-id-419 .c-entry__header {
  	display:none;
	}
.page-id-830 .c-entry__header {
  	display:none;
	}
.page-id-865 .c-entry__header {
  	display:none;
	}
.page-id-135 .c-entry__header {
  	display:none;
	}

@media (max-width: 768px) {
	h2{font-size:18px}
}
html { scroll-behavior: smooth;}

@media(min-width: 768px){
.br-sp {display: none;}
}

.narrow-con {
	width: 85%;
	max-width: 1200px;
	margin: 0 auto;
}
.wide-con {
	width: 85%;
	max-width: 1800px;
	margin: 0 auto;
}

/*タイトル*/
.ttl-en-con{
	display:flex;
	align-items:center;
	margin-bottom:max(calc(var(--vh, 1vh) * -2),-24px);
}
.ttl-en{
	font-size:max(calc(var(--vh, 1vh) * 5),30px);
	color:#cea845;
	letter-spacing: 3px;
}
.ttl-jp{
	color:#645329;
	font-weight:normal;
	font-size:max(calc(var(--vh, 1vh) * 2),14px);
}
.sub-ttl-en{
	font-size:max(4vh,30px);
	margin-bottom:-1vh;
}
.sub-ttl-jp{
	font-weight:normal;
	font-size:max(1vw,14px);
}

.page-ttl-con{
	text-align:center;
	background-size: cover;        
	background-position: center;
	background-repeat: no-repeat;
	padding:10vh 0px;
}
.page-ttl-jp{
	font-size:max(calc(var(--vh, 1vh) * 5),30px);
	letter-spacing: 3px;
	color:#fff;
}
/*フレックスボックス*/
.flex-2{
	display:flex;
}
.flex-2-re{
	display:flex;
	flex-direction:row-reverse;
}
 @media screen and (max-width: 767px) {
.flex-2, .flex-2-re{
	flex-direction:column;
}}

/*ボタン*/
.btn_25-cen a{
	margin:20px auto;
}
a.btn_25 {
	display: flex;
	justify-content:center;
	align-items: center;
	position: relative;
	overflow: hidden;
	text-decoration: none;
	border-radius: 100vw;
	border:1px solid #fff;
	color: #fff;
	max-width:220px;
	height:50px;
}
a.btn_25_rev {
	border:1px solid #cea845;
	color: #cea845;
	background-color:#fff;
}
a.btn_25:hover::before {
  transform: scaleX(1);
}
a.btn_25:hover {
	color: #fff;
	border:1px solid #cea845;
	transition: all 0.7s;
}
a.btn_25 span {
  position: relative;
  z-index: 1;
}
a.btn_25::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  transform: scaleX(0);
  transform-origin: 0 50%;
  width: 100%;
  height: inherit;
  border-radius: inherit;
  background-color:
    #cea845;
  transition: all 0.5s;
}

/*下線*/
.under-line{
	background: linear-gradient(transparent 60%, rgba(206, 168, 69, 0.6) 60%);

}


/****トップページ****/

.hero-sec {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	height: calc(var(--vh, 1vh) * 100);
	width:100vw;
	overflow:hidden;
	position:relative;
}
.hero-bg-wrapper {
	position:fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: calc(var(--vh, 1vh) * 100);
	z-index: -1;  /* hero-sec の背面に配置 */
}

.hero-bg {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero-sec > * {
  z-index: 2;
}
.hero-logo{
	width:20vw;
	min-width:200px;
	margin:0 auto;
	opacity: 0;
	animation: fadeIn 2s forwards;
	animation-delay: 0.4s;
	z-index:4;
}
.hero-sec h1{
	color:#000;
	margin-top:10px;
	opacity: 0;
	animation: fadeIn 2s forwards;
	animation-delay: 0.4s;
	z-index:4;
	font-size:max(calc(var(--vh, 1vh) * 2),16px);
}
.upper{
	margin-top:0px !important;
	z-index:5;
}
@keyframes fadeIn {
  to {
    opacity: 1;
  }
}
.scroll_down {
    position: absolute;
    bottom: 20px;
    font-size: 18px;
	z-index:5;
}

.scroll_down a{
  color: #cea845;
  font-size: 12px;
  letter-spacing: 2px;
  position: absolute;
  bottom: 10px;
  left: 50%;
  display: block;
  background-size: 14px auto;
  z-index: 2;
  text-decoration: none; 
  transform: translate(-50%, -50%);
}

.scroll_down a:before {
  position: absolute;
  top: calc(50% - 50px);
  left: calc(50% - 8px);
  transform: rotate(-45deg);
  display: block;
  width: 12px;
  height: 12px;
  content: "";
  border: 1px solid #cea845;
  border-width: 0px 0 1px 1px;
}

.scroll_down a:after {
  position: absolute;
  width: 33px;
  height: 33px;
  border: 1px solid #cea845;
  content: "";
  border-radius: 100%;
  top: calc(50% - 58px);
  left: calc(50% - 18px);
}

.scroll_down a span::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 33px;
  height: 33px;
  border-radius: 100%;
  box-sizing: border-box;
  box-shadow: 0 0 0 0 #cea845;
  opacity: 0;
  -webkit-animation: circle 3s infinite;
  animation: circle 3s infinite;
  top: calc(50% - 58px);
  left: calc(50% - 18px);
}
@-webkit-keyframes circle {
  0% { opacity: 0; }
  30% { opacity: 1; }
  60% { -webkit-box-shadow: 0 0 0 40px rgba(206, 168, 69, 0.1); opacity: 0; }
  100% { opacity: 0; }
}
@keyframes circle {
  0% { opacity: 0; }
  30% { opacity: 1; }
  60% { 
    box-shadow: 0 0 0 40px rgba(206, 168, 69, 0.1);
    opacity: 0; 
  }
  100% { opacity: 0; }
}
.hero-sec-2{
	background-color:#fff;
	margin-top:0px !important;

}
.hero-sec-2 .flex-2-inner{
	flex:1;
	min-width: 0;
}

.hero-2-text-con{
	align-content:center;
	padding-left:max(5vw,10px);
	padding-right:10px;
	padding-top:50px;
	padding-bottom:50px;
}
.hero-2-img-con{
	display:flex;
	align-content:center;
	align-items:center;
	justify-content: center;
	overflow: visible;  
	padding:10px;
}
.hero-2-img{
	width: 100%;
	height: auto;
	display: block;
}
.hero-2-ttl{
	color:#645329;
	font-size:max(calc(var(--vh, 1vh) * 3),24px);

}
.hero-2-text{
	color:#645329;
	margin-top:10px;
	margin-bottom:50px;
}
@media (max-width: 768px) {
.hero-2-text{
	padding:20px 0px;
}	
}

/*トップページタイトル*/
.top-ttl-en{
	font-size:max(calc(var(--vh, 1vh) * 5),30px);

}
.top-ttl-jp{
	font-size:max(calc(var(--vh, 1vh) * 2),14px);
	font-weight:normal;
}
/*コンセプト*/
.concept-sec{
	margin-top:0px !important;
	padding-top:100px;
	padding-bottom:20px;
	background: linear-gradient(to bottom, #fff, #cea845);
	color:#000;
	position:relative;
}
.concept-sec::after {
  content: "";
  position: absolute;
  bottom: calc(var(--vh, 1vh) * -10);
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 50vw solid transparent;
  border-right: 50vw solid transparent;
  border-top: calc(var(--vh, 1vh) * 10.05) solid #cea845; 
	z-index:1;
}


.concept-con{
	margin:calc(var(--vh, 1vh) * 20) 0px;
	position:relative;
	z-index:1;
}

.concept-con .concept-text-con{
	flex:1;
}
.concept-con .concept-img-con{
	flex:1;
}

.concept-lable{
	position:absolute;
	transform: translatex(-50%);
	font-size:max(calc(var(--vh, 1vh) * 18),50px);
	left:0px;
	top:calc(var(--vh, 1vh) * -10);
	z-index:0;
	color:rgba(255,255,255,0.3);
}
.concept-con h3{
	position:relative;
	margin-bottom:20px;
	font-size:max(calc(var(--vh, 1vh) * 2),18px);
	z-index:1;
}

.concept-1 a{
	margin-top:50px;
}
/*目的別*/
.purpose .flex-2-inner{
	flex:1;
}
.purpose-sec{
	background-color:#fff;
	padding-top:calc(var(--vh, 1vh) * 15);
	position:relative;
	padding-bottom:50px;
}

.purpose-sec::after {
  content: "";
  position: absolute;
  bottom: calc(var(--vh, 1vh) * -10);
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 50vw solid transparent;
  border-right: 50vw solid transparent;
  border-top: calc(var(--vh, 1vh) * 10.05) solid #fff; 
	z-index:1;
}
.purpose-info-con{
	margin-top:50px;
	margin-bottom:100px;
}
.purpose-info-ttl span{
	font-size:max(calc(var(--vh, 1vh) * 1.5),18px);
	font-weight:bold;
}
.purpose-info-con p{
	margin-bottom:10px;
}

.purpose-text-con, .purpose-img-con{
	aspect-ratio: 1 / 1; 
	display: flex;
	flex-direction:column;
	justify-content:center;
	align-content:center;
	position:relative;
}
.purpose-text-inner-con{
	padding:25px;
	z-index:1;
}
.purpose-lable{
	position:absolute;
	width:95%;
	opacity:0.05;
	bottom:10px;
	z-index:-1;
}
.purpose-ttl{
	margin-bottom:10px;
	font-size:max(calc(var(--vh, 1vh) * 2),22px);
}

.purpose-img-inner-con{
  position: absolute;
  inset: 0;
}
.purpose-img-inner-con img{
	object-position: 35% 75%;
	object-fit:cover;
	height:100%;
	width:100%;
}

.purpose-text-inner-con a{
	margin-top:50px;
}

.purpose-sec .btn_25-cen{
	margin:10vh 0px;
}
/*お客様の声*/
.voice-sec{
	margin-top:0px !important;
	background-color:#f8f8f3;
	padding:calc(var(--vh, 1vh) * 15) 0px;
}
.voice-sec .flex-2-inner{
	flex:1;
}
.voice-sec .top-ttl-en-con{
	text-align:center;
}
.voice-info-con{
	max-width:900px;
	padding:20px 0px;
	margin: 10px auto;
}
.voice-info-con p{
	margin:10px 0px;
}
.voice-num-con{
	padding:5vh 0px;
}

.voice-num-ttl{
	text-align:center;
}
.voice-num-text{
	text-align:center;
}
.voice-num-text span{
	font-size:max(calc(var(--vh, 1vh) * 5),40px);
}
.voice-num-info{
	font-size:10px;
	text-align:right;
}

 @media screen and (max-width: 767px) {
.voice-num-con .flex-2-inner{
	margin-bottom:20px;
}}

.voice{
	padding:50px 25px;
	background-color:#fff;
	border-radius:50px 10px;
	margin:50px 0px;
	position:relative;
}
.voice-lable{
	position:absolute;
	width:100px;
	top:calc(var(--vh, 1vh) * -1);
	left:calc(var(--vh, 1vh) * -3);
	transform:rotate(-10deg);
}
@media screen and (min-width: 768px){
.voice-left{
	margin-right:calc(var(--vh, 1vh) * 10);
}
.voice-right{
	margin-left:calc(var(--vh, 1vh) * 10);
}
}
.voice-ttl{
	font-size:max(calc(var(--vh, 1vh) * 1),18px);
	margin-bottom:10px;
}
.voice-gen{
	font-size:12px;
}
/*よくあるご質問*/

.q-a-sec{
	margin-top:0px !important;
	background-color:#fff;
	position:relative;
	padding:50px 0px;
}
.q-a-sec::before {
  content: "";
  position: absolute;
  bottom: calc(var(--vh, 1vh) * -10);
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 50vw solid transparent;
  border-right: 50vw solid transparent;
  border-top: calc(var(--vh, 1vh) * 10.05) solid #fff; 
	z-index:1;
}
.q-a-sec .top-ttl-en-con{
	margin-bottom:50px;
}
.q-a-sec::after {
  content: "";
  position: absolute;
  top: calc(var(--vh, 1vh) * -10);
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 50vw solid transparent;
  border-right: 50vw solid transparent;
  border-bottom: calc(var(--vh, 1vh) * 10.05) solid #fff; 
	z-index:1;
}

.q-a{
	border-top:1px solid #f3f3f3;
	padding:5px;
}
.q-a:last-child{
	border-bottom:1px solid #f3f3f3;
}
.q-lable, .a-lable{
	font-size:max(calc(var(--vh, 1vh) * 3),24px);
	margin-right:2vh;
}
.q-lable{
	color:#cea845;
}
.a-lable{
	color:#cccccc;
}
.a, .q{
	display: flex;
	align-items: center;
	margin:10px 0px;
}


.q .text{
	font-size:max(calc(var(--vh, 1vh) * 1),18px);
	font-weight:bold;
}
.a .text> span{ display: block; }

/*お知らせ*/
.news-sec{
	margin-top:0px !important;
	background-color:#f8f8f3;
	position:relative;
	padding:calc(var(--vh, 1vh) * 15) 0px;
}

.news-sec .narrow-con{
	padding-bottom:100px;
}
.news-con{
	margin:50px 0px;
}
.news:first-child{

	border-top:1px solid #f3f3f3;
}
.news{
	border-bottom:1px solid #f3f3f3;
	padding:15px 10px;
}
.news-date{
	font-size:80%;
}
/*フッター上部*/
.fotter-top-sec{
	background-image:url(https://fuwalu.com/wp-content/uploads/2022/06/top00002.jpg);
	background-position:center;
	background-size:cover;
	position:relative;
}
.fotter-top-sec::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index:1;
}
.fotter-top-ttl{
	position:relative;
	color:#fff;
	font-size:max(calc(var(--vh, 1vh) * 5),24px);
}
.fotter-top-sec .flex-2{
	height:max(calc(var(--vh, 1vh) * 30),400px);
	align-items:center;
	justify-content:space-around;
	align-content:center;
	position:relative;
	z-index:2;
}
.fotter-top-text-con{
	z-index:2;
}
.fotter-top-contact-con{
	z-index:2;
	color:#fff;
}
.fotter-top-contact-text{
	font-size:max(calc(var(--vh, 1vh) * 1),18px);
	margin-bottom:10px;
	font-weight:bold;
	text-align:center;
}
.fotter-top-sec a{
	margin:0 auto;
	text-decoration:none;
	display:flex;
	color:#fff;
	border:1px solid #fff;
	justify-content:center;
	align-items:center;
	gap:10px;
	padding:10px 20px;
	font-size:min(4vw,18px);
	width:200px;
	transition:0.3s
}
.fotter-top-sec a:hover{
	background-color:#fff;
	color:#cea845;
	
}
/****着付け・ヘアメイクページ****/
.page-id-135 .page-ttl-con{
	background-image:linear-gradient(to bottom, rgba(0,0,0,0.1),rgba(0,0,0,0.1)),url("https://fuwalu.com/wp-content/uploads/2025/11/dressing_hairmake-eyec.jpg");
}

/****商品一覧ページ****/

.product-sec .top-ttl-en-con{
	position:relative;
	z-index:3;
	text-align:center;
	margin-bottom:calc(var(--vh, 1vh) * 10);
}
.oil-inner-con, .tea-inner-con, .option-inner-con {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(auto-fit, minmax(550px, 1fr));
    max-width: 1800px;
    margin: 0 auto;
}



.product-img{
	width:max(calc(var(--vh, 1vh) * 10),150px);
}
.product{
	display:flex;
	width:100%;
	
}
.product-text-con{
	width:100%;
}
@media (max-width: 699px){
	.product{
	display:flex;
		flex-direction:column;
}
}
.product-ttl{
	font-size:max(1vw,18px);	
}


.product-price{
	font-size:max(calc(var(--vh, 1vh) * 1),14px);
}
.product-amount{
	font-size:max(calc(var(--vh, 1vh) * 1),14px);
	color:gray;
	align-items:flex-end;
}
/* エッセンシャルオイル*/
.oil-con{
	background-color:#f8f8f3;
	padding:calc(var(--vh, 1vh) * 10) 0px;
	position:relative;
}
.oil-inner-con{
	margin-top:calc(var(--vh, 1vh) * 5);
}
.oil-con::after {
  content: "";
  position: absolute;
  top: calc(var(--vh, 1vh) * -10);
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 50vw solid transparent;
  border-right: 50vw solid transparent;
  border-bottom: calc(var(--vh, 1vh) * 10) solid #f8f8f3; 
	z-index:1;
}
.oil-con::before {
  content: "";
  position: absolute;
  bottom: calc(var(--vh, 1vh) * -10);
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 50vw solid transparent;
  border-right: 50vw solid transparent;
  border-top: calc(var(--vh, 1vh) * 10) solid #f8f8f3; 
	z-index:1;
}
/* ハーブティー*/
.tea-con{
	position:relative;
	padding:calc(var(--vh, 1vh) * 10) 0px;
	background-color:#f3f8f3;
}

.tea-con::before {
  content: "";
  position: absolute;
  bottom: calc(var(--vh, 1vh) * -10);
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 50vw solid transparent;
  border-right: 50vw solid transparent;
  border-top: calc(var(--vh, 1vh) * 10) solid #f3f8f3; 
	z-index:1;
}
.tea-inner-con{
	margin-top:calc(var(--vh, 1vh) * 5);
}
/* オプション小物*/
.option-con{
	position:relative;
	padding:calc(var(--vh, 1vh) * 10) 0px;
}
/************************************
** Contact form 7 CSSカスタマイズ
************************************/


/* reCAPTCHA表示を消す */

.grecaptcha-badge {
	/* 表示を消す */
	visibility: hidden !important;
;
}

@media screen and (max-width: 767px) {
	
	table {font-size:100%;
  display: block;
  width: 100%;
}
	table tbody {
		display: block;
  width: 100%;
}
	table tr {
  display: block;
  width: 100%;
}
table th {
  display: block;
  width: 100%;
}
table.CF7_table tr  {width: 100%;
 }
}

.CF7_table input{
	max-width:65vw;
}

/* table */


table.CF7_table {
	width: 100%;
	margin: 0 auto;
}
table.CF7_table tr {
	border-top: 1px solid #e5e5e5;
}
table.CF7_table th {
  background-color: #F6F8F8;
	font-size: 100%;
	vertical-align: middle;
	text-align:left;
	font-weight:lighter;

}
table.CF7_table tr,
table.CF7_table th,
table.CF7_table td {
	padding: 0.75rem 0.75rem !important;
}
.single .entry-content table.CF7_table,
.page .entry-content table.CF7_table {
	display: table;
}
.CF7_table ::placeholder {
	color: #797979;
}

/* 文字数の多いセルのフォントサイズ */
.CF7_many{font-size:90%}

/* テキストエリアの設定 */
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;
	background-color: #F6F8F8;
	font-size:100%;

}

/*「必須」文字*/
.CF7_req{
	font-size: .9em;
	padding: 4px 7px;
	background: #738c40;
	color: #fff;
	border-radius: 3px;
	margin-right:1em;
}

/*「任意」文字*/
.CF7_unreq{
	font-size: .9em;
	padding: 4px 7px;
	background: #443127;
	color: #fff;
	border-radius: 3px;
	margin-right:1em;
}
/* 「送信する」ボタン */
.wpcf7 input.wpcf7-submit {
	background-color: #738c40;
	border: 2px solid #738c40;
	color:#ffffff;
	font-size:100%;
	margin:0 auto;
	padding: 10px 20px;
	transition: all 0.5s 0s ease;
}
.wpcf7 input.wpcf7-submit:hover {
	color: #738c40;
	background-color:rgba(255,255,255,0.2);
}
.CF7_btn{
	text-align: center;
	margin: 0px;
}
.wpcf7-spinner{
	width:0;
	margin:0;
}
/****ヘッダーカスタマイズ****/
 /* 標準時のボタンのスタイル */
.header-button .fa-instagram{
	height:36px;
	color:#443127;
	transition:0.3s;
}
.header-button .fa-instagram:hover{
	color:#758c40;
}
/****フッターカスタマイズ****/
.l-footer {
	border-top: 0px;
	z-index:2;
}		
.l-footer-widget-area{
	background:#000;
	color:#fff;
}
.fotter{
	display:flex;
	justify-content:space-around;
	padding:10px;
}

@media screen and (max-width: 767px) {
.fotter{
	display:flex;
	flex-direction:column;
	justify-content:space-around;
	
}	
}
.fotter .en{
	font-size:max(1.5vh,16px);
	margin-bottom:-10px;
}
.fotter .jp{
	font-size:max(1vh,12px);
}
.fotter-1, .fotter-2, .fotter-3{
	flex:1;
}
.ume{
	height:max(calc(var(--vh, 1vh) * 3),24px);
	margin-right:10px;
}

.l-footer-widget-area__item .fotter a{
	text-decoration:none;
	color:#fff;
	transition: 0.5s;
	display:flex;
	align-items:center;
	margin-bottom:20px;

}
.l-footer-widget-area__item .fotter a:hover{
	color:#cea845;
}

.fotter .i-con{
	margin-left:10px;
}
.fotter-img-con{
	display:flex;
	flex-direction:column;
}
.fotter-img{
	width:10vh;
	margin-bottom:20px;
}
.fotter-img-con a{
	justify-content:center;
	align-items:center;
    text-align:center;
	
}
.fotter-img-con .fa-instagram{
	height:max(3vh,36px);
}
.c-copyright {
	text-align:center;
	font-size:11px;
	background:#000;
}
.fotter-img-con .fa-instagram:hover{
	color:#cea845;
}
