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

html {
	font-size: 62.5%;
}

@media screen and (max-width: 799px) {
	.only-pc, .no-sp
	{ display: none !important; }
	.only-sp, .no-pc
	{ display: block !important; }
	img.only-sp, img.no-pc
	{ display: inline-block !important; }
}

.serif {
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  font-style: normal;
}

body {
	width: 100%;
	height: 100%;
	word-wrap: break-word;
  	overflow-wrap: break-word;
	line-height: 1.8;
	color: #333;
	font-weight: 400;
	font-family: Noto Sans;
	font-size: 1.6rem;
	text-align: justify;
}
img {
	display: block;
	max-width: 100%;
	max-height: 100%;
}

/* ==========================================================
 汎用パーツ
========================================================== */

.parent {
	display: grid;
}

/*  font
---------------------------------------------------------- */
.en ,
.sub {
	font-family: "Noto Serif JP", serif;
	font-weight: 400;
}

/*  section
---------------------------------------------------------- */
.about ,
.profile-global ,
.news {
	max-width: 1000px;
	margin: 0 auto;
}
section {
	padding: 135px 0 125px;
}

/*  ttl
---------------------------------------------------------- */
h2 {
	margin-bottom: 50px;
}
/*  txt
---------------------------------------------------------- */
.txt-01 {
	margin-bottom: 30px;
}

/* ==========================================================
 header / footer
========================================================== */

.header .logo,
.footer .logo {
  display: block;
}

/* header
---------------------------------------------------------- */
header {
	position: relative;
	max-width: 1600px;
	margin: 0 auto;
}
.cw-logo ,
.sp-logo {
	height: 80px;
}
header .logo {
	display: flex;
	gap: 20px;
	justify-content: center;
	align-items: center;
	margin: 20px 0;
}
.kv-txt {
	position: absolute;
	display: flex;
	justify-content: center;
	align-items: center;
	bottom: 0;
	left: 0;
	background: rgba(144, 104, 46, 0.85);
	width: 50%;
	height: 30%;
	max-width: 700px;
	max-height: 230px;
}
.kv-txt img {
	width: 70%;
}

/* footer
---------------------------------------------------------- */
.footer .logo {
	height: 75px;
	margin: 0 auto 30px;
}
.footer {
	text-align: center;
	padding: 30px 0;
	background-color: #fff;
	font-size: 12px;
	color: #757575;
}
/* news
---------------------------------------------------------- */
section.news {
	padding-bottom: 0;
}
.news {
	font-size: 16px;
}
.news .box-01 {
	background: #fff;
}
.news .item {
	display: flex;
	flex-wrap: wrap;
	border-bottom: #e6e6e6 solid 1px;
	padding: 30px;
}
.news .date {
	margin-right: 20px;
}
.news .link-more {
	display: flex;
	justify-content: right;
	align-items: center;
	margin-top: 40px;
	text-decoration: none;
	font-size: 16px;
}
.news .link-more::after {
	content: "";
	display: block;
	background: url(../img/icon_arrow.svg) no-repeat;
	background-size: contain;
	width: 20px;
	height: 20px;
	margin-left: 10px;
}
/* about
---------------------------------------------------------- */
.about .parent {
	grid-template-columns: 1fr 440px;
	gap: 60px;
}
.about .logo {
	height: 110px;
	margin: 0 auto;
}
.about h3 {
	font-size: 26px;
	font-weight: 700;
	text-align: center;
	margin: 40px 0 30px;
}

/* profile
---------------------------------------------------------- */
.profile ul , .writer ul {
	list-style: disc;
	margin-left: 1.8rem;
}
.profile h2 {
	max-width: 1000px;
	margin: 0 auto 50px;
}
.profile {
	background-color: #f9f7f2;
	width: auto;
}
.profile .parent {
	max-width: 1000px;
	grid-template-columns: 300px 1fr;
	gap: 65px;
	padding: 60px 0 50px 40px;
	border-bottom: #ddd solid 1px;
	margin: 0 auto;
}
.profile .parent:first-of-type {
	padding-top: 0;
}
.profile .parent:last-of-type {
	border-bottom: 0;
	padding-bottom: 0;
}
.profile .parent img {
	width: 300px;
	border-radius: 50%;
}
.profile .child {
	text-align: center;
}
.name {
	font-size: 24px;
	font-weight: 700;
	margin-top: 30px;
}
.en {
	font-size: 12px;
	color: #999;
}
.career {
	margin-top: 30px;
}

/* ==========================================================
 post.html
========================================================== */
body.post .main {
	max-width: 1000px;
	margin: 0 auto;
	padding-bottom: 0;
}
body.post .footer {
	background: #fff;
}
body.post .main .date {
	text-align: right;
	margin-bottom: 50px;
}
body.post h2 {
	font-size: 30px;
	font-weight: 500;
}
section.writer {
	margin-top: 100px;
	background: #f9f7f2;
	padding: 50px;
}
.writer .box-writer {
	max-width: 700px;
	margin: 0 auto;
}
.writer .parent {
	grid-template-columns: 150px 1fr;
	gap: 60px;
}
.writer .ttl {
	margin-bottom: 20px;
	font-size: 18px;
	display: flex;
	align-items: center;
}
.writer .ttl::after {
	background: url(../img/icon_medal.svg) no-repeat;
	background-size: contain;
	content: "";
	display: block;
	width: 25px;
	height: 25px;
	margin-left: 5px;
}
.writer .parent img {
	width: 150px;
	height: auto;
	border-radius: 50%;
}
.writer .parent .name {
	margin-top: 0;
}
.writer .parent .career {
	margin-top: 20px;
}
.writer .child a {
	display: inline-block;
	margin-top: 20px;
	color: #037abe;
}
/* ==========================================================
 post-list.html
========================================================== */
body.post-list .news {
	background: #f9f7f2;
	max-width: 100%;
	padding-bottom: 120px;
}
body.post-list .news .box-01 {
	max-width: 1000px;
	margin: 0 auto;
	background: #fdf8f1;
}
body.post-list h2 {
	font-size: 30px;
	font-weight: 700;
	text-align: center;
}
body.post-list .footer {
	background-color: #fff;
}
.link-top {
	display: flex;
	justify-content: right;
	align-items: center;
	margin: 0 auto 40px;
	text-decoration: none;
	font-size: 14px;
	max-width: 1000px;
	color: #333;
}
.link-top:before {
	content: "";
	display: block;
	background: url(../img/icon_arrow.svg) no-repeat;
	background-size: contain;
	transform: rotate(180deg);
	width: 20px;
	height: 20px;
	margin-right: 10px;
}

/* ==========================================================
 メディアクエリ
========================================================== */
@media screen and (max-width: 800px) {
	.header .logo {
		margin: 10px 0;
	}
	.cw-logo ,
	.sp-logo {
		height: 50px;
	}
	h2 {
		margin-bottom: 30px;
	}
	h2 img {
		height: 20px;
	}
	section {
		max-width: 100%;
		padding: 70px 20px 60px;
	}
	.about .parent {
		grid-template-columns: 1fr;
	}
	.about .logo {
		height: 90px;
	}
	.about h3 {
		font-size: 20px;
		margin: 30px 0 20px;
		text-align: left;
	}
	.profile .parent {
		padding: 50px 0;
		grid-template-columns: 1fr;
		gap: 30px;
	}
	.profile .parent:last-of-type {
		padding-bottom: 0;
	}
	.profile .child {
		margin: 0 auto;
	}
	.profile .parent img {
		width: 250px;
	}
	.profile .name {
		margin-top: 10px;
		font-size: 20px;
	}
	
	body.post .main {
		padding: 50px 20px 0 20px;
	}
	body.post .main .date {
		margin-bottom: 30px;
	}
	.writer .parent {
		display: block;
	}
	.writer .parent img {
		margin: 0 auto 10px;
	}
	section.writer {
		padding: 30px 20px;
		margin-top: 50px;
	}
	.writer .parent .name {
		text-align: center;
	}
	.writer .ttl {
		justify-content: center;
	}
	.writer .child a {
		display: flex;
        justify-content: center;
	}
	body.post h2 {
		font-size: 20px;
	}

	body.post-list h2 {
		font-size: 20px;
	}
	.link-top {
		padding-right: 20px;
	}
}