@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%);
}



/*==========================================
 *  con1 
 ==========================================*/
.con1_outside {
  padding-top: 100px;
  padding-bottom: 100px;
  background-image: url(../img/index_img/con1_bg.png);
  background-repeat: repeat-x;
  background-position: center top;
}
.con1_lead {
  text-align: center;
  font-size: 113%;
  margin-bottom: 30px;
}
.con1_flex_box {
  display: flex;
  justify-content: space-between;
  margin-bottom: 60px;
}
.con1_flex_box li {
  width: 30%;
}
.con1_about {
  position: relative;
  padding: 30px;
  border-radius: 6px; /*角の丸み*/
  background-color: rgba(75, 192, 190, 0.20);
  margin-bottom: 30px;
}
.con1_about .con1_about_title {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  display: inline-block;
  top: -20px;
  width: 30%;
	text-align: center;
}
.con1_about_lead {
  color: #4BC0BE;
  font-size: 138%;
  font-weight: 700;
  margin-bottom: 10px;
	text-align: center;
}
.con1_about_txt {
  font-size: 113%;
}
/* 小さい画面用の設定-------------- */
@media (max-width:767px) {
  .con1_outside {
    background-size: 50%; /* 元の50%のサイズに縮小 */
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .con1_lead {
    font-size: 100%;
    margin-bottom: 30px;
  }
  .con1_flex_box {
    margin-bottom: 40px;
    flex-wrap: wrap;
  }
  .con1_flex_box li {
    width: 48%;
  }
  .con1_flex_box li:last-child {
    margin-left: auto;
    margin-right: auto;
  }
.con1_about {
padding: 20px;
padding-top: 30px;
}
.con1_about .con1_about_title {
width: 60%;
top: -10px;

}

.con1_about_lead {
  font-size: 119%;
line-height: 1.4;
}
.con1_about_txt {
font-size: 94%;
text-align: left;
}
	
}
/* -------------end------------- */

/*==========================================
 *  con２ 
 ==========================================*/
.con2_outside {
	padding-top: 100px;
	padding-bottom: 100px;
background-color: rgba(224,213,200,0.30);
}

.con2_flex_box{display: flex;
justify-content: space-between;
margin-bottom: 30px;}

.con2_flex_box li{width: 30%;}

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

.con2_menu_title{color: #4BC0BE;
font-size: 125%;
line-height: 1.2;}

.con2_menu_subtitle{
color: #E0D5C8;
	font-size: 88%;
}

.con2_menu_txt{
color: #3a3a3a;
}



/* 小さい画面用の設定-------------- */
@media (max-width:767px){
.con2_outside {
	padding-top: 50px;
	padding-bottom: 50px;}
	
.con2_flex_box{flex-wrap: wrap;}

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

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

/*==========================================
 *  con3 
 ==========================================*/
.con3_outside {

background-color: #4BC0BE;
}

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

.con3_flex_box > li{width: 50%;
box-sizing: border-box;}

.con3_flex_box > li:first-child{
	width: calc(50% - 160px); /* margin-left(80px) + margin-right(80px) を差し引く */
  margin: 60px 80px;
	border: 2px solid #ffffff;
	position: relative;
	text-align: center;
	box-sizing: border-box;
	
}

.con3_flex_box > li:first-child a{
color: #ffffff;
	
}

.con3_title_01{position: absolute;
	width: 50%;
	top:-100px;
	left: -80px;
}

.con3_title_02{position: absolute;
	width: 50%;
	bottom:-80px;
	right: -80px;
	z-index: 999;
}

.con3_title_wrap {
  display: flex;
  flex-direction: column; /* 縦並びにする */
  justify-content: center; /* 上下中央 */
  align-items: center;     /* 左右中央 */
  text-align: center;      /* 改行を含むテキストを中央揃え */
  height: 100%; /* 必要に応じて高さを指定 */
}


.con3_title{font-size: 228%;
font-variant: 700;
line-height: 1.2;
margin-bottom: 30px;}

.con3_subtitle{font-size: 125%;
margin-bottom: 30px;}

.con3_bt_more  {
position: relative; /* 疑似要素用 */
  padding-right: 1em; /* 矢印のスペース確保 */
}



/* 疑似要素で Font Awesome の矢印を追加 */
.con3_bt_more: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%);
}

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

.con3_inner_flex_box > li{width: 50%;}

/* 小さい画面用の設定-------------- */
@media (max-width:767px){

.con3_contents{width: 100%;}
	
.con3_flex_box{flex-wrap: wrap;}

.con3_flex_box > li{width: 100%;}

.con3_flex_box > li:first-child{
width: calc(100% - 30px); /* margin-left(80px) + margin-right(80px) を差し引く */
margin: 30px 30px;
padding-top: 30px;
padding-bottom: 30px;
}
	
.con3_title_01{position: absolute;
	width: 35%;
	top:-40px;
	left: -30px;
}

.con3_title_02{position: absolute;
	width: 35%;
	bottom:-40px;
	right: -30px;
}

	.con3_title{font-size: 188%;
margin-bottom: 20px;}

.con3_subtitle{font-size: 119%;
margin-bottom: 20px;}

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

/*==========================================
 *  con4 
 ==========================================*/
.con4_outside {
  position: relative;
  padding-top: 100px;
  padding-bottom: 100px;
  z-index: 0; /* 子要素より下に */
}

.con4_outside::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/index_img/con4_bg.jpg) center/cover no-repeat;
  opacity: 0.8; /* 背景のみ透明度80% */
  z-index: -1;  /* 背景として下に配置 */
}


.con4_inner{
background-color: rgba(255,255,255,0.80);
padding: 30px;
border-radius: 10px;
}

.con4_news_flex_upper{margin-bottom: 30px;}

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

.con4_news_flex > li:first-child{
width: 30%;}

.con4_news_flex > li:last-child{
width: 70%;}

/* con4見出し ------------------------------*/
.con4_title_box{
color: #604C3F;
position: relative;
}

.con4_title_img{position: absolute;
top:0;
left: -20px;
width: 76px;
height: 60px;}

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

/* 英語タイトル（上） */
.con4_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;
}

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





/* 小さい画面用の設定-------------- */
@media (max-width:767px){
.con4_outside {
  padding-top: 50px;
  padding-bottom: 50px;
}


.con4_title_img{position: absolute;
top:0;
left: 10px;
width: 66px;
height: 53px;}
	
.con4_title_sub {
font-size: 200%;
padding-left: 10px;
padding-right: 10px;

}

.con4_news_flex{
 flex-wrap: wrap;
}

.con4_news_flex li:first-child{
width: 100%;
margin-bottom: 10px;
}

.con4_news_flex li:last-child{
width: 100%;
}

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



/* news_dl-------------- */

.news_dl {
margin-bottom: 10px;
}

.news_dl dt {
	clear: left;
	float: left;
	width: 7em;
    padding-left: 1em;
}

.news_dl dd {
	padding-left: 8em;
    padding-right: 1em;
	margin-bottom: 5px;
	padding-bottom: 5px;
	border-bottom-width: 1px;
	border-bottom-style: dashed;
	border-bottom-color: #CCC;
    position: relative;}

.news_dl dd a{
color: #212121;}

.news_dl dd::after{font-family: "Font Awesome 5 Free";
content: "\f105";
font-weight: 900;
position: absolute;
top: 50%;
right: 10px;
margin-top: -16px;
}

/* 小さい画面用の設定-------------- */
@media (max-width:767px){
.news_dl dt {
	clear: none;
	float: none;
	width: 100%;
    padding-left: 0em;
}

.news_dl dd {
	padding-left: 0em;
    padding-right: 0em;
	padding-right: 1em;
}
	
	.news_dl dd::after{right: 5px;
}

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

/*==========================================
 *  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: #4BC0BE;
color: #ffffff;}

.footer_links_box{margin-bottom: 100px;}

.footer_links{display: flex;
justify-content: center;
}

.footer_links > li{
font-size: 88%;}

.footer_links > li a{
color: #ffffff;}

.footer_links > li::after{
	content:"｜";
	padding-right: 5px;
	padding-left: 5px;
}

.footer_links > li:last-child::after{
	content:"";
	padding-right: 0px;
	padding-left: 0px;
}



/* 小さい画面用の設定-------------- */
@media (max-width:767px){
 .footer{
width: 90%;
	}
    
.footer_links{flex-wrap: wrap;}
    
.footer_links > li{
width: 100%;}
    
.footer_links > li::after,
.footer_links > li:last-child::after{
content: "\f105"; 
  font-family: "Font Awesome 5 Free"; 
  font-weight: 900; 
padding-right: 0px;
padding-left: 0.5em;
}
}
/* -------------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; /* ヘッダーの高さ分 */
}


/************************************
新着情報
*************************************/

/* clearfix */
.clearfix:after { content:"."; display:block; clear:both; height:0; visibility:hidden; }
.clearfix { display:inline-block; }

/* for macIE \*/
* html .clearfix { height:1%; }
.clearfix { display:block; }

ul#newsList{
	margin:0 0 15px;
	padding:0;
	
}
ul#newsList li{
	margin:0;
	padding:5px 0;
	margin-bottom:3px;
	border-bottom:1px dotted #ccc;
	list-style-type:none;
	line-height: 1.8;
	padding-left: 1em;
}
a{color:#3a3a3a;text-decoration:underline;}
a:hover{color:#3a3a3a;text-decoration:none;}
	
.catName{
	display:inline-block;
	padding:3px 8px;
	border:1px solid #ccc;
	border-radius:6px;
	font-size:11px;
	line-height:100%;
	margin:0 2px;
}
.newMark{
	display:inline-block;
	padding:1px 4px;
	font-size:14px;
	line-height:100%;
	background:#4BC0BE;
	color:#fff;
	border-radius:2px;
}
.comment{
	display:block;
	padding:3px 0;
	float:left;
	overflow:hidden;
	width:500px;/* 本文部分の幅。ここは特に設置ページ合わせて変更下さい */
}
.thumbNailWrap{
	display:block;
	width:110px;
	float:left;
	height:80px;
	overflow:hidden;
}




.bt_insta {background-color: rgba(75, 192, 190, 1.00);
	text-align: center;

}



.bt_insta a{
    padding-top: 10px;
    padding-right: 10px;
    padding-bottom: 10px;
    display: block;
	color: #fff;
	font-weight: 700;}

