@charset "utf-8";
#content > section {
	width: 100%;
}
#content .inn {
	width: 100%;
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	min-height: 1%;
}
#content .inn img {width: 100%;}
.tit01 {
	color: #99001F;
	font-weight: bold;
	border-bottom: 3px solid #C1B8BC;
	padding: 0.3em;
	margin-bottom: 0.3em;
	position: relative;
	font-size: 19px;
	font-size: 1.9rem;
}
.tit01::after {
	content: '';
	background-color: #99001F;
	width: 4em;
	height: 3px;
	position: absolute;
	bottom: -3px;
	left: 0;
	z-index: 1;
}
.tit01 span {
	background: #99001F;
	display: inline-block;
	color: #FFF;
	font-size: 15px;
	font-size: 1.5rem;
	padding: 2px 10px;
	margin-bottom: 5px;
}
.tit02 {
	position: relative;
	margin-bottom: 30px;
}
.tit02::before {
	content: "";
    border-top: 1px solid #A3CDDC;
    width: 100%;
    height: 1px;
    position: absolute;
    top: 50%;
    z-index: 1;
}
.tit02 p {
	display: flex;
	background: #A3CDDC;
	width: 110px;
	height: 110px;
	border-radius: 55px;
	font-size: 20px;
	font-size: 2.0rem;
	color: #fff;
	text-align: center;
	position: relative;
	z-index: 5;
	margin: 0 auto;
	align-items: center;
	justify-content: center;
	line-height: 1.4;
}
.tit03 {
	font-size: 23px;
	font-size: 2.3rem;
	position: relative;
	text-align: center;
	padding-top: 40px;
	line-height: 1.6;
	margin-bottom: 60px;
}
.tit03::after {
	position: absolute;
	content: "";
	bottom: -15px;
	left: 50%;
	width: 9rem;
	transform: translateX(-50%);
	border-bottom: 4px dotted #4C4C4C;
}
.select {
	background: #C1B8BC;
	height: 40px;
	width: 400px;
	border-radius: 5px;
	position: relative;
	z-index: 1;
	margin:30px 0 30px 15px;
}

.select::after {
	position: absolute;
	content: '';
	width: 8px;
	height: 8px;
	right: 10px;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
	border-bottom: 2px solid #4B4246;
	border-right: 2px solid #4B4246;
	z-index: -1;
}
select#menu-cat {
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
	background: none;
	border: none;
	color: #61555B;
	font-size: 16px;
	width: 100%;
	height: 100%;
	padding: 0 10px;
}
option[selected][disabled] {
	display: none;
}
select#menu-cat option {
	background:#F5F5F5;
	color: #333;
}
.btn {text-align: center;}
.btn a {
	background:#F4A4A6;
	text-align: center;
	display: inline-block;
	width: 40%;
	padding: 0 30px;
	height: 52px;
	font-size: 17px;
	font-size: 1.7rem;
	position: relative;
	color: #fff !important;
	line-height: 52px;
	margin: 0 auto;
	text-decoration: none !important;
}
.btn a::after {
	content: "";
	display: block;
	position: absolute;
	right: 20px;
	width: 10px;
	height: 10px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 50%;
	margin-top: -7px;
}
/*----------------------------------
MAIN AREA
------------------------------------*/
#mainArea h1 {
	background: url("../images/tit_main.jpg") no-repeat top center;
	background-size: cover;
	height: 400px;
	width: 100%;
	font-family: "ソフトゴシック R",Soft Gothic Regular !important;
	font-size: 38px;
	font-size: 3.8rem;
	color: #99001F;
	text-align: center;
	position: relative;
	margin-top: 20px;
}
#mainArea h1 span {
	display: block;
	width: 100%;
	background: rgb(255,255,255,0.6);
	position: absolute;
	bottom: 0;
	margin: 0;
	padding: 15px 10px;
}
#mainArea #cat {margin: 0 15px;}
#mainArea #cat h2 {
	font-size: 22px;
	font-size: 2.2rem;	
}
#mainArea #cat p {
	font-size: 18px;
	font-size: 1.8rem;	
	margin: 20px 30px 40px;
	line-height: 1.8;
}
/*----------------------------------
article
------------------------------------*/
#article .inn > .flex {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
#article .inn  > .flex > div {
	width: 30%;
	margin-bottom: 20px;
	display: flex;
	flex-direction: column;
}
#article .inn  > .flex > div h2 {
	flex-grow: 1;
	display: block;
}
#article .inn  > .flex > div:after {
    content: "";
    display: block;
    width: 30%;
    height: 0;
}
#article .inn  > .flex > div img {
	width: 100%;
	height: 220px;
	object-fit: cover;
}
#article .inn  > .flex > div a {
	display: block;
	margin-top: 10px;
	flex-grow: 1;
}
#article .inn  > .flex > div a .flex {
	display: flex;
	justify-content: space-between;
	margin-top: 10px;
}
#article .inn  > .flex > div a .flex h3 {
	color: #FFF;
	font-size: 15px;
	font-size: 1.5rem;
	font-weight: bold;
	background: #565656;
	padding: 2px 10px;
	display: inline-block;
}
#article .inn  > .flex > div a .flex time {
	font-size: 14px;
	font-size: 1.4rem;
	display: inline-block;	
}
#article .inn  > .flex > div > a p:last-of-type {
	margin-top: 10px;
}
#article .inn  > .flex > div p {
	font-size: 15px;
	font-size: 1.5rem;
}
#article .inn  > .flex > div > p {
	margin-top: 10px;
}
/*----------------------------------
エントリー
------------------------------------*/
article {
	font-size: 16px;
	font-size: 1.6rem;
	min-height: 1%;
	line-height: 1.8;
}
article h3 {
	text-align: center;
	color: #99001F;
	font-size: 23px;
	font-size: 2.3rem;
	font-weight: bold;
	margin-bottom: 30px;
}
article h4 {
	text-align: center;
	padding: 10px 15px;
	font-size: 23px;
	font-size: 2.3rem;
	margin:40px 0 20px;
	border-top:dashed 1px #9ACBD8;
	border-bottom:dashed 1px #9ACBD8;
}
article h5 {
	font-size: 20px;
	font-size: 2.0rem;
	font-weight: bold;
	margin: 15px 30px;
}
article h6 {
	font-size: 20px;
	font-size: 2.0rem;
	font-weight: bold;
	margin: 15px 30px;
	border-bottom:solid 1px #555;
	display: inline;
}
article .inn > p {
	margin: 0 30px 30px;
}
article p {
	text-align: justify;
}
article .inn > p a {
	text-decoration: underline;
	color: #F08184;
}
article .inn > p a:hover {
	text-decoration: none;
}
article p.kome {
	font-size: 12px;
	font-size: 1.2rem;	
}
article table {
	border-collapse: collapse;
	text-align: center;
	margin: 0 auto 30px;
}
article table th,
article table td {
	border: solid 1px #ccc;
	padding: 10px;
}
article table th {
	background: #9ACBD8;
}
article ul,
article ol {
	margin-top: 30px;
	margin-bottom: 30px;
}
article ul li {
	list-style: disc;
	list-style-position: outside;
	margin: 0 0 5px 60px;
}
article ol li {
	list-style: decimal;
	list-style-position: outside;
	margin: 0 0 5px 60px;
}
article .btn a {margin-top: 30px;}
article p.caption {
	font-weight: bold;
	font-size: 14px;
	font-size: 1.4rem;
}
#kanren {
	margin-top: 50px;
	border-top:solid 1px #CBCBCB;
}
#kanren > .flex {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
#kanren > .flex > div {
	width: 23%;
	margin: 0 1% 10px;
}
#kanren > .flex > div:after {
    content: "";
    display: block;
    width: 23%;
    height: 0;
}
#kanren > .flex > div img {
	width: 100%;
	height: 200px;
	object-fit: cover;
}
#kanren > .flex > div a h3 {
	color: #FFF;
	font-size: 15px;
	font-size: 1.5rem;
	background: #565656;
	padding: 2px 10px;
	display: inline-block;
	margin-top: 10px;
}
#kanren > .flex > div a time {
	font-size: 13px;
	font-size: 1.3rem;
	margin-top: 10px;
	display: block;
	text-align: right;
}
#kanren > .flex > div a p {
	font-size: 14px;
	font-size: 1.4rem;
	margin-top: 10px;
}

/*----------------------------------
foot
------------------------------------*/
#foot {
	margin-top: 40px;
}
#foot .flex {
	display: flex;
	justify-content: space-around;
	margin-top: 50px;
}
#foot .flex .bnr {
	width: 35%;
}
#foot .flex p:last-of-type {
	width: 55%;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.8;
}
@media screen and (max-width: 1199px){

}
@media screen and (max-width: 767px){	
	.select {
		height: 44px;
		width: 95%;
		margin:30px auto 30px;
	}
	#mainArea h1 {
		height: 200px;
		font-size: 2.0rem;
	}
	#mainArea h1 span {
		padding: 10px;
	}
	#mainArea #cat h2 {
		font-size: 1.9rem;	
	}
	#mainArea #cat p {
		font-size: 1.6rem;	
	margin: 20px 0 40px;
	}
	#article .inn > .flex {
		flex-direction: column;
		margin: 0 15px;
	}
	#article .inn  > .flex > div {
		width: 100%;
		padding-bottom: 20px;
		border-bottom:dashed 1px #CCC;
	}
	#article .inn  > .flex > div:last-of-type {
		border-bottom:none;
	}
	.btn {margin: 0 15px;}
	.btn a {width: 100%;}
	.tit03 {
	font-size: 2.0rem;
	line-height: 1.6;
	margin-bottom: 40px;
	}
/*----------------------------------
エントリー
------------------------------------*/
	article h3 {
		font-size: 2.0rem;
		margin: 0 15px 30px;
	}
	article .inn > p {
		margin: 0 15px 30px;
		font-size: 1.5rem;
	}
	article h4 {
		padding: 5px 0;
		font-size: 2.0rem;
		margin:40px 15px 20px;
	}
	article h5 {
		font-size: 1.8rem;
		margin: 0 15px;
	}
	#kanren > .flex {
		flex-direction: column;
	}
	#kanren > .flex > div {
		width: 95%;
		border-bottom:dashed 1px #CBCBCB;
		padding-bottom: 10px;
		margin: 0 auto;
	}
	#kanren > .flex > div img {
	width: 100%;
	height: auto;
	object-fit: contain;
}
	#kanren > .flex > div .flex {
		display: flex;
		justify-content: space-around;
	}
	#kanren > .flex > div .flex > p {
		width: 30%;
	}
	#kanren > .flex > div .flex > .txt {
		width: 65%;
	}
	#kanren > .flex > div a h3 {
	font-size: 1.4rem;
	}
/*----------------------------------
foot
------------------------------------*/
	#foot {
		margin-top: 20px;
	}
	#foot .flex {
		flex-direction: column;
		margin: 30px 15px 0;
	}
	#foot .btn a {font-size: 1.5rem;}
	#foot .flex .bnr {
		width: 100%;
	}
	#foot .flex p:last-of-type {
		width: 100%;
		margin-top: 15px;
		font-size: 1.5rem;
	}
}