@charset "UTF-8";

/*================================================
 *  CSSリセット
 ================================================*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}

img{
	width: 100%;
	vertical-align:bottom; /* img要素にここを指定 */
}

a:link {
	text-decoration: none;	
}

a:hover img {
    opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
}




/*================================================
 *  一般・共通設定
 ================================================*/

body {
font-family: 'M PLUS 1p', sans-serif;
	color: #3a3a3a;
	line-height: 1.8;
	word-wrap: break-word;
    font-size: 100%;
	font-weight: 400;
	}

/* 小さい画面用の設定-------------- */
@media (max-width:767px){
body {
    font-size: 90%;
	}
	}
/* -------------end------------- */



/*================================================
 *  リンクスタイル
 ================================================*/
a:hover {
	opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
}


/*================================================
 *  ヘッダー
 ================================================*/

.inside_header{display: flex;
justify-content: space-between;
max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    padding-top: 10px;
    padding-bottom: 10px;
    align-items: center;
}

.inside_header > li:first-child{width: 28%;
padding-left: 10px;}
.inside_header > li:last-child{width: 60%;}

.inside_header_shop{display: flex;
justify-content: flex-end;
}

.inside_header_shop > li{width: 33%;
line-height: 1.4;}

.inside_header_shop_name{font-size: 88%;}
.inside_header_shop_tel{font-size: 150%;
color: #E83F2A;
font-family: 'Rubik', sans-serif;
font-weight: 500;}



/* 小さい画面用の設定-------------- */
@media (max-width:767px){
.inside_header > li:first-child{width: 60%;}
.inside_header > li:last-child{display: none;}
}
/* -------------end------------- */



/* ========================================

 * スマホメニューの電話
 
======================================== */

.sp_header_tel_ul{
	padding-left: 10px;
	padding-right: 10px;
	margin-top: 10px;
}

.sp_header_tel_ul li{margin-bottom: 10px;
	line-height: 1.4;
	text-align: center;
	border-radius: 6px;
	background-color: rgba(224,213,200,0.50);
	
padding-top: 5px;
padding-bottom: 5px;}

.sp_header_tel_ul li a{color: #ffffff;
}

.sp_header_name{font-size: 88%;
	color: #604C3F;}
.sp_header_tel{font-size: 150%;

font-family: 'Rubik', sans-serif;
font-weight: 500;
color: #E83F2A;}


/* ========================================

 * グロナビ固定
 
======================================== */

.nav_fixed {
		position:fixed;
		top:0;
		left:0;
z-index: 10000;}



/* ========================================

    ■ Header■ Keyv

======================================== */
#keyv {
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
    position: relative;}

/* 大きい画面用の設定-------------- */
@media (min-width:768px) {
    .header_outside {
        background-image: url("../img/index_img/main_bg.webp");
        background-position: center top;
        background-repeat: no-repeat;
        background-size: cover;
    }
}
/* -------------end------------- */

.main_title {
    position: absolute;
    width: 30%;
    top:8%;
    left: 8%;

    
    /* アニメーション追加 */
    opacity: 0; /* 初期状態は透明 */
    animation: fadeIn 5s ease-out forwards; /* アニメーション時間を3秒に変更 */
}

/* 小さい画面用の設定-------------- */
@media (max-width:767px) {
.main_title {
position: absolute;
width: 40%;
top:8%;
left: 5%;
}
}

/* アニメーション定義 */
@keyframes fadeIn {
    0% {
        opacity: 0; /* 透明 */
    }
    100% {
        opacity: 1; /* 完全に表示 */
    }
}
/* -------------end------------- */


/* ========================================

    ■ common

======================================== */

.contents{
	max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
    width: 96%;
    box-sizing: border-box;
}

/* 小さい画面用の設定-------------- */
@media (max-width:767px){
.contents{
	width: 90%;
    box-sizing: border-box;
}
	}
/* -------------end------------- */



/* 共通見出し ------------------------------*/
.page_title_flex{display: flex;
justify-content: center;
text-align: center;
color: #604C3F;
margin-bottom: 30px;}

.page_title {
  display: block;
  text-align: center;}

/* 英語タイトル（上） */
.page_title_sub {
  font-size: 250%;
  font-weight: 500;
  line-height: 1.2;
  text-align: center;
  margin-bottom: 3px; /* 英語と線の間隔 */
	  padding-left: 20px;
  padding-right: 20px;
	font-family: "Cormorant Garamond", serif;
}

/* 線（英語の下、日本語の上） */
.page_title_sub::after {
  content: "";
  display: block;
  width: 50px;              /* 線の長さ */
  height: 2px;              /* 線の太さ */
  background-color: #E0D5C8; /* 線の色 */
  margin: 0 auto 0px;      /* 線を中央寄せ + 日本語との間隔 */
}


.page_title_flex > li:first-child,
.page_title_flex > li:last-child
{width: 95px;
  height: 76px;
}

/* 小さい画面用の設定-------------- */
@media (max-width:767px){
.page_title_flex{
margin-bottom: 20px;}


/* 英語タイトル（上） */
.page_title_sub {
  font-size: 188%;
	  padding-left: 8px;
  padding-right: 8px;
}

.page_title_flex > li:first-child,
.page_title_flex > li:last-child
{width: 59px;
height: 47px;
}

}
/* -------------end------------- */


.bt_more {
text-align: right;
}

.bt_more a {
color: #604C3F;
  display: block;
  text-decoration: none;
  position: relative; /* 疑似要素用 */
  padding-right: 1em; /* 矢印のスペース確保 */
}



/* 疑似要素で Font Awesome の矢印を追加 */
.bt_more a::after {
  content: "\f105"; /* fa-angle-right の Unicode */
  font-family: "Font Awesome 5 Free"; /* バージョンに合わせて変更 */
  font-weight: 900; /* solid アイコンの場合は必要 */
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}



/*==========================================
 *  con5 
 ==========================================*/
.con5_outside {
	padding-top: 100px;
	padding-bottom: 100px;
	background-image: url(../img/index_img/con5_bg.png);
	background-repeat: repeat-x;
	background-position: center top;
	background-color: rgba(224,213,200,0.30);
}

.con5_logo{width: 40%;
margin-left: auto;
margin-right: auto;
margin-bottom: 50px;}

.con5_flex_box{display: flex;
justify-content: space-between;}

.con5_flex_box li{width: 28%;
color: #6A4832;}

.con5_flex_box li img{margin-bottom: 10px;}

.con5_salon_name{text-align: center;
font-size: 94%;
margin-bottom: 5px;}

.con5_salon_add{
font-size: 88%;
line-height: 1.4;}

.con5_salon_tel{
font-size: 138%;
color: #E83F2A;
font-family: 'Rubik', sans-serif;
font-weight: 500;}

.con5_salon_time{
font-size: 88%;
line-height: 1.4;}

/* 小さい画面用の設定-------------- */
@media (max-width:767px){
.con5_outside {
padding-top: 50px;
padding-bottom: 50px;
background-size: 50%; /* 元の50%のサイズに縮小 */
}

.con5_logo{width: 90%;
margin-bottom: 30px;}

.con5_flex_box{flex-wrap: wrap;}

.con5_flex_box li{width: 100%;
margin-bottom: 30px;
}
	
.con5_flex_box li:last-child{
margin-bottom: 0px;}

.con5_flex_box li img{display: block; 
margin-bottom: 5px;
width: 70%;
margin-left: auto!important;
margin-right: auto!important;
}


.con5_salon_add{text-align: center;}

.con5_salon_tel{text-align: center;}

.con5_salon_time{text-align: center;}
}
/* -------------end------------- */




/*================================================
 *  footer
 ================================================*/
.footer_outside{
 padding-top: 30px;
padding-bottom: 50px;
background-color: #ef841b;
color: #ffffff;}





/* 小さい画面用の設定-------------- */
@media (max-width:767px){
 .footer{
width: 90%;
	}

}
/* -------------end------------- */


/*================================================
 *  COPY
 ================================================*/
address{
	text-align: center;
	font-size: 75%;
    font-weight: 300;
}


/* ====================================================
　pagetop
==================================================== */

.pagetop {
    display: none;
    position: fixed;
    bottom: 15px;
    right: 15px;
	z-index: 1000;
}
.pagetop a {
    display: block;
   color: #999999;
    font-size: 300%;
}
.pagetop a:hover {
display: block;}


/* ====================================================
　page_btm_fixed
==================================================== */
#page_btm_fixed{
  position: fixed;
    right: 15px;}


.footer_bt_mail {background-color: #E40080;
  position: relative;
	text-align: center;
}

.footer_bt_mail:before {
  font-family: "Font Awesome 5 Free";
  content: "\f0e0";
  position: absolute;
  top: 50%;
  left: 20px;
  margin-top: -24px;
	color: #fff;
	font-size: 200%;
}


.footer_bt_mail a{
    padding-top: 20px;
    padding-right: 20px;
    padding-left: 60px;
    padding-bottom: 20px;
    display: block;
	color: #fff;
	font-weight: 700;}


/* 小さい画面用の設定-------------- */
@media (max-width:767px){
#page_btm_fixed{
position: fixed;
	right: 0;
  bottom: 0;
width: 100%;
	

}

}
/* -------------end------------- */


/************************************
送信完了
*************************************/

.thanks_img{width:30%;
margin-left: auto;
margin-right: auto;
padding-top: 50px;}


/* 小さい画面用の設定-------------- */
@media (max-width:767px){
.thanks_img{width: 50%;
margin-left: auto;
margin-right: auto;
padding-top: 50px;}
	}
/* -------------end------------- */


/* ====================================================
　改行位置
==================================================== */
@media print, screen and (min-width: 768px) {
br.sp { display: none; }
br.pc { display: inline; }
}
@media screen and (max-width: 767px) {
br.sp { display: inline; }
br.pc { display: none; }
}


	 
	 


/* PC向けレイアウトの指定：961px以上では固定レイアウト */
.miniimage { display: none; }  /* miniを非表示 */
.bigimage  { display: block; 
line-height: 0px;} /* bigを表示 */
	
@media only screen and (max-width: 768px) {
.miniimage {
	display: block;
	line-height: 0px;
} /* miniを表示 */
.bigimage  { display: none; }   /* bigを非表示 */
}


/*  PCのみに表示するメニュー*/
.only_smt { display: none; }  /* miniを非表示 */
.only_pc  { display: block; 
} /* bigを表示 */
	
/*  スマホのみに表示するメニュー*/
@media only screen and (max-width: 768px) {
.only_smt {
	display: block;
	
} /* miniを表示 */
.only_pc  { display: none; }   /* bigを非表示 */
}

.salon_box {
  scroll-margin-top: 80px; /* ヘッダーの高さ分 */
}



