@charset "UTF-8";

body {
	font-family:  "Zen Maru Gothic", sans-serif;
	color: #3b3a3a;	
  background: url(../images/background_images_pc.png);
  background-size: contain;
  background-repeat: repeat-y;
	background-color: #f9f9e7;
	margin: 0;
}

img {
	/* 最大幅を100%に指定 */
	max-width: 100%;
}

a {
	/* デフォルトCSSを打ち消す */
	text-decoration: none;
	color: #3b3a3a;
}
ul {
	/* デフォルトCSSを打ち消す */
    list-style-type: none;
}

/** -----------------------------------
    レイアウト
-------------------------------------**/
#pochinitsuite, #menu, #shitsuke, #insta, #tenpo, #ryokinhyo, #kiyaku, #nanobubble-ex {
  margin: 80px 0;
}

.pochinitsuite1, .pochinitsuite2, .nanobubble, .syokaitokuten, .shower, .ozon{
  margin: 40px 0;
}

html {
  scroll-padding-top: 110px; /*ヘッダーの高さ分設定*/
}

.section-inner {
	/* 横幅を100%に設定 */
	width: 100%; 
	/* 横幅の最大値を960pxに設定 */
	max-width: 960px; 
	/* 左右中央に配置 */
	margin: 0 auto; 
	/* 画面からはみ出した部分のイラストを非表示 */
	overflow: auto; 
}

.col-1 {
  display: flex;
  align-items: center;
	margin: 60px 0;
}

.col-2 {
	display: flex;
	justify-content: space-between;
  align-items: center;
}

.col-2 .item {
	width: calc((100% - 40px)/2);
}

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

.col-3 .item {
  width: calc((100% - 60px)/3);
}

/* pcとspで表示を切り替えたい時のCSS① */
.pc-only {
	/* pc時に表示 */
    display: block; 
}
.sp-only {
	/* pc時に非表示 */
 	 display: none; 
}


/** -------- スマホ -------- **/
@media screen and (max-width: 768px) {

	html {
		scroll-padding-top: 60px; /* ヘッダーの高さ分設定*/
	}
	#pochinitsuite, #menu, #shitsuke, #insta, #tenpo, #ryokinhyo, #kiyaku, #nanobubble-ex {
		margin: 40px 0;
	}
	
	.col-1, .pochinitsuite1, .pochinitsuite2, .nanobubble, .syokaitokuten, .shower, .ozon{
		margin: 40px 0;
	}

	.section-inner {
		/* 左右に24pxの余白（padding） */
		
		/* 最大幅を550pxに */
		max-width: 90%; 
	}

	.col-2 {
		/* sp時は横並びを解除 */
		display: block;
	}

	.col-2 .item {
		/* sp時の要素は横幅いっぱいになるように */
		width: 100%;
	}

  .col-3 {
		/* sp時は横並びを解除 */
		display: block;
		text-align: center;
	}

	.item {
		text-align: center;
	}

	.item img {
		width: 80%;
		padding: 12px 0;
	}

	/* pcとspで表示を切り替えたい時のCSS② */
	.pc-only {
		/* pc時に非表示 */
		display: none; 
	}
	.sp-only {
		/* pc時に表示 */
		display: block; 
	}

}

/** -----------------------------------
    テキスト
-------------------------------------**/
h2 {
	font-weight: bold;
  letter-spacing: -0.05em;
	font-size: 30px;
  text-align: center;
}

h2.medium {
	font-weight: bold;
  letter-spacing: -0.05em;
	font-size: 30px;
  text-align: left;
	margin: 0 auto;
}

p {
	font-size: 18px;
  letter-spacing: 0.10em;
  line-height: 1.5;
  text-align: left;
}

p.medium {
	font-size: 20px;
  letter-spacing: 0.10em;
  text-align: left;
  margin-bottom: 20px;
}

/** -------- スマホ -------- **/
@media screen and (max-width: 768px) {
	h2 {
		/* フォントサイズ26px */
		font-size: 15px;
	}

	h2.medium {
		font-size: 15px;
	}

	p {
		/* フォントサイズ15px */
		font-size: 15px;
	}

	p.medium {
		font-size: 15px;
	}

	.midashi {
		text-align: center;
	}
	.midashi img {
		width: 60%;
	}

	.col-1 .item img {
		width: 60%;
	}
}

/** -----------------------------------
    ヘッダー
-------------------------------------**/
#header {
	box-sizing: border-box;
	/* 背景色を指定 */
	background-color: rgba(255, 255, 255, 0.8);
	/* 横幅を指定 */
	width: 100vw;
	/* 高さを指定 */
	height: 110px;
	/* ロゴとメニューを横並びに・左右に散るように指定 */
	display: flex;
	/* 左右に散るように指定 */
	justify-content: space-between;
	/* 上下中央に配置 */
	align-items: center;
	/* 左右に内側余白を設定 */
	padding: 0 70px;
	/* ヘッダーをページ上部に固定 */
	position: fixed;
	top: 0;
	/* ほか要素よりも重なり順を1つ上に指定 */
	z-index: 1;
}

.header-logo {
	/* ロゴをヘッダーの上下中央にするための記述① */
	display: flex;
	align-items: center;
	/* ロゴの横幅を指定 */
	width: 200px;
}

.header-logo a {
	/* ロゴをヘッダーの上下中央にするための記述② */
	display: flex;
}

ul.gnav-pc li {
	/* inline要素にして横並びにする */
	display: inline;
}

ul.gnav-pc li img {
  width: auto;
  height: 20px;
	margin: 0 20px 0 20px
}

ul.gnav-pc li a:hover {
	/* メニューをホバーした時、透明度0.7 */
	opacity: 0.7;
}

#menu-button {
	/* ハンバーガーボタンはpc時に非表示にする */
  	display: none;
}

/** -------- スマホ -------- **/
@media screen and (max-width: 768px) {
	#header {
		/* sp時ヘッダー高さを60pxに */
		height: 60px;
		/* 左右の余白を削除 */
		padding: 0;
	}

	#header h1 {
		/* sp時ロゴの大きさを横幅180pxに */
		width: 130px;
		/* 左余白24px */
		margin-left: 24px;
	}

	ul.gnav-sp {
		padding: 0;	
	}

ul.gnav-sp li img {
		margin-bottom: 20px;
	}

	nav.gnav-pc-wrap {
		/* sp時、pc用のメニューは非表示にする */
		display: none;
	}

	#menu-button {
		/* sp時ハンバーガーメニューを表示 */
		display: block;
		/* ハンバーガーメニューのクリックエリア 横60px,高さ60pxに指定 */
		width: 40px;
		height: 30px;
		/* paddingでクリックエリアに内側余白を作る */
		padding: 18px 16px;
	}

	.menu-button-inner{
		/* 親要素#menu-buttonの大きさいっぱいに要素を広げる */
		display: block;
		width: 100%;
		height: 100%;
		/* span（三本の線）の配置基準とするため、position:relative;を指定 */
		position: relative;
	}

	.menu-button-inner span{
	    display: block;
		/* 高さ3px 横幅100%の矩形にする */
	    width: 100%;
	    height: 4px;
			border-radius: 10px;
		/* positionで配置したい要素なので、absoluteを指定 */
	    position: absolute;
	}
	.menu-button-inner span:nth-of-type(1){
		/* ハンバーガーボタン一番目の線 */
		top: 0;
		background: #f794cc;
	}
	.menu-button-inner span:nth-of-type(2){
		/* ハンバーガーボタン二番目の線（上下中央に配置） */
		top: 0;
		bottom: 0;
		margin: auto;
		background: #ccccca;
	}
	.menu-button-inner span:nth-of-type(3){
		/* ハンバーガーボタン三番目の線 */
	  bottom: 0;
		background: #81f8f1;
	}

	/* ハンバーガーボタンをクリックしたら×にする */
	.close span:nth-of-type(1){
	    width: 100%;
		/* 線を45度右下に傾ける */
	    transform: rotate(45deg);
		/* 位置の微調整 */
		top: 10px;
	}
	.close span:nth-of-type(2){
		/* 2番目の線は見えなくする */
	    opacity: 0;
	}
	.close span:nth-of-type(3){
	    width: 100%;
		/* 線を45度右上に傾ける */
	    transform: rotate(-45deg);
		/* 位置の微調整 */
		bottom: 16px;
	}
}

/* SP用ハンバーガーメニュー中身のスタイル */
.gnav-sp-wrap {
	/* JSで表示させるので、最初は非表示にしておく */
	display: none;
	/* 背景色を指定 */
	background-color: #f9f9e7;
	/* 背景色を画面いっぱいに広がるようにする */
	width: 100vw;
	height: 100vh;
	/* スクロールしないように画面に固定 */
	position: fixed;
	/* 他の要素よりも重なり順を上にする */
	z-index: 1;
	/* メニューの位置を調整するため、上部に内側余白をつける */
	padding-top: 100px;
}

ul.gnav-sp li {
	/* 左右中央に配置 */
	text-align: center;
	/* 下側に余白30px */
	margin-bottom: 60px;
}

/** -----------------------------------
    メインビジュアル
-------------------------------------**/

#mainvisual {
	position: relative;
	max-width: 100vw;
	margin-top: 120px;
	text-align: center;
}

#mainvisual {
  animation: fadeIn 5s cubic-bezier(0.33, 1, 0.68, 1) forwards;
}
 
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

#mainvisual .pc {
	width: 75%;
	margin: 0 auto;
}

#mainvisual .sp {
	display: none;
}

.subcopy {
	position: absolute;
	bottom: 25%;
	left: 2%;
  width: 40%;
	border-radius: 10px;
  background-color: rgba(255, 255, 255, 0.6);
  padding: 5px 10px;
}

.maincopy {
	position: absolute;
	bottom: 10%;
	left: 2%;
  width: 45%;
	border-radius: 10px;
  background-color: rgba(255, 255, 255, 0.6);
  padding: 10px 16px;
}

.subcopy {
  animation: slideIn 5s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

@keyframes slideIn {
  0% {
    transform: translateX(180px);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
  }
  40%,100% {
    opacity: 1;
  }
}

.maincopy {
  animation: slideIn 5s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

@keyframes slideIn {
  0% {
    transform: translateX(180px);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
  }
  40%,100% {
    opacity: 1;
  }
}

/** -------- スマホ -------- **/
@media screen and (max-width: 768px) {
	#mainvisual {
		position: relative;
		margin-top: 60px;
		text-align: center;
	}

	#mainvisual .sp{
		display: block;
		width: 90%;
		margin: 0 auto;
	}

	#mainvisual .pc {
		display: none;
	}

	.subcopy {
		width: 50%;
		bottom: 25%;
		left: 1%;
	}
	
	.maincopy {
		width: 60%;
		bottom: 12%;
		left: 1%;
	}

}

/* ポチについて1 */
#pochinitsuite .col-1 .midashi {
  position: relative;
  margin: 0 auto;
  width: 240px;
}

#pochinitsuite .col-1 .item {
  position: absolute;
  left: 36%;
  width: 150px;
}

.pc {
	display: block;
	width: calc((100% - 60px)/3);
}

.sp {
	display: none;
}

/* ----- スマホ ----- */

@media screen and (max-width: 768px) {
	#pochinitsuite .midashi {
		width: 40%;
	}

	#pochinitsuite .col-1 .item {
		position: absolute;
		text-align: center;
		width: 100px;
	}

	#pochinitsuite .pochinitsuite1 .col-2 {
		display: flex;
		flex-direction: column-reverse;
	}

	.pc {
		display: none;
	}

	.sp {
		display: block;
		width: 70%;
		margin: 20px auto;
	}

}

/* ポチについて２ */
/* ----- スマホ----- */
@media screen and (max-width: 768px) {
	#pochinitsuite .pochinitsuite2 .col-3 .sp {
		width: 90%;
	}

}

/* 初回特典 */
.syokaitokuten {
  width: 70%;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
	.syokaitokuten{
		width: 80%;
	}
}

/* メニュー */
#menu {
	background-color: rgba(235, 254, 253, 0.5);
}

#menu .col-1 .midashi {
  position: relative;
  margin: 0 auto;
  width: 160px;
}

#menu .col-1 .item {
  position: absolute;
  left: 38%;
  width: 150px;
}

#menu h2 {
	text-align: center;
}

#menu p {
	text-align: center;
}

#menu .text {
	margin-bottom: 60px;
}

a.ryokin-button {
	display: block;
	width: 300px;
	height: 100px;
	background-color: #f794cc;
	color: #fff;
	font-size: 25px;
	letter-spacing: 0.08em;
	line-height: 95px;
	text-align: center;
	border-radius: 50px;
	margin: 50px auto;
	transition: .4s cubic-bezier(0.37, 0, 0.63, 1);
}

	a.ryokin-button:hover {
		background: #fff;
		color: #f794cc;
		letter-spacing: 0.15em;
		border-style: solid;
	}

	/* ----- スマホ ----- */
	@media screen and (max-width: 768px){
		#menu .col-1 .item {
			position: absolute;
			text-align: center;
			width: 100px;
		}

		#menu .text {
			margin-bottom: 35px;
		}
		
		a.ryokin-button {
			display: block;
			width: 160px;
			height: 55px;
			font-size: 15px;
			letter-spacing: 0.08em;
			line-height: 50px;
			text-align: center;
			border-radius: 50px;
			margin: 20px auto;
		}

	}


/* 訓練・しつけ */
#shitsuke .col-1 .midashi {
  position: relative;
  margin: 0 auto;
  width: 240px;
}

#shitsuke .col-1 .item {
  position: absolute;
  left: 35%;
  width: 150px;
}

/* ----- スマホ----- */
@media screen and (max-width: 768px){
#shitsuke .col-1 .item {
	position: absolute;
	text-align: center;
	width: 100px;
}
}

/* インスタ */
#insta .col-1 .midashi {
  position: relative;
  margin: 0 auto;
  width: 240px;
}

#insta .col-1 .item {
  position: absolute;
  left: 35%;
  width: 150px;
}

.insta-logo {
	text-align: center;
}


.acount p{
	text-align: center;
	text-decoration: underline;
}

.acount p:hover {
	color: blue;
	opacity: 80%;
}

.insta_list{
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin: 20px 0;
}

.insta_list li{
	position: relative;
	width: calc((100% - 40px)/3);
}

@media screen and (max-width: 750px){
	.insta_list li{
			width: calc((80% - 10px)/3);
	}
}

.insta_list li::before{
content: "";
display: block;
padding-top: 100%;
}

.insta_list a{
position: absolute;
top: 0;
width: 100%;
height: 100%;
}

.insta_list img{
width: 100%;
height: 100%;
object-fit: cover;
}


/* ----- スマホ----- */
@media screen and (max-width: 768px){
	#insta .col-1 .item {
		position: absolute;
		text-align: center;
		width: 100px;
	}
	}

/* 店舗案内 */
#tenpo .text p {
	font-size: 20px;
	text-align: center;
}

#tenpo .col-1 .midashi {
  position: relative;
  margin: 0 auto;
  width: 160px;
}

#tenpo .col-1 .item {
  position: absolute;
  left: 38%;
  width: 150px;
}

#tenpo .col-2 {
  margin: 50px 0;
}

a.tel {
	color: blue;
	text-decoration: underline;
}

a.tel:hover {
	opacity: 60%;
}

.item .tenpo-button {
	display: flex;
}

a.map-button {
	display: block;
	width: 180px;
	height: 70px;
	background-color: #f794cc;
	color: #fff;
	font-size: 20px;
	letter-spacing: 0.08em;
	line-height: 65px;
	text-align: center;
	border-radius: 50px;
	margin-right: 20px;
	transition: .4s cubic-bezier(0.37, 0, 0.63, 1);
}

a.map-button:hover {
	background: #fff;
	color: #f794cc;
	letter-spacing: 0.15em;
	border-style: solid;
}

a.tel-button {
	display: block;
	width: 180px;
	height: 70px;
	background-color: #f794cc;
	color: #fff;
	font-size: 20px;
	letter-spacing: 0.08em;
	line-height: 65px;
	text-align: center;
	border-radius: 50px;
	transition: .4s cubic-bezier(0.37, 0, 0.63, 1);
}

a.tel-button:hover {
	background: #fff;
	color: #f794cc;
	letter-spacing: 0.15em;
	border-style: solid;
}

/*----- スマホ -----*/
@media screen and (max-width: 768px){
	#tenpo .col-1 .item {
		position: absolute;
		text-align: center;
		width: 100px;
	}

#tenpo .text p {
	font-size: 15px;
	text-align: center;
}

h2.medium{
	margin: 10px 0 0 8%;
}

p.medium {
	margin: 0 0 3% 8%;
}

.tenpo-button {
	display: flex;
	justify-content: center;
	margin-top: 15px
	
}

a.map-button {
	width: 130px;
	height: 50px;
	font-size: 13px;
	line-height:46px;
	
}

a.tel-button {
	width: 130px;
	height: 50px;
	font-size: 13px;
	line-height:46px;
}

}

/* フッター */
#footer {
	background-color: #fff;
	color: #3b3a3a;
	text-align: center;
	padding: 10px 20px;
}

p.copyright {
	text-align: center;
}

/* ----- スマホ----- */
@media screen and (max-width: 768px){
	p.copyright {
		font-size: 10px;
	}
}

/* 料金表 */
#ryokinhyo .col-1 .midashi {
  position: relative;
  margin: 50px auto;
  width: 160px;
}

#ryokinhyo .col-1 .item {
  position: absolute;
  left: 38%;
  width: 150px;
}

.ryokinhyo {
	padding-bottom: 50px;
	width: 700px;
	margin: 0 auto;
}

#ryokinhyo ul {
	list-style-type: disc;
	width: 80%;
	margin: auto;
}

#ryokinhyo ul li {
	font-size: 18px;
	text-align: left;
	margin-bottom: 25px;
}

/* ----- スマホ ----- */
@media screen and (max-width: 768px){

	#ryokinhyo .col-1 .midashi {
		margin: 0 auto;
	}

	#ryokinhyo .col-1 .item {
		position: absolute;
		text-align: center;
		width: 100px;
	}
	
.ryokinhyo {
	width: 80%;
	margin: 0 auto;
}

#ryokinhyo ul {
	width: 80%;
	padding: 0 0 0 10px;
}

#ryokinhyo ul li {
	font-size: 15px;
}
}

/* トリミング規約 */
#kiyaku .col-1 .midashi {
  position: relative;
  margin: 0 auto;
  width: 280px;
}

#kiyaku .col-1 .item {
  position: absolute;
  left: 33%;
  width: 150px;
}

#kiyaku .list  {
	display: flex;
	text-align: center;
	list-style-type: disc;
	width: 80%;
	margin: 40px auto;
}

#kiyaku .list img {
	width: 50px;
	height: 100%;
}

#kiyaku .list p {
	font-size: 18px;
	margin: auto 10px;
}

/* ----- スマホ ----- */
@media screen and (max-width: 768px){
	#kiyaku .col-1 .item {
		position: absolute;
		text-align: center;
		width: 100px;
	}
#kiyaku .list img {
	width: 30px;
}

#kiyaku .list {
	width: 100%;
}

#kiyaku .list p {
	font-size: 15px;
}
}

/* ナノバブル説明 */
#nanobubble-ex .col-1 .midashi {
  position: relative;
  margin: 0 auto;
  width: 560px;
}

#nanobubble-ex .col-1 .item {
  position: absolute;
  left: 25%;
  width: 150px;
}

/* ----- スマホ ---- */
@media screen and (max-width: 768px){
	#nanobubble-ex .col-1 .item {
		position: absolute;
		align-items: center;
		width: 100px;
	}

	#nanobubble-ex .shower .col-2 {
		display: flex;
		flex-direction: column-reverse;
	}

}

