@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400..800;1,400..800&family=Noto+Serif+JP:wght@200..900&display=swap');

.hidden{
display:none;
}
body,html{
	font-family: 'Noto Serif JP', serif;
	font-weight:600;
	color: #444;
	text-align: center;
	font-size: 18px;
	line-height:1.5;
	scroll-behavior: smooth;
}
header{
padding:12px 0 0;
margin:0 auto;
font-weight:600;
font-size:0.9em;
text-align:center;
background-color: #FFF;
}
section{
padding:40px 0;
}
#logo {
	font-size: 32px;
	letter-spacing: 0.12em;
	padding:0 0 16px;
	width:100%;
}
#logo a {
color: #444;
margin-left:15px;
}
#logo span {
padding:0 25px 0 0;
}
header nav{
display: flex;
padding:12px 5px;
text-align:center;
border-top: 1px solid #EEEEEE;
}
header nav ul{
display: flex;
margin:0 auto;
}
header nav ul li{
	padding:0 15px 0;
	letter-spacing: 0.1em;
}

header a{
	color: #444;
	text-decoration: none;
}
header a:hover {
    color: #000000;
    transition: all .4s;
}
#topimg img{
width:100%;
height:auto;
}

main{
padding:0 0 60px;
}
main a{
	color: #E74692;
	text-decoration: underline;
}
#container{
width:100%;
padding:0;
}

#sns{
	color: #FFFFFF;
	background-color: #EA5C9F;
	font-size:0.9em;
	font-weight:600;
	width:100%;
}
#sns ul{
  width:100%;
  display: flex;
}
	
#sns li{
flex-basis: 33%;
padding:10px 0;
}

#sns li a{
	color: #FFFFFF;
	display:block;
}

#sns li a:hover{
	text-decoration: underline;
}
i {
	font-size:1.2em;
	margin-right:10px;
}
.facebook{
	border-right-width: 1px;
	border-left-width: 1px;
	border-right-style: solid;
	border-left-style: solid;
	border-right-color: #FFFFFF;
	border-left-color: #FFFFFF;
}

footer{
	padding:30px 0;
	background-color: #F7F4F0;
	font-weight:400;
	font-size:0.8em;
}
footer a{
	color: #444;
}
#footer_inner,
#address_inner{
	width:90%;
	margin:0 auto;
max-width:1000px;
	text-align:left;
}

footer nav{
	display:flex;
flex-wrap:wrap;
justify-content:space-between;
	width:100%;
	height:auto;
	line-height:1.8;
}

footer nav div{
display:block;
}
footer nav dl dt,
footer nav dl dd {
	white-space: nowrap;
	font-weight:600;
}
footer nav dl dd {
	display:inline-block;
	padding-left:25px;
	font-weight:400;
}
footer nav dl a {
	color: #485973;
	text-decoration: underline;
}
footer table{
	display:flex;
	width:100%;
}
footer table td{
	width:33%;
	text-align: left;
	vertical-align: top;
font-size: 14px;
}
address{
	padding:20px 0;
	background-color: #293341;
	color: #FFF;
	font-weight:400;
	font-size:0.7em;
}
address a{
	color: #FFF;
}
/* */

.content{
margin:0 auto;
padding:60px 0 50px;
background: #FFF;
}

.content2{
margin:0 auto;
padding:30px 0 20px;
background-color: #F6F6F6;
}
.content_inner{
margin:0 auto;
width:92%;
max-width:1000px;
}
.content_inner iframe{
width:100%;
height:400px;
max-width:1000px;
}

.text_box{
	padding:20px 0;
	text-align: left;
	line-height:1.9;
	color: #666;
}
.text_box p{
	padding:0 0 30px;
}
.text_box ul{
	padding:10px 0 10px 20px;
	line-height:1.5;
}
.text_box ul li{
	list-style-position: inside;
	list-style-type: disc;
}
.text_box table{
	width:100%;
	margin-bottom:30px;
}
.text_box table tr{
	border-bottom: 1px solid #EEE;
}
.text_box table th,
.text_box table td{
	padding:3px 0;
	font-size:0.8em;
}
.text_box table th p,
.text_box table td p{
	padding:0;
	text-align:right;
}

figure {
float: left;
margin-right: 5%;
width: 30%;
}
figure img {
max-width: 100%;
}
hr {
margin:0;
padding:0;
clear:both;
height:0;
border:none;
}

.photo {
line-height:1.5;
text-align:center;
}
.photo p {
padding:10px 0;
}
.photo img{
width:100%;
height:auto;
}

h1,h2,h3,h4,h5,h6{
line-height:1;
}
h1{
padding:0;
margin:0 auto;
}
.text_box h1 {
font-size:1.4em;
font-weight:600;
padding:0 0 30px;
margin:0 auto;

	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
}

h2 {
	font-size:1em;
	padding: 0.6rem;
	color: #FFF;
	font-weight:600;
	margin:0 auto 25px;
	text-align:center;
	letter-spacing: 0.2em;
}


.content h2 {
	background-color: #485973;
}
.content2 h2 {
	background-color: #7B4041;
}

h3{
	font-size:1.1em;
	line-height:1;
	text-align:left;
	font-weight:600;
	padding: 2px 0 2px 15px;
	margin-bottom:10px;
	color: #333;
	position: relative;
	border-left-width: 3px;
	border-left-style: solid;
	border-left-color: #44546D;
}


h4{
	font-size:1em;
	line-height:1;
	text-align:left;
	font-weight:600;
	padding: 10px 0 0;
}

#pagetop {
position: fixed;
bottom: 15px;
right: 15px;
}
#pagetop a {
display:block;
color:#666666;
font-size:1.75em;
}


/* splide */
#splide_box{
width:100%;
margin:0 auto 15px;
}
.splide__slide img {
  width: 100%;
  height: auto;
  object-fit: cover;
}
.button {
  display: block;
  position: absolute;
  width: 40px;
  height: 40px;
  padding: 4px 0 0 0;
  background: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  top: 50%;
  transition: 0.2s;
  z-index: 2;
}
.button::before {
  content: "";
  width: 1.5rem;
  height: 1.5rem;
  border: 0;
  border-top: solid .3rem #FFF;
  border-right: solid .3rem #FFF;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}

.button:disabled:before {
  border-top: solid .5rem #a9a9a9;
  border-right: solid .5rem #a9a9a9;
}

.button.__previous {
  left: 0px;
}
.button.__prev::before {
  transform: rotate(-135deg);
}

.button.__next {
  right: 0px;
}
.button.__next::before {
  transform: rotate(45deg);
}
.button:not(:disabled):hover {
  opacity: 0.8;
}

.button:disabled {
  cursor: not-allowed;
}

ol {
margin:0 auto;
padding:0 0 10px;
display: table;
width:100%;
font-weight:600;
}
ol li{
margin:0;
padding:3px 6px;
display:inline-table;
}
/* more */

.more {
margin:0 auto;
padding:10px 0;
display: table;
width:100%;
font-weight:600;
text-align:center;
}
.more-text{
margin:0;
padding:3px 6px;
display:inline-table;
}
.more-text a,
ol li a{
	display:table-cell;
    background-color: rgba(255, 255, 255, 1);
    border: 2px solid #485973;
    border-radius: 25px;
    white-space: nowrap;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-tap-highlight-color: transparent;
    transition: all .4s;
    padding: 5px 30px;
    cursor: pointer;
	font-size: 0.85em;
    color: #485973;
	text-decoration: none;
}
.more-text a:hover,
ol li a:hover{
	border: 2px solid #9C4B4B;
	color: #FFF;
	text-decoration: none;
	background-color: #9C4B4B;
}
.more-text a::after {
  font-family: "Font Awesome 5 Free";
  content: "\f054";
  font-weight: 900;
  margin-left:16px;
    transition: transform .3s ease-in-out;
}

/* メニュー */

#openbtn {
  cursor: pointer;
  width: 50px;
  height: 50px;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 9999;
}

#openbtn span {
  display: inline-block;
  transition: all 0.4s;
  position: absolute;
  left: 13px;
  width: 45%;
  height: 3px;
  border-radius: 2px;
  background-color: #666;
}
#openbtn span:nth-of-type(1) {
  top: 15px;
}
#openbtn span:nth-of-type(2) {
  top: 23px;
}
#openbtn span:nth-of-type(3) {
  top: 31px;
}
#openbtn.active span:nth-of-type(1) {
  top: 18px;
  left: 18px;
  transform: translateY(6px) rotate(-45deg);
  width: 30%;
}
#openbtn.active span:nth-of-type(2) {
  opacity: 0;
}
#openbtn.active span:nth-of-type(3) {
  top: 30px;
  left: 18px;
  transform: translateY(-6px) rotate(45deg);
  width: 30%;
}
#gnav dl {
	font-family:noto sans jp,yu gothic,メイリオ,meiryo,ヒラギノ角ゴ pro w3,hiragino kaku gothic pro,osaka,ms pgothic,ＭＳ Ｐゴシック,ms gothic,sans-serif;
	text-align: center;
	width: 100%;
	position: absolute;
	z-index: 999;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size:0.9em;
}
#gnav dl dt,
#gnav dl dd {
	display: block;
	width: 95%;
	margin:0 auto;
}
#gnav dl dt {
	color: #FFF;
	background: #333;
	padding: 15px 0;
}
#gnav dd a {
	display: block;
	color: #333;
	padding: 12px 0;
	font-weight:600;
	border-bottom: 1px solid #EEEEEE;
}

#gnav dd a:hover{
	color: #996633;
}
#gnav {
  position: fixed;
  z-index: 999;
  top: 0;
  right: -120%;
  width: 100%;
  height: 100vh;
  background-color: #FFF;
  transition: all 0.6s;
  opacity: 1;
}
#gnav.list_active #gnav_list {
  position: fixed;
  z-index: 999;
  width: 100%;
  height: 100vh;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
#gnav.list_active {
  right: 0;
}

.line_top{
	border-top-width: 1px;
	border-top-style: solid;
	border-top-color: #EEE;
}
.link{
margin:-20px 0 20px;
text-align:right;
}

.bana{
display:flex;
padding:30px 0 0;
margin:0 auto;
width:90%;
max-width:1000px;
gap: 30px;
}
.bana div{
display:flex;
width:50%;
}
.bana div a{
display:block;
}
.bana div img{
width:100%;
height:auto;
}

.sub_content {
	background-color: #EBF1ED;
	padding: 0 0 10px;
}
.sub_inner {
margin:15px auto 15px;
width:95%;
}

.bg_white{
	padding: 70px 0 70px;
    background-color: #FFF;
    background-clip: border-box;
    border: 0;
    border-radius: 0.25rem;
}

/* フェードイン用のCSS */
.slide-bottom {
   opacity: 0;
   transform: translateY(25px);
   transition: all 2s 0s ease-out;
 }

/* PC */
@media screen and (min-width:768px) {
.sp{
display:none;
}

}

/* スマホ */
@media only screen and (max-width: 767px) {
.pc{
display:none;
}

body{
line-height: 1.2;
font-size: 14px;
}

#logo {
	font-size: 22px;
}

table th,
table td{
font-size:0.85em;
}

header{
}
header h1{
padding:0;
margin:0;
}
header nav{
}
header nav ul{
white-space: nowrap;
overflow-x: scroll;
  overflow-scrolling: touch;  /* スクロールを滑らかにする */
  -webkit-overflow-scrolling: touch;  /* スクロールを滑らかにする */
  /*IE(Internet Explorer)・Microsoft Edgeへの対応*/
  -ms-overflow-style: none;
  /*Firefoxへの対応*/
  scrollbar-width: none;
}

 /*Google Chrome、Safariへの対応*/
header nav ul::-webkit-scrollbar{
  display: none;
}

header nav ul li{
font-size:0.85em;
padding:0 10px;
}


#container{
  margin-inline: auto;
}

.content{
margin:0;
padding:0;
}

section{
padding:10px 0;
}

#content_about,
#content_sponsorship,
#content_news_inner,
.inner_info,
#footer_inner,
#address_inner{
	width:92%;
}

.text_box p,
.text_box2 p{
	line-height:1.5;
}
table p,
table th,
table td{
	line-height:1.5;
}

.bana{
display:block;
}
.bana div{
display:block;
width:100%;
padding:0 0 15px;
}

.2column {
	flex-direction: column;
}

footer nav dl{
	width:100%;
	margin:0 auto 20px;
	gap:0;
}
footer nav dl dt,
footer nav dl dd{
	display:block;
	text-align:center;
}
footer nav dl dd {
	padding:0 2px;
}
footer nav{
	display:block;
	text-align:center;
}
}