@charset "utf-8";
/* ===========================================================
 *
 * 癒し空間ユチ スタイルシート
 * Last UpDate : 2025/12/26 *
=========================================================== */

/* ----------------------------------------------------------
	style.css
---------------------------------------------------------- */
/* zen-old-mincho-regular - japanese */
@font-face {
  font-display: swap;
  font-family: 'Zen Old Mincho';
  font-style: normal;
  font-weight: 400;
  src: url('zen-old-mincho-v12-japanese-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* zen-old-mincho-700 - japanese */
@font-face {
  font-display: swap;
  font-family: 'Zen Old Mincho';
  font-style: normal;
  font-weight: 700;
  src: url('zen-old-mincho-v12-japanese-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* zen-old-mincho-900 - japanese */
@font-face {
  font-display: swap;
  font-family: 'Zen Old Mincho';
  font-style: normal;
  font-weight: 900;
  src: url('zen-old-mincho-v12-japanese-900.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* league-script-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'League Script';
  font-style: normal;
  font-weight: 400;
  src: url('league-script-v28-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* ----------------------------------------------------------
 common
---------------------------------------------------------- */


html{ font-size: 62.5%; font-feature-settings: "palt"; }

body {
color: #333;
background-color: #fff;
/* background: url("/info/wp-content/uploads/bg_top01.png") no-repeat top center; */
background-size: cover;
font-family: 'Zen Old Mincho',"Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;;
font-weight: 400;
font-style: normal;
letter-spacing: 1px;
font-size: 16px;
font-size: 1.6rem;
}
/*
@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop, .h2Wrap{ line-height: 1.7 !important; }

}
*/


:root{
	--main-color: #712eaa;
	--main-color-rgb: 113,46,170;
	--contact-color: #c34cb9;
	--yoyaku-color: #2eaa6e;
	/*
	scroll-padding: 80px;
	*/
	scroll-behavior: smooth;
	--header-height: 100px;
}


/* ----------------------------------------------------------
 link
---------------------------------------------------------- */
a:link		{ color: #333; text-decoration: none; }
a:visited	{ color: #333; text-decoration: none; }
a:hover		{ color: var(--main-color); text-decoration: none; }
a:active	{ color: var(--main-color); text-decoration: none; }

a { -ms-filter: "alpha( opacity=60 )"; -webkit-transition: 0.5s ease-in-out; -moz-transition: 0.5s ease-in-out; -o-transition: 0.5s ease-in-out; transition: 0.5s ease-in-out; }


/* ----------------------------------------------------------
 header
---------------------------------------------------------- */
header{ position: fixed; top: 0; width: 100%; height: var(--header-height); z-index: 5; background-color: #fff; box-shadow: 0px 8px 16px -6px rgba(0, 0, 0, 0.1); }
.header_sec{ display: flex; align-items: center; justify-content: space-between; }

.header_logo{ margin-left: 20px; flex-basis: 25%; color: var(--main-color); }
.header_logo a{ display: block; color: var(--main-color); }
.header_logo a:hover{ opacity: .6; }

.header_logo{ font-size: 3rem; font-weight: 700; line-height: 1; }
.header_logo span{ margin-left: 20px; font-size: 1.6rem; vertical-align: middle; font-family: 'League Script'; font-weight: normal; }

.gnavi{ flex-basis: 40%; margin: 0 20px 0 auto ; }
.gnavi ul{ display: flex; }
.gnavi ul li{ flex: 1 0 auto; }
.gnavi ul li a{ position: relative; display: block; line-height: var(--header-height); color: #222; font-size: 2rem; font-weight: 500; text-align: center; letter-spacing: 2px; }
.gnavi ul li a:after{ position: absolute; content: ""; display: block; height: 3px; background-color: var(--main-color); bottom: 15px; left: 0; width: 0; transition: all 0.5s ease; }
.gnavi ul li a:hover::after{ width: 100%; }

.header_btn{ flex-basis: 16%; display: flex; }

.header_contact{ flex-basis: 50%; border-right: 1px solid #fff; }
.header_contact a{ display: block; color: #fff; background-color: var(--contact-color); font-size: 1.8rem; text-align: center; letter-spacing: 2px; line-height: var(--header-height); display: flex; align-items: center; justify-content: center; }
.header_contact a i{ font-size: 2rem; margin-right: 10px; vertical-align: sub; }
.header_contact a:hover{ background-color: #f5f5f5; color: var(--contact-color); }


.header_yoyaku{ flex-basis: 50%; }
.header_yoyaku a{ display: block; color: #fff; background-color: var(--yoyaku-color); font-size: 1.8rem; text-align: center; letter-spacing: 2px; line-height: var(--header-height); display: flex; align-items: center; justify-content: center; }
.header_yoyaku a i{ font-size: 2rem; margin-right: 10px; vertical-align: sub; }
.header_yoyaku a:hover{ background-color: #f5f5f5; color: var(--yoyaku-color); }

#nav-toggle{ display: none; }
#gloval-nav{ display: none; }



/* ----------------------------------------------------------
 footer
---------------------------------------------------------- */

footer{ padding: 60px 0 10px 0; }
.footer_sec{ text-align: center; }

.footer_logo{ font-size: 3rem; font-weight: 700; color: var(--main-color); text-align: center; margin-bottom: 20px; }
.footer_logo a:hover{ opacity: .6; }
.footer_add{ font-size: 1.6rem; margin-bottom: 30px; }

.footer_sns{ margin-bottom: 30px; }
.footer_sns_list{ display: flex; justify-content: center; }
.footer_sns_item{ margin: 0 10px; }
.footer_sns_item i{ font-size: 3.5rem; }
.footer_sns_item a{ color: #777; }
.footer_sns_instagram a:hover{ color: #333; }
.footer_sns_facebook a:hover{ color: #0866ff;  }
.footer_sns_youtube a:hover{ color: #f00; }


.footer_copyright{ font-size: 1rem; margin-bottom: 20px; }


/* ----------------------------------------------------------
 hx
---------------------------------------------------------- */

.h1_wrap{ text-align: center; background: url("/info/wp-content/uploads/bg_h101.jpg") no-repeat center top; background-size: cover; padding: 70px 0; margin-top: var(--header-height); }
.h1_wrap h1{ font-size: 4.5rem; letter-spacing: 3px; color: #fff; font-weight: 700; }
.h1_wrap h1 span{ display: block; color: #fff; font-size: 2.8rem !important; font-family: 'League Script'; text-transform: capitalize; line-height: 1 !important; font-weight: 700; }


.h2_wrap{ margin-bottom: 30px; }
h2{ font-size: 4rem; color: var(--main-color); font-weight: 700; }
h2 span,
.h2_span{ display: block; font-size: 2.8rem !important; font-family: 'League Script'; text-transform: capitalize; line-height: 1 !important; font-weight: 700; color: var(--main-color); }




h3{ font-size: 4rem; color: var(--main-color); font-weight: 700; padding: 20px; border-top: 2px solid  var(--second-color); border-bottom: 2px solid  var(--second-color); margin-bottom: 40px;  }

h4{ position: relative; font-size: 3.2rem; font-weight: 700; margin-bottom: 30px; padding: 0 0 10px 40px; border-bottom: 1px solid #712eaa; }
h4:before{ position: absolute; left: 0; top: 0; font-family: 'icomoon' !important; content: "\e905"; display: block; color: #f38e2d; }
h4 span{ font-size: 2rem; }

h5{ font-size: 2.3rem; color: #712eaa; background-color: #f0e9f5; padding: 10px 15px; border-radius: 10px; margin-bottom: 20px; }


/* ぱんくず */
.breadcrumbs_sec{ letter-spacing: 2px; text-align: center; max-width: 90%; margin: 0 auto; } 
.breadcrumbs_sec > span{ display: inline-block; position: relative; color: #fff; font-size: 1.2rem; }
.breadcrumbs_sec > span span{ margin-left: 15px; }
.breadcrumbs_sec > span a span{ margin-left: 0; }
.breadcrumbs_sec > span:first-child span{ margin-left: 0; }
.breadcrumbs_sec > span br{ display: none; }
.breadcrumbs_sec > span:before{ content: "/"; display: block; position: absolute; top: 0; left: 5px; color: #fff; font-size: 12px; }
.breadcrumbs_sec span:first-child:before{ content: ""; margin-left: 0; }
.breadcrumbs_sec > span a{ color: #fff; font-size: 1.2rem; margin: 0 0 0 20px; }
.breadcrumbs_sec > span:first-child a{ margin: 0 0 0 0; }
.breadcrumbs_sec span a:hover{ opacity: 0.6; }


/* ----------------------------------------------------------
 contents
---------------------------------------------------------- */
.wrapper{ padding-top: var(--header-height); }
.contents{ width: 1200px; margin: 0 auto 100px auto; padding-top: 80px; }


/* ページ内アンカーリンク */
.main_nav{ background-color: #eee; padding: 15px 0; }
.main_nav > nav{ }
.main_nav > nav > ul{ display: flex; justify-content: center; }
.nav_item{ position: relative; color: #fff; font-size: 1.5rem; padding: 0 20px 0 0; }
.nav_item:after{ content: "/"; display: block; position: absolute; top: 0; right: 8px; color: #333; }
.nav_item:last-child:after{ display: none; }
.nav_item a{ color: #333; font-size: 1.5rem; letter-spacing: 2px; }


.top_img{ position: relative; width: 100%; margin: 0 0 60px 0; }
/*
.top_img:before{ position: absolute; content: ""; width: 100%; height: 100%; background: linear-gradient(270deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.6) 100%); z-index: 1; }
*/
.top_img01{  }
.top_img01 img{ width: 100%; height: auto; }

/*
.top_img_catch{ position: absolute; left: 420px; top: 280px; z-index: 2; font-size: 8rem; color: #fff;font-weight: 900; letter-spacing: 3px; line-height: 1.3; text-shadow: black 0 0 5px; }
.top_img_catch span{ font-size: 6.5rem; }
*/


.top_img01_btn01{ width: 350px; }
.top_img01_btn01 a{ display: block; color: var(--contact-color); font-size: 2.2rem; border: 2px solid var(--contact-color); padding: 10px; text-align: center; border-radius: 10px; background-color: #fff; }
.top_img01_btn01 a:hover{ background-color: var(--contact-color); color: #fff; }

/* 癒し空間ユチとは about */
.about{ width: 90%; max-width: 1300px; margin: 0 auto 100px auto; }

.about p{ font-size: 1.7rem; line-height: 2.2; font-weight: 400; letter-spacing: 2px; }
.about img{ border-radius: 10px; }

.about_sec{  }
.about_sec > div{ display: flex; justify-content: space-between; }
.about_sec_txt{ flex-basis: 48% !important; margin: 0 !important; padding: 0 !important; }
.about_sec_img{ flex-basis: 48% !important; margin: 0 !important; padding: 0 !important; }
.about_sec_img img{ border-radius: 10px; }


/* ごあいさつ greeting */
.greeting{ width: 90%; max-width: 1100px; margin: 0 auto 100px auto; }

.greeting p{ font-size: 1.8rem; line-height: 2.2; font-weight: 700; letter-spacing: 2px; }
.greeting img{ border-radius: 10px; }


.greeting_sec{  }
.greeting_sec > div{ display: flex; justify-content: space-between; align-items: center; }
.greeting_sec_txt{ flex-basis: 62% !important; max-width: 62% !important; margin: 0 !important; padding: 0 !important; }
.greeting_sec_img{ flex-basis: 33% !important; margin: 0 !important; padding: 0 !important; }
.greeting_sec_img img{ width: 100%; height: auto; border-radius: 10px; }

.top_btn01{ width: 350px; }
.top_btn01 a{ display: block; color: var(--contact-color); font-size: 2.2rem; border: 2px solid var(--contact-color); padding: 10px; text-align: center; border-radius: 10px; }
.top_btn01 a:hover{ background-color: var(--contact-color); color: #fff; }



/* 主な活動内容 activity */
.bg_activity{ background: url("/info/wp-content/uploads/bg_activity01.jpg") no-repeat top center; background-size: cover; padding: 80px 0 100px 0; }
.activity{ }

.activity .h2_wrap{ width: 90%; max-width: 1100px; margin: 0 auto; text-align: center; }
.bg_activity h2,
.bg_activity h2 span{ color: #fff; }
.activity_sec h2,
.activity_sec h2 span{ color: var(--main-color); }

.activity .h201 span{ display: inline-block !important; }

/*
.activity h3{ width: 90%; max-width: 1100px; margin: 0 auto 10px auto; font-size: 2.5rem; color: #fff; padding: 0 0 10px 0; border-bottom: 1px dotted #ccc; }
*/

.activity_sec h3{ font-size: 2.5rem; color: #333; font-weight: 400; padding: 0; border: 0; margin-bottom: 20px; }

.activity_txt{ width: 90%; max-width: 1100px; margin: 0 auto 40px auto; color: #fff; font-size: 1.7rem; letter-spacing: 2px; line-height: 2.2; }

.activity_img{ width: 90%; margin: 0 auto; }
.activity_img img{ border-radius: 10px; width: 96%; height: auto; }

.activity_img p{ color: #fff; text-align: center; font-size: 3rem; }
.activity_img p span{ font-size: 1.8rem; }

.bg_activity02{ background: url("/info/wp-content/uploads/bg_activity02.jpg") no-repeat top center; background-size: cover; padding: 80px 0; margin-bottom: 80px; }

.p_att01{ background-color: #eee; padding: 15px; text-align: center; font-size: 2.1rem; }


.top_info{ width: 950px; max-width: 90%; margin: 0 auto; padding: 60px 0 80px 0;  }
.top_info .h2_wrap{ text-align: center; }
.top_info_list{}
.top_info_item{ display: flex; align-items: center; border-bottom: 1px solid #ccc; margin-bottom: 10px; padding-bottom: 10px; }
.top_info_item_date{ font-size: 1.6rem; padding: 10px 20px; }
.top_info_item_tit{ font-size: 2rem; padding: 10px; }
.top_info .top_btn01{ margin: 30px auto 0 auto; }



/* お問い合わせ contact */
.contact{ background-color: #f5f5f5; padding: 80px 0 40px 0; }
.contact h2{ text-align: center; }


.tit01{ font-size: 5.5rem; font-weight: 700; letter-spacing: 1px; }

.txt01{ font-size: 1.9rem; letter-spacing: 1px; line-height: 2; }
.txt02{ font-size: 2.1rem; letter-spacing: 1px; line-height: 2.2; }
.txt03{ width: 80%; margin: 0 auto; font-size: 1.7rem; letter-spacing: 2px; line-height: 2.5; }




.yoyaku_btn{ width: 260px; }
.yoyaku_btn a{ display: block; color: #fff; font-size: 1.8rem; font-weight: 700; letter-spacing: 2px; text-align: center; padding: 15px; border-radius: 10px; border: 1px solid var(--yoyaku-color);  background-color: var(--yoyaku-color); }
.yoyaku_btn a:hover{ background-color: #fff; color: var(--yoyaku-color); }



.map_sec{}
.map_sec iframe{ width: 100%; aspect-ratio: 5/5; }

.contact_sec{ max-width: 900px; margin: 0 auto; }

/* フォーム */
.contact_item{display: flex; width: 100%; padding: 20px 20px; border-bottom: 1px solid #ccc;}
.contact_tit{ width: 30%; font-weight: 700; position: relative; padding-left: 80px; }
.contact_tit span.must{ position: absolute; display: block; font-size: 1.5rem; line-height: 1; letter-spacing: 2px; background-color: #E02E30; color: #fff; margin-right: 15px; border: 1px solid #E02E30; padding: 6px 8px; left: 0px; top: -5px; border-radius: 30px; }
.contact_tit span.optional{ position: absolute; display: block; font-size: 1.5rem; line-height: 1; letter-spacing: 2px; background-color: #aaa; color: #fff; margin-right: 15px; border: 1px solid #aaa; padding: 6px 8px; left: 0px; top: -5px; border-radius: 30px; }
.contact_txt,
.contact_adress,
.contact_txtarea{ width: 70%; }
.contact_txt input{font-size: 2rem; background: #f7f7f7; height: 35px; padding: 8px; border: 1px solid #ccc;}
.contact_txtarea textarea{font-size: 2rem; padding: 8px; background: #f7f7f7; border: 1px solid #ccc;}
.contact_adress_sub p{padding: 15px 0;}
.contact_adress input{background: #f7f7f7; border: 1px solid #ccc; height: 35px; margin-left: 15px; font-size: 2rem;}
.contact_submit{border-bottom: none;}
.contact_submit_btn{text-align: center; }
.contact_submit_btn input{ font-weight: 300; background-color: #e47e19; color: #fff; font-size: 1.8rem; 
    letter-spacing: 1px; padding: 15px 30px; cursor: pointer;   -webkit-appearance: none; border-radius: 0;}

input[type="checkbox"]{float: left;}
.contact_check{display: flex;}
.contact_submit .contact_tit{width: 30%;}
.wpcf7-spinner{display: block;}

.contact_submit_btn{ text-align: center; margin-top: 60px; margin-bottom: 60px;  }
.contact_submit_btn input{ background-color: var(--main-color); color: #fff; font-size: 2rem; letter-spacing: 2px; padding: 15px 25px; cursor: pointer; transition: 0.5s ease-in-out; font-weight: 400; font-style: normal; border: 0; }
input.wpcf7-submit:hover{ background-color: #999; }


.contact h4{ font-size: 2.5rem !important; color: #999; font-weight: 500; }
.contact ol{ margin-left: 25px; }
.contact ol li{ list-style-type: decimal; line-height: 1.8; margin-bottom: 5px; }

::placeholder{ color: #999; }


.thanks_sec{ padding-top: 80px; }


/* プロフィール */
.profile_sec{ width: 1100px; margin: 0 auto; }

.table_profile{}
.table_profile table{  }
.table_profile table tr th{ border-bottom: 1px solid #ccc !important; border-top: 0 !important; border-right: 0 !important; border-left: 0 !important; background: none !important; font-size: 1.8rem; font-weight: 700; padding: 15px !important; }
.table_profile table tr td{ border-bottom: 1px solid #ccc !important; border-top: 0 !important; border-right: 0 !important; border-left: 0 !important; font-size: 1.8rem; padding: 15px !important; }

.table_profile table thead{ border-bottom: 2px solid var(--second-color); }

.greeting_sec_txt p{ font-size: 1.8rem; line-height: 2.2; font-weight: 400; letter-spacing: 2px;  }

.alignment_list{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.alignment_item{ flex-basis: 48%; position: relative; display: flex; padding: 0 0 0 30px; margin-bottom: 15px; }
.alignment_item:before{ content: ""; display: block; position: absolute; left: 0; top: 8px; width: 15px; height: 15px; background-color: #8495da; border-radius: 100%;  }
.alignment_tit01{ font-size: 2.2rem; }
.alignment_url01{ margin: 3px 0 0 10px; }
.alignment_url01 a{ display: block; width: 25px; height: 25px; border-radius: 100%; background-color: #2c366e;  text-align: center; }
.alignment_url01 svg{ width: 15px; fill: #fff; }
.alignment_url01 a:hover{ opacity: .6; }

.link_list{ display: flex; flex-wrap: wrap; gap: 20px; }
.link_item{ }
.link_btn01{}
.link_btn01 img{ width: 90%; height: auto; max-width: 300px; max-height: 80px; object-fit: contain; }
.link_btn01 a:hover{ opacity: .6; }


/* 主な活動 */
.activity_sec{}
.activity_sec p{ font-size: 1.8rem; line-height: 2.2; font-weight: 400; letter-spacing: 2px; }

.list_activity01{}
.list_activity01 li{ position: relative; font-size: 2.2rem; padding: 0 0 0 30px; margin-bottom: 10px; }
.list_activity01 li:before{ content: ""; display: block; position: absolute; top: 8px; left: 0; width: 15px; height: 15px; border-radius: 100%; background-color: #8495da; }

.list_activity02{ display: flex; }
.list_activity02 li{ flex: 1 0 auto; position: relative; font-size: 2.2rem; padding: 0 0 0 30px; margin-right: 30px; }
.list_activity02 li:before{ content: ""; display: block; position: absolute; top: 8px; left: 0; width: 15px; height: 15px; border-radius: 100%; background-color: #8495da; }


/* スケジュール */
.schedule_sec{ width: 1100px; margin: 60px auto 80px auto; }
.schedule_sec_list{ }
.schedule_sec_item{ display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid #ccc; }

.schedule_sec_date{ flex-basis: 8%; font-size: 1.6rem; }
.schedule_term{ flex-basis: 15%; padding: 20px 0; }
.schedule_term a{ display: block; color: #fff; font-size: 1.5rem; text-align: center; padding: 3px 10px; border-radius: 40px; }
.schedule_term a:hover{ opacity: .6; }
.cat_1day01 a{ background-color: #f85e7b; }
.cat_bts01 a{ background-color: #58b06f; }
.cat_event01 a{ background-color: #b5c036; }
.cat_counseling01 a{ background-color: #4c789a; }
.cat_healing01 a{ background-color: #5eb2ca; }
.cat_kouza01 a{ background-color: #c05736; }

.schedule_sec_tit01{ flex-basis: 70%; font-size: 2rem; }
.schedule_sec_tit01 a:hover{ opacity: .6; }


.pagination{ text-align: center; margin: 40px auto; }
.wp-pagenavi{ clear: both; }
.wp-pagenavi a,
.wp-pagenavi span{ text-decoration: none; border: 1px solid var(--main-color) !important; padding: 5px 10px !important; margin: 2px; border-radius: 5px; color: var(--main-color); font-size: 1.7rem !important; font-weight: 700; }
.wp-pagenavi a:hover, .wp-pagenavi span.current{ border-color: #000; }
.wp-pagenavi span.current{ font-weight: bold; background-color: var(--main-color) !important; color: #fff; }


.schedule_single_sec{ width: 1100px; margin: 60px auto 100px auto; }
.schedule_single_date{ display: flex; align-items: center; }
.schedule_sec_date01{ margin-right: 10px; }
.schedule_single_date .schedule_term{}

.schedule_single_sec01{}
.schedule_single_sec01 p{ font-size: 1.6rem; letter-spacing: 2px; line-height: 1.6; margin-bottom: 30px; }
.schedule_single_sec01 h2{ position: relative; font-size: 3.2rem; font-weight: 700; margin-bottom: 30px; padding: 0 0 10px 40px; border-bottom: 1px solid #712eaa; }
.schedule_single_sec01 h2:before{ position: absolute; left: 0; top: 0; font-family: 'icomoon' !important; content: "\e905"; display: block; color: #f38e2d; }

.schedule_single_sec01 h3{ font-size: 2.3rem; color: #712eaa; background-color: #f0e9f5; padding: 10px 15px; border-radius: 10px; margin-bottom: 20px; }

.schedule_single_sec01 h4{ position: relative; color: #8495da; font-size: 2.3rem; padding: 0 0 0 30px; margin-bottom: 20px; border-bottom: 0; }
.schedule_single_sec01 h4:before{ position: absolute; content: ""; display: block; left: 0; top: 10px; width: 15px; height: 15px; background-color: #8495da; border-radius: 100%; }

.schedule_single_sec01 .wp-block-button{ width: 600px; margin: 0 auto; }
.schedule_single_sec01 .wp-block-button a{ display: block; color: #fff; background-color: #712eaa; border: 1px solid #712eaa; font-size: 2rem; text-align: center; border-radius: 10px; }
.schedule_single_sec01 .wp-block-button a:hover{ color: #712eaa; background-color: #fff; }

/* 料金 */
.price_sec{ width: 1000px; margin: 0 auto; }
.price_list{ margin-top: 30px; }
.price_item{ display: flex; align-items: center; border-bottom: 1px solid #ccc; padding: 15px 0; }
.price_tit01{ flex-basis: 60%; position: relative; font-size: 2.6rem; padding: 0 0 0 30px; }
.price_tit01:before{ position: absolute; content: ""; display: block; width: 10px; height: 10px; background-color: #e1df2e; border-radius: 100px; left: 0; top: 15px; }
.price_time01{ flex-basis: 20%; font-size: 2rem; }
.price_time01 span{ font-size: 1.6rem; color: #fff; background-color: #35994f; border-radius: 40px; padding: 3px 10px; margin-right: 10px; }
.price_price01{ flex-basis: 20%; font-size: 2rem; }
.price_price01 span{ font-size: 1.6rem; color: #fff; background-color: #3f75b8; border-radius: 40px; padding: 3px 10px; margin-right: 10px; }

.plan_txt01{ font-size: 2rem; }

.news_sec{ width: 90%; max-width: 1000px; margin: 60px auto; }
.news_sec p{ font-size: 1.8rem; letter-spacing: 2px; line-height: 1.6; margin-bottom: 20px; }
.news_sec_list{}
.news_sec_item{ display: flex; align-items: center; border-bottom: 1px solid #ccc; }
.news_sec_date{ font-size: 1.6rem; margin-right: 20px; }
.news_sec_tit01{ font-size: 2rem; }
.news_sec_tit01 a{ display: block; padding: 20px 0; }

.news_single_sec{ width: 90%; max-width: 1000px; margin: 60px auto; }
.news_single_sec h2{ line-height: 1.3; }
.news_single_sec01{}
.news_single_sec01 p{ font-size: 1.8rem; letter-spacing: 2px; line-height: 1.8; margin-bottom: 20px; }


/* ----------------------------------------------------------
 SP CSS
---------------------------------------------------------- */
@media screen and (max-width: 520px){
img,video {
  max-width: 100%;
  height: auto;
}

/* フォントサイズ10px=62.5% */
html{ font-size: 60%; scroll-padding-top: 80px; }

/* 基本のフォントサイズ */
body{ font-size: 1.8rem; height: auto !important; height: 100%; padding-top: 0; }

/* 非表示用 */
.noneSP		{ display: none !important; }


/* ----------------------------------------------------------
 header
---------------------------------------------------------- */

header{ position: fixed; width: 100%; z-index: 5; height: calc(var(--header-height) - 40px); background-color: #fff; box-shadow: 0px 8px 16px -6px rgba(0,0,0,0.1); }
.header_sec{ height: 60px; }
	
.header_logo{ margin-left: 10px; flex-basis: 48%; color: var(--main-color); }
.header_logo a{ display: block; color: var(--main-color); }
.header_logo a:hover{ opacity: .6; }
.header_logo img{ max-width: 180px; height: auto; }



.gnavi{ display: none; }
.header_contact{ display: none; }
.header_yoyaku{ display: none; }


#nav-toggle {
display: block !important;
position: fixed;
top: 10px;
right: 10px;
width: 40px;
height: 40px;
cursor: pointer;
background-color: var(--main-color);
padding: 11px;
}
#nav-toggle > div {
  position: relative;
  width: 20px;
}
#nav-toggle span {
  width: 100%;
  height: 2px;
  left: 0;
  display: block;
  background: #fff;
  position: absolute;
  transition: transform 0.6s ease-in-out, top 0.5s ease;
}
#nav-toggle span:nth-child(1){ top: 0; }
#nav-toggle span:nth-child(2){ top: 7px; }
#nav-toggle span:nth-child(3){ top: 14px; }

.open #nav-toggle span{ background: #fff; }
.open #nav-toggle span:nth-child(1){ top: 7px; transform: rotate(45deg); }
.open #nav-toggle span:nth-child(2){ top: 14px; width: 0; left: 50%; }
.open #nav-toggle span:nth-child(3){ top: 7px; transform: rotate(-45deg); }

#gloval-nav{
	background-color: rgba(0,0,0,.7);
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	text-align: center;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	font-size: 20px;
	transform: translateX(-100%);
	transition: opacity 0.6s ease, visibility 0.6s ease;
	padding-top: 40px;
}

#gloval-nav a {
	display: block;
	color: #fff;
	padding: 20px 0;
	transition: color 0.6s ease;
	font-size: 2rem;
}
#gloval-nav ul{ display: flex; flex-wrap: wrap !important; justify-content: flex-start !important; }
#gloval-nav .gnavi__list{ padding: 0; height: auto; }
#gloval-nav ul li{
  opacity: 0;
  transform: translateX(-200px);
  transition: transform 0.6s ease, opacity 0.2s ease;
  flex-basis: 100%;
}
#gloval-nav ul li:nth-child(2){ transition-delay: 0.15s; }
#gloval-nav ul li:nth-child(3){ transition-delay: 0.3s; }
#gloval-nav ul li:nth-child(4){ transition-delay: 0.45s; }
#gloval-nav ul li:nth-child(5){ transition-delay: 0.6s; }
#gloval-nav ul li:nth-child(6){ transition-delay: 0.75s; }
#gloval-nav ul li:nth-child(7){ transition-delay: 0.9s; }
#gloval-nav ul li:nth-child(8){ transition-delay: 1.05s; }

/* open */
.open{ overflow: hidden; }
.open #gloval-nav {
	visibility: visible;
	transform: translateX(0);
	transition: transform 0.6s;
}
.open #gloval-nav li {
	opacity: 1;
	transform: translateX(0);
	transition: transform 1s ease, opacity 0.9s ease;
}

#nav-toggle{ z-index: 100; }
#gloval-nav{ z-index: 10; }



/* ----------------------------------------------------------
 footer
---------------------------------------------------------- */
/* ページ下部 固定メニュー */
.btm_menu { position: fixed; bottom: -50px; width: 100%; border-top: 1px solid #fff; z-index: 99; }
.btm_menu li { float: left; width: 50%; }
.btm_menu li:first-child a { border-right: 1px solid #fff; }
.btm_menu li a{ display: block; height: 50px; text-align: center; font-size: 1.6rem; padding: 15px 5px 5px; background-color: var(--main-color); color: #fff; transition: .5s;}
.btm_menu li:nth-child(1) a{ background-color: var(--contact-color); }
.btm_menu li:nth-child(2) a{ background-color: var(--yoyaku-color); }
.btm_menu li a i{ font-size: 1.8rem; margin-right: 10px; }
.btm_menu li a:hover { background-color: #fff; color: #313F73; transition: .5s;}
.btm_menu ul:after { content: ''; clear: both; display: block; }

.grecaptcha-badge{ bottom: 70px !important; }


/* ----------------------------------------------------------
 hx
---------------------------------------------------------- */
.h1_wrap{ padding: 30px 0; margin-top: 60px; }
.h1_wrap h1{ font-size: 3.5rem; }
.h1_wrap h1 span{ font-size: 2rem !important; }


.h2_wrap{ margin-bottom: 20px; }
h2{ font-size: 3rem; color: var(--main-color); font-weight: 700; line-height: 1.3; }
h2 span,
.h2_span{ display: block; font-size: 2.2rem !important; font-family: 'League Script'; text-transform: capitalize; line-height: 1 !important; font-weight: 700; color: var(--main-color); }

.activity .h201 span{ display: inline-block !important; }


h3{ font-size: 2.9rem; color: var(--main-color); font-weight: 700; padding: 20px; border-top: 2px solid  var(--second-color); border-bottom: 2px solid  var(--second-color); margin-bottom: 40px;  }

h4{ position: relative; font-size: 2rem; font-weight: 700; margin-bottom: 30px; padding: 0 0 10px 30px; border-bottom: 1px solid #712eaa; }
h4:before{ position: absolute; left: 0; top: 0; font-family: 'icomoon' !important; content: "\e905"; display: block; color: #f38e2d; }
h4 span{ font-size: 1.5rem; }

    
/* ----------------------------------------------------------
 contents
---------------------------------------------------------- */
.wrapper{ /* padding-top: var(--header-height); */ padding-top: 60px; }
.contents{ width: 100%; margin: 0 auto 100px auto; padding-top: 0; }

.top_img{ position: relative; width: 100%; margin: 0 0 20px 0; }
/*
.top_img:before{ position: absolute; content: ""; width: 100%; height: 100%; background: linear-gradient(270deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.6) 100%); z-index: 1; }
*/


/* ページ内アンカーリンク */
.main_nav{ padding: 15px; }
.main_nav > nav{ }
.main_nav > nav > ul{ flex-wrap: wrap; }



.top_img01_btn01{ width: 300px; margin: 0 auto; }
.top_img01_btn01 a{ display: block; color: var(--contact-color); font-size: 1.8rem; border: 2px solid var(--contact-color); padding: 10px; text-align: center; border-radius: 10px; background-color: #fff; }
.top_img01_btn01 a:hover{ background-color: var(--contact-color); color: #fff; }


/* 癒し空間ユチとは about */
.about{ width: 90%; max-width: 1300px; margin: 0 auto 100px auto; }

.about p{ font-size: 1.7rem; line-height: 2.2; font-weight: 700; letter-spacing: 2px; }
.about img{ border-radius: 10px; }

.about_sec{  }
.about_sec > div{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.about_sec_txt{ flex-basis: 100% !important; margin: 0 !important; padding: 0 !important; }
.about_sec_img{ flex-basis: 100% !important; margin: 0 !important; padding: 0 !important; }
.about_sec_img img{ border-radius: 10px; }


/* ごあいさつ greeting */
.greeting{ width: 90%; max-width: 1100px; margin: 0 auto 100px auto; }

.greeting p{ font-size: 1.8rem; line-height: 2.2; font-weight: 700; letter-spacing: 2px; }
.greeting img{ border-radius: 10px; }


.greeting_sec{  }
.greeting_sec > div{ display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; }
.greeting_sec_txt{ flex-basis: 100% !important; max-width: 100% !important; margin: 0 !important; padding: 0 !important; }
.greeting_sec_img{ flex-basis: 100% !important; margin: 0 !important; padding: 0 !important; text-align: center; }
.greeting_sec_img img{ width: 60%; height: auto; border-radius: 10px; margin-top: 20px; }




/* 経歴・プロフィール profile */
.profile{  }

.table_profile{}
.table_profile table{  }
.table_profile table tr th{ border-bottom: 1px solid #ccc !important; border-top: 0 !important; border-right: 0 !important; border-left: 0 !important; background: none !important; font-size: 1.8rem; font-weight: 700; padding: 15px !important; }
.table_profile table tr td{ border-bottom: 1px solid #ccc !important; border-top: 0 !important; border-right: 0 !important; border-left: 0 !important; font-size: 1.8rem; padding: 15px !important; }

.table_profile table thead{ border-bottom: 2px solid var(--second-color); }


.top_btn01{ width: 300px; margin: 70px auto 0 auto; }
.top_btn01 a{ display: block; color: var(--contact-color); font-size: 1.8rem; border: 2px solid var(--contact-color); padding: 10px; text-align: center; border-radius: 10px; }
.top_btn01 a:hover{ background-color: var(--contact-color); color: #fff; }



/* 主な活動内容 activity */
.bg_activity{ background: url("/info/wp-content/uploads/bg_activity01.jpg") no-repeat top center; background-size: cover; padding: 80px 0 100px 0; }
.activity{ }

.bg_activity .h2_wrap{ width: 90%; max-width: 1100px; margin: 0 auto; }
.bg_activity h2,
.bg_activity h2 span{ color: #fff; }

.bg_activity h3{ width: 90%; max-width: 1100px; margin: 0 auto 10px auto; font-size: 2.5rem; color: #fff; padding: 0 0 10px 0; border-bottom: 1px dotted #ccc; }

.activity_txt{ width: 90%; max-width: 1100px; margin: 0 auto 40px auto; color: #fff; font-size: 1.7rem; letter-spacing: 2px; line-height: 2.2; }

.activity_img{ width: 90%; margin: 0 auto; }
.activity_img img{ border-radius: 10px; width: 100%; height: auto; }


.bg_activity02{ background: url("/info/wp-content/uploads/bg_activity02.jpg") no-repeat top center; background-size: cover; padding: 80px 0; margin-bottom: 0; }


.activity_img p{ color: #fff; text-align: center; font-size: 2rem; }
.activity_img p span{ font-size: 1.4rem; }
	
.activity_sec{ width: 90%; margin: 60px auto; }

.activity_sec p{ font-size: 1.6rem; line-height: 1.6; font-weight: 400; letter-spacing: 2px; }

/* 主な活動 */
.activity_sec{}
.activity_sec p{ font-size: 1.8rem; line-height: 2.2; font-weight: 700; letter-spacing: 2px; }

.list_activity01{}
.list_activity01 li{ position: relative; font-size: 1.8rem; padding: 0 0 0 30px; margin-bottom: 10px; }
.list_activity01 li:before{ content: ""; display: block; position: absolute; top: 6px; left: 0; width: 12px; height: 12px; border-radius: 100%; background-color: #8495da; }

.list_activity02{ display: flex; flex-wrap: wrap; }
.list_activity02 li{ flex: 1 0 auto; position: relative; font-size: 2rem; padding: 0 0 0 30px; margin-right: 30px; }
.list_activity02 li:before{ content: ""; display: block; position: absolute; top: 8px; left: 0; width: 15px; height: 15px; border-radius: 100%; background-color: #8495da; }

.p_att01{ background-color: #eee; padding: 15px; text-align: center; font-size: 1.7rem !important; line-height: 1.3 !important; }


/* スケジュール */
.schedule_sec{ width: 90%; margin: 60px auto 80px auto; }
.schedule_sec_list{  }
.schedule_sec_item{ flex-wrap: wrap; justify-content: flex-start; margin-bottom: 10px; }

.schedule_sec_date{ flex-basis: 8%; font-size: 1.6rem; margin-right: 20px; }
.schedule_term{ flex-basis: 38%; padding: 0; }
.schedule_term a{ display: block; color: #fff; font-size: 1.5rem; text-align: center; padding: 3px 10px; border-radius: 40px; }

.schedule_sec_tit01{ flex-basis: 100%; font-size: 1.8rem; line-height: 1.4; }
.schedule_sec_tit01 a{ display: block; padding: 10px 0; }
.schedule_sec_tit01 a:hover{ opacity: .6; }


.schedule_single_sec{ width: 90%; margin: 60px auto 100px auto; }
.schedule_single_date{ display: flex; align-items: center; margin-bottom: 10px; }
.schedule_sec_date01{ margin-right: 10px; }
.schedule_single_date .schedule_term{}


.schedule_single_sec01{}
.schedule_single_sec01 p{ font-size: 1.6rem; letter-spacing: 2px; line-height: 1.6; margin-bottom: 30px; }
.schedule_single_sec01 h2{ position: relative; font-size: 2.2rem; font-weight: 700; margin-bottom: 20px; padding: 0 0 10px 40px; border-bottom: 1px solid #712eaa; }
.schedule_single_sec01 h2:before{ position: absolute; left: 0; top: 0; font-family: 'icomoon' !important; content: "\e905"; display: block; color: #f38e2d; }

.schedule_single_sec01 h3{ font-size: 2.1rem; color: #712eaa; background-color: #f0e9f5; padding: 10px 15px; border-radius: 10px; margin-bottom: 20px; }

.schedule_single_sec01 h4{ position: relative; color: #8495da; font-size: 2rem; padding: 0 0 0 30px; margin-bottom: 20px; border-bottom: 0; }
.schedule_single_sec01 h4:before{ position: absolute; content: ""; display: block; left: 0; top: 10px; width: 15px; height: 15px; background-color: #8495da; border-radius: 100%; }

/* 料金 */
.price_sec{ width: 90%; margin: 60px auto; }
.price_list{ margin-top: 30px; }
.price_item{ flex-wrap: wrap;  padding: 15px 0; }
.price_tit01{ flex-basis: 100%; position: relative; font-size: 2.6rem; font-weight: 700; padding: 0 0 0 30px; }
.price_tit01:before{ position: absolute; content: ""; display: block; width: 10px; height: 10px; background-color: #e1df2e; border-radius: 100px; left: 0; top: 15px; }
.price_time01{ flex-basis: 50%; font-size: 2rem; }
.price_time01 span{ font-size: 1.6rem; color: #fff; background-color: #35994f; border-radius: 40px; padding: 3px 10px; margin-right: 10px; }
.price_price01{ flex-basis: 50%; font-size: 2rem; }
.price_price01 span{ font-size: 1.6rem; color: #fff; background-color: #3f75b8; border-radius: 40px; padding: 3px 10px; margin-right: 10px; }

.plan_txt01{ font-size: 1.6rem; margin-bottom: 5px; }





.lucky_sec{ width: 90%; max-width: 1200px; background-color: #fff; border-radius: 10px; margin: 0 auto 40px auto; padding: 20px; }
.lucky_sec01{ border: 1px dashed #d4c0e5; border-radius: 10px; padding: 20px; }
.lucky_sec_tit{ display: flex; flex-wrap: wrap; }
.lucky_sec_ico01{ color: var(--main-color); font-size: 2rem; margin-right: 10px; }
.lucky_sec_tit01{ font-size: 2rem; color: var(--main-color); font-family: 'League Script'; }
.lucky_sec_tit02{ flex-basis: 100%; margin-top: 5px; margin-bottom: 20px; }
.lucky_sec_tit02 h2{ font-size: 3rem; line-height: 1.2; letter-spacing: 3px; }
.lucky_sec h3{ margin: 0 auto 20px auto; font-size: 2.3rem; color: var(--main-color); padding: 10px 10px; background-color: #f5f5f5; border-radius: 10px; }
.lucky_sec h4{ font-size: 2rem; border-bottom: 1px solid #ccc; padding-bottom: 5px; margin-bottom: 5px; }
.lucky_sec_list{ display: flex; justify-content: space-between; flex-wrap: wrap; margin-bottom: 40px; }
.lucky_sec_item{ flex-basis: 100%; margin-bottom: 20px; }



/* 料金表 price */
.price{  }
.column02{ width: 100%; max-width: 1100px; margin: 0 auto 20px auto; padding-top: 40px; }
.column02_list{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.column02_item{ flex-basis: 90%; width: 90%; margin: 0 auto 30px auto; padding-top: 20px; }
.column02_item:nth-child(1){ padding-bottom: 60px; border-bottom: 1px solid #ccc; }
.column02_item ul{ margin-left: 30px; }
.column02_item li{ list-style-type: disc; }

/* 講座 course */

/* お問い合わせ contact */
.contact{ background-color: #eee; padding: 80px 0 30px 0; }
.contact h2{ text-align: center; }


.tit01{ font-size: 5.5rem; font-weight: 700; letter-spacing: 1px; }

.txt01{ font-size: 1.9rem; letter-spacing: 1px; line-height: 2; }
.txt02{ font-size: 2.1rem; letter-spacing: 1px; line-height: 2.2; }
.txt03{ width: 80%; margin: 0 auto; font-size: 1.7rem; letter-spacing: 2px; line-height: 2.5; }




.yoyaku_btn{ width: 260px; }
.yoyaku_btn a{ display: block; color: #fff; font-size: 1.8rem; font-weight: 700; letter-spacing: 2px; text-align: center; padding: 15px; border-radius: 10px; border: 1px solid var(--yoyaku-color);  background-color: var(--yoyaku-color); }
.yoyaku_btn a:hover{ background-color: #fff; color: var(--yoyaku-color); }



.map_sec{}
.map_sec iframe{ width: 100%; aspect-ratio: 5/5; }

.contact_sec{ width: 90%; margin: 0 auto; }

/* フォーム */

.contact_item{flex-wrap: wrap; width: 100%; padding: 20px 20px; border-bottom: 1px solid #ccc;}
.contact_tit{ flex-basis: 100%; width: 100%; font-weight: 700; position: relative; margin-left: 0; margin-bottom: 5px; }
.contact_tit span{ position: initial; margin-right: 15px; padding: 2px 6px; left: 0; top: 0px; font-size: 1.4rem; }
.contact_txt,
.contact_adress,
.contact_txtarea{ width: 100%;}
.contact_txt input{ flex-basis: 100%; width: 100%; font-size: 2rem; background: #f7f7f7; height: 35px; padding: 8px; border: 1px solid #ccc; }
.contact_txtarea textarea{ width: 100%; font-size: 2rem; padding: 8px; background: #f7f7f7; border: 1px solid #ccc;}
.contact_adress_sub p{padding: 10px 0;}
.contact_adress input{ width: 100%; background: #f7f7f7; border: 1px solid #ccc; height: 35px; margin-left: 0; font-size: 2rem;}
.contact_submit{border-bottom: none;}
.contact_submit_btn{text-align: center; }
.contact_submit_btn input{ font-weight: 300; background-color: #e47e19; color: #fff; font-size: 1.8rem; 
    letter-spacing: 1px; padding: 15px 30px; cursor: pointer;   -webkit-appearance: none; border-radius: 0;}

input[type="checkbox"]{float: left;}
.contact_check{display: flex;}
.contact_submit .contact_tit{width: 30%;}
.wpcf7-spinner{display: block;}




.contact_submit_btn{ text-align: center; margin: 60px auto; }
.contact_submit_btn input{ background-color: var(--main-color); color: #fff; font-size: 2rem; letter-spacing: 2px; padding: 15px 25px; cursor: pointer; transition: 0.5s ease-in-out; font-family: source-han-sans-japanese, sans-serif; font-weight: 400; font-style: normal; border: 0; width: 100%; }
input.wpcf7-submit:hover{ background-color: #999; }

.privacy_sec{}
.privacy_sec h3{ font-size: 2.4rem !important; color: #999; font-weight: normal; }
.privacy_sec ol{ margin-left: 25px; }
.privacy_sec ol li{ list-style-type: decimal; line-height: 1.8; margin-bottom: 5px; }

::placeholder{ color: #999; }


.thanks_sec{ padding-top: 80px; width: 90%; margin: 0 auto; }


/* プロフィール */
.profile_sec{ width: 90%; margin: 60px auto; }


.top_info{ width: 950px; max-width: 90%; margin: 0 auto; padding: 60px 0 80px 0;  }
.top_info .h2_wrap{ text-align: center; }
.top_info_list{}
.top_info_item{ display: flex; align-items: center; flex-wrap: wrap; border-bottom: 1px solid #ccc; margin-bottom: 10px; padding-bottom: 10px; }
.top_info_item_date{ font-size: 1.4rem; padding: 10px 0 0 0; }
.top_info_item_tit{ flex-basis: 100%; font-size: 1.8rem; padding: 10px 0; }
.top_info .top_btn01{ margin: 30px auto 0 auto; }



.news_sec{ max-width: 1000px; width: 90%; margin: 60px auto 40px auto; }
.news_sec_list{}
.news_sec_item{ display: flex; align-items: center; flex-wrap: wrap; border-bottom: 1px solid #ccc; margin-bottom: 10px; }
.news_sec_date{ flex-basis: 100%; font-size: 1.4rem; margin-right: 0px; }
.news_sec_tit01{ flex-basis: 100%; font-size: 1.8rem; }
.news_sec_tit01 a{ display: block; padding: 10px 0 20px 0; }



.alignment_list{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.alignment_item{ flex-basis: 100%; position: relative; display: flex; padding: 0 0 0 30px; margin-bottom: 15px; }
.alignment_item:before{ content: ""; display: block; position: absolute; left: 0; top: 10px; width: 12px; height: 12px; background-color: #8495da; border-radius: 100%;  }
.alignment_tit01{ font-size: 1.6rem; }
.alignment_url01{ margin: 3px 0 0 10px; }
.alignment_url01 a{ display: block; width: 25px; height: 25px; border-radius: 100%; background-color: #2c366e;  text-align: center; }
.alignment_url01 svg{ width: 15px; fill: #fff; }
.alignment_url01 a:hover{ opacity: .6; }



.link_list{ display: flex; flex-wrap: wrap; gap: 20px; }
.link_item{ }
.link_btn01{}
.link_btn01 img{ width: 80%; height: auto; }
.link_btn01 a:hover{ opacity: .6; }


}

/* ----------------------------------------------------------
 SP CSS END
---------------------------------------------------------- */

/* ----------------------------------------------------------
 TAB CSS
---------------------------------------------------------- */
@media screen and (min-width: 521px) and (max-width: 1024px){

img,video {
  max-width: 100%;
  height: auto;
}

/* フォントサイズ10px=62.5% */
html{ font-size: 50%; scroll-padding-top: 80px; }

/* 基本のフォントサイズ */
body{ font-size: 1.8rem; padding-top: 0; }

/* 非表示用 */
.noneTAB		{ display: none !important; }

/* ----------------------------------------------------------
 header
---------------------------------------------------------- */
header{ position: fixed; top: 0; width: 100%; height: 60px; z-index: 5; background-color: #fff; box-shadow: 0px 8px 16px -6px rgba(0, 0, 0, 0.1); }
.header_sec{ display: flex; align-items: center; justify-content: space-between; }

.header_logo{ margin-left: 20px; flex-basis: 30%; color: var(--main-color); margin-top: 10px; }
.header_logo a{ display: block; color: var(--main-color); }
.header_logo a:hover{ opacity: .6; }
.header_logo img{ width: 100%; height: auto; max-width: 180px; }


.gnavi{ display: none; }

.header_btn{ display: none; }

.header_contact{ display: none; } 
.header_yoyaku{ display: none; }


#nav-toggle {
display: block !important;
position: fixed;
top: 10px;
right: 10px;
width: 40px;
height: 40px;
cursor: pointer;
background-color: var(--main-color);
padding: 11px;
}
#nav-toggle > div {
  position: relative;
  width: 20px;
}
#nav-toggle span {
  width: 100%;
  height: 2px;
  left: 0;
  display: block;
  background: #fff;
  position: absolute;
  transition: transform 0.6s ease-in-out, top 0.5s ease;
}
#nav-toggle span:nth-child(1){ top: 0; }
#nav-toggle span:nth-child(2){ top: 7px; }
#nav-toggle span:nth-child(3){ top: 14px; }

.open #nav-toggle span{ background: #fff; }
.open #nav-toggle span:nth-child(1){ top: 7px; transform: rotate(45deg); }
.open #nav-toggle span:nth-child(2){ top: 14px; width: 0; left: 50%; }
.open #nav-toggle span:nth-child(3){ top: 7px; transform: rotate(-45deg); }

#gloval-nav{
	background-color: rgba(0,0,0,.7);
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	text-align: center;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	font-size: 20px;
	transform: translateX(-100%);
	transition: opacity 0.6s ease, visibility 0.6s ease;
	padding-top: 40px;
}

#gloval-nav a {
	display: block;
	color: #fff;
	padding: 20px 0;
	transition: color 0.6s ease;
	font-size: 2rem;
}
#gloval-nav ul{ display: flex; flex-wrap: wrap !important; justify-content: flex-start !important; }
#gloval-nav .gnavi__list{ padding: 0; height: auto; }
#gloval-nav ul li{
  opacity: 0;
  transform: translateX(-200px);
  transition: transform 0.6s ease, opacity 0.2s ease;
  flex-basis: 100%;
}
#gloval-nav ul li:nth-child(2){ transition-delay: 0.15s; }
#gloval-nav ul li:nth-child(3){ transition-delay: 0.3s; }
#gloval-nav ul li:nth-child(4){ transition-delay: 0.45s; }
#gloval-nav ul li:nth-child(5){ transition-delay: 0.6s; }
#gloval-nav ul li:nth-child(6){ transition-delay: 0.75s; }
#gloval-nav ul li:nth-child(7){ transition-delay: 0.9s; }
#gloval-nav ul li:nth-child(8){ transition-delay: 1.05s; }

/* open */
.open{ overflow: hidden; }
.open #gloval-nav {
	visibility: visible;
	transform: translateX(0);
	transition: transform 0.6s;
}
.open #gloval-nav li {
	opacity: 1;
	transform: translateX(0);
	transition: transform 1s ease, opacity 0.9s ease;
}

#nav-toggle{ z-index: 100; }
#gloval-nav{ z-index: 10; }


/* ----------------------------------------------------------
 footer
---------------------------------------------------------- */
/* ページ下部 固定メニュー */
.btm_menu { display: none; }



/* ----------------------------------------------------------
 hx
---------------------------------------------------------- */
.h1_wrap{ text-align: center; background: url("/info/wp-content/uploads/bg_h101.jpg") no-repeat center top; background-size: cover; padding: 30px 0; margin-top: 60px; }
.h1_wrap h1{ font-size: 4.5rem; letter-spacing: 3px; color: #fff; font-weight: 700; }
.h1_wrap h1 span{ display: block; color: #fff; font-size: 2.8rem !important; font-family: 'League Script'; text-transform: capitalize; line-height: 1 !important; font-weight: 700; }


.h2_wrap{ margin-bottom: 30px; }
h2{ font-size: 3rem; color: var(--main-color); font-weight: 700; }
h2 span,
.h2_span{ display: block; font-size: 2.2rem !important; font-family: 'League Script'; text-transform: capitalize; line-height: 1 !important; font-weight: 700; color: var(--main-color); }

.activity .h201 span{ display: inline-block !important; }


h3{ font-size: 4rem; color: var(--main-color); font-weight: 700; padding: 20px; border-top: 2px solid  var(--second-color); border-bottom: 2px solid  var(--second-color); margin-bottom: 40px;  }

h4{ position: relative; font-size: 2.7rem; font-weight: 700; margin-bottom: 30px; padding: 0 0 10px 30px; border-bottom: 1px solid #712eaa; }
h4:before{ position: absolute; left: 0; top: 0; font-family: 'icomoon' !important; content: "\e905"; display: block; color: #f38e2d; }
h4 span{ font-size: 1.8rem; }

h5{ font-size: 2.3rem; color: #712eaa; background-color: #f0e9f5; padding: 10px 15px; border-radius: 10px; margin-bottom: 20px; }


/* ぱんくず */
.breadcrumbs_sec{ letter-spacing: 2px; text-align: center; } 
.breadcrumbs_sec > span{ display: inline-block; position: relative; color: #fff; font-size: 1.2rem; }
.breadcrumbs_sec > span span{ margin-left: 15px; }
.breadcrumbs_sec > span a span{ margin-left: 0; }
.breadcrumbs_sec > span:first-child span{ margin-left: 0; }
.breadcrumbs_sec > span br{ display: none; }
.breadcrumbs_sec > span:before{ content: "/"; display: block; position: absolute; top: 0; left: 5px; color: #fff; font-size: 12px; }
.breadcrumbs_sec span:first-child:before{ content: ""; margin-left: 0; }
.breadcrumbs_sec > span a{ color: #fff; font-size: 1.2rem; margin: 0 0 0 20px; }
.breadcrumbs_sec > span:first-child a{ margin: 0 0 0 0; }
.breadcrumbs_sec span a:hover{ opacity: 0.6; }


/* ----------------------------------------------------------
 contents
---------------------------------------------------------- */

.wrapper{ padding-top: 60px; }
.contents{ width: 90%; margin: 0 auto 100px auto; padding-top: 0; }

.top_img{ padding-top: 0px; margin: 0 0 30px 0; }


/* 癒し空間ユチとは about */
.about{ width: 90%; margin: 0 auto 100px auto; }

.about p{ font-size: 1.7rem; line-height: 2.2; font-weight: 700; letter-spacing: 2px; }
.about img{ border-radius: 10px; }

.about_sec{  }
.about_sec > div{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.about_sec_txt{ flex-basis: 100% !important; margin: 0 !important; padding: 0 !important; margin-bottom: 20px; }
.about_sec_img{ flex-basis: 100% !important; margin: 0 !important; padding: 0 !important; text-align: center; }
.about_sec_img img{ border-radius: 10px; width: 420px; height: 280px; }

.top_btn01{ margin: 60px auto 0 auto; }




/* ごあいさつ greeting */
.greeting{ width: 90%; max-width: 1100px; margin: 0 auto 100px auto; }

.greeting p{ font-size: 1.8rem; line-height: 2.2; font-weight: 700; letter-spacing: 2px; }
.greeting img{ border-radius: 10px; }


.greeting_sec{  }
.greeting_sec > div{ display: flex; justify-content: space-between; align-items: center; }
.greeting_sec_txt{ flex-basis: 62% !important; max-width: 62% !important; margin: 0 !important; padding: 0 !important; }
.greeting_sec_img{ flex-basis: 33% !important; margin: 0 !important; padding: 0 !important; }
.greeting_sec_img img{ width: 100%; height: auto; border-radius: 10px; }


/* 経歴・プロフィール profile */
.profile{ }

.table_profile{}
.table_profile table{  }
.table_profile table tr th{ display: block; width: 100%; border-bottom: 0px solid #ccc !important; border-top: 0 !important; border-right: 0 !important; border-left: 0 !important; background: #f5f5f5 !important; font-size: 1.8rem; font-weight: 700; padding: 5px 15px !important; margin-top: 10px; }
.table_profile table tr td{ display: block; width: 100%; border-bottom: 1px solid #ccc !important; border-top: 0 !important; border-right: 0 !important; border-left: 0 !important; font-size: 1.8rem; padding: 5px 0 15px 0 !important; }

.table_profile table th{ width: 20% !important; }

.alignment_list{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.alignment_item{ flex-basis: 100%; position: relative; display: flex; padding: 0 0 0 30px; margin-bottom: 15px; }
.alignment_item:before{ content: ""; display: block; position: absolute; left: 0; top: 8px; width: 15px; height: 15px; background-color: #8495da; border-radius: 100%;  }
.alignment_tit01{ font-size: 2.2rem; }
.alignment_url01{ margin: 3px 0 0 10px; }
.alignment_url01 a{ display: block; width: 25px; height: 25px; border-radius: 100%; background-color: #2c366e;  text-align: center; }
.alignment_url01 svg{ width: 15px; fill: #fff; }
.alignment_url01 a:hover{ opacity: .6; }

.link_btn01 img{ width: 90%; height: auto; max-width: 200px; max-height: 60px; object-fit: contain; }



/* 主な活動 */
.activity_sec{ margin-top: 40px; }
.activity_sec p{ font-size: 1.8rem; line-height: 2.2; font-weight: 400; letter-spacing: 2px; }

.list_activity01{}
.list_activity01 li{ position: relative; font-size: 2rem; padding: 0 0 0 30px; margin-bottom: 10px; }
.list_activity01 li:before{ content: ""; display: block; position: absolute; top: 8px; left: 0; width: 15px; height: 15px; border-radius: 100%; background-color: #8495da; }

.list_activity02{ display: flex; flex-wrap: wrap; }
.list_activity02 li{ flex: 1 0 auto; position: relative; font-size: 2.2rem; padding: 0 0 0 30px; margin-right: 30px; }
.list_activity02 li:before{ content: ""; display: block; position: absolute; top: 8px; left: 0; width: 15px; height: 15px; border-radius: 100%; background-color: #8495da; }

/* スケジュール */
.schedule_sec{ width: 90%; margin: 60px auto 80px auto; }
.schedule_sec_list{ }
.schedule_sec_item{ display: flex; justify-content: flex-start; flex-wrap: wrap; align-items: center; border-bottom: 1px solid #ccc; padding-bottom: 10px; margin-bottom: 10px; }

.schedule_sec_date{ flex-basis: 8%; font-size: 1.6rem; margin-right: 20px; }
.schedule_term{ flex-basis: 25%; padding: 0; }
.schedule_term a{ display: block; color: #fff; font-size: 1.5rem; text-align: center; padding: 3px 10px; border-radius: 40px; }
.schedule_term a:hover{ opacity: .6; }

.schedule_sec_tit01{ flex-basis: 100%; font-size: 2rem; margin-top: 10px; }

.schedule_single_sec{ width: 90%; margin: 60px auto 100px auto; }

.schedule_single_sec01{ margin-top: 20px; }
.schedule_single_sec01 p{ font-size: 1.6rem; letter-spacing: 2px; line-height: 1.6; margin-bottom: 30px; }
.schedule_single_sec01 h2{ position: relative; font-size: 2.2rem; font-weight: 700; margin-bottom: 20px; padding: 0 0 10px 30px; border-bottom: 1px solid #712eaa; }
.schedule_single_sec01 h2:before{ position: absolute; left: 0; top: 0; font-family: 'icomoon' !important; content: "\e905"; display: block; color: #f38e2d; }

.schedule_single_sec01 h3{ font-size: 2rem; color: #712eaa; background-color: #f0e9f5; padding: 10px 15px; border-radius: 10px; margin-bottom: 20px; }

.schedule_single_sec01 h4{ position: relative; color: #8495da; font-size: 1.9rem; padding: 0 0 0 30px; margin-bottom: 20px; border-bottom: 0; }
.schedule_single_sec01 h4:before{ position: absolute; content: ""; display: block; left: 0; top: 10px; width: 15px; height: 15px; background-color: #8495da; border-radius: 100%; }

	

/* 主な活動内容 activity */
.bg_activity{ background: url("/info/wp-content/uploads/bg_activity01.jpg") no-repeat top center; background-size: cover; padding: 80px 0 100px 0; }
.activity{ }

.bg_activity .h2_wrap{ width: 90%; max-width: 1100px; margin: 0 auto; }
.bg_activity h2,
.bg_activity h2 span{ color: #fff; }

.bg_activity h3{ width: 90%; max-width: 1100px; margin: 0 auto 10px auto; font-size: 2.5rem; color: #fff; padding: 0 0 10px 0; border-bottom: 1px dotted #ccc; }

.activity_txt{ width: 90%; max-width: 1100px; margin: 0 auto 40px auto; color: #fff; font-size: 1.7rem; letter-spacing: 2px; line-height: 2.2; }

.activity_img{ width: 90%; margin: 0 auto; }
.activity_img img{ border-radius: 10px; width: 96%; height: auto; }


.bg_activity02{ background: url("/info/wp-content/uploads/bg_activity02.jpg") no-repeat top center; background-size: cover; padding: 80px 0; margin-bottom: 80px; }

.activity_sec h3{ font-size: 2rem; color: #333; font-weight: 400; padding: 0; border: 0; margin-bottom: 20px; }

.lucky_sec{ width: 90%; max-width: 1200px; background-color: #fff; border-radius: 10px; margin: 0 auto 40px auto; padding: 20px; }
.lucky_sec01{ border: 1px dashed #d4c0e5; border-radius: 10px; padding: 40px; }
.lucky_sec_tit{ display: flex; flex-wrap: wrap; }
.lucky_sec_ico01{ color: var(--main-color); font-size: 2rem; margin-right: 10px; }
.lucky_sec_tit01{ font-size: 2rem; color: var(--main-color); font-family: 'League Script'; }
.lucky_sec_tit02{ flex-basis: 100%; margin-top: 5px; margin-bottom: 20px; }
.lucky_sec_tit02 h2{ font-size: 3.5rem; line-height: 1.2; letter-spacing: 3px; }
.lucky_sec h3{ margin: 0 auto 20px auto; font-size: 2.5rem; color: var(--main-color); padding: 10px 20px; background-color: #f5f5f5; border-radius: 10px; }
.lucky_sec h4{ font-size: 2rem; border-bottom: 1px solid #ccc; padding-bottom: 5px; margin-bottom: 5px; }
.lucky_sec_list{ display: flex; justify-content: space-between; margin-bottom: 40px; }
.lucky_sec_item{ flex-basis: 48%; }



/* 料金表 price */
.price{  }
.column02{ width: 100%; max-width: 1100px; margin: 0 auto 80px auto; background-color: #fff; padding-top: 30px; }
.column02_list{ width: 90%; margin: 0 auto; display: flex; justify-content: space-between; }
.column02_item{ flex-basis: 48%; margin-bottom: 30px; }
.column02_item ul{ margin-left: 30px; }
.column02_item li{ list-style-type: disc; }

/* 料金 */
.price_sec{ width: 90%; margin: 60px auto 0 auto; }
.price_list{ margin-top: 30px; }
.price_item{ display: flex; align-items: center; flex-wrap: wrap; border-bottom: 1px solid #ccc; padding: 15px 0; }
.price_tit01{ flex-basis: 100%; position: relative; font-size: 2.6rem; padding: 0 0 10px 30px; }
.price_tit01:before{ position: absolute; content: ""; display: block; width: 10px; height: 10px; background-color: #e1df2e; border-radius: 100px; left: 0; top: 15px; }
.price_time01{ flex-basis: 40%; font-size: 2rem; }
.price_time01 span{ font-size: 1.6rem; color: #fff; background-color: #35994f; border-radius: 40px; padding: 3px 10px; margin-right: 10px; }
.price_price01{ flex-basis: 40%; font-size: 2rem; }
.price_price01 span{ font-size: 1.6rem; color: #fff; background-color: #3f75b8; border-radius: 40px; padding: 3px 10px; margin-right: 10px; }

.plan_txt01{ font-size: 1.8rem; }


/* 講座 course */

/* お問い合わせ contact */
.contact{ background-color: #eee; padding: 80px 0 40px 0; }
.contact h2{ text-align: center; }


.tit01{ font-size: 5.5rem; font-weight: 700; letter-spacing: 1px; }

.txt01{ font-size: 1.9rem; letter-spacing: 1px; line-height: 2; }
.txt02{ font-size: 2.1rem; letter-spacing: 1px; line-height: 2.2; }
.txt03{ width: 80%; margin: 0 auto; font-size: 1.7rem; letter-spacing: 2px; line-height: 2.5; }




.yoyaku_btn{ width: 200px; }
.yoyaku_btn a{ display: block; color: #fff; font-size: 1.8rem; font-weight: 700; letter-spacing: 2px; text-align: center; padding: 15px; border-radius: 10px; border: 1px solid var(--yoyaku-color);  background-color: var(--yoyaku-color); }
.yoyaku_btn a:hover{ background-color: #fff; color: var(--yoyaku-color); }



.map_sec{}
.map_sec iframe{ width: 100%; aspect-ratio: 5/5; }

.contact_sec{ max-width: 900px; width: 90%; margin: 0 auto; }

/* フォーム */
.contact_item{display: flex; flex-wrap: wrap; width: 100%; padding: 20px 20px; border-bottom: 1px solid #ccc;}
.contact_tit{ flex-basis: 100%; width: 30%; font-weight: 700; position: relative; margin-left: 0; padding-left: 60px; }
.contact_tit span{ position: absolute; left: 0; font-size: 1.5rem; line-height: 1; letter-spacing: 2px; background-color: #E02E30; color: #fff; margin-right: 15px; border: 1px solid #E02E30; padding: 6px 8px;  top: -5px; border-radius: 30px; }
.contact_txt,
.contact_adress,
.contact_txtarea{ flex-basis: 100%; width: 70%; margin-top: 10px; }
.contact_txt input{ width: 100%; font-size: 2rem; background: #f7f7f7; height: 35px; padding: 8px; border: 1px solid #ccc;}
.contact_txtarea textarea{ width: 100%; font-size: 2rem; padding: 8px; background: #f7f7f7; border: 1px solid #ccc;}
.contact_adress_sub p{padding: 15px 0;}
.contact_adress input{background: #f7f7f7; border: 1px solid #ccc; height: 35px; margin-left: 15px; font-size: 2rem;}
.contact_submit{border-bottom: none;}
.contact_submit_btn{text-align: center; }
.contact_submit_btn input{ font-weight: 300; background-color: #e47e19; color: #fff; font-size: 1.8rem; 
    letter-spacing: 1px; padding: 15px 30px; cursor: pointer;   -webkit-appearance: none; border-radius: 0;}

input[type="checkbox"]{float: left;}
.contact_check{display: flex;}
.contact_submit .contact_tit{width: 30%;}
.wpcf7-spinner{display: block;}

.contact_submit_btn{ text-align: center; margin-top: 60px; margin-bottom: 60px;  }
.contact_submit_btn input{ background-color: var(--main-color); color: #fff; font-size: 2rem; letter-spacing: 2px; padding: 15px 25px; cursor: pointer; transition: 0.5s ease-in-out; font-weight: 400; font-style: normal; border: 0; }
input.wpcf7-submit:hover{ background-color: #999; }


.contact h4{ font-size: 2.5rem !important; color: #999; font-weight: 500; }
.contact ol{ margin-left: 25px; }
.contact ol li{ list-style-type: decimal; line-height: 1.8; margin-bottom: 5px; }

::placeholder{ color: #999; }


.thanks_sec{ padding-top: 90px; width: 90%; margin: 0 auto; }

.wpcf7-spinner{ display: block !important; margin: 0 auto !important; }


/* プロフィール */
.profile_sec{ width: 90%; margin: 0 auto; padding-top: 40px; }



}
/* ----------------------------------------------------------
TAB CSS END
---------------------------------------------------------- */

/* ----------------------------------------------------------
PC CSS
---------------------------------------------------------- */
@media print, screen and (min-width: 1025px) and (max-width: 1800px){

/* フォントサイズ10px */
html{ font-size: 62.5%; scroll-padding-top: 100px; }

/* 基本のフォントサイズ */
body{ font-size: 16px; font-size: 1.8rem; }

/* 非表示用 */
.nonePC		{ display: none !important; }

/* ----------------------------------------------------------
 header
---------------------------------------------------------- */
header{ top: 0; width: 100%; height: var(--header-height); z-index: 5; background-color: #fff; }
.header_sec{ display: flex; align-items: center; justify-content: space-between; }

.header_logo{ margin-left: 20px; flex-basis: 20%; color: var(--main-color); }
.header_logo a{ display: block; color: var(--main-color); }
.header_logo a:hover{ opacity: .6; }
.header_logo a img{ width: 100%; height: auto; }

.gnavi{ flex-basis: 55%; margin: 0 20px 0 auto ; }
.gnavi ul{ display: flex; }
.gnavi ul li{ flex: 1 0 auto; }
.gnavi ul li a{ position: relative; display: block; line-height: var(--header-height); color: #222; font-size: 1.6rem; font-weight: 500; text-align: center; letter-spacing: 2px; }
.gnavi ul li a:after{ position: absolute; content: ""; display: block; height: 3px; background-color: var(--main-color); bottom: 15px; left: 0; width: 0; transition: all 0.5s ease; }
.gnavi ul li a:hover::after{ width: 100%; }


.header_btn{ flex-basis: 12%; display: flex; flex-wrap: wrap; }

.header_contact{ flex-basis: 100%; border-right: 0; border-bottom: 1px solid #fff; }
.header_contact a{ display: block; color: #fff; background-color: var(--contact-color); font-size: 1.6rem; text-align: center; letter-spacing: 2px; line-height: calc((var(--header-height) / 2) - 1px);; display: flex; align-items: center; justify-content: center; }
.header_contact a i{ font-size: 2rem; margin-right: 10px; vertical-align: sub; }
.header_contact a:hover{ background-color: #fff; color: var(--contact-color); }


.header_yoyaku{ flex-basis: 100%; }
.header_yoyaku a{ display: block; color: #fff; background-color: var(--yoyaku-color); font-size: 1.6rem; text-align: center; letter-spacing: 2px; line-height: calc(var(--header-height) / 2); display: flex; align-items: center; justify-content: center; }
.header_yoyaku a i{ font-size: 2rem; margin-right: 10px; vertical-align: sub; }
.header_yoyaku a:hover{ background-color: #fff; color: var(--yoyaku-color); }

#nav-toggle{ display: none; }
#gloval-nav{ display: none; }

/* ----------------------------------------------------------
 footer
---------------------------------------------------------- */
/* ページ下部 固定メニュー */
.btm_menu { display: none; }


/* ----------------------------------------------------------
 hx
---------------------------------------------------------- */
.h1_wrap{ text-align: center; background: url("/info/wp-content/uploads/bg_h101.jpg") no-repeat center center; background-size: cover; padding: 50px 0; }
.h1_wrap h1{ font-size: 4.5rem; letter-spacing: 3px; color: #fff; font-weight: 700; }
.h1_wrap h1 span{ display: block; color: #fff; font-size: 2.8rem !important; font-family: 'League Script'; text-transform: capitalize; line-height: 1 !important; font-weight: 700; }


.h2_wrap{ margin-bottom: 30px; }
h2{ font-size: 4rem; color: var(--main-color); font-weight: 700; }
h2 span,
.h2_span{ display: block; font-size: 2.8rem !important; font-family: 'League Script'; text-transform: capitalize; line-height: 1 !important; font-weight: 700; color: var(--main-color); }



h3{ font-size: 4rem; color: var(--main-color); font-weight: 700; padding: 20px; border-top: 2px solid  var(--second-color); border-bottom: 2px solid  var(--second-color); margin-bottom: 40px;  }

h4{ position: relative; font-size: 3.2rem; font-weight: 700; margin-bottom: 30px; padding: 0 0 10px 40px; border-bottom: 1px solid #712eaa; }
h4:before{ position: absolute; left: 0; top: 0; font-family: 'icomoon' !important; content: "\e905"; display: block; color: #f38e2d; }
h4 span{ font-size: 2rem; }


h5{ font-size: 2.3rem; color: #712eaa; background-color: #f0e9f5; padding: 10px 15px; border-radius: 10px; margin-bottom: 20px; }


/* ぱんくず */
.breadcrumbs_sec{ letter-spacing: 2px; text-align: center; } 
.breadcrumbs_sec > span{ display: inline-block; position: relative; color: #fff; font-size: 1.2rem; }
.breadcrumbs_sec > span span{ margin-left: 15px; }
.breadcrumbs_sec > span a span{ margin-left: 0; }
.breadcrumbs_sec > span:first-child span{ margin-left: 0; }
.breadcrumbs_sec > span br{ display: none; }
.breadcrumbs_sec > span:before{ content: "/"; display: block; position: absolute; top: 0; left: 5px; color: #fff; font-size: 12px; }
.breadcrumbs_sec span:first-child:before{ content: ""; margin-left: 0; }
.breadcrumbs_sec > span a{ color: #fff; font-size: 1.2rem; margin: 0 0 0 20px; }
.breadcrumbs_sec > span:first-child a{ margin: 0 0 0 0; }
.breadcrumbs_sec span a:hover{ opacity: 0.6; }


/* ----------------------------------------------------------
 contents
---------------------------------------------------------- */
.wrapper{ /* padding-top: var(--header-height); */ }
.contents{ width: 90%; margin: 0 auto 100px auto; padding-top: 40px; }

.top_img{ }


/* 癒し空間ユチとは about */
.about{ width: 90%; max-width: 1300px; margin: 0 auto 100px auto; }

.about p{ font-size: 1.7rem; line-height: 2.2; font-weight: 700; letter-spacing: 2px; }
.about img{ border-radius: 10px; }

.about_sec{  }
.about_sec > div{ display: flex; justify-content: space-between; }
.about_sec_txt{ flex-basis: 48% !important; margin: 0 !important; padding: 0 !important; }
.about_sec_img{ flex-basis: 48% !important; margin: 0 !important; padding: 0 !important; }
.about_sec_img img{ border-radius: 10px; }


/* ごあいさつ greeting */
.greeting{ width: 90%; max-width: 1100px; margin: 0 auto 100px auto; }

.greeting p{ font-size: 1.8rem; line-height: 2.2; font-weight: 700; letter-spacing: 2px; }
.greeting img{ border-radius: 10px; }


.greeting_sec{  }
.greeting_sec > div{ display: flex; justify-content: space-between; align-items: center; }
.greeting_sec_txt{ flex-basis: 62% !important; max-width: 62% !important; margin: 0 !important; padding: 0 !important; }
.greeting_sec_img{ flex-basis: 33% !important; margin: 0 !important; padding: 0 !important; }
.greeting_sec_img img{ width: 100%; height: auto; border-radius: 10px; }


/* 経歴・プロフィール profile */
.profile{ width: 100%; margin: 0 auto 100px auto; }




/* 主な活動内容 activity */
.bg_activity{ background: url("/info/wp-content/uploads/bg_activity01.jpg") no-repeat top center; background-size: cover; padding: 80px 0 60px 0; }
.activity{ }

.activity .h2_wrap{ width: 90%; max-width: 1000px; margin: 0 auto; text-align: center; }
.activity h2,
.activity h2 span{ /* color: #fff; */ }
.activity_sec h2,
.activity_sec h2 span{ color: var(--main-color); }

.activity .h201 span{ display: inline-block !important; }

/*
.activity h3{ width: 90%; max-width: 1100px; margin: 0 auto 10px auto; font-size: 2.5rem; color: #fff; padding: 0 0 10px 0; border-bottom: 1px dotted #ccc; }
*/

.activity_sec h3{ font-size: 2.5rem; color: #333; font-weight: 400; padding: 0; border: 0; margin-bottom: 20px; }

.activity_txt{ width: 90%; max-width: 1100px; margin: 0 auto 40px auto; color: #fff; font-size: 1.7rem; letter-spacing: 2px; line-height: 2.2; }

.activity_img{ width: 90%; margin: 0 auto; }
.activity_img img{ border-radius: 10px; width: 96%; height: auto; }

.activity_img p{ color: #fff; text-align: center; font-size: 1.8rem; }



.bg_activity02{ background: url("/info/wp-content/uploads/bg_activity02.jpg") no-repeat top center; background-size: cover; padding: 80px 0; margin-bottom: 80px; }

.p_att01{ background-color: #eee; padding: 15px; text-align: center; font-size: 2.1rem; }

.activity_sec p{ font-size: 1.6rem; line-height: 2.2; font-weight: 400; letter-spacing: 2px; }


.lucky_sec{ width: 90%; max-width: 1200px; background-color: #fff; border-radius: 10px; margin: 0 auto 40px auto; padding: 20px; }
.lucky_sec01{ border: 1px dashed #d4c0e5; border-radius: 10px; padding: 40px; }
.lucky_sec_tit{ display: flex; flex-wrap: wrap; }
.lucky_sec_ico01{ color: var(--main-color); font-size: 2rem; margin-right: 10px; }
.lucky_sec_tit01{ font-size: 2rem; color: var(--main-color); font-family: 'League Script'; }
.lucky_sec_tit02{ flex-basis: 100%; margin-top: 5px; margin-bottom: 20px; }
.lucky_sec_tit02 h2{ font-size: 3.5rem; line-height: 1.2; letter-spacing: 3px; }
.lucky_sec h3{ margin: 0 auto 20px auto; font-size: 2.5rem; color: var(--main-color); padding: 10px 20px; background-color: #f5f5f5; border-radius: 10px; }
.lucky_sec h4{ font-size: 2rem; border-bottom: 1px solid #ccc; padding-bottom: 5px; margin-bottom: 5px; }
.lucky_sec_list{ display: flex; justify-content: space-between; margin-bottom: 40px; }
.lucky_sec_item{ flex-basis: 48%; }



/* 料金表 price */
.price{  }
.column02{ width: 100%; max-width: 100%; margin: 0 auto; background-color: #fff; padding-top: 80px; padding-bottom: 80px; }
.column02_list{ width: 90%; max-width: 1100px; margin: 0 auto; display: flex; justify-content: space-between; }
.column02_item{ flex-basis: 48%; margin-bottom: 30px; }
.column02_item ul{ margin-left: 30px; }
.column02_item li{ list-style-type: disc; }

/* 講座 course */

/* お問い合わせ contact */
.contact{ background-color: #eee; padding: 80px 0 40px 0; }
.contact h2{ text-align: center; }


.tit01{ font-size: 5.5rem; font-weight: 700; letter-spacing: 1px; }

.txt01{ font-size: 1.9rem; letter-spacing: 1px; line-height: 2; }
.txt02{ font-size: 2.1rem; letter-spacing: 1px; line-height: 2.2; }
.txt03{ width: 80%; margin: 0 auto; font-size: 1.7rem; letter-spacing: 2px; line-height: 2.5; }




.yoyaku_btn{ width: 260px; }
.yoyaku_btn a{ display: block; color: #fff; font-size: 1.8rem; font-weight: 700; letter-spacing: 2px; text-align: center; padding: 15px; border-radius: 10px; border: 1px solid var(--yoyaku-color);  background-color: var(--yoyaku-color); }
.yoyaku_btn a:hover{ background-color: #fff; color: var(--yoyaku-color); }



.map_sec{}
.map_sec iframe{ width: 100%; aspect-ratio: 5/5; }

.contact_sec{ max-width: 900px; }

/* フォーム */
.contact_item{display: flex; width: 100%; padding: 20px 20px; border-bottom: 1px solid #ccc;}
.contact_tit{ width: 30%; font-weight: 700; position: relative; margin-left: 0; padding-left: 80px; }
.contact_tit span.must{ position: absolute; display: block; font-size: 1.5rem; line-height: 1; letter-spacing: 2px; background-color: #E02E30; color: #fff; margin-right: 15px; border: 1px solid #E02E30; padding: 6px 8px; left: 0px; top: -5px; border-radius: 30px; }
.contact_tit span.optional{ position: absolute; display: block; font-size: 1.5rem; line-height: 1; letter-spacing: 2px; background-color: #aaa; color: #fff; margin-right: 15px; border: 1px solid #aaa; padding: 6px 8px; left: 0px; top: -5px; border-radius: 30px; }
.contact_txt,
.contact_adress,
.contact_txtarea{ width: 70%; }
.contact_txt input{font-size: 2rem; background: #f7f7f7; height: 35px; padding: 8px; border: 1px solid #ccc;}
.contact_txtarea textarea{font-size: 2rem; padding: 8px; background: #f7f7f7; border: 1px solid #ccc;}
.contact_adress_sub p{padding: 15px 0;}
.contact_adress input{background: #f7f7f7; border: 1px solid #ccc; height: 35px; margin-left: 15px; font-size: 2rem;}
.contact_submit{border-bottom: none;}
.contact_submit_btn{text-align: center; }
.contact_submit_btn input{ font-weight: 300; background-color: #e47e19; color: #fff; font-size: 1.8rem; 
    letter-spacing: 1px; padding: 15px 30px; cursor: pointer;   -webkit-appearance: none; border-radius: 0;}

input[type="checkbox"]{float: left;}
.contact_check{display: flex;}
.contact_submit .contact_tit{width: 30%;}
.wpcf7-spinner{display: block;}

.contact_submit_btn{ text-align: center; margin-top: 60px; margin-bottom: 60px;  }
.contact_submit_btn input{ background-color: var(--main-color); color: #fff; font-size: 2rem; letter-spacing: 2px; padding: 15px 25px; cursor: pointer; transition: 0.5s ease-in-out; font-weight: 400; font-style: normal; border: 0; }
input.wpcf7-submit:hover{ background-color: #999; }


.contact h4{ font-size: 2.5rem !important; color: #999; font-weight: 500; }
.contact ol{ margin-left: 25px; }
.contact ol li{ list-style-type: decimal; line-height: 1.8; margin-bottom: 5px; }

::placeholder{ color: #999; }


/* プロフィール */
.profile_sec{ width: 90%; margin: 0 auto; }

.table_profile{}
.table_profile table{  }
.table_profile table tr th{ width: 13% !important; border-bottom: 1px solid #ccc !important; border-top: 0 !important; border-right: 0 !important; border-left: 0 !important; background: none !important; font-size: 1.8rem; font-weight: 700; padding: 15px !important; }
.table_profile table tr td{ border-bottom: 1px solid #ccc !important; border-top: 0 !important; border-right: 0 !important; border-left: 0 !important; font-size: 1.8rem; padding: 15px !important; }

.table_profile table thead{ border-bottom: 2px solid var(--second-color); }

.greeting_sec_txt p{ font-size: 1.8rem; line-height: 2.2; font-weight: 700; letter-spacing: 2px;  }

.alignment_list{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.alignment_item{ flex-basis: 48%; position: relative; display: flex; padding: 0 0 0 30px; margin-bottom: 15px; }
.alignment_item:before{ content: ""; display: block; position: absolute; left: 0; top: 8px; width: 15px; height: 15px; background-color: #8495da; border-radius: 100%;  }
.alignment_tit01{ font-size: 2rem; }
.alignment_url01{ margin: 3px 0 0 10px; }
.alignment_url01 a{ display: block; width: 25px; height: 25px; border-radius: 100%; background-color: #2c366e;  text-align: center; }
.alignment_url01 svg{ width: 15px; fill: #fff; }
.alignment_url01 a:hover{ opacity: .6; }

	
/* スケジュール */
.schedule_sec{ width: 90%; margin: 60px auto 80px auto; }
.schedule_single_sec{ width: 90%; margin: 60px auto 100px auto; }


/* 料金 */
.price_sec{ width: 90%; margin: 0 auto; }
.plan_txt01{ font-size: 1.8rem; }


}
/* ----------------------------------------------------------
 PC CSS END
---------------------------------------------------------- */
/* ----------------------------------------------------------
 PC WIDE CSS
---------------------------------------------------------- */
@media screen and (min-width: 1801px){
/* フォントサイズ10px */
html{ font-size: 62.5%; height: 100%; }

/* 基本のフォントサイズ */
body{ font-size: 16px; font-size: 1.8rem; height: 100%; }

/* 非表示用 */
.nonePCWIDE		{ display: none !important; }

/* ----------------------------------------------------------
 header
---------------------------------------------------------- */


/* ----------------------------------------------------------
 footer
---------------------------------------------------------- */
/* ページ下部 固定メニュー */
.btm_menu{ display: none; }



/* ----------------------------------------------------------
 hx
---------------------------------------------------------- */



/* ----------------------------------------------------------
 contents
---------------------------------------------------------- */


}
/* ----------------------------------------------------------
 PCWIDE CSS END
---------------------------------------------------------- */