@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.2
*/


/*--------------------------------------
  初期化
--------------------------------------*/

/*画像の下に余白が出るのを防ぐ*/
figure img {
	vertical-align: bottom;
}

/*画像のブロックを中央に寄せる*/
.main .wp-block-image{
	margin:0 auto;
}

/*テーマが出力するヘッダーを非表示にする*/
#header-container {
	display: none;
}

/*コンテンツの余白を削除する*/
.main,
.sidebar{
	padding:0 5px 5px 5px !important;
}
.content{
	  margin-top: 0px;
}

/*ブロックがウインドウからはみ出さないようにする*/
div {
	max-width: 100%;
}

/*不要な余白が出るのを防ぐ*/
.date-tags{
	margin:0;
}

/*不要な余白が出るのを防ぐ*/
.entry-content{
	margin-top:0;
}

/*フッターの文字が最前面に出るのを防ぐ*/

.footer-bottom {
	position:static;
}

/*mainの下に余白が出るのを防ぐ*/
#main-scroll,
.main-scroll{
	display:none;
}

.entry-content{
	margin-bottom:0;	
}



/*--------------------------------------
  基本クラス定義
--------------------------------------*/

.center {
	text-align: center;
}

.right {
	text-align: right;
}
.left {
	text-align: left;
}

input,textarea{
	padding:5px;
	border-radius:6px;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
}


strong {
	font-weight: bold;
}

strong footer,
strong #sidebar{
	font-weight: normal!important;
}

.margin_top_0{	
	margin-top:0;
    margin-block-start: 0 !important;
}

/*--------------------------------------
  全体定義
--------------------------------------*/
body {
	font-family : verdana, sans-serif;
	font-size : 16px !important;
	line-height : 1.6;
	background: #fff;
	color: #333;
	margin: 0;
	padding: 0;
}

@media screen and (min-width : 768px){
body{
	font-size:18px !important;
}

}/*@media screen and (min-width : 768px)*/

@media screen and (min-width : 1024px) {

body{
	font-family: Meiryo, "メイリオ", verdana, sans-serif;
	font-size:20px !important;
}

}/*@media screen and (min-width : 1024px)*/

/*--------------------------------------
  クリアフィックス
---------------------------------------*/
.clearfix:after {
	visibility: hidden;
	height: 0;
	display: block;
	font-size: 0;
	content: " ";
	clear: both;
}

* html .clearfix {
	zoom: 1;
}

*:first-child+html .clearfix {
	zoom: 1;
}

/*--------------------------------------
  画像
--------------------------------------*/
a:hover img {
	opacity: 0.8;
	filter: alpha(opacity=80);
	-ms-filter: "alpha( opacity=80 )";
}

/*--------------------------------------
  リンク
--------------------------------------*/
a {
	color: #000;
	text-decoration:none;
}

a:hover {
	color: #999;
}

/*ページ内リンクの場合、固定ヘッダーの分だけ移動先をずらす*/
a.anchor {
    display: block;
    padding-top: 70px;
    margin-top: -70px;
}
@media screen and (min-width : 1024px){
a.anchor {
    padding-top: 43px;
    margin-top: -43px;
}

}/*@media screen and (min-width : 1024px)*/

/*--------------------------------------
  PC、スマホ表示切替定義
--------------------------------------*/
.blk-pc{
	display:none;
	margin:auto;
}
.blk-sp{
	display:table;
	width:100%;
	margin:auto;

}

@media screen and (min-width : 768px){
.blk-contact{
	color:#008000;
	font-weight:bold!important;
}

}/*@media screen and (min-width : 768px)*/

@media screen and (min-width : 1024px) {

.blk-pc{
	display:table;
}
.blk-sp{
	display:none;	
}

}/*@media screen and (min-width : 1024px)*/


/*--------------------------------------
  コンテンツエリア
--------------------------------------*/
#contents {
	width: 100%;
	margin: 0 auto;
}

#contents p {
	margin-bottom: 10px;
}

@media screen and (min-width : 768px){
#contents {
	width: 95%;
}

#contents #main {
	padding: 20px 35px;
	margin-bottom: 24px;
	border-radius: 8px;
	border: 0px solid #ddd;
}

}/*@media screen and (min-width : 768px)*/

/*--------------------------------------
  見出しベース
--------------------------------------*/
h1,h2,h3{
	line-height : 1.5;
}

h1, h1.entry-title{
	margin-top: 0;
	margin-bottom: 0;
}

h2,h3{
	margin-top: 20px;
	margin-bottom: 20px;
}

/*--------------------------------------
  H1見出し定義
--------------------------------------*/
h1 {
	font-size: 1.5em; 
	background-color:#bfd641;
	padding:15px;
	color:white;
	font-weight:bold;
	border-radius:15px;
}

/*--------------------------------------
  H2見出し定義
--------------------------------------*/
h2.h2_type1{
	font-size: 1.3em;
	color:white;
	font-weight:bold;
/*	font-weight:normal;*/
/*	background:#e4f3d4;*/
	background-color:#bfd641;
/*	color:#333;*/
/*	border: 5px solid #84ac28;*/
/*	border: 5px solid #99ff99;*/
	border-radius:25px;
	box-sizing:border-box;
	margin: 20px 0 0 0;
	padding: 5px 0 5px 20px;
/*	text-shadow:-1px 1px 0 rgb(255 255 255);*/
	vertical-align:baseline;
}

/*--------------------------------------
  H3見出し定義
--------------------------------------*/
.article h3{
	font-size: 1.2em;
	font-weight:normal;
	border:none;
	border-bottom: 2px solid #ccc;
	margin: 20px 0;
	padding: 0 0 5px 0;
}

.article h3.point-title{
	color: #ff4500;
	background:none;
	font-size:1.5em;
	font-weight:bold;
	border: none;
	margin: 10px 0;
	padding: 0;
}

@media screen and (min-width: 1024px){
.article h3{
	background: #e3ffda;
    border-bottom: 2px #d2facf solid;
	border-left: 4px #d2facf solid;
	border-radius:15px;
	box-sizing:border-box;
	padding: 5px 0 2px 15px;
	font-weight:normal;
}
}/*@media screen and (min-width: 1024px)*/

/*--------------------------------------
  テキスト書式定義
--------------------------------------*/

.has-vivid-red-color,
.red{
	color:#ff0000 !important;
}

.bold{
	font-weight:bold;
}

.margin_bottom_0{
	margin-bottom:0;
}

.tyuigaki_small{
	font-size:8pt;
	margin-top:-10px;
}

.yellow_under{
	background: linear-gradient(transparent 50%, yellow 50%);
}


/*--------------------------------------
  画像サイズ定義
--------------------------------------*/
.full_width		, .full_width		figure	, .full_width		figure img,
.max_width_400	, .max_width_400	figure	, .max_width_400	figure img,
.max_width_450	, .max_width_450	figure	, .max_width_450	figure img,
.max_width_600	, .max_width_600	figure	, .max_width_600	figure img,
.max_width_90_persent	, .max_width_90_persent	figure	, .max_width_90_persent	figure img
{
	width:100%;
	height:auto;
	margin:0 auto;
}

.max_width_400{max-width:400px;}
.max_width_450{max-width:450px;}
.max_width_600{max-width:600px;}
.max_width_90_persent{max-width:90%;}

/*--------------------------------------
  キャッチフレーズ定義
--------------------------------------*/
#header .caption {
	color: #000;
	font-size: 0.65em;
	font-weight:bold;
	padding: 0;
	border: 0px solid #444;
	margin: 10px 0;
}

/*--------------------------------------
  ナビゲーションメニュー、スマホ用
--------------------------------------*/
.menu_button_img{
	display:none;
}

.menu_button_img_show{
	display:block;
}

ul.menu{
	list-style: none;
	padding-left:0 !important;
}

nav#menu {
	font-size:16px;
	margin-bottom: 0;
}

.togmenu {
	display: none;
	color: black;
	background:#E3FFDA;
}

.menubtn {
	padding: 0;
	color: black;
	text-align: right;
	cursor: pointer;
}

.togmenubtn {
	background:#E3FFDA;
}

nav#menu ul {
	overflow-x: hidden;
}

nav#menu ul li {
	width: 250px;
	text-align: left;
	border-bottom: 1px solid #ddd;
	background:#E3FFDA;
}

nav#menu ul li a {
	display: block;
	color : black;
	padding : 8px 10px;
}

nav#menu ul li a:hover {
	color: #666;
}

nav#menu ul li ul.sub-menu {
	display:none;
	list-style: none;
	margin: 0;
	padding: 0;
}

nav#menu ul li ul.sub-menu li a {
	padding-left: 40px;
}


/*--------------------------------------
  ナビゲーションメニュー、PC用
--------------------------------------*/
@media screen and (min-width : 1024px){

nav#menu {
	padding: 0;
}

nav#menu ul {
	width: 100%;
	margin: 0 auto;
	max-width: 1000px;
	height: 43px;
	overflow: visible;
}

/* MENUボタンを隠す */
.menubtn {
	display: none;
}

/* ナビを表示 */
.togmenu {
	display: block;
}

nav#menu ul li {
	position: relative;
	margin: 0;
	padding: 0;
	text-align: left;
	float: left;
	width: auto;
	height:43px;
	border: none;
}
	
nav#menu ul li a {
	display: block;
	color : black;
	padding : 8px 0.4em;
}

nav#menu ul li a:hover {
	color: #666;
}

nav#menu ul li ul.sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
}

nav#menu ul li:hover,
nav#menu ul li ul.sub-menu li:hover {
	border-bottom: 3px solid #3cb371;
}

/* カーソルをのせると子を表示 */
nav#menu ul li:hover ul.sub-menu {
	display: block;
}

nav#menu ul li ul.sub-menu li {
	overflow: hidden;
	width: 220px;
	height: 0;
}

nav#menu ul li:hover ul.sub-menu li {
	min-height: 40px;
}

nav#menu ul li ul.sub-menu li a {
	padding : 8px 1em;
}
	
.menu_fixed{
	position: fixed;
	top: 0;
	left: 0;
	width:100%;
	z-index:9991;
}

}/* @media screen and (min-width : 1024px) */


/*--------------------------------------
  パンくずリスト
--------------------------------------*/
.breadcrumb {
  display: flex; /* リストを横並びに */
  flex-wrap: wrap; /* リストが折り返すように */
  list-style: none; /* リストスタイルを無しに */
}
.breadcrumb__list:not(:last-of-type)::after {
  content: ">"; /* 区切り文字 */
  margin: 0 .6em; /* 区切り文字の左右の余白 */
}


.breadcrumb {
  margin: 5px 0;
  padding: 0;
  list-style: none;
}

.breadcrumb li {
/*  display: inline-block;*//*横に並ぶように*/
  display: flex; /* リストを横並びに */
  flex-wrap: wrap; /* リストが折り返すように */
  list-style: none;
  font-weight: bold;/*太字*/
}

.breadcrumb li:after {
  /* ▶を表示*/
  font-family: FontAwesome;
  content: '\f0da';
  padding: 0 0.3em;
  color: #bfd641;
}

.breadcrumb li:last-child:after {
  content: '';
}

.breadcrumb li a {
  display: inline-block;
  padding: 0.2em 0.8em;
  border-radius: 15px;
  text-decoration: none;
  color: white;
  background: #bfd641;
  font-size: 0.9em;
}

.breadcrumb li a:hover {
/*  background: #e4f3d4;*/
/*  background: #c9dbfb;*/
}

/*--------------------------------------
  サイドバー
--------------------------------------*/
.side-info{
	font-size:16px;
	line-height:1.6;
	display:block;
	box-sizing:border-box;
	text-align: left;
	background: #e3ffda;
	border: 4px #d2facf solid;
	padding:10px;
	margin-bottom:15px;
	
}
.side-info table{
	width:100%;
	table-layout:fixed;
	text-align:justify;
	margin-bottom:0;
}
.side-info table tr,
.side-info table th{
	padding:2px;
	background:#fff;
	text-align:center;
	vertical-align:middle!important;
}
.side-info table th{
	font-weight:bold;
}

.side-info table,
.side-info table tr,
.side-info table th,
.side-info table td{
	border:1px solid gray;
}

/*
.side-menu{
	display:block;
	background:#ff9999;
	padding: 0 0 5px 0;
	width:100%;
	margin-bottom:15px;
	font-size:16px;
}

.side-menu-head{
	padding: 10px;
}

ul.side-menu-list{
	width:100%!important;
	display:block!important;
	padding:0 10px!important;
	margin:0 0 10px!important;
	box-sizing:border-box!important;
}
ul.side-menu-list li{
	display:block!important;
	width:100%!important;
	font-size:1.5em;
	background: #fff url("../../uploads/2021/02/side_menu_icon24x24min.png") no-repeat right center ;
	padding-left:5px!important;
	padding-right:10px!important;
	line-height:2.0em!important;
	box-sizing:border-box!important;
	margin-bottom:5px;
	text-align:left;
	border:0;
}
*/

.side-menu{
	margin-top:15px;
	margin-bottom:15px;
}

.side-menu-head{
	background-color:#238207;
	color:white;
	text-align:center;
	font-size:22px;
	font-weight:bold;
	padding: 12px;
	margin-bottom:12px;
}

ul.side-menu-list{
	padding-left:0;
}

ul.side-menu-list li{
	list-style:none;
	color:#0000EE;
	text-decoration:underline;
	font-size:22px;
	padding: 8px 0;
	border-bottom: 1px solid gray;
}

.side-menu2{
	display:block;
	background:#88E1C5;
	padding: 5px 0;
	width:100%;
	margin-bottom:15px;
	font-size:16px;
}
ul.side-menu-list2{
	width:100%!important;
	display:block!important;
	padding:0 10px!important;
	margin:0 0 10px!important;
	box-sizing:border-box!important;
}
ul.side-menu-list2 li{
	display:block!important;
	width:100%!important;
	font-size:1.5em;
	background: #fff url("../../uploads/2021/02/side_menu_icon2_24x24min.png") no-repeat right center ;
	padding-left:5px!important;
	padding-right:10px!important;
	line-height:2.0em!important;
	box-sizing:border-box!important;
	margin-bottom:5px;
	text-align:left;
	border:0;
}

@media screen and (min-width : 1024px) {

	
#sub .side_widget li ul li {
	width: 100%;
	display: block;
	padding: 0.1em 0;
	text-indent: 0;
	box-sizing:border-box;
}

#sub .side_widget li ul li ul li {
	text-indent: 1em;
}

#sub .side_widget li ul li ul li ul li {
	text-indent: 2em;
}

#sub .side_widget li ul li ul {
	display: inline;
}

/*
ul.side-menu-list{
	width:100%!important;
	display:block!important;
	padding:0 10px!important;
	margin:0 0 10px!important;
	box-sizing:border-box!important;
}
ul.side-menu-list li{
	display:block!important;
	font-size:1.0em;
	width:100%!important;
	background: #fff url(../../uploads/2021/02/side_menu_icon24x24min.png) no-repeat right center;
	padding-left:10px!important;
	padding-right:10px!important;
	line-height:2.0em!important;
	box-sizing:border-box!important;
	margin-bottom:5px!important;
	border:0;
}
*/
	
ul.side-menu-list2{
	width:100%!important;
	display:block!important;
	padding:0 10px!important;
	margin:10px 0!important;
	box-sizing:border-box!important;
}
ul.side-menu-list2 li{
	display:block!important;
	width:100%!important;
	font-size:1.0em;
	background: #fff url("../../uploads/2021/02/side_menu_icon2_24x24min.png") no-repeat right center ;
	padding-left:10px!important;
	padding-right:10px!important;
	line-height:2.0em!important;
	box-sizing:border-box!important;
	margin-bottom:5px!important;
	text-align:left;
	border:0;
}

}/*@media screen and (min-width : 1024px)*/

/*-----------------------------------
  サイドバー新着記事
------------------------------------*/
.side_new {
	margin: 0 0 15px 0;
	text-align: left;
	display: table;
	width: 100%;
	font-size:16px;
}

.side_new:hover {
	text-decoration: none;
	background: #eee;
}

.side_thumb {
	display: table-cell;
	width: 105px;
	padding: 0 5px 0 0;
}

.side_title {
	font-size: 90%;
	display: table-cell;
	vertical-align: top;
}

.side_title span {
	color: #333;
}

select#cat {
	width: 100%;
	padding: 0.5em 0 0.5em 0.2em;
	font-size: 100%;
	color: #333;
}


/*-----------------------------------
  サイドバーSNSアイコン
------------------------------------*/
.side-sns {
	margin-bottom: 12px;
	padding: 0.3em;
	font-size: 30px;
}

.side-sns ul {
	list-style: none;
	padding-left:0;
	display: table;
	table-layout: fixed;
	width: 100%;
}

.side-sns ul li {
	display: table-cell;
	vertical-align: middle;
	text-align: center;
}

.side-sns ul li a {
	color: #666;
	text-shadow: -1px 1px 0 rgba(255, 255, 255, 1);
}

.side-sns ul li a:hover {
	color: #ff7ddf;
	text-shadow: -1px 1px 0 rgba(255, 255, 255, 1);
}


/*--------------------------------------
  検索フォーム
--------------------------------------*/
#searchform {
	margin-bottom: 24px;
	width: 100%;
	max-width:250px;
	background: #fff;
	padding: 5px 0;
	border: 1px solid #ccc;
	border-radius: 5px;
	box-sizing:border-box;
	line-height:1.4;
}

#searchform input[type="text"] {
	height: 24px;
	float: left;
	margin: 0;
	width: 100%;
	max-width:220px;
	border: 1px solid #fff;
	padding: 0 0 0 5px;
	font-size: 15px;
	box-sizing:border-box;
}

#searchform button {
	margin: 0;
	padding: 0;
	background: #fff;
	border: 0;
	color: #111;
	font-size: 18px;
}

#searchform button:hover {
	color: #ff7ddf;
}

/*--------------------------------------
  トップに戻るボタン
--------------------------------------*/
@media screen and (max-width : 600px){
	
.go-to-top{
	display:none !important;
}

}/* @media */
	

/*--------------------------------------
  フッター施術メニュー
--------------------------------------*/

.footer_menu_title{
	margin-bottom:5px!important;
	border-left:5px solid #ffd700;
	padding:5px 0 5px 8px;
	font-size:20px;
	line-height:1.5;
}

.footer_menu_list{
	width:280px;
	display:block;
	font-size:14px;
	list-style: none;
	padding-left:0;
}

/*--------------------------------------
  さくら音楽教室
--------------------------------------*/

.h2_music_school a{
	text-decoration: underline;
}

/*--------------------------------------
  来院から施術までの流れ
--------------------------------------*/
.raiin_kara_sejutu{
	width: 600px;
	margin: 0 auto;
}

/*--------------------------------------
  チェックボックスのリスト定義
--------------------------------------*/
ul.check_box{
	list-style:none; /*通常のlist-styleは使わない*/
	padding-left:0;
}

ul.check_box > li{
	background-image: url("../../uploads/2021/02/checkbox25x25min.png");
	background-repeat: no-repeat;
	background-position: left 2px;  /*ずれを調整*/
	line-height: 30px;
	padding-left: 30px;
	margin:20px 0;
}

/*--------------------------------------
 * アニメーション001
 * -----------------------------------*/
@-webkit-keyframes pulse {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

@keyframes pulse {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

.animation001 {
  -webkit-animation-name: pulse;
  animation-name: pulse;
	
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
	
  -webkit-animation-duration: 3s;
  animation-duration: 3s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

/*--------------------------------------
 * 点滅アニメーション
 * -----------------------------------*/

.tenmetu{
	animation:TENMETU 0.4s ease-in-out infinite alternate;
}

@keyframes TENMETU {0%{opacity:1.0;}100% {opacity:0;}}


/*--------------------------------------
 * 上からフェードインアニメーション
 * -----------------------------------*/

.fade-in{ 
　opacity:0;
  animation-name:fade-in;
  animation-duration:5s; 
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@keyframes fade-in {
	0% {
		transform: translateY(-110px);
	}
	50% {
		transform: translateY(-110px);
	}
	100%{
		opacity:1;
		transform: translateY(0);
	}
}

/*--------------------------------------
 * 左から右に光るアニメーション
 * -----------------------------------*/
.reflection-img{
    position    :relative;
    overflow    :hidden;
}
 
.reflection {
    height      :100%;
    width       :30px;
    position    :absolute;
    top         :-180px;
    left        :0;
    background-color: #fff;
    opacity     :0;
    transform: rotate(45deg);
    animation: reflection 2s ease-in-out infinite;
    -webkit-transform: rotate(45deg);
    -webkit-animation: reflection 2s ease-in-out infinite;
    -moz-transform: rotate(45deg);
    -moz-animation: reflection 2s ease-in-out infinite;
    -ms-transform: rotate(45deg);
    -ms-animation: reflection 2s ease-in-out infinite;
    -o-transform: rotate(45deg);
    -o-animation: reflection 2s ease-in-out infinite;
}
 
@keyframes reflection {
    0% { transform: scale(0) rotate(45deg); opacity: 0; }
    80% { transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { transform: scale(4) rotate(45deg); opacity: 1; }
    100% { transform: scale(50) rotate(45deg); opacity: 0; }
}
@-webkit-keyframes reflection {
    0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -webkit-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -webkit-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}
@-moz-keyframes reflection {
    0% { -moz-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -moz-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -moz-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -moz-transform: scale(50) rotate(45deg); opacity: 0; }
}
@-ms-keyframes reflection {
    0% { -ms-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -ms-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -ms-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -ms-transform: scale(50) rotate(45deg); opacity: 0; }
}
@-o-keyframes reflection {
    0% { -o-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -o-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -o-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -o-transform: scale(50) rotate(45deg); opacity: 0; }
}

/*--------------------------------------
  PC版ヘッダーボタン
--------------------------------------*/
.logo_pc{width:65%}
.tel_otoiawase_pc{width:25%;}
.map_pc{width:10%}

/*--------------------------------------
 * スマホ版ヘッダーボタン
 * -----------------------------------*/
.sp_top_button{
	position: fixed !important;
	top: 0px;
	width:100%;
	text-align: left;
	z-index:999;
}

.sp_top_button img{
    width: 100%;
	height:auto;
}


.sp_top_bg{
	position: relative;
    width: 100%;
    max-width: 480px;
}

.sp_top_haikei{
	position:absolute;
	top:0;
	left:0;
    width: 100%;
	z-index: -1;
}

.sp_top_menu_button{
	float:left;
	box-sizing:border-box;
	width:14.5%;
	height:auto;
}

.sp_top_logo{
	float:left;
	box-sizing:border-box;
	width:44%;
	height:auto;
	margin-right:1%;
}

.sp_top_line_button{
	float:left;
	box-sizing:border-box;
	width:40%;
	height:auto;

}

/*--------------------------------------
 * スマホ版フッタボタン
 * -----------------------------------*/
.sp_bottom_button{
	position: fixed !important;
	bottom: 0;
	left:0;
	width:100%;
	z-index:999;
}

.sp_bottom_button img{
    width: 100%;
	height:auto;
}

.sp_bottom_bg{
	position: relative;
    width: 100%;
    max-width: 480px;
}

.sp_bottom_josei{
    width: 100%;
	z-index: 0;
}

.sp_bottom_tel_button{
	position:absolute;
	bottom: 5px;
	left: 1%;
	width:48.5%;
	height:auto;
	z-index: 1;
}

.sp_bottom_line_button{
	position:absolute;
	bottom: 5px;
	left: 50.5%;
	width:48.5%;
	height:auto;
	z-index: 1;
}

/*--------------------------------------
 * PC版フッタボタン
 * -----------------------------------*/
.pc_bottom_button{
	position: fixed;
	bottom: 20px;
	left:20px;
	width:260px;
	height:219px;
	z-index:9990;
}

.pc_bottom_bg{
	position: relative;
    width: 100%;
}


.pc_bottom_mail_button{
	position:absolute;
	top: 15px;
	left: 108px;
	width:130px;
}

.pc_bottom_line_button{
	position:absolute;
	top: 80px;
	left: 108px;
	width:130px;
}


/*--------------------------------------
  Feedlyボタン定義
--------------------------------------*/

a.feedlyButton {
	color: #777777;
	text-align: center;
	text-decoration: none;
}

a.feedlyButton:hover {
	color: #333333;
}
a.feedlyButton:visited {
	color: #777777;
}
.arrow_box_feedly {
	background: none repeat scroll 0 0 #FFFFFF;
	border: 1px solid #CCCCCC;
	border-radius: 3px 3px 3px 3px;
	height: 35px;
	width: 66px;
	margin-bottom: 8px;
	position: relative;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}
.arrow_box_feedly:after, .arrow_box_feedly:before {
	border: medium solid transparent;
	content: " ";
	height: 0;
	left: 50%;
	pointer-events: none;
	position: absolute;
	top: 100%;
	width: 0;
}
.arrow_box_feedly:after {
	border-color: #FFFFFF rgba(255, 255, 255, 0) rgba(255, 255, 255, 0);
	border-width: 4px;
	margin-left: -4px;
}
.arrow_box_feedly:before {
	border-color: #CCCCCC rgba(204, 204, 204, 0) rgba(204, 204, 204, 0);
	border-width: 5px;
	margin-left: -5px;
}
.arrow_box_feedly img {
	margin: 0;
	border: none;
}
.arrow_box_feedly span {
	line-height: 35px;
}


/*--------------------------------------
  横並び定義１
--------------------------------------*/
ul.col2,
ul.col2-point{
    display:table;
    width:100%;
	margin:0 0 0;
	list-style:none;
	box-sizing:border-box;
	padding-left:0;
}

ul.col2:after,
ul.col2-point:after{
	clear:both;
}

ul.col2 > li{
    display: block;
	list-style-type:none;
	width:100%;
	margin:0;
	float:left;
	border-collapse:collapse;
	box-sizing:border-box;
	padding-top: 0;
	padding-bottom: 0;
	padding-left: 10px;
	padding-right: 10px;
}
ul.col2-point > li{
	display: block;
	list-style-type:none;
	border-collapse:collapse;
	box-sizing:border-box;
	padding-top: 0;
	padding-bottom: 10px;
	padding-left: 10px;
	padding-right: 10px;
}
ul.col2-point > li.l{
	width:100%;
	margin:0!important;
	float:left;
}
ul.col2-point > li.r{
	width:100%;
	margin:0!important;
	float:right;
}

.blk-point-head{
	width:97%;
	margin:15px 1.5% 0 1.5%;
	border-radius:15px 15px 0 0;
	background:#bfd641;
	border:1px #bfd641 solid;
/*	background:#e4f3d4;*/
/*	border:1px #e4f3d4 solid;*/
/*	background:#ffbbbb;*/
/*	border:1px #ffbbbb solid;*/
	padding-top:10px;
	padding-left:20px;
	box-sizing:border-box;
}
.blk-point{
	margin:0 1.5% 15px;
	border:1px #bfd641 solid;
/*	border:1px #e4f3d4 solid;*/
/*	border:1px #ffbbbb solid;*/
	padding:10px;
	box-sizing:border-box;
	width:97%;
}

@media screen and (min-width : 768px){

ul.col2 > li{
	width:50%;
	padding-top: 0;
	padding-bottom: 10px;
	padding-left: 10px;
	padding-right: 10px;
}
ul.col2-point > li.l{
	width:33%;
	margin:0 2% 0 0!important;
}
ul.col2-point > li.r{
	width:65%;
	margin:0 0 0 0!important;
}
}/* @media screen and (min-width : 768px) */

/*--------------------------------------
  横並び定義２
--------------------------------------*/
ul.u-flow{
 	list-style: none; 
    display: table;
	box-sizing:border-box;
	margin:0 auto;
	margin-bottom:5px;
	padding:0;
}

ul.u-flow > li{
    display: block;
	box-sizing:border-box;
    width: 100%;
	text-align:center;
 	list-style-type: none;
	padding: 5px 0;
    float: none;
	margin:0;
}
ul.u-flow > li.sent{
	text-align:left;
	padding: 5px 15px;

}
@media screen and (min-width : 768px){

ul.u-flow > li{
    display: table-cell;
    width: 30%;
	padding: 5px 0;
    float: left!important;
}
ul.u-flow > li.sent{
    width: 70%;
}
	
}/* @media screen and (min-width : 768px) */


/*--------------------------------------
  PC用フッター定義
--------------------------------------*/

#footer {
	width: 100%;
	margin: 0 auto;
	clear: both;
	background: #e3ffda;
	/* thnx! http://subtlepatterns.com/ */
}

#footer-in {
	width: 1024px;
	margin: 0 auto;
}

#footer-in p {
	margin-bottom: 5%;
}

.footer_l {
	float: left;
	width: 320px;
	font-size: 0.8em;
	margin: 0 20px 0 0!important;
}

.footer_c{
	width: 320px;
	margin: 0 20px 0 0!important;
}

.footer_r{
	width: 320px;
	margin: 0 0 0 0!important;
}
#footer-in ul li{
	line-height:1.2em;
}
#footer-in ul li a {
	font-size:0.7em;
	line-height:0.9em;
}

/*--------------------------------------
 * Contact Form 7カスタマイズ
 * スマホContact Form 7カスタマイズ
--------------------------------------*/

@media(max-width:500px){

div.v2 .inquiry th,div.v2 .inquiry td {
 display:block!important;
 width:100%!important;
 border-top:none!important;
 -webkit-box-sizing:border-box!important;
 -moz-box-sizing:border-box!important;
 box-sizing:border-box!important;
}

div.v2 .inquiry tr:first-child th{
 border-top:1px solid #d7d7d7!important;
}

/* 必須・任意のサイズ調整 */	
div.v2 .inquiry .haveto,div.v2 .inquiry .any {	
font-size:10px;
}
	
}/*@media(max-width:500px)*/

/*見出し欄*/
div.v2 .inquiry th{
 text-align:left !important;
 vertical-align:middle !important;
 font-size:14px;
	font-weight:bold !important;
 color:#444;
 padding-right:5px;
 width:30%;
 background:#f7f7f7;
 border:solid 1px #d7d7d7;
}
/*通常欄*/
div.v2 .inquiry td{
 font-size:14px;
 font-weight:bold !important;
 line-height:1.8;
 border:solid 1px #d7d7d7;
 background: white;
}
/*横の行とテーブル全体*/
div.v2 .entry-content .inquiry tr,div.v2 .entry-content table{
 border:solid 1px #d7d7d7;	
}
/*必須の調整*/
div.v2 .haveto{
 font-size:13px;
 padding:5px;
 background:#ff9393;
 color:#fff;
 border-radius:2px;
 margin-right:5px;
 bottom:1px;
}
/*任意の調整*/
div.v2 .any{
 font-size:13px;
 padding:5px;
 background:#93c9ff;
 color:#fff;
 border-radius:2px;
 margin-right:5px;
 bottom:1px;
}
/*ラジオボタンを縦並び指定*/
div.v2 .verticallist .wpcf7-list-item{
 display:block;
}

/*ボタンの設定*/

div.v2 .wpcf7-back,
div.v2 .wpcf7-confirm,
div.v2 .wpcf7-submit{
    width: 100%;
    /*ボタン幅*/
    padding: 10px;
    /*ボタン内の余白*/
    margin-bottom: 20px;
    border-radius: 30px;
    /*角丸のサイズ*/
    font-size: 24px;
	font-weight:bold;
    /*文字サイズ*/
    letter-spacing: 0.1em;
    border: 1px solid #006400;
    display: inline-block;
    padding: 0.5em 1em;
    text-decoration: none;
    background: #006400;
    /*ボタン色*/
    color: #FFF;
    border-radius: 3px;
    margin: 0 8px;
	cursor: pointer;
	filter: drop-shadow(2px 2px 2px rgba(0,0,0,0.2));
}

div.v2 .wpcf7-back {
    border: 1px solid #f0f0f0;
    background: #fff;
    color: #292929;
}

div.v2 .wpcf7-submit{
	padding-top:1.5em;
	padding-bottom:1.5em;
}

@media(max-width:600px){
div.v2 .wpcf7-back,
div.v2 .wpcf7-confirm,
div.v2 .wpcf7-submit{
    display:block;
	margin:3px auto;
}
}

div.v2 .wpcf7 {
    background: #ffffe0;
	padding:10px 20px;
}

div.v2 .wpcf7 h2.h2_type2{
    color: #494949;
    font-size: 20px;
    font-weight: bold;
    border: none;
    background: none;
    text-align: center;
    margin: 1em 0 0 0;
}

div.v2 span.wpcf7-not-valid-tip{
	font-weight:bold;
}

div.v2 div.wpcf7-mail-sent-ok {
border: 2px solid #398f14 !important;
}
div.v2 div.wpcf7-mail-sent-ng,
div.v2 div.wpcf7-spam-blocked,
div.v2 div.wpcf7-validation-errors {
	border: 2px solid red;
	color: red;
	font-weight:bold;
}

div.v2 .textsp{
	width:95%;
}

div.v2 .hizuke{
	max-width:15em;
	width:95%;
}

div.v2 .onamae,
div.v2 .denwa_bangou,
div.v2 .mail_address,
div.v2 .message {
	width:95%;
}


div.v2 *,
div.v2 * {
	font-family: 'Noto Sans Japanese', "游ゴシック", YuGothic, "HG丸ゴシックM-PRO", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}


div.v2 a:hover img{
}

div.v2 p,
div.v2 p {
	font-size:16px;
	font-weight: 500;
	line-height:2.2;
}

.space_s {
    height: 10px;
}

.space_m {
    height: 20px;
}

.space_l {
    height: 30px;
}

.space10px {
    height: 10px;
}

div.v2 b {
    font-weight: bold;
}

div.v2 h2.h2_type2{
    clear: both;
	padding: 5px 24px;
/*	background-color: #ecf1b0;*/
	background-color:#bfd641;
    background-repeat: repeat;
    border-radius: 12px;
/*    color: #656b44;*/
	color:white;
    font-weight: bold;
/*    border: #bfd63f solid 5px;*/
/*    border: #99ff99 solid 5px;*/
    padding-left: 17px;
    margin-bottom: 10px;
    margin-top: 10px;
    font-size: 24px;
	line-height:2;
}

div.v2 h3,
div.v2 h3 {
	font-size:18px;
    font-weight: bold;
	line-height:1.5;
	padding: 10px 0 10px 10px;
    margin-left: 8px;
    margin-bottom: 20px;
    margin-top: 19px;
	background:none;
	border-radius: 0;
	border:none;
	border-left: 6px solid #bfd63f;
}

div.v2 .red_moji {
    color: #F44336;
}

div.v2 p {

}

div.v2 .access_box {
    width: 100%;
}

div.v2 .access_in {
    width: 95%;
	max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}


div.v2 .access_in_left,
div.v2 .access_in_right {
    float: left;
    padding: 0 1%;
    width: 50%;
	height:auto;
    text-align: center;
}

div.v2 .clear {
    clear: both;
}

@media (max-width: 480px) {

div.v2 .access_in1,
div.v2 .access_in2 {
	width: 100%;
}

}

div.v2 .yakusoku_title {
    padding: .5em .75em;
	background-image: url(../../uploads/2021/02/bg320x440min.jpg);
    border-radius: 6px;
    color: #212121;
    margin-top: 20px;
    margin-bottom: 20px;
    font-size: 22px;
    font-weight: bold;
	line-height:1;
    width: 92%;
    margin-left: auto;
    margin-right: auto;
}

/*--------------------------------------
 * 今すぐLINE予約するバナー
 * -----------------------------------*/

div.v2 .imasugu_line_yoyaku_tyuui{
	text-align:center;
	font-weight:bold;
	font-size:120%;
	line-height:1.4;
	margin-top:0;
}

div.v2 .imasugu_line_yoyaku_tyuui .sp_br{
	display:none;
}

@media (max-width: 600px) {
	div.v2 .imasugu_line_yoyaku_tyuui .sp_br{
		display:initial;
	}
}


/**************************************
 * 漫画のアコーディオン
 *************************************/
.cp_box {
    position: relative;
}

.cp_box input {
    display: none;
}

.cp_box input:checked + label {
    background: inherit;
}

.cp_box input:checked + label::after {
    font-family: FontAwesome;
    content: "" " 閉じる";
}

.cp_box label {
    position: absolute;
    z-index: 1;
    bottom: 0;
    width: 100%;
    height: 140px;
    cursor: pointer;
    text-align: center;
    background: linear-gradient(to bottom, rgba(250, 252, 252, 0) 0%, rgba(250, 252, 252, 0.95) 90%);
}

.cp_box label::after {
    line-height: 2.5rem;
    position: absolute;
    z-index: 2;
    bottom: 20px;
    left: 50%;
    width: 16rem;
    font-family: FontAwesome;
	content: "" " 続きをよむ";
    transform: translate(-50%, 0px);
    letter-spacing: 0.05em;
    color: #fff;
    background-color: #43a23f;
    border-radius: 20px;
}

.cp_box input:checked + label::after {
    font-family: FontAwesome;
    content: "" " 閉じる";
}

.cp_box *, .cp_box *:before, .cp_box *:after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.cp_container {
    overflow: hidden;
    height: 140px;
    transition: all 0.5s;
}

.cp_box input:checked ~ .cp_container {
    height: auto;
    padding-bottom: 80px;
    transition: all 0.5s;
}

@media (max-width: 480px) {

    .cp_container {
        overflow: hidden;
        height: 100px;
        transition: all 0.5s;
    }
}

.clear {
    clear: both;
}

/**************************************
 * 予約のバナー
 *************************************/

.yoyakuWaku {
    background: #fff;
	padding: 12px;
    border: #bfd63f solid 4px;
    border-radius: 8px;
	max-width:700px;
	margin:0 auto;
}

.Yoyaku_in2 {
    width: 100%;
	margin:0 auto;
}

.Yoyaku_in2_left {
    float: left;
	margin: 0;
	width: 49%;
    text-align: center;
}

.Yoyaku_in2_right {
    float: right;
    margin: 0;
	width: 49%;
    text-align: center;
}

/*--------------------------------------
 * ヘッダー画像
 * -----------------------------------*/

.gazou_div{
overflow:hidden;
position: relative;
height: 550px;
}

.gazou_img {
position: absolute;
top: 50%;
left: 50%;
max-width: 2250px !important;
width: auto;
height: 100%;
transform: translate(-50%, -50%);
}

/*--------------------------------------
 * LINE予約の入れ方バナー
 * -----------------------------------*/
.yoyaku_irekata{
	position:relative;
	margin:0 auto;
	width:95%;
}
.yoyaku_irekata img{
	width:100%;
}

.yoyaku_irekata_button{
	position:absolute;
	bottom:0;
	left:2.5%;
	width:95%;
}

/*--------------------------------------
 * 症状別バナー
 * -----------------------------------*/
.syoujyou_banner{
	width:95%;
	max-width:600px;
	margin:0 auto;
}

.syoujyou_banner img{
	width:100%;
	height:auto;
}

/*--------------------------------------
 * コロナウイルス対策画像
 * -----------------------------------*/
.coronavirus_taisaku{
	width:100%;
	height:auto;
	margin:0 auto 10px auto;
}

/*--------------------------------------
 * オファーバナー
 * -----------------------------------*/
.topoffer {
	max-width:700px;
    border: solid 9px #d29f00;
    border-radius: 3px;
    background-image: url(../../uploads/2021/02/topofferbg_min710x353min.jpg);
	margin:0 auto;
}

.topoffer .line_yoyaku_button{
	margin: 10px 15px;
}

.offer_ryoukinhyou_button_pc{
	margin:25px auto !important;
}

.offer_goyoyaku_button_pc{
	margin:25px auto !important;
}

.offerbotanL {
    float: right;
    width: 49.5%;
    margin-top: 0px;
    padding: 0%;
}

.offerbotanR {
    float: left;
    width: 49.5%;
    margin-top: 0px;
    padding: 0%;
    margin-bottom: 8px;
}

.offerbotanL img,
.offerbotanR img{
	display:block;
	margin:20px auto !important;
}

@media (max-width: 480px) {

.topoffer {
    border: solid 5px #d29f00;
}
	
}/*@media (max-width: 480px)*/

/*--------------------------------------
 * トライアルキャンペーンバナー
 * -----------------------------------*/
.trial{
	position: relative;
	
	width:100%;
}

.trial_bg{
	width:100%;
}

.trial_button{
	position: absolute;
	left: 8%;
	bottom: 8%;
	
	width:85%;
}

.trial_button img{
	width:100%;
}

/*--------------------------------------
 * 料金表
 * -----------------------------------*/

.ryoukin{
	font-size: 14pt;
	margin:20px 0 !important;
}

.ryoukin_link{
	color: #ff0000;
	text-decoration: underline;
}

/*--------------------------------------
 * オファー下の注意書き
 * -----------------------------------*/
.offer_tyuigaki{
/*	display:none;*/
	max-width:700px;
	font-family:sans-serif;
	color:#fff;
	font-size: 20px;
	line-height: 28px;
	font-weight:bold;
	background-color:#ff0000;
	text-align:center;
	margin:0 auto;
}

/*--------------------------------------
 * 上部固定のお知らせバナー
 * -----------------------------------*/
.oshirase{
	display:table;
	position: fixed;
	top: 20px;
	left: 5%;
	width:90%;
	height:90px;
	border-radius:10px;
	z-index:9999;
	background-color:#253bd0;
}

.oshirase_text_and_img{
	position:relative;
	display:table-cell;
	width:85%;
}

.oshirase_text{
	vertical-align:top;
	font-size:16px;
	color:yellow;
	font-weight:bold;
	padding:8px;
}

.oshirase_text span{
	background: linear-gradient( rgba(255, 0, 0, 0)60%, rgba(255, 0, 0, 1)60%, rgba(255, 0, 0, 1));
	padding:4px;
}


@media screen and (min-width : 700px) {
.oshirase_br_sp{
	display:none;	
}
}

.oshirase_img{
	position:absolute;
	right:8px;
	bottom:0;
	width:50px;
	z-index:-1;
}

.oshirase_close_button{
	display:table-cell;
	width:15%;
	vertical-align:middle;
	text-align:center;
	cursor: pointer;
	padding:8px;
	background-color:#fffacd;
	border-radius:10px;
}

/*--------------------------------------
 * トップの口コミの表
 * -----------------------------------*/
.kutikomi,
.kutikomi tr,
.kutikomi tr:nth-of-type(2n+1),
.kutikomi td
{
	border:none;
	background:transparent;
}

.kutikomi td:first-child figure
{
	text-align:right;
}

/*--------------------------------------
 * トップの症状別バナー
 * -----------------------------------*/
/*
.syoujou_banner
{
	border-collapse:collapse;
}

.syoujou_banner,
.syoujou_banner tbody,
.syoujou_banner tr,
.syoujou_banner tr:nth-of-type(2n+1),
.syoujou_banner td
{
	border:none;
	background:transparent;
	padding:0;
}

.syoujou_banner td:first-child figure
{
	text-align:right;
}

.syoujou_banner tr:nth-last-child(-n+2) td figure
{
	text-align:center;
}
*/

.syoujou_banner
{
	border-collapse:collapse;
}

.syoujou_banner,
.syoujou_banner tbody,
.syoujou_banner tr,
.syoujou_banner tr:nth-child(2n+1),
.syoujou_banner td
{
	border:none;
	background:transparent;
	padding:0;
}

.syoujou_banner tr td:nth-child(1) figure
{
	text-align:right;
}

.syoujou_banner tr td:nth-child(2) figure
{
	text-align:left;
}

.syoujou_banner tr:first-child td figure,
.syoujou_banner tr:last-child td figure
{
	text-align:center;
}

/*
*{
	outline: 1px solid #ff0000;
}
*/

