@charset "UTF-8";

/*ギャラリー管理*/
/*gallery_02*/
#gallery02{
	background: #e9b4be;
}
#maru_02{
	color: #e9b4be;
	font-size: 18px;
	margin-left: 20px;
}
#galllery_text_2_02{
	font-size: 25px;
	color: #ffffff;
	font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-style: normal;
	line-height:0.5; /*縦の間隔*/
	padding-top: 15px;
}
.plan{
	text-align: center;
}
.plan_text{
	width: 330px;
	height: 50px;
	color: #ffffff;
	background-color: #FF0004;
	font-size: 20px;
	font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-style: normal;
	display: inline-block;
	border-radius: 25px;
	margin-bottom: 15px;
}
.plan_text p{
	line-height: 50px;
}
.kakaku_sub{
	color: #ffffff;
	background-color: #e9b4be;
	font-size: 12px;
	font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-style: normal;
	display: inline-block;
	border-radius: 0 10px 10px 0;
}
.kakaku_sub p{
	padding-top: 6px;
	padding-bottom: 8px;
	padding-left: 25px;
	padding-right: 25px;
	line-height: 1.2;
	justify-content: center;
}
#op_02{
	background-color: #e9b4be;
}
#op_1_02{
	background-color: #f4dadf;
}
/*gallery_03*/
#gallery03{
	background: #c9d3c5;
}
#gallery03_text{
	font-family: hiragino-mincho-pron, sans-serif;
    font-weight: 300;
    font-style: normal;
	color: #666666;
}
#galllery_text_2_03{
	font-size: 18px;
	color: #4d4d4d;
	font-family: hiragino-mincho-pron, sans-serif;
    font-weight: 300;
    font-style: normal;
	line-height:0.5; /*縦の間隔*/
	letter-spacing: 0.15em; /*横の間隔*/
	padding-top: 18px;
}
#galllery_text_min_2_03{
	font-size: 12px;
	color: #a69258;
	font-family: hiragino-mincho-pron, sans-serif;
    font-weight: 300;
    font-style: normal;
	letter-spacing: 0.15em; /*横の間隔*/
	padding-top: 5px;
}
.plan_text_03{
	color: #666666;
	font-size: 20px;
	font-family: hiragino-mincho-pron, sans-serif;
    font-weight: 300;
    font-style: normal;
	letter-spacing: 0.15em; /*横の間隔*/
}
.plan_line{
	width: 85%;
	height: 1.5px;
	background: #b0c9d9;
	margin: 0 0 20px auto;
}
#gallery03_text_sub{
	font-size: 12px;
	color: #666666;
	font-family: hiragino-mincho-pron, sans-serif;
    font-weight: 300;
    font-style: normal;
}
#gallery03_text_sub_2{
	font-size: 15px;
	color: #666666;
	font-family: hiragino-mincho-pron, sans-serif;
    font-weight: 300;
    font-style: normal;
	padding: 20px 0 0 0;
}

#maru_03{
	color: #c9d3c5;
	font-size: 18px;
	margin-left: 20px;
}
#gallery03_kakaku_sub{
	background: #c9d3c5;
	font-size: 9px;
	font-family: hiragino-mincho-pron, sans-serif;
    font-weight: 300;
    font-style: normal;
	color: #534741;
	letter-spacing: 0.1em; /*横の間隔*/
}
#gallery03_kakakusub_p{
	line-height: 1.5;
}
/*gallery_04*/
#gallery04{
	background: #f4ece0;
}
#maru_04{
	color: #f4ece0;
	font-size: 18px;
	margin-left: 20px;
}
#galllery_text_min_2_04{
	color: #534741;
	font-size: 20px;
	padding-top: 15px;
}
#op_04{
	background-color: #e3ddcd;
}
#op_1_04{
	background-color: #f4ece0;
}
.speechBubble {
  position: relative;
  display: inline-block;
  margin-top: 20px;
  padding: 12px 16px;
  border-radius: 8px;
  background-color: #e3ddcd;
  text-align: left;
  font-size: 10px;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: 0.07em;
  color: #231815;
  margin-left: 10px;
}
.speechBubble::after {
  content: "";
  position: absolute;
  top: 0;
  left: 15%;
  border-style: solid;
  border-width: 0 0 20px 20px;
  border-color: transparent transparent #e3ddcd;
  translate: -50% -100%;
  transform: skew(-20deg);
  transform-origin: bottom;
}
/*ID_photo*/
#small_2{
	color: #333;
	font-size: 13px;
	padding-left: 40px;
	font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-style: normal;
}
/*about*/
.about_text{
	width: 100%;
	margin-bottom: 40px;
}
.about_text p{
	font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-style: normal;
	font-size: 15px;
	letter-spacing: 0; /*横の間隔*/
	line-height: 1.5; /*縦の間隔*/
	padding: 0 20px 0 20px;
}
.about_photo{
	width: 100%;
	height: auto;
	display: grid;
    place-content: center;
	margin: 20px 0;
}
.about_photo img{
	width: 90%;
	margin: 0 auto;
}
.about_us_photo{
	max-width: 350px;
	max-height: 350px;
	margin: 0 auto;
}
.about_us_photo img{
	max-width: 350px;
	max-height: 350px;
}
.us{
	font-family: a-otf-jun-pro, sans-serif;
    font-weight: 300;
    font-style: normal;
}
.about_us_name{
	display: flex;
}
.about_us_post{
	font-size: 17px;
	color: #3B3B3B;
	padding-left: 30px;
	padding-top: 15px;
}
#j{
	font-size: 15px;
	color: #3B3B3B;
	padding-left: 30px;
	padding-top: 25px;
}
#e{
	font-size: 15px;
	color: #777777;
	padding-left: 20px;
	padding-top: 25px;
}
.about_us_comment{
	font-size: 13px;
	color: #3B3B3B;
	padding-left: 40px;
	padding-right: 40px;
	padding-top: 15px;
	padding-bottom: 80px;
	line-height: 2; /*縦の間隔*/
}
@media screen and (min-width: 481px){
.about_text{
	text-align: center;	
}
.about_photo{
	max-width: 600px;
	margin: 20px auto;
}
.pc{
	display:flex;
	justify-content: center;
}
.about_us_photo{
	width: 350px;
}
.us{
	width: 350px;
	padding-bottom: 100px;
}
}

/*----*/

.gallery{
	width: 100%;
	height: auto;
	background: #ffffff;
	margin-top: 80px;
	margin-bottom: 0px;
}

.gallery_photo{
	text-align: center;
}

div.gallery img{
	margin-top: 0px;	
	width: 100%;
    height: auto;
}

/*-title-*/
.galllery_title{
	position: relative;
	margin: 0 auto;
    text-align: center;
	margin-top: 30px;
}
.galllery_line{
	width: auto;
	height: 40px;
	background: #b0c9d9;
}

.galllery_box{
	width: auto;
	height: 80px; /*タイトルと写真の間隔*/
	background: #ffffff;
}
.galllery_text{
  position: absolute;
  top: 6px;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}
.galllery_text{
	font-size: 40px;
	color: #786756;
	font-family: "M PLUS Rounded 1c", sans-serif;
}
.galllery_text_min{
  position: absolute;
  top: 60px;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}
.galllery_text_min{
	font-size: 15px;
	color: #5A5A5A;
	font-family: "M PLUS Rounded 1c", sans-serif;
}
/*-photo-*/
.gallery_01_01 {
  display: grid;
  gap: 0;
  grid-template-columns: repeat(4, 1fr);
  column-gap: .2rem;
  grid-row-gap: 0rem;
  margin-left: 5px;
  margin-right: 5px;
  margin-bottom: 40px; /*写真とpriceの間隔*/
  justify-content: center;
}

div.item_g img{
width: 100%;
aspect-ratio: 1 / 1;
object-fit: cover;
border-radius: 10px; /*角を丸く*/
}

/*-title_2-*/
.galllery_title_2{
	margin: 0 auto;
}
.galllery_line_2{
	width: auto;
	height: 63px;
	background: #b0c9d9;
	margin: 0 auto;
	text-align: center;
}
.galllery_box_2{
	width: auto;
	height: 30px;
	background: #ffffff;
}
#galllery_text_2{
	font-size: 30px;
	color: #ffffff;
	font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-style: normal;
	line-height:0.5; /*縦の間隔*/
	padding-top: 15px;
}
#galllery_text_min_2{
	font-size: 15px;
	color: #ffffff;
	font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-style: normal;
}
/*sub*/
.gallery_sub{
	position: relative;
	margin: 0 auto;
}
.gallery_sub_text{
	font-size: 18px;
	color: #333;
	font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-style: normal;
	text-align: center;
}
.gallery_sub_min{
	font-size: 15px;
	color: #333;
	font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-style: normal;
	text-align: center;
}
/*価格表*/
.price_list{
	display: flex;
	align-items: flex-end; /*文字の下揃え*/
	font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-style: normal;
	letter-spacing: 0.08em; /*横の間隔*/
	line-height:1.5; /*縦の間隔*/
}
#maru{
	color: #b0c9d9;
	font-size: 18px;
	margin-left: 20px;
}
 #big{
	color: #333;
	font-size: 18px
}
 #small{
	color: #333;
	font-size: 13px;
}

.price_line{
	width: 90%;
	height: 2px;
	background: #b0c9d9;
	text-align: left;
	margin-bottom: 20px;
}

.kakaku{
	display: grid;
	text-align: right;
	margin-right: 20px;
	font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-style: normal;
	letter-spacing: 0.08em; /*横の間隔*/
	line-height:1.5; /*縦の間隔*/
}

#price_list_menu{
	color: #333;
	font-size: 15px;
}
#price_list_menu_min{
	font-size: 13px;
}
.space{
	width: auto;
	height: 10px;
	background: #ffffff;
}
.price_photo{
	text-align: center;
}
.price_photo img{
	width: 100%;
	height: auto;
}

.option{
	width: 100%;
	height: auto;
	padding-bottom: 10px;
	padding-top: 10px;
	margin-top: 20px;
	margin-bottom: 50px;
	background: #98cbcb;
	font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-style: normal;
	letter-spacing: 0.08em; /*横の間隔*/
	line-height:1.5; /*縦の間隔*/
}
#price_list_op{
	color: #fff;
	margin-left: 20px;
}
.option_1{
	width: auto;
	padding: 10px;
	margin-left: 20px;
	margin-right: 20px;
	background: #cce5e5;
}
.option_2{
	width: auto;
	padding: 10px;
	margin-left: 20px;
	margin-right: 20px;
	margin-top: 10px;
	margin-bottom: 20px;
	background: #cce5e5;
}

.option_line{
	width: 50%;
	height: 1px;
	background: #ffffff;
	text-align: left;
	margin-bottom: 20px;
}
@media (min-width: 480px) {
.price_list_pc{
	width: 50%;
	margin: 0 auto;
}
}
/*クリックで拡大*/
.modal {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgb(0,0,0);
  background-color: rgba(0,0,0,0.9);
  align-items: center;
  justify-content: center;
  animation: modalFadeIn 0.3s;
}

.modal img {
  max-width: 90%;  /* 画像の最大幅を親要素(modal)の90%に制限し、画面内に収まるようにする */
  max-height: 100vh;  /* 画像の最大高さをビューポートの高さ(100vh)に制限し、画面内に収まるようにする  */
  object-fit: contain;  /* 画像の比率を保持しつつ、指定された高さと幅に収める */
}


@keyframes modalFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes modalFadeOut {
  from { opacity: 1; }
  to { opacity: 0; }
}