﻿@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Josefin+Sans:wght@600&display=swap');

html{ 
	font-size: 14px;
}
body{
	font-family: "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";
	-webkit-text-size-adjust: none;
	word-wrap: break-word;
	overflow-wrap: break-word;
	letter-spacing: 0.5px;
	line-height: 1.8;
	margin: 0 auto;
}
a{
	text-decoration: none;
	color: #4d4d4d;
}
.font_un{
    font-family: "Josefin Sans", "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";
}

/* ----- ▼全ページ共通▼ --------------- */

/* ----- ローディング ----- */
#wrap{
	opacity:0.0;
}
.loading{
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  z-index:99999;
}
.loading::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  background-color: #fff;
  width: 0;
  height: 1px;
}
.loading {
  -webkit-animation: loadingline 2.6s forwards;
          animation: loadingline 2.6s forwards;
}
.loading::before {
  -webkit-animation: loadingopen 2.6s forwards;
          animation: loadingopen 2.6s forwards;
}
@keyframes loadingline {
  70% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    display: none;
    z-index: -1;
  }
}
@keyframes loadingopen {
  0% {
    width: 0;
    height: 1px;
  }
  50% {
    width: 100%;
    height: 1px;
  }
  90% {
    width: 100%;
    height: 100%;
  }
  100% {
    width: 100%;
    height: 100%;
  }
}

/* ----- ヘッダー ----- */
header{
	z-index: 101;
}
.h_tel_btn{
	line-height: 20px;
}
#header .h_box > li:last-child{
	width: 40px;
	margin-left: 20px;
}

/* ----- メニュー ----- */
.overlay_l::before{
	content: "";
	display: block;
	position: absolute;
	top: 10px;
	right: 10px;
	bottom: 10px;
	left: 10px;
	border: solid 1px rgba(255,255,255,0.7);
	z-index: 1;
}
.menu_list span::before{
  content: '/';
  margin-right: 10px;
}

/* ----- フッター ----- */
.sf_access iframe{
  width: 100%;
  height: 320px;
}
.s_footer_info_l::before{
	content: "";
	display: block;
	position: absolute;
	top: 10px;
	right: 10px;
	bottom: 10px;
	left: 10px;
	border: solid 1px rgba(255,255,255,0.7);
	z-index: 1;
}

/* ----- ページの切り替え処理 ----- */
.pp-scrollable{
	overflow: hidden;
	overflow-y: auto;
}
.scrollpage_box{
	box-sizing: border-box;
}
#pp-nav.right{
	right: 36px;
  background-color: rgba(255,255,255,0.6);
  padding: 10px 0;
  border-radius: 20px;
  box-sizing: border-box;
}
#pp-nav span{
	background-color: currentColor!important;
	border-color: currentColor!important;
	transition: 0.3s;
	width: 6px;
	height: 6px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	box-sizing: border-box
}
#pp-nav .active span{
	background-color: transparent!important;
	width: 12px;
	height: 12px
}

/* ----- ページスクロール ----- */
#page_top{
	bottom: 5%;
	margin: auto;
	right: 25px;
	z-index: 4;
	width: 40px;
	height: 130px;
}
#page_top a{
	width: 40px;
	height: 130px;
	box-sizing: border-box;
}
#page_top .scroll_u{
	width: 1px;
	height: 50px;
	top: 0;
	right: 0;
	left: 0;
	margin: auto;
}
#page_top .scroll_u .scroll_bar{
	animation: lineu 2s ease 0s infinite;
}
@keyframes lineu{
	0% {
		top: 50px;
		height: 0;
	}
	20% {
		top: 0;
		height: 50px;
	}
	40% {
		top: 0;
		height: 0;
	}
	100% {
		top: 0;
		height: 0;
	}
}

/* ----- ▼トップページ▼ --------------- */

/* ----- main_img ----- */
#main_img .swiper-wrapper::before{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 1;
	background-color: transparent;
	background-image: radial-gradient(rgba(68, 68, 68, 0.4) 0%, transparent 0%);
	background-size: 3px 3px;
}
.main_img_txt{
	font-weight: bold;
	letter-spacing: 4px;
	text-indent: 4px;
	z-index: 3;
}

/* ----- content1 ----- */
.intro_img a::before{
	content: "";
	display: block;
	position: absolute;
	top: 10px;
	right: 10px;
	bottom: 10px;
	left: 10px;
	border: solid 1px rgba(255,255,255,0.7);
	z-index: 1;
}
.intro_img a span{
	content: "";
	display: block;
	position: absolute;
	top: -30%;
	left: -10%;
	width: 100%;
	height: 100%;
	z-index: -1;
}
.intro_img div{
  font-size: 4em;
  color: transparent;
  top: -9%;
  left: -6%;
  -webkit-text-stroke: 1px #fff;
  pointer-events: none;
}

/* ----- content2 ----- */
.c2_box{
	height: 50%;
}
.c2_box_bg::before{
	content: "";
	display: block;
	position: absolute;
	top: 10px;
	right: 10px;
	bottom: 10px;
	left: 10px;
	border: solid 1px rgba(255,255,255,0.7);
	z-index: 1;
}
.contents_no span{
	width: 60px;
	height: 1px;
	transform: rotate(-45deg);
	left: 0;
	top: 0;
	bottom: 10px;
	margin: auto
}
.contents_no{
	top: 20px;
	left: 20px;
	z-index: 1;
}
.modal_wrap{
	top: 0;
	left: 0;
	opacity: 0.95;
	z-index: 102;
}
.modal_wrap .modal_scroll{
	overflow-y: auto;
}
.modal_wrap .close_bt{
	top: 20px;
	right: 20px;
	cursor: pointer
}

/* ----- top_cms ----- */
.cms_box .cms_box_bg {
    background-color: var(--white);
    position: absolute;
    content: '';
    top: 50%;
    left: 0;
    width: 100%;
    height: 50%;
    z-index: -1;
}

/* ----- moreボタン ----- */
.more_btn > span{
	cursor: pointer;
}
.more_btn .more_line{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: '';
  transition: all .5s ease-in-out;
  transform: translateX(-99%);
}
.more_btn a:hover .more_line, .more_btn > span:hover .more_line{
  -webkit-transform: translateX(0%);
  transform: translateX(0%);
}
.more_btn a i, .more_btn > span i{
  position: absolute;
  top: calc(50% - .55em);
  right: 1rem;
  transition: all 0.3s;
}
.more_btn a:hover i, .more_btn > span:hover i{
  position: absolute;
  top: calc(50% - .55em);
  right: 1rem;
}

/* ----- ▼下層ページ▼ --------------- */

/* ----- ページタイトル ----- */
#page_title::before{
	display: inline-block;
  content: "";
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.2);
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
}
#page_title .page_title_inner{
	padding: 130px 20px;
}
#page_title .title_box{
  transform: translateX(-50%);
  left: 50%;
  bottom: -50px;
  padding: 35px;
}

/* ----- ページャー ----- */
.pager li{
	margin: 0 10px;
}
.pager li a{
	width: 60px;
	height: 60px;
}

/* ----- カテゴリリスト ----- */
.cate_label{
	max-width: 200px;
	box-sizing: border-box;
}
.cate_list{
	width: calc(100% - 200px);
	box-sizing: border-box;
}
.cate_list li{
	max-width: 25%;
	min-width: 160px;
	box-sizing: border-box;
}

/* ----- page7 ----- */
#page7 .map{
	height: 320px;
}
#page7 .map iframe{
	width: 100%;
	height: 100%;
	box-sizing: border-box;
}

/* ----- page8 ----- */
#page8 #form dl dt label{
	cursor: pointer;
}
#page8 input[type="text"]{
	width: calc(100% - 10px);
	height: 20px;
	border: 1px solid #cccccc;
	background-color: #fcfcfc;
}
#page8 textarea{
	width: calc(100% - 10px);
	border: 1px solid #cccccc;
	background-color: #fcfcfc;
}
#page8 input:focus, #page8 textarea:focus{
	background-color: #ffffff;
}
#page8 button{
	text-indent: 4px;
	cursor: pointer;
}

/* ----- page9 ----- */
#page9 h3 .line {
  position: absolute;
  content: '';
  width: 30px;
  height: 1px;
  bottom: -1px;
  left: 0;
  transition: 0.5s;
}

/* ----- page10 ----- */
#page10 a::before{
    display: none;
	position: absolute;
  font-family: "Font Awesome 5 Free";
  content: "\f105";
	font-weight: 900;
	left: 10px;
}
#page10 a .line{
	position: absolute;
	content: '';
	width: 30px;
	height: 1px;
	bottom: -1px;
	left: 0;
	transition: 0.5s;
}
#page10 a:hover .line{
  width: 100%;
}

/* ---------- PC ---------- */
@media screen and (min-width:769px){

}

/* ---------- TB ---------- */
@media screen and (max-width: 768px){
	.border_rad0_tb{
		border-radius: 0;
	}
  .main_img_txt{
    max-width: 980px;
    width: 80%;
  }
	.intro_img a span{
    top: -14%;
    left: -14%;
	}
  .intro_img div {
    font-size: 3em;
    top: -7%;
  }
  .contents_no{
    top: 6px;
    left: 6px;
    z-index: 1;
  }
  .c2_box{
    height: 32vh;
  }
	.cms_box .cms_box_bg{
		top: 30px;
    height: 110px;
	}
	#page_top{
    right: 0px;
	}
	#page_title .page_title_inner{
			padding: 110px 20px;
	}
	#page10 a:hover::after{
    width: 30px;
  }
}

/* ---------- SP ---------- */
@media screen and (max-width: 667px){
	#wrap, .scrollpage_box{
		height: auto;
	}
  .c2_box{
    height: auto;
  }
	.c2_box_bg{
		height: 40vh;
	}
	.s_footer_info_l{
		height: 40vh;
	}
	#page_top {
    bottom: 40px;
	}
	#page_top a{
		width: 30px;
	}
	#page_title .page_title_inner {
    padding: 80px 20px;
	}
	#page_title .title_box {
    bottom: -40px;
    padding: 25px;
    width: 82%!important;
	}
	.pager li:not(.prev){
		display: none;
	}
	.pager li a {
    width: 120px;
    height: 50px;
	}
	.cate_label{
		max-width: 100%;
		box-sizing: border-box;
	}
	.cate_label p{
		padding: 0;
		margin: 0;
	}
	.cate_list li{
		max-width: 100%;
	}
	#page8 button{
		max-width: 130px;
	}
}

/* ---------- IE ---------- */
@media all and (-ms-high-contrast:none){
  .intro_box{
    margin: 0;
  }
  .h_box_mail a{
    padding-top: 7px;
    padding-bottom: 2px;
  }
  .intro_img div{
    color: #fff;
  }
  .more_btn > span, .more_btn > a{
    padding: 13px 10px 7px;
  }
  .sf_contact_mail a{
    padding-top: 8px;
    padding-bottom: 2px;
  }
  .pager li a span{
    top: 52%;
  }
	.cate_list_wrap p{
    padding-top: 3px;
  }
	.cate_list li a{
    padding: 7px 20px 3px;
  }
  #page8 .phone_wrap a{
    padding-top: 10px;
  }
  #page8 .phone_txt h4 span, #page8 .phone_txt p{
    padding-top: 7px;
    padding-bottom: 2px;
  }
  #page8 button{
    padding-top: 12px;
    padding-bottom: 8px;
  }
  #page9 .box_wrap p a{
    padding-top: 7px;
    padding-bottom: 2px;
  }
}
