@charset "utf-8";

/* ---------------------------------------------------
 * base
/* ---------------------------------------------------*/

html {
    font-size: 62.5%;	/*適宜変更お願いします*/
    width: 100%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

body {
    text-align: center;
    font-size: 10px;
    font-family: 'Noto Sans JP', YuGothic, 'Yu Gothic', 'ヒラギノ角ゴシック', 'Hiragino Sans', sans-serif;
    color: #000000;
    line-height: 1.75;
    width: 100%;
	background-image: url("../img/bg.webp");/*背景画像固定*/
	background-repeat: repeat;     	/*背景画像固定*/
	background-attachment: fixed;	/*背景画像固定*/
	background-position: top center;	/*背景画像固定*/
	
    font-weight: 400;	/*適宜変更お願いします*/
    font-feature-settings: "palt" 1;	/*自動カーニング*/
	
	/*テキストの選択とコピー無効化  */
	-webkit-user-select: none;
    -moz-user-select: none;  
    -ms-user-select: none; 
    user-select: none;
}

img {
    max-width: 100%;
    height: auto;
	
	pointer-events: none;	/*画像のドラッグ、ダウンロード禁止*/
    -webkit-user-drag: none;	/*画像のドラッグ、ダウンロード禁止*/
    user-drag: none;	/*画像のドラッグ、ダウンロード禁止*/
}

a {
    color: #fff;
}

a:hover {
    /*opacity: 0.8;*/
    text-decoration: none;
}

p {
    text-align: justify;
    hanging-punctuation: allow-end;	/*文字のぶら下げ*/
}

.wrap-shadow {
	background-image: url("../img/shadow.webp");
	background-repeat: repeat-y;
	background-position: center top;
	background-position:50% 0%;
}

table {
			width: 100%;
			border-collapse: collapse;
			font-size: 16px;
			color: #333333;
			text-align: left;
			line-height: 1.2;
			margin-top: 2em;
		}
		
		th, td {
			padding: 10px;
			text-align: left;
			border-top: 2px solid #777777; /* 項目、内容1の上に横線 */
			border-bottom: 2px solid #777777; /* 項目、内容1の下に横線 */
		}
		th {
			width: 20%; /* 比率 */
		}
		td {
			width: 80%; /* 比率 */
		}
		tr:not(:last-child) {
			border-bottom: 2px solid #777777; /* 横線のみ */
		}

		/* td内のリンク文字を変更 */
		table td a {
			color: #0000ff ; /* 文字色 */
			 /* font-weight: bold;  太字 */
			/*text-decoration: none;    下線を消す */
		}


footer {
  text-align: center;
  padding: 50px 0;
  color: white;
  background-color: #333333;
  font-family: "Meiryo", "メイリオ", sans-serif;
  font-size: 18px;
  line-height: 1.5;
}

/*   キランボタンここから   */
.reflection_btn1:hover {
  filter: brightness(110%);
}

.reflection_btn1{
	top: 0%;
    width       :80%;
    height      :unset;
    position: absolute;
    overflow    :hidden;
    margin: auto;
    z-index: 999; /* ←ここ！ */
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	border-radius: 0px;
		
}

.reflection {
    
    height      :80%;
    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.3; }
    81% { transform: scale(4) rotate(45deg); opacity: 0.8; }
    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.3; }
    81% { -webkit-transform: scale(4) rotate(45deg); opacity: 0.8; }
    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.3; }
    81% { -moz-transform: scale(4) rotate(45deg); opacity: 0.8; }
    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.3; }
    81% { -ms-transform: scale(4) rotate(45deg); opacity: 0.8; }
    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.3; }
    81% { -o-transform: scale(4) rotate(45deg); opacity: 0.8; }
    100% { -o-transform: scale(50) rotate(45deg); opacity: 0; }
}
/*   キランボタンここまで　*/

.btbox{
	position: relative;
    max-width: 750px;
    margin-left: auto;
    margin-right: auto;
}


/*アコーディオン PCここから*/
.details {
	transition: .3s;
	overflow: hidden;
	margin-top: -10px;
	padding-bottom: 20px;
	&:last-of-type {
		margin-bottom: 0;
	}
}
.details[open] {
	margin-top: 0;
	padding-bottom: 10px;
} 
.details-summary {
	display: block;
    transition: .3s;
	transform: translateY(10px);
	&:hover {
		cursor: pointer;
	}
}
.details-summary::-webkit-details-marker {
	display: none;
}
.details[open] .details-summary {
	transform: translateY(0);
}
.details-content {
	border-bottom: 2px solid #d5d4d4;
	border-left: 2px solid #fd5d4d4;
	border-right: 2px solid #d5d4d4;
}

.accordion-box {
    position: relative;
    max-width: 710px;
    margin-left: auto;
    margin-right: auto;
}

.gray-back {
    position: relative;
    margin-left: auto;
    margin-right: auto;	
	background-color: #ebebeb;
	padding-bottom: 6em;
	max-width: 750px;
}

/*アコーディオンPCここまで*/

.white-back {
    position: relative;
    margin-left: auto;
    margin-right: auto;	
	background-color: #fff;
	padding-bottom: 6em;
	max-width: 750px;
}
	
.yellow-back {
    position: relative;
    margin-left: auto;
    margin-right: auto;	
	background-color: #fdfcf9;
}


 .mapbox{
    max-width: 670px;
    margin-left: auto;
    margin-right: auto;
	background-color: #fff;
	z-index: 999; /* ←ここ！ */
} 

.gmap_wrapper {
	max-width: 670px;	/*1000pxは任意の値にする*/
}

.gmap {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 56.25%;    /*16:9の比率にしたい場合、9/16=56.25%*/
}

.gmap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}



/* ---------------------------------------------------
 * common（PC　min-width: 1023px）
/* ---------------------------------------------------*/
.wrap {
	width: 100%;
	max-width: 100%;
}

.container {
    position: relative;
    max-width: 750px;
    margin-left: auto;
    margin-right: auto;
}


.-pc {
    display: block;
}

.-sp {
    display: none;
}

*, *::before, *::after {
    -webkit-box-sizing: inherit;
    box-sizing: inherit;	/*親要素のbox-sizingを継承*/
}

/*-----------------タブレットサイズ-----------------------
@media (min-width: 600px) and (max-width: 1023px) {
    body {
        font-size: 3.2rem;
    }
    .-pc {
        display: none;
    }
    .-sp {
        display: block;
    }
    .wrap {
        max-width: 100%;
        width: 100%;
    }
}
----------------------------------------*/

/*-----------------スマホサイズ-----------------------*/

@media screen and (max-width:600px) {
    .-pc {
        display: none;
    }
    .-sp {
        display: block;
    }
    body {
        font-size: 4.2vw;
    }
    .wrap {
        max-width: 100%;
        width: 100%;
    }


	
/*アコーディオン スマホここから*/
.accordion-box {
    position: relative;
    max-width: 94%;
    margin-left: auto;
    margin-right: auto;
}

.gray-back {
    position: relative;
    max-width: 750px;
    margin-left: auto;
    margin-right: auto;	
	background-color: #ebebeb;
	padding-bottom: 2em;
}

/*アコーディオンスマホここまで*/	
	
.white-back {
    position: relative;
    max-width: 750px;
    margin-left: auto;
    margin-right: auto;	
	background-color: #fff;
	padding-bottom: 2em;
}	
	
		
footer {
 text-align: center;
  padding: 50px 0;
  color: white;
  background-color: #333333;
  font-family: "Meiryo", "メイリオ", sans-serif;
  font-size: 18px;
  line-height: 1.5;
}
	
 .mapbox{
    width: 90%;
} 
	
	
	
	
	
	
	
	
	
@media screen and (max-width: 960px) {
  footer {
  text-align: center;
    padding: 50px 0;
    padding: 5.208vw;
    color: white;
    background-color: #333333;
    font-family: "Meiryo", "メイリオ", sans-serif;
    font-size: 18px;
    font-size: clamp(10px, 1.875vw, 18px);
    line-height: 1.5;
  }
}
    section#section-01,
    section#section-02,
    section#section-03,
    section#section-04,
    section#section-05,
    section#section-06,
    section#section-07,
    section#section-08,
    section#section-09,
    section#section-10,
    section#section-11,
    section#section-12,
    section#section-13,
    section#section-14,
    section#section-15,
    section#section-16,
    section#section-17,
    section#section-18,
    section#section-19,
    section#section-20,
    section#section-21,
    section#section-22,
    section#section-23,
    section#section-24,
    section#section-25,
    section#section-26,
    section#section-27,
    section#section-28,
    section#section-29,
    section#section-30,
    section#section-31,
    section#section-32,
    section#section-33,
    section#section-34,
    section#section-35,
    section#section-36,
    section#section-37,
    section#section-38,
    section#section-39,
    section#section-40,
    section#section-41,
    section#section-42,
    section#section-43,
    section#section-44,
    section#section-45,
    section#section-46,
    section#section-47,
    section#section-48,
    section#section-49,
    section#section-50{
    background: none !important;
  }
}
/*----------------------------------------*/
