﻿@media (prefers-reduced-motion: reduce) {
	* {
		transition-duration: 0.001s !important;
		animation-duration: 0.001s !important
	}
}
*, :before, :after {
	-webkit-box-sizing: inherit;
	box-sizing: inherit;
	border-width: 0;
	border-style: solid
}
* {
	margin: 0;
	padding: 0;
	font-size: inherit;
	line-height: inherit
}
:before, :after {
	vertical-align: inherit;
	text-decoration: inherit
}
a, area, button, input, label, select, textarea, [tabindex] {
	-ms-touch-action: manipulation;
	touch-action: manipulation
}
h1, h2, h3, h4, h5, h6, p, span, a, address, th, td, label, li {
	max-height: 100%
}
button, [type='button'], [type='date'], [type='datetime'], [type='datetime-local'], [type='email'], [type='month'], [type='number'], [type='password'], [type='reset'], [type='search'], [type='submit'], [type='tel'], [type='text'], [type='time'], [type='url'], [type='week'], textarea {
	min-height: 1.5em;
	font-family: "Zen Old Mincho", serif;
}
select {
	font-family: "Zen Old Mincho", serif;
	color: inherit
}
button {
	color: inherit;
	background: transparent
}
[type='date'], [type='time'] {
	color: inherit;
	background: transparent
}
:root {
	/*width: 100vw;*/
	height: 100vh;
	box-sizing: border-box;
	font: 62.5%/1.5 system-ui, -apple-system, "Segoe UI", "Helvetica Neue", Helvetica, Arial, "Roboto", "Oxygen-Sans", "Ubuntu", "Cantarell", "Hiragino Sans", "ヒラギノ角ゴシック", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Meiryo", "メイリオ", "YuGothic", "游ゴシック", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
	cursor: default;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	line-sizing: normal;
	text-spacing: trim-start allow-end trim-adjacent ideograph-alpha ideograph-numeric
}
html {
	font-size: 16px !important;
	letter-spacing: 0.1em;
	color: #2D2D2D
}
body {
	position: relative;
	width: 100%;
	min-height: 100vh;
	-webkit-box-sizing: border-box;
	-webkit-tap-highlight-color: transparent;
	font-family: "Zen Old Mincho", serif;
	  font-weight: 400;
	  font-style: normal;
}
pre {
	white-space: pre-wrap
}
button, [type="button"], [type="reset"], [type="submit"] {
	-webkit-appearance: button
}
#header_wrap {
	display: flex;
	align-items: center;
	padding: 10px 0;
}
.isurugiyama2nd header {
	box-shadow: 0 0 3px 1px rgba(51,51,51,.2);
}
.header_nav {
  position: relative;
}

.hamburger {
  position: fixed;
  top: 12px;
  right: 2vw;
  z-index: 100;
  width: 48px;
  height: 48px;
  border: none;
  background: transparent;
  cursor: pointer;
}

.hamburger__line {
  position: absolute;
  left: 11px;
  width: 26px;
  height: 2px;
  background-color: #333;
  transition: all .4s;
}

.hamburger__line:nth-of-type(1) {
  top: 14px;
}
.hamburger__line:nth-of-type(2) {
  top: 23px;
}
.hamburger__line:nth-of-type(3) {
  top: 32px;
}

/* メニューオープン時 */
.hamburger.active .hamburger__line:nth-of-type(1) {
  transform: translateY(9px) rotate(-45deg);
}
.hamburger.active .hamburger__line:nth-of-type(2) {
  opacity: 0;
}
.hamburger.active .hamburger__line:nth-of-type(3) {
  transform: translateY(-9px) rotate(45deg);
}

.nav {
  position: fixed;
  top: 0;
  left: 0;
  width: 300px;
  height: 100vh;
  background-color: #fff;
  box-shadow: 2px 0 4px rgba(0,0,0,.1);
  transform: translateX(-100%);
  transition: transform .4s;
  z-index: 90;
}

.nav.active {
  transform: translateX(0);
}

.nav__list {
  margin: 0;
  padding: 100px 0 0;
  list-style: none;
}

.nav__item {
  padding: 0 20px;
}

.nav__link {
  display: block;
  padding: 15px 0;
  color: #333;
  text-decoration: none;
  border-bottom: 1px solid #eee;
}

.sitename_sub {
	font-size: .6em;
}
.sitename_area {
	font-size: 18px;
}
.sitename_area a {
	text-decoration: none;
	color: #000;
}
.sitename_area h1 {
	font-weight: 400;
}
main {
	padding-bottom: 50px;
}
.main_area {
	width: 92vw;
	max-width: 1150px;
	margin: 0 auto;
}
.top_linkbtn,
main section {
	padding-bottom: 60px;
}

.top_hero {
	position: relative;
	margin-bottom: 30px;
}
.top_hero img {
	vertical-align: top;
}

.top_hero .caption {
	position: absolute;
	background-color: rgba(0,0,0,0.50);
	padding: 5px;
	display: inline-block;
	color: #fff;
	font-size: 30px;
	left: 0;
}

.isurugiyamasite img {
	width: 100%;
	height: auto;
}
.isurugiyama_top main section h2,
.isurugiyama2nd main h1 {
	text-align: center;
	font-size: 1.4em;
	padding-bottom: 20px;
}
.isurugiyama_top main section h2 a,
.isurugiyama2nd main h1 a {
	text-decoration: none;
	color: #000;
}

.isurugiyama2nd main section h2 {
	text-align: left;
	font-size: 1.3em;
	margin-bottom: 20px;
}
.isurugiyama2nd main section h3 {
	text-align: left;
	border-bottom: 1px solid #000;
		padding-bottom: 10px;
	margin-bottom: 20px;
	font-size: 1.1em;
	
}
.isurugiyama2nd article {
	padding-top: 30px;
}
main article p {
	text-align: left;
	padding-bottom: 1.8em;
}
p.lead_text {
	line-height: 2;
	font-size: 1.05em;
	}
figure {
	text-align: center;
	margin: 0 auto;
}
figcaption {
	text-align: center;
	font-size: 12px;
	padding: 10px 0;
}
figure img {
	vertical-align: text-top;
}
figure.map img {
	max-width: 700px;
}
figure.sect_bnr  {
	margin-bottom: 30px;
}
figure.sect_bnr2 {
	margin-bottom: 10px;
}
.text_sm {
	font-size: .8em;
}
.text_c {
	text-align: center !important;
}
.marg_bt {
	margin-bottom: 30px;
}
.marg_tp {
	margin-top: 30px;
}

.btn_area {
	padding: 40px 0;
}
.btn_area a {
	display: block;
	text-decoration: none;
}
.btn_area .btn_style {
	display: block;
	text-align: center;
	transition: all 0.3s ease;
}
.btn_area .btn_style span {
	font-size: 12px;
}
.btn_area .btn_style:hover,
.top_linkbtn .linkbtn_bk a:hover {
	opacity: .7;
}
.top_linkbtn .linkbtn_bk a:hover {
	background-color: #666;
}
.btn_area .btn_style.btn1 {
	background-color: #000;
}

.btn_area .btn_style.btn2 {
	background-color: #EAEAEA;
	color: #000;
	border: 1px solid #707070;
	line-height: 80px;
	height: 80px;
	padding: 0 15px;
	font-size: 1.2em;
}

.top_linkbtn .linkbtn_bk {
	background-color: #000;
	color: #fff;
	text-align: center;
	
}
.top_linkbtn .linkbtn_bk a {
	display: block;
	text-decoration: none;
	color: #fff;
	text-align: center;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
}
.top_linkbtn .linkbtn_bk:not(.naibu) a {
	display: block;
	text-decoration: none;
	color: #fff;
	text-align: center;
	display: flex;
	flex-grow: 1;
	height: 100%;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
}
.naibubtn {
	border: 5px solid #000;
}
.top_linkbtn .linkbtn_bk .naibubtn a {
	background-color: #fff;
	color: #000;
	display: flex;
	align-items: center;
	line-height: 1.1;
	justify-content: center;
	padding: 10px 0;
}
.photo_area + section {
	padding-top: 50px;
}
.photo_area {
	display: flex;
}
.photo_area.photo_area3,
.photo_area.photo_area2 {
	grid-gap: 10px;
	flex-wrap: wrap;
}
.photo_area.photo_mini {
	max-width: 500px;
	justify-content: center;
	margin: 0 auto;
}
	
.photo_area img {
	flex: 1;
	min-width: 0;
}
.photo_area2 img {
	width: calc((100% - 10px) / 2);
	flex: auto;
}
.photo_area3 img {
	width: calc((100% - 20px) / 3);
	flex: auto;
}

.bnr_list {
	display: flex;
	grid-gap: 10px;
	padding: 40px 0;
	margin: 0 auto;
}
.bnr_list li {
	display: block;
}
.bnr_list li a {
	display: block;
	text-align: center;
	border: 1px solid #707070;
	text-decoration: none;
	color: #000;
	
}

footer {
	background-color: #000;
}
footer p {
	font-size: 12px;
	color: #fff;
	line-height: 1.2;
	padding: 10px 0;
	
}

.tab-buttons {
	display: flex;
	border-bottom: 2px solid #000;
	background: #fff;
}

.tab-button {
	flex: 1;
	padding: 15px 10px;
	background: transparent;
	border: none;
	cursor: pointer;
	color: #898989;
	transition: all 0.3s ease;
	position: relative;
}

.tab-button:hover {
	background: rgba(0,0,0,0.05);
}

.tab-button.active {
	color: #fff;
	background-color: #000;
}

.tab-button.active::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 0;
	right: 0;
	height: 2px;
	background: #000;
}

.tab-content {
	display: none;
	padding: 30px 0;
	animation: fadeIn 0.3s ease;
}

.tab-content.active {
	display: block;
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

#support_link {
	background-color: #F5F5F5;
	text-align: center;
	padding: 60px 0 20px 0;
}

.gallery-set {
	margin-bottom: 40px;
}

.gallery-swiper {
  width: 100%;
  overflow: hidden;
}

.gallery-swiper img {
  width: 100%;
  height: auto;
  display: block;
}

.thumb-swiper .swiper-wrapper {
	flex-wrap: wrap;
	grid-gap: 5px !important;
}
.thumb-swiper .swiper-slide {
	width: calc((100% - 35px ) / 8) !important;
	margin: 0 !important;
	cursor: pointer;
}
.thumb-swiper .swiper-slide:hover {
	opacity: .7;
}

.wak {
	border: 1px solid #000;
	padding: 25px 15px;
	text-align: center;
}

.wak.kenboku {
	width: 20em;
	margin: 20px auto;
}
.isurugiyama2nd main section.wak h3 {
	text-align: center;
	border: none;
}
.wak figure {
	padding: 30px 0;
}
/* SP ONLY */
@media screen and (max-width: 767.9px) {
	body {
		font-size: 15px;
	}
	.pc_only,
	.pctab_only {
		display: none;
	}
	.btn_area a {
		max-width: 80vw;
		margin: 0 auto;
	}
	.btn_area a:nth-child(n+2) {
		margin-top: 15px;
	}
	
	
	.top_hero {
		display: flex;
		grid-gap: 1px;
		flex-wrap: wrap;
	}
	.top_hero .photo_right {
		width: calc((100% - 1px) / 2);
	}
	.top_hero .caption {
		top: 15px;
		font-size: 18px;
	}
	
	.linkbtn_bk {
		margin-bottom: 10px;
	}
	.linkbtn_bk > a {
		padding: 10px 0;
	}
	.linkbtn_bk.naibu {
		padding: 0;
		display: flex;
		/*justify-content: space-between;*/
	}
	.linkbtn_bk.naibu a {
		display: flex;
		align-items: center;
		justify-content: center;
		flex-grow: 1;
	}
	.top_linkbtn .linkbtn_bk .naibubtn {
		margin-left: auto;
	}
	.top_linkbtn .linkbtn_bk .naibubtn a {
		padding: 10px;
	}
	.naibubtn a:nth-child(n + 2) {
		border-top: 5px solid #000;
	}
	.bnr_list {
		flex-wrap: wrap;
	}
	.bnr_list li {
		width: calc((100% - 10px) / 2);
	}
	.tab-button h2 {
		font-size: 13px;
	}
	.thumb-swiper .swiper-slide {
		width: calc((100% - 10px) / 3) !important;
	}

}
/* SP AND TAB */
@media screen and (max-width: 1149.9px) {
	.pc_only {
		display: none;
	}
	.flex_box figure {
		margin-bottom: 15px;
	}

}

/* TAB and PC */

@media screen and (min-width: 768px) {
	.sp_only {
		display: none;
	}
	.btn_area {
		display: flex;
		justify-content: center;
		grid-gap: 30px;
		padding: 40px 0;
	}
	.btn_area a {
		width: 100%;
		max-width: 14em;
	}
	.sitename_area a {
		display: flex;
		align-items: center;
		grid-gap: 15px;
		font-size: 18px;
	}
	.isurugiyama_top .sitename_area h1,
	.isurugiyama2nd .sitename_area .sitename {
		font-size: 26px;
	}

	.top_hero {
		display: flex;
		grid-gap: 1px;
		justify-content: center;
	}
	.top_hero img.main {
		width: auto;
		height: 720px;
	}
	.top_hero .top_hero_mini {
		height: 720px;
		width: auto;
	}
	.top_hero img.mini {
		height: calc((720px - 1px) / 2);
		width: auto;
	}
	
	.top_hero {
    display: grid;
    grid-template-columns: 2fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 1px;
    aspect-ratio: 21 / 9; /* 全体の比率 */
}

.top_hero .photo_left {
    grid-row: 1 / 3; /* 上下2行分 */
}

.top_hero .photo_left img,
.top_hero .photo_right img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
	
	.top_hero .photo_left {
    grid-row: 1 / 3; /* 上下2行分 */
}

.top_hero .photo_left img,
.top_hero .photo_right img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
	
	
	
	.top_hero .caption {
		bottom: 15px;
	}
	
	.top_linkbtn {
		display: flex;
		justify-content: center;
		grid-gap: 10px;
	}
	

	.linkbtn_bk {
		width: calc((100% - 20px) / 3);
		max-width: 300px;
	}
	.linkbtn_bk.naibu {
		align-content: space-between;
	}
	.naibubtn {
		display: flex;
		width: 100%;
	}
	.naibubtn a {
		width: 50%;
		color: #000;
	}
	.naibubtn a:nth-child(n + 2) {
		border-left: 5px solid #000;
	}
	
	.bnr_list {
		grid-gap: 20px;
		justify-content: center;
	}

}
/* PC ONLY */
@media screen and (min-width: 1150px) {
	.tab_only {
		display: none;
	}
	.flex_box {
		display: flex;
		grid-gap: 30px;
		align-items: center;
	}
.flex_box figure {
		display: flex;
	width: 40%;
	max-width: 400px;
	flex-shrink: 0;
	}
.flex_box figure .text_area {
	flex-grow: 0;

	}
	.isurugiyama_top .sitename_area h1,
	.isurugiyama2nd .sitename_area .sitename {
		font-size: 36px;
	}
	.sitename_sub {
		font-size: 18px;
	}
	p.lead_text {
		text-align: center;
	}
	.wak {
	padding: 40px;
}

.wak figure {
	padding: 30px 0;
	max-width: 700px;
}

	
}

/* LIST COMMON */
ul.liststyle {
	margin-left: 1.4rem;
	padding-bottom: 20px;
	margin-bottom: 10px;
	margin-top: 0;
}
ol {
	margin: 0;
	padding-bottom: 15px;
	padding-left: 2em;
}
dd ul.liststyle, li ul.liststyle {
	padding-bottom: 0;
	margin-bottom: 0;
}
ul.liststyle li, ol li {
	margin-bottom: 5px;
}
ul.liststyle > li:before {
	content: "•";
	display: inline-block;
	margin-left: -1.4em;
	width: 1.4em;
	text-align: center;
}
ul.liststyle.listNotice > li:before {
	content: "※";
	display: inline-block;
	margin-left: -1.4em;
	width: 1.4em;
}
ul.liststyle.listNotice2 > li:before {
	content: "＊";
	display: inline-block;
	margin-left: -1.4em;
	width: 1.4em;
}
ul.liststyle.listkakkonum {
    list-style: none;
	padding-left: 1.4em;
  }
ul.liststyle.listkakkonum > li {
    counter-increment: my-counter; /* カウンターを増やす */
}
ul.liststyle.listkakkonum > li:before {
    content: "(" counter(my-counter) ")"; 
    display: inline-block;
	margin-left: -3.2em;
	width: 3.2em;
  }
.dl_list dd {
	margin-bottom: 15px;
}
.dl_list.withline {}
.dl_list.withline dt {
	margin: 0;
	padding: 30px;
}
.dl_list.withline dd {
	border-bottom: 1px solid #999999;
	margin: 0;
	padding: 30px;
}

.gmap iframe {
  width: 100%;
  aspect-ratio: 16 / 9; /* 縦横比を16:9に固定 */
}

.movie_area video {
	max-width: 700px;
	margin: 15px auto;
}
.movie_area video{
	display:block;
	width:100%;
	height:auto;
}
