@charset "utf-8";

body .sp-item {
	display: none;
}
body .pc-item {
  display: block;
}

@media screen and (max-width: 640px) {
	body {
		min-width: inherit;
		height:100%;
	}
	body .sp-item {
		display: block;
	}
	body .pc-item {
		display: none;
	}
	body .sp-item img {
		width:100%;
	}
	body .sp-item .scroll img {
		width: auto !important;
		max-width: none !important;
	}
}

/* ----------------------------------------------------
    共通
---------------------------------------------------- */

body {
	max-width: inherit;
	height: 100%;
	background: url(../images/bg-body.png) repeat center center;
	background-attachment: fixed;
}
.main {
	font-family: 'ヒラギノ角ゴシック','Hiragino Sans','Meiryo UI',sans-serif;
	font-weight: 400;
	line-height: 1.7;
	font-size: 20px;
	color:#333;
	background-color: #fff;
	text-align: justify;
	font-feature-settings: "palt";
	overflow-x: hidden;
	max-width: 1024px;
	margin: 0 auto;
	box-shadow: 0 0 8px #ccc;
}
img {
	margin: 0 auto;
	width: 100%;
	height: auto;
}

@media screen and (max-width: 640px) {
	img {
		max-width: 100%;
		height: auto;
	}
	.scroll img {
		width: auto !important;
		max-width: none !important;
		min-width: auto !important;
	}
	body {
		width: 100%;
	}
	.inner {
		width: 94%;
	}
}

/* ----------------------------------------------------
    CTA
---------------------------------------------------- */
.btn {
	transition: all .2s;
	filter: drop-shadow(5px 5px 5px rgba(153,153,153,0.75));
}
.btn:hover {
	opacity: 0.8;
}
.btns {
	position: absolute;
	bottom: 160px;
	left: 50%;
	transform: translateX(-50%);
	width: 675px;
}
.btns02 {
	bottom: 170px;
}
.btns03 {
	bottom: 105px;
}
.btns04 {
	bottom: 240px;
}
.btns05 {
	bottom: 240px;
}
.btns06 {
	bottom: 268px;
}

@media screen and (max-width: 640px) {
	.btns {
		bottom: 17%;
		width: 92%;
	}
	.btns02 {
		bottom: 16.5%;
	}
	.btns03 {
		bottom: 12%;
	}
	.btns04 {
		bottom: 6%;
		width: 82%;
	}
	.btns05 {
		bottom: 7%;
		width: 82%;
	}
	.btns06 {
		bottom: 7%;
		width: 82%;
	}
	.btn-phone-sp {
		margin-top: 12px;
		display: block;
	}
	.btns04 .btn,
	.btns05 .btn,
	.btns06 .btn {
		filter: drop-shadow(5px 5px 5px rgba(153,153,153,0.4));
	}
}

/* ----------------------------------------------------
    main
---------------------------------------------------- */
.sec06,
.sec16,
.sec18,
.sec21,
.sec22,
.sec23 {
	position: relative;
}

/* @media screen and (max-width: 640px) {} */



/* ----------------------------------------------------
    footer
---------------------------------------------------- */
.footer {
	background-color: #8c7b65;
	color: #fff;
	padding: 30px 0;
	font-size: 14px;
	font-weight: 200;
	text-align: center;
}
.footer-link {
	width: 92%;
	margin: 0 auto;
}
.footer-link a {
	color: #fff;
	text-decoration: none;
	display: inline-block;
}
.footer-link a:hover {
	opacity: 0.8;
	transition: all .2s;
}
.copy-right {
	text-align: center;
}

/* @media screen and (max-width: 640px) {} */


/* ----------------------------------------------------
    固定ボタン
---------------------------------------------------- */
.fixed-bottom-link {
	position: fixed;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	z-index: 100;
	display: none; /* 初期状態では非表示 */
	text-align: center;
	background-color: rgba(252, 245, 228, 0.7);
	padding: 2px 0 10px;
}
.fixed-bottom-link.show {
	display: block; /* クラスが付与されたら表示 */
}
.fixed_btn {
	width: 750px;
	height: auto;
	display: inline-block;
}
.fixed_btn a {
	display: inline-block;
	transition: .2s;
}
.fixed_btn a:hover {
	transform: scale(1.03);
	cursor: pointer;
}

/*フッターまでスクロールしたら消す*/
.is-hidden {
  visibility: hidden;
  opacity: 0;
}

@media screen and (max-width: 640px) {
	.fixed-bottom-link {
		bottom: 0px;
		left: 50%;
		transform: translateX(-50%);
		padding: 10px 0;
	}
	.fixed_btn {
		width: 94%;
	}
}

/* ----------------------------------------------------
    横スクロール
---------------------------------------------------- */
@media screen and (max-width: 640px) {
	.sec11 {
		position: relative;
	}
	.scroll {
		position: absolute;
		bottom: 4.6%;
		right: 0;
		overflow: auto;
		width: 96%;
		height: auto;
		max-width: 600px;
		-ms-overflow-style: none; /* IE, Edge */
		scrollbar-width: none; /* Firefox */
	}
	.scroll::-webkit-scrollbar {
		display: none; /* Chrome, Safari, Opera */
	}
	.scroll img {
		width: auto !important;
		max-width: calc(100vw * 1.57) !important;
		min-width: 100% !important;
		height: auto !important;
		transform: none;
		transform-origin: left top;
		margin-right: 20px;
	}
}


