@charset "utf-8";
/* CSS Document */



/* コンテンツA： ヒーローイメージ */
.conA {
	display: flex;
	align-items: center;
	justify-content: center;
	background-image:url("../img/main_back.gif");
	background-position: center;
	background-size: cover;
	color: #fff;
	color: var(--text-bright-color);
	text-align: center;
	padding: 0 10px;
	padding-top: 30px;
	position: relative;
}


.conA .container{
	height: 250px;
	display: flex;
	align-items: center;
	justify-content: center;
	
	
}



.conA h1 {
	margin-top: 0;
	margin-bottom: 0px;
	font-family: 'Montserrat', sans-serif;
	font-size: 24px;
	letter-spacing: 0.1em;
	margin-left: 0.2em;
	font-family: "Zen Maru Gothic", sans-serif;
	color: #534741;
}


.conA p{
	color: #f7931e;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight: 600;
}


.tree03{
	position: absolute;
	left: 0;
	top:20%;
	width: 110px;
}

.tree04{
	position: absolute;
	right: 20px;
	bottom:0px;
	width: 80px;
}



@media (min-width: 768px) {
	
	
	.conA{
		padding-top: 100px;
	}
	
	
	.conA .container{
		height: 300px;
	}
	
	.conA h1 {
		font-size: 40px;
	}

	.conA p {
		font-size: 24px;
	}
	
	
.tree03{
	top:30%;
	width: auto;
}

.tree04{
	width: auto;
	
}
}




/* コンテンツページ: 記事 */


.post{
	padding-top: 50px;
	padding-bottom: 0px;
	background:#f9f4f2;
}


.post .container {
	width: 90%;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	padding: 10px 1em 30px;
	background: #fff;
	border-radius: 20px;
	position: relative;
	box-sizing: border-box;
}


.post p {
	/*text-align: center;*/
	margin-bottom: 1em;
}

.post img {
	max-width: 100%;
}

.post table{
	width: 100%;
	max-width: 900px;
	margin: 0 auto;
	border-collapse: collapse;
}

.post th{
	width: 10%;
	padding: 1em;
}

.post th.line, .post td.line{
	border-bottom: 2px dashed #f9d4a2;
}

.post td{
	line-height: 2;
	padding: 1em;
}

.post h1{
	font-size: 18px;
	color:#534741;
font-family: "Zen Maru Gothic", sans-serif;
	margin-bottom: 0.1em;
	border-bottom: 1px solid #534741;
	padding-bottom: 0.5em;
}

p.date{
	/*margin-bottom: 20px;*/
	color:#534741;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight: 500;
}

.post h2{
	margin-bottom: 0.5em;
	color:#534741;
}

@media print, screen and (min-width: 768px){
	
	
	.post{
		padding-top: 100px;
		padding-bottom: 0px;
	}	

	
	.post .container{
		padding: 10px 40px 40px;
	}
	
	
	.post table{
		font-size: 18px;
	}
	
	.post h1{
		font-size: 32px;
	}
	
	p.date{
	margin-bottom: 40px;
		font-size: 18px;
}

	
}




.title{
	font-family: "Kiwi Maru", serif;
	font-family: "Zen Maru Gothic", sans-serif;
	text-align: center;
	color: #534741;
	margin-top: 0;
	margin-bottom:1em;
	font-size: 20px;
}



@media print, screen and (min-width: 768px){
	.title{
	font-size: 32px;
		margin-bottom:1.5em;
		font-weight: 500
	
}
	}



.box01{
	margin-bottom: 50px;
}

@media print, screen and (min-width: 768px){
.box01{
	margin-bottom: 80px;
}	
	
}


.wp-block-gallery{
	max-width: 900px;
	margin: 0 auto;
}

.link{
	display: flex;
	justify-content: space-between;
	flex-wrap: nowrap;
	margin-top: 2em;
}





/* コンテンツB： 概要（アイコン＋テキスト） */


.conB{
	padding-top: 30px;
	padding-bottom: 30px;
}

.conB .container {
	/*padding-top: 20px;*/
	padding-bottom: 20px;
}

.conB .text {
	padding-left: 20px;
	padding-right: 20px;
	/*padding-bottom: 20px;*/
	/*text-align: center;*/
	margin-bottom: 20px;
}




.conB .text h2{
	font-weight: normal;
	font-size: 16px;
	color:#534741;
font-family: "Zen Maru Gothic", sans-serif;
	font-weight: 500;
	
}

.conB a {
	color: #5D9AB2;
	color: var(--main-color);
	text-decoration: none;
	font-family: "Kiwi Maru", serif;
}

.conB a:hover	{
	text-decoration: underline;
}

.conB img{
	width: 100%;
	height: 250px;
	object-fit: cover;
	object-position: top center;
	margin-bottom: 12px;
}

@media (min-width: 768px) {
	
	.conB{
		padding-top: 80px;
		padding-bottom: 80px;
	}
	
/*	
.conB .text:first-child{
	border-right: 2px dashed #f9d4a2;
}
	
	
.conB .text:nth-child(2){
	border-right: 2px dashed #f9d4a2;
}	
	*/
	
	.conB .container {
		display: flex;
		max-width: 1200px;
		margin-left: auto;
		margin-right: auto;
	}


	.conB .text	{
		flex: 1;
	}
	
.conB .text h2{
	font-size: 18px;
}	
	
	
}

/*
@media print, screen and (min-width: 768px){
.honbun{
	display: flex;
}
}
*/

.post table th{
	white-space: nowrap
}



.post table {
    width: 100%;
    border-collapse: collapse;
}
    
.post th, .post td{
    display: block;
    width: 96%; 
    }
    
.post th {
    padding: 0.2em;
    margin: 0 auto;
    box-sizing: border-box;
    text-align: left;
	font-weight: normal;
}
    
.post td {
    padding: 0.5em;
    margin:0 auto 0.6em;
    box-sizing: border-box;
    border-bottom: 1px solid #ccc;
}



@media(min-width:768px) {
.post table {
    max-width: 700px;
    margin: 0 auto;
    /*border: 1px solid #ccc;*/
}
.post th {
    display: table-cell;
    width: 20%;
    padding: 0.5em;
    /*border: 1px dashed #ccc;
    border-right: 1px solid #ccc;*/
	white-space: nowrap;
	border-bottom: 1px solid #ccc;
}
.post td {
    display: table-cell;
    /*border: 1px dashed #ccc;*/
}
}


.post .container{
	position: relative;
}


.post .tag-info{
	position: absolute;
	right: 10px;
	top:20px;
	background: #E87B43;
	color: #fff;
	padding: 0.2em 0.5em;
	border-radius: 5px;
	font-size: 12px;
}


.post .tag-arch{
	position: absolute;
	right:10px;
	top:20px;
	background: #A2CD7F;
	color: #fff;
	padding: 0.2em 0.5em;
	border-radius: 5px;
	font-size: 12px;
}


@media print, screen and (min-width: 768px){


.post .tag-info{
	font-size: 14px;
	right:20px;
}


.post .tag-arch{
	font-size: 14px;
	right:20px;
}

	
}
