@charset "UTF-8";
/* CSS Document */
/*===================================================
	土台作成用CSS
===================================================*/

/*//////////////////////////////////////////////////
	共通設定
///////////////////////////////////////////////////*/
* {
			box-sizing: border-box;
		-ms-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}

html, body {
	width:100%;
	height:100%;
}

body {
	-webkit-text-size-adjust: 100%;
	/*font-family: Hiragino Kaku Gothic Pro,"ヒラギノ角ゴシック Pro",Meiryo,"メイリオ", Osaka,MS PGothic,"ＭＳ Ｐゴシック",sans-serif;*/
	font-size: 14px;
	line-height: 1.7;
	word-break: break-all;
	text-align: center;
	color: #000000;
	background-color: #FFF;
/*
	min-width: 960px;
*/
	z-index: 1;
}

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

/* 画像幅 */
/*img {
	width: 100%;
}*/

/*float解除*/
.clearfix:after {
	content: ".";
	display: block;
	height: 0;
	font-size: 0;
	clear: both;
	visibility: hidden;
}

/*//////////////////////////////////////////////////
	ページ共通部分設定
///////////////////////////////////////////////////*/
/*背景*/

#bg1, #bg2, #bg3, div#contents_wrap {
	z-index:-3;
	top:0;
	left:0;
	width:100%;
	height:100%;
}

#bg1{
	background:#FFEAEA;
}

#bg2 {
	z-index:-2;
	background-image:url(../img/bg-01_l.png);
}

#bg3 {
	z-index:-1;
	background-image:url(../img/bg-02_l.png);
}

.back {
	position: fixed;
	width: 100%;
	height: 900%;
	top: 0;
	left: 0;
	z-index: -3;
}
#back1 {
	background:#FFEAEA;
}
#back2 {
	background-image:url(../img/bg-01_l.png);
	background-size: contain;
}
#back3 {
	background-image:url(../img/bg-02_l.png);
	background-size: contain;
}

/* 要素 */

div#contents_wrap{
	z-index:1;
}

	div#top_wrap {
		max-width:960px;

		margin:0 auto;
		background:#fff;
		border:#000 solid 10px;
		margin-bottom:10px;
	}

	div#middle_wrap {
		max-width:960px;

		margin:0 auto;
		background:#fff;
		border:#000 solid 10px;
		margin-bottom:10px;
	}

	div#bottom_wrap {
		max-width:960px;

		margin:0 auto;
		background:#fff;
		border:#000 solid 10px;
		margin-bottom:10px;
	}
/* --------------------------------------------------
	1. header
-------------------------------------------------- */
header {
	width: 100%;
	background: #FFFFFF;
}
	header .headWrap {
		position: relative;
		overflow: hidden;
		max-width: 1100px;
		margin: 0 auto;
		padding: 20px 10px 15px;
	}
		header .headWrap h1 {
			float: left;
			padding-top: 5%;
		}
			header .headWrap h1 a {
				display: block;
			}
		header .headWrap ul {
			float: right;
		}
			header .headWrap ul li + li {
				margin-top: 10px;
			}
	header .slideBtn {
		display: none;
	}
	#navToggle {
		display: none;
		position: absolute;
		right: 12px;
		top: 20px;
		width: 34px;
		height: 36px;
		cursor: pointer;
		z-index: 101;
	}
		#navToggle div {
			position: relative;
		}
			#navToggle span {
				display: block;
				position: absolute;
				height: 4px;
				width: 100%;
				background: #666;
				left: 0;
				-webkit-transition: .35s ease-in-out;
				-moz-transition: .35s ease-in-out;
				transition: .35s ease-in-out;
			}
			#navToggle span:nth-child(1) {
				top: 0;
			}
			#navToggle span:nth-child(2) {
				top: 11px;
			}
			#navToggle span:nth-child(3) {
				top: 22px;
			}
/* nav
-------------------------------------------------------------- */
nav {
	width: 100%;
	background: url("../img/bg_nav.png") repeat-x;
	background-size: 35px auto;
	}
	nav ul {
			display: flex;
		width: 100%;
			max-width: 960px;
			margin: 0 auto;
			padding: 0;
			list-style: none;
		}
		nav ul li {
			flex: 1;
			min-width: 0;
			text-align: center;
		    font-size: 16px;
		    line-height: 50px;
		    font-weight: bold;
		}
		nav ul li a {
		  display: block;
		  color: #FFFFFF;
		  text-decoration: none;
		  font-size: 16px;
		  white-space: nowrap;
		}
@media screen and (max-width: 768px) {

  header .headWrap {
    padding: 15px 10px;
  }

  header .headWrap h1 {
    float: none;
    padding-top: 0;
    width: 70%;
  }

  header .headWrap h1 img {
    max-width: 100%;
    height: auto;
  }

  header .headWrap ul {
    display: none;
  }

  #navToggle {
    display: block;
  }

  nav {
    display: none;
    width: 100%;
    background: #fff;
  }

  nav.open {
    display: block;
  }

  nav ul {
    display: block;
    max-width: 100%;
  }

  nav ul li {
    flex: none;
    width: 100%;
    font-size: clamp(11px, 1.5vw, 16px);
    font-size: 15px;
    border-bottom: 1px solid #ddd;
  }

  nav ul li a {
    padding: 15px 20px;
    text-align: left;
    line-height: 1;
	font-size: 16px;
  }
}
/* --------------------------------------------------
	2. main
-------------------------------------------------- */
#kv {
	background: url("../img/kv.png") top center no-repeat;
	background-size: cover;
}
	#kv h2 {
		max-width: 1066px;
		margin: 0 auto;
		padding-top: 30%;
	}
section {
	max-width: 960px;
	margin: 0 auto 60px;
}

/* 契約実績
-------------------------------------------------------------- */
#con1 table {
	width: 100%;
}
#con1 table thead tr {
	text-align: center;
	color: #FFFFFF;
	border-bottom:1px solid #000000;
	background: #E64110;
}
	#con1 table thead tr th {
		font-size: 20px;
		text-align: center;
		border-right:1px solid #000000;
	}
	#con1 table thead tr th:last-child{
		border: none;
	}
#con1 table tbody tr {
	border-left:1px solid #000000;
	border-bottom:1px solid #000000;
}
	#con1 table tbody tr th {
		font-size: 23px;
		color: #000000;
		text-align: center;
		border-right:1px solid #000000;
		background: #FFEAB4;
	}
	#con1 table tbody tr td {
		font-size: 25px;
		color: #E64110;
		font-weight: bold;
		text-align: center;
		border-right:1px solid #000000;
		background: #FFFFFF;
	}
		#con1 table tbody tr td em {
			font-size: 40px;
		}
#con1 table + p {
	text-align: right;
}
	#con1 table + p img {
		width: 463px;
	}
/* 製品一覧リスト */
#con1 > div {
	overflow-y: scroll;
	height: 800px;
	padding: 20px;
	border: 2px solid #FFA000;
	background: #FFFFFF;
	-webkit-overflow-scrolling: touch;
}
	#con1 > div ul {
		/*margin: -10px 0 0 -10px;*/
	}
		#con1 > div ul li {
			display: inline-block;
			/*margin: 10px 0 0 10px;*/
		}

/* お知らせ
-------------------------------------------------------------- */
.banner-list{
  display: flex;
  align-items: center; /* 縦位置揃え */
  gap: 10px; /* 余白 */
  list-style: none; /* ・を消す */
  padding: 0;
  margin: 0;
  flex-wrap: nowrap;
  flex-direction: row;
  justify-content: center;
}
@media (min-width: 961px) {
 .banner-list{
  align-items: center; /* 縦位置揃え */
  gap: 20px; /* 余白 */
  list-style: none; /* ・を消す */
  padding: 0;
  margin: 0;
  flex-wrap: nowrap;
  flex-direction: row;
  justify-content: center;
}
.banner-list li {
	height: auto;
	gap: 50px;
	}
}
.banner-img {
  display: block;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
.banner-img2 {
  display: block;
  position: relative;
  padding: 50px 0;
}
.banner-img3 {
  display: block;
  position: relative;
  margin: 0 auto;
  padding: 50px 0;
}
@media screen and (max-width: 768px) {
  .banner-list {
    flex-direction: column;
    align-items: center;
    gap: 15px;
  }

  .banner-img {
    width: 90%;
    left: 0;
    transform: none;
    margin: 0 auto;
  }
	
  .banner-img2 {
    width: 90%;
    left: 0;
    transform: none;
    margin: 0 auto;
	padding: 50px 0;
  }
  .banner-img3 {
    width: 90%;
    left: 0;
    transform: none;
	margin: 0 auto;
	padding: 30px 0;
  }
}
#news .news-area {
  max-width: 900px;
  margin: 0 auto;
  padding: 60px 20px;
  text-align: center;
}

/* 見出し（雲っぽいのは画像 or 疑似要素でOK） */
.news-heading {
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  display: inline-block;
  padding: 10px 30px;

  background: none;
  color: #ff7bac; /* 文字色はそのまま */

  font-size: 36px;
  font-weight: 800;       /* ← ここを太く */

  /* 白フチ（太め）＋ドロップシャドウ */
  text-shadow:
    3px  0   0 #fff,
   -3px  0   0 #fff,
    0   3px  0 #fff,
    0  -3px  0 #fff,
    3px  3px 0 #fff,
   -3px -3px 0 #fff,
    3px -3px 0 #fff,
   -3px  3px 0 #fff,

    0 6px 8px rgba(0, 0, 0, 0.25);
}

/* 枠 */
.news-box {
  border: 3px solid #ff8bb0;
  border-radius: 30px;
  padding: 20px 30px;
  background: #fff;
  font-family:
    "Hiragino Mincho ProN",
    "Yu Mincho",
    "游明朝",
    "MS PMincho",
    serif;
  font-weight: bold;
}

/* リスト */
.news-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.news-list li {
  display: flex;
  gap: 30px;
  padding: 20px 0;
  border-bottom: 1px solid #ff8bb0;
  font-size: 18px;
}

.news-list li:last-child {
  border-bottom: none;
}

.news-list time {
  font-weight: bold;
  white-space: nowrap;
}

/* ボタン */
.news-more {
  margin-top: 100px;
}

.more-btn {
  display: inline-block;
  padding: 15px 60px;
  background: #ff6f8d;
  color: #fff;
  border-radius: 999px;
  text-decoration: none;
  font-weight: bold;
  transition: 0.3s;
}

.more-btn:hover {
  opacity: 0.8;
}

@media screen and (max-width: 768px)  {
	.news-heading {
    font-size: 26px;
    letter-spacing: 0.14em;
    text-shadow:
      2px  0   0 #fff,
     -2px  0   0 #fff,
      0   2px  0 #fff,
      0  -2px  0 #fff,
      0 4px 6px rgba(0,0,0,0.25);
  }
  .news-list li {
    flex-direction: column;
    gap: 10px;
    text-align: left;
  }
}

/* 製品のご案内
-------------------------------------------------------------- */
#con2 {
	background:rgba(229,84,109,0.1);
}
#con2 dl {
	position: relative;
	padding:0 10px 50px;
	background: url("../img/line_product.png") bottom no-repeat;
}
@media (min-width: 961px) {
	#con2 .type1 dt {
		position: absolute;
		top:0;
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 1;
		pointer-events: none;
	}
	#con2 .type1 dd {
		position: relative;
		display: inline-block;
		width: 32%;
		z-index: 2;
		cursor: pointer;
	}
	#con2 .type1 dt + dd + dd {
		position: relative;
		top: 80px;
	}
	#con2 dl dd ul li {
		display: inline-block;
		cursor: pointer;
	}
	#con2 .type2 dt {
		position: absolute;
		top:0;
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 1;
		pointer-events: none;
	}
		#con2 .type2 ul li {
			width: 45%;
		}
		#con2 .type2 ul li:nth-child(2) {
			padding-left: 5%;
		}
	#con2 .type2 dd {
		position:relative;
		z-index: 2;
	}
	#con2 .type3 dt {
		position: absolute;
		top:0;
		bottom:0;
		left: 0;
		right: 0;
		width: 329px;
		height: 394px;
		margin: auto;
		pointer-events: none;
	}
		#con2 .type3 ul li:nth-child(n+4) {
			width: 48%;
		}
		#con2 .type3 ul li:nth-child(4) {
			padding-right: 5%;
		}
	#con2 .type3 dd {
		position:relative;
		z-index: 10;
	}
	#con2 .type4 dt {
		position: absolute;
		top:0;
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 1;
		pointer-events: none;
	}
		#con2 .type4 ul li {
			width: 45%;
			padding-top: 20px;
		}
		#con2 .type4 ul li img {
			width: 90%;
		}
	#con2 .type4 dd {
		position:relative;
		z-index: 10;
	}
	#con2 .type5 dt {
		position: absolute;
		bottom:0;
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 1;
		pointer-events: none;
	}
		#con2 .type5 ul li {
			width: 32%;
		}
		#con2 .type5 ul li:nth-child(n+4) {
			width: 45%;
		}
	
	#con2 .type5 dd {
		position:relative;
		z-index: 10;
	}
	
	#con2 .type6 dt {
		position: absolute;
		top:0;
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 1;
		pointer-events: none;
	}
		#con2 .type6 ul li {
				width: 45%;
			}
			#con2 .type6 ul li:nth-child(2) {
				width: 40%;
				padding-left: 10%;
			}
	#con2 .type6 dd {
		position:relative;
		z-index: 10;
	}
	#con2 .type7 {
		padding: 40px 0 90px;
		background: url("../img/pc/frame_01.png") no-repeat;
	}
	#con2 .type7 dt {
		position: absolute;
		top:0;
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 1;
		pointer-events: none;
	}
		#con2 .type7 .typeList {
			overflow: hidden;
		}
			#con2 .type7 .typeList li {
				float: left;
				width: 45%;
			}
			#con2 .type7 .typeList li + li {
				float: right;
			}
	#con2 .type7 dd {
		position:relative;
		z-index: 10;
	}
	#con2 .type8 li {
		padding: 40px 0;
		background: url("../img/pc/frame_02.png") no-repeat;
	}
	#con2 .type8 dd {
		position:relative;
		z-index: 10;
	}
}
/*--↓2026.4 追記↓--*/
#con2 .p-item {
  margin: 0;
  text-align: center;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
}

#con2 .p-item_image img {
  display: block;
  width: 100%;
  height: auto;
}

#con2 .p-item_text {
  background: #fff;
  padding: 12px 10px 14px;
  box-sizing: border-box;
  font-family:
    "Hiragino Mincho ProN",
    "Yu Mincho",
    "游明朝",
    "MS PMincho",
    serif;
  flex: 1;
	border-radius: 10px;
}
/* 共通カード幅 */
#con2 .p-item {
  width: 300px;
}

/* 3列 */
#con2 .p-item-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  justify-content: center;
}

/* 2列 */
#con2 .p-item-wrap2 {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  justify-content: center;

  max-width: 620px; /* 300×2 + 20 */
  margin: 0 auto;
}

#con2 .p-item_text .size,
#con2 .p-item_text .stone {
  margin: 4px 0 0;
  font-size: 15px;
  color: #000;
  font-weight: bold;
  line-height: 1.4;
  min-height: calc(1.4em * 2);
  word-break: break-word;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

#con2 .p-item_text .size {
  margin: 8px 0;
  padding: 0 8px;
  border: 1px solid #000;
  width: 100%;
  box-sizing: border-box;
}

/*カードの高さをそろえる*/
#con2 .p-item_text .size,
#con2 .p-item_text .stone {
  margin: 4px 0 0;
  font-size: 15px;
  color: #000;
  font-weight: bold;
  line-height: 1.4;
  min-height: calc(1.4em * 2);
  word-break: break-word;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}


#con2 .p-item_text .size {
  margin: 8px 0;
  padding: 0 8px;
  border: 1px solid #000;
  width: 100%;
  box-sizing: border-box;
}


#con2 .p-item_text h3 {
  margin: 0 0 5px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.1;
}

#con2 .p-item_text .price {
  margin: 0;
  font-size: 14px;
  color: #d70000;
  font-weight: bold;
}

#con2 .p-item_text .price span {
  font-size: 20px;
}

#con2 .p-item_text .note {
  margin: -5px;
  font-size: 15px;
  color: #000;
  font-weight: bold;
}

#con2 .p-item_text .size, .p-item_text .stone {
  margin: 4px 0 0;
  font-size: 15px;
  color: #000;
  font-weight: bold;
  line-height: 1.4;
  /*min-height: calc(1.4em * 2); /* ← 2行分確保 */
  word-break: break-word;
  display: flex;          /* ←追加 */
  align-items: center;    /* ←縦中央 */
  justify-content: center;
  text-align: center;
}

#con2 .p-item_text .size {
  margin: 8px 0;
  padding: 0 8px;
  border: 1px solid #000;
  width: 100%;
  box-sizing: border-box;
  text-align: center;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 1024px) {
  #con2 .p-item {
    width: calc((100% - 20px) / 2);
  }
}

@media screen and (max-width: 768px) {
  #con2 .p-item {
    width: 100%;
  }
}

/* 見出し（雲っぽいのは画像 or 疑似要素でOK） */
.p-wa {
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  display: inline-block;
  padding: 50px 0;
  
  background: none;
  color: #ff7bac; /* 文字色はそのまま */

  font-size: 36px;
  font-weight: 800;       /* ← ここを太く */

  /* 白フチ（太め）＋ドロップシャドウ */
  text-shadow:
    3px  0   0 #fff,
   -3px  0   0 #fff,
    0   3px  0 #fff,
    0  -3px  0 #fff,
    3px  3px 0 #fff,
   -3px -3px 0 #fff,
    3px -3px 0 #fff,
   -3px  3px 0 #fff,

    0 6px 8px rgba(0, 0, 0, 0.25);

  margin-bottom: 30px;
}

@media screen and (max-width: 768px) {
  .p-wa {
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  display: inline-block;
  padding-top: 50px;
  
  background: none;
  color: #ff7bac; /* 文字色はそのまま */

  font-size: 26px;
  font-weight: 800;       /* ← ここを太く */

  /* 白フチ（太め）＋ドロップシャドウ */
  text-shadow:
    3px  0   0 #fff,
   -3px  0   0 #fff,
    0   3px  0 #fff,
    0  -3px  0 #fff,
    3px  3px 0 #fff,
   -3px -3px 0 #fff,
    3px -3px 0 #fff,
   -3px  3px 0 #fff,

    0 6px 8px rgba(0, 0, 0, 0.25);

  margin-bottom: 30px;
 }
}

.others-wrap {
  display: block;
  position:relative;
  padding: 50px 0;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
.others-wrap {
  display: block;
  position:relative;
  padding: 10px 0;
  margin: 0 auto;
}
}

@media screen and (max-width: 768px) {
  #con2 .p-item-wrap2 .p-item {
    width: 100%;
  }
}
/* 納骨堂 */
.noukotsu-box {
  position: relative;
  font-weight: bold;
  max-width: 900px;
  margin: 0 auto;
  padding: 80px 50px 80px;

  /* 背景の枠画像 */
  background: url("../img/pc/frame_01.png") no-repeat center;
  background-size: contain;
}

/* 上の画像エリア */
.frame-images {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 20px;
}

.img-left {
  width: 40%;
}

.img-right {
  width: 40%;
}

#con2 .noukotsu-text {
  max-width: 320px;  /* ← 好きな幅に調整 */
  margin: 15px auto;    /* 中央寄せ */
}

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

  /* 背景をSP用に変更 */
  .noukotsu-box {
    padding: 40px 20px;

    background: url("../img/smt/noukotsu-frame-sp.png") no-repeat center;
    background-size: contain;
  }

  /* 縦並びにする */
  .noukotsu-images {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }

  .img-left,
  .img-right {
    width: 70%;
  }

  /* テキストも下に配置 */
  .noukotsu-text {
    margin-top: 20px;
    width: 70%;
  }
}

/*--↑2026.4 追記↑--*/
/* 5つの安心
-------------------------------------------------------------- */
#con4 {
	max-width: 100%;
	padding-top:80px;
	margin: 0 auto;
	background: #f7f5fa;
}
	#con4 .contBox {
		max-width: 960px;
		margin: 0 auto;
		padding: 20px 0;
	}
	#con4 .contBox h3 {
		margin-top: -80px;
	}
	#con4 .contBox div {
		overflow: hidden;
		padding: 20px 0;
		border-bottom: 1px solid #000000;
	}
	#con4 .contBox div:last-child {
		border: none;
	}
	#con4 .contBox dl {
		float: right;
		width: 50%;
		text-align: left;
	}
		#con4 .contBox dl em {
			font-weight: bold;
			color: #F64E3D;
		}
		#con4 .contBox dl a {
			color: #F64E3D;
			text-decoration: underline;
		}
		#con4 .contBox dl a:hover {
			text-decoration: none;
		}
	#con4 .contBox dl + p {
		float: left;
	}

/* 墓じまい　2026.4追記
-------------------------------------------------------------- */
#hakajimai {
  max-width: 100%;
  background-color: #FFFFFF;
  margin: 0 auto;
}

/* PC */
#hakajimai .hakajimai-Box {
  max-width: 960px;
  margin: 0 auto;
  padding: 50px;
}

/* 画像 */
#hakajimai img {
  width: 100%;
  height: auto;
  display: block;
}

/* 画像切替（PC） */
#hakajimai .pc-img {
  display: block;
}

#hakajimai .sp-img {
  display: none;
}

/* SP */
@media screen and (max-width: 768px) {

  #hakajimai .hakajimai-Box {
    padding: 0;
    max-width: 100%;
  }

  #hakajimai .pc-img {
    display: none;
  }

  #hakajimai .sp-img {
    display: block;
  }
}

/* リフォーム
-------------------------------------------------------------- */
#reform .after {
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  display: inline-block;
  padding: 10px 30px;

  background: none;
  color: #ff0000; /* 文字色はそのまま */

  font-size: 36px;
  font-weight: 800;       /* ← ここを太く */

  /* 白フチ（太め）＋ドロップシャドウ */
  text-shadow:
    3px  0   0 #fff,
   -3px  0   0 #fff,
    0   3px  0 #fff,
    0  -3px  0 #fff,
    3px  3px 0 #fff,
   -3px -3px 0 #fff,
    3px -3px 0 #fff,
   -3px  3px 0 #fff,

    0 6px 8px rgba(0, 0, 0, 0.25);
}
@media screen and (max-width: 768px)  {
	#reform .after {
    font-size: 26px;
    text-shadow:
      2px  0   0 #fff,
     -2px  0   0 #fff,
      0   2px  0 #fff,
      0  -2px  0 #fff,
      0 4px 6px rgba(0,0,0,0.25);
  }
}

#reform {
	max-width: 100%;
	margin: 0 auto;
	background: #FFFFFF;
}
	#reform h3 {
		max-width: 952px;
		margin: 0 auto;
	}
	#reform img {
		width: 100%;
		max-width: 960px;
		padding-bottom: 30px;
	}


/* お問い合わせ
-------------------------------------------------------------- */
#contact {
	max-width: 100%;
	margin: 0 auto;
	padding: 50px 0;
	background: #FFFFFF;
}
#contact h3{
	width: 90%;
}
	#contact > * {
		margin: 0 auto 30px;
	}
	#contact .map {
		max-width: 960px;
		height: 300px;
		padding: 10px;
		background: #D3B669;
	}
		#contact .map .mapBox iframe {
			width: 100%;
			height: 280px;
		}


/*お問い合わせフォーム*/
div#contact_form_wrap{
	max-width:960px;
	margin:0 auto;
}





/* ご案内
-------------------------------------------------------------- */
#guide {
	max-width: 100%;
	margin: 0 auto;
	background: #FFFFFF;
}
	#guide h3 + div {
		max-width:960px;
		margin: 0 auto;
	}
		#guide h3 + div ul {
			overflow: hidden;
			padding: 30px 0;
			border-bottom: 1px solid #000000;
		}
		#guide h3 + div ul:last-child {
			border: none;
		}
			#guide h3 + div ul li {
				width: 48%;
				float: left;
				font-size: 16px;
				text-align: left;
			}
			#guide h3 + div ul li + li {
				float: right;
			}

/* イベント
-------------------------------------------------------------- */
#event {
	max-width: 100%;
	margin: 0 auto;
	padding: 0 10px;
	background: #FFFFFF;
}
	#event > * {
		max-width: 960px;
		margin: 0 auto 30px;
		font-size: 15px;
		text-align: left;
	}
		#event h3 img {
			max-width: 960px;
		}
		#event ul li {
			display: inline-block;
			width: 30%;
		}
		#event table {
			width: 100%;
			margin: 0 auto;
			border-top: 1px solid #000000;
			border-left: 1px solid #000000;
			border-right: 1px solid #000000;
		}
			#event table tr {
				border-bottom: 1px solid #000000;
			}
				#event table tr th {
					width: 40%;
					padding: 10px 0 10px 20px;
					background: #E6E65A;
				}
					#event table tr th img {
						vertical-align: middle;
					}
					#event table .tel1 th img {
						width: 203px;
					}
					#event table .tel2 th img {
						width: 251px;
					}
					#event table .tel3 th img {
						width: 261px;
					}
				#event table tr td {
					font-size: 24px;
					font-weight: bold;
					text-align: center;
					vertical-align: middle;
				}

/* 仲間たち
-------------------------------------------------------------- */
.friend {
	max-width: 100%;
	padding: 40px 10px;
	background: #FFFFFF;
}
	.friend > p {
		margin-bottom: 30px;
	}
	.friend p + p + p {
		width: 50%;
		margin: 0 auto;
	} 
/* --------------------------------------------------
	ページトップへ
-------------------------------------------------- */
#page-top-btn {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 10000;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

#page-top-btn.show {
  opacity: 1;
  visibility: visible;
}

#page-top-btn a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  background: #ff7bac;
  color: #fff;
  text-decoration: none;
  border-radius: 50%;
  font-size: 16px;
  font-weight: bold;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

#page-top-btn a:hover {
  opacity: 0.8;
}

@media screen and (max-width: 960px) {
  #page-top-btn {
    right: 15px;
    bottom: 15px;
  }

  #page-top-btn a {
    width: 50px;
    height: 50px;
    font-size: 14px;
  }
}
/* --------------------------------------------------
	3. footer
-------------------------------------------------- */
footer {
	background: #FFF9F9;
}
	footer .footWrap {
		position: relative;
		max-width: 980px;
		min-height: 230px;
		margin: 0 auto;
		padding: 20px 10px;
	}
/*
	footer .footWrap #pagetop {
		width: 120px;
		height: 34px;
		line-height: 34px;
		position: absolute;
		top: -30px;
		right: 0;
		z-index: 999;
		border-radius: 6px 6px 0 0;
		background: #FFF9F9;
	}
*/
/*
		footer .footWrap #pagetop a {
			display: block;
		}
*/
/*
			footer .footWrap #pagetop a img {
				vertical-align: middle;
			}
*/
		footer .footWrap .info {
			position: absolute;
			bottom: 10px;
			text-align: left;
		}
			footer .footWrap .info dt {
				display: inline-block;
			}
			footer .footWrap .info dt + dd {
				display: inline-block;
				font-size: 15px;
				color: #CC3366;
			}
			footer .footWrap .info dt + dd + dd {
				display: block;
				font-size: 10px;
				color: #999999;
			}
			footer .footWrap .info br {
				display: none;
			}
		footer .footWrap .bnr {
			float: right;
			width: 370px;
			text-align: right;
		}
			footer .footWrap .bnr li {
				display: inline-block;
			}
			footer .footWrap .bnr li + li {
				margin-left: 10px;
			}
		footer .footWrap .footLink {
			overflow: hidden;
			float: left;
			width: 590px;
			text-align: left;
		}
			footer .footWrap .footLink li {
				float: left;
				width: 190px;
			}
				footer .footWrap .footLink li a {
					color: #000000;
				}
	/* コピーライト */
	footer .copy {
		padding: 5px 10px;
		color: #FFFFFF;
		background: #825A00;
	}

/* --------------------------------------------------
	会社概要
-------------------------------------------------- */
#about {
  max-width: 860px;
  margin: 50px auto;
  padding: 60px 60px 80px;
  background: #fff;
  border-radius: 10px;
  box-sizing: border-box;
  font-family:
    "Hiragino Mincho ProN",
    "Yu Mincho",
    "游明朝",
    "MS PMincho",
    serif;
  color: #222;
}

#about .about-title {
  margin: 0 0 40px;
  text-align: center;
  font-size: 36px;
  font-weight: bold;
  color: #b12a2a;
  line-height: 1.4;
}

#about .about-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}

#about .about-table tr {
  border-bottom: 1px solid #666;
}

#about .about-table th,
#about .about-table td {
  padding: 10px 0;
  vertical-align: top;
  font-size: 17px;
  line-height: 1.8;
  text-align: left;
}

#about .about-table th {
  width: 200px;
  padding-right: 20px;
  font-weight: bold;
  box-sizing: border-box;
}

#about .about-table td {
  width: calc(100% - 170px);
  box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  #about {
    padding: 40px 20px 50px;
	margin: 100px 20px 30px;
  }

  #about .about-title {
    margin-bottom: 25px;
    font-size: 26px;
  }

  #about .about-table th,
  #about .about-table td {
    font-size: 14px;
    line-height: 1.7;
    padding: 8px 0;
  }

  #about .about-table th {
    width: 105px;
    padding-right: 10px;
  }

  #about .about-table td {
    width: calc(100% - 105px);
  }
}
/* --------------------------------------------------
	個人情報の取り扱いについて
-------------------------------------------------- */
#privacy {
  max-width: 860px;
  margin: 50px auto;
  padding: 60px 20px;
  border-radius: 10px;
  background: #fff;
  box-sizing: border-box;
  font-family:
    "Hiragino Mincho ProN",
    "Yu Mincho",
    "游明朝",
    "MS PMincho",
    serif;
}

#privacy .privacy-title {
  text-align: center;
  font-size: 34px;
  color: #b12a2a;
  margin-bottom: 40px;
}

#privacy .privacy-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}

#privacy .privacy-table tr {
  border-bottom: 1px solid #666;
}

#privacy .privacy-table th,
#privacy .privacy-table td {
  padding: 12px 0;
  text-align: left;
  vertical-align: top;
  line-height: 1.8;
}

#privacy .privacy-table th {
  width: 180px;
  font-weight: bold;
  padding-right: 20px;
}

#privacy .privacy-table td {
  width: calc(100% - 180px);
}

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

  #privacy {
    padding: 40px 20px 50px;
    margin: 100px 20px 30px;
  }

  #privacy .privacy-title {
    margin-bottom: 25px;
    font-size: 26px;
  }

  /* ←これが重要（縦並び化） */
  #privacy .privacy-table,
  #privacy .privacy-table tbody,
  #privacy .privacy-table tr,
  #privacy .privacy-table th,
  #privacy .privacy-table td {
    display: block;
    width: 100%;
  }

  #privacy .privacy-table tr {
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 1px solid #ccc;
  }

  #privacy .privacy-table th {
    font-size: 14px;
    padding: 0 0 5px;
    font-weight: bold;
  }

  #privacy .privacy-table td {
    font-size: 14px;
    line-height: 1.7;
    padding: 0;
  }
}