@charset "utf-8";

/* ===================================================
	About CSS
====================================================== */
/* ---------------------------------------------------
.cnt_nav
------------------------------------------------------ */
.cnt_nav {
	display: flex;
	justify-content: center;
}
.cnt_nav li {
	width: 320px;
	margin: 0 15px;
}
.cnt_nav a {
	position: relative;
	z-index: 0;
	display: flex;
	padding: 10px 45px;
}
.cnt_nav a::after {
	position: absolute;
	top: 50%;
	right: 25px;
	width: 10px;
	transform: translateY(-50%) rotate(90deg);
}
.cnt_nav a.active {
	color: #fff;
	background: #e5ac34;
	border-color: #e5ac34;
}
.cnt_nav a.active::after {
	background-image: url(../img/arrow_wht.svg);
}

@media screen and (max-width: 600px) {
	.cnt_nav {
		flex-wrap: wrap;
		width: calc(86% + 10px);
	}
	.cnt_nav li {
		max-width: calc((100% - 20px) / 2);
		margin: 0 5px 10px;
	}
	.cnt_nav a {
		padding: 8px 25px 8px 15px;
	}
	.cnt_nav a::after {
		right: 10px;
	}
}

/* ---------------------------------------------------
.cmn_lead
------------------------------------------------------ */
.cmn_lead {
	padding: 60px 0;
}

@media screen and (max-width: 600px) {
	.cmn_lead {
		padding: 30px 0 45px;
	}
}

/* ---------------------------------------------------
.list_dot
------------------------------------------------------ */
.list_dot li {
	position: relative;
	z-index: 0;
	padding: 0 0 0 20px;
	margin: 0 0 15px;
	font-weight: bold;
}
.list_dot li::before {
	position: absolute;
	top: 0.8em;
	left: 0;
	width: 15px;
	height: 15px;
	content: "";
	background: #d29e31;
	border-radius: 50%;
	transform: translateY(-50%);
}

@media screen and (max-width: 600px) {
	.list_dot li {
		margin-bottom: 5px !important;
	}
}

/* ---------------------------------------------------
#sec01
------------------------------------------------------ */
#sec01 {
	padding: 100px 0 150px;
	overflow: hidden;
}

@media screen and (max-width: 600px) {
	#sec01 {
		padding: 60px 0 100px;
	}
}

/* sec01a */
#sec01a {
	padding: 45px 0;
	color: #3a3527;
	border-image-source: linear-gradient(#faf6e8, #faf6e8); /* 色 */
	border-image-slice: 0 fill; /* 変更しない */
	border-image-outset: 0 100vw; /* どれだけはみ出すか上下左右 */
}
#sec01a h2 {
	margin: 0 0 45px;
	font-size: 28px;
	font-weight: bold;
	text-align: center;
}
#sec01a .flex_box {
	display: flex;
	justify-content: space-between;
}
#sec01a .txt {
	display: flex;
	flex-direction: column;
	width: 630px;
}
#sec01a .txt > p {
	margin: auto 0;
	line-height: 2;
}
#sec01a .img_sm {
	display: flex;
	justify-content: space-between;
	margin: 20px 0 0;
}
#sec01a .img_sm p {
	max-width: calc((100% - 10px) / 2);
}

@media screen and (max-width: 600px) {
	#sec01a h2 {
		margin-bottom: 15px;
		font-size: 20px;
		line-height: 1.6;
	}
	#sec01a .flex_box {
		display: block;
	}
	#sec01a .txt {
		display: block;
		width: auto;
	}
	#sec01a .txt > p {
		line-height: 1.8;
	}
	#sec01a .img_sm p {
		max-width: calc((100% - 5px) / 2);
	}
}

/* sec01b */
#sec01b {
	padding: 75px 0 0;
}
#sec01b .cmn_tit {
	margin-bottom: 35px;
}
#sec01b .cmn_dl {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-bottom: 25px;
}
#sec01b .cmn_dl > div {
	width: 500px;
	padding: 35px 0;
}
#sec01b .cmn_dl dt {
	width: 120px;
}
#sec01b .cmn_dl dd img {
	vertical-align: baseline;
}
#sec01b .cmn_dl dd .flex_list {
	display: flex;
	flex-wrap: wrap;
}
#sec01b .cmn_dl dd .flex_list li + li::before {
	content: "／";
}
#sec01b .cmn_dl > div.full {
	width: 100%;
}
#sec01b .img {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#sec01b .img p:not(.note) {
	max-width: calc((100% - 2px) / 2);
}
#sec01b .img .note {
	width: 100%;
	margin: 5px 0 0;
}

@media screen and (max-width: 600px) {
	#sec01b {
		padding-top: 45px;
	}
	#sec01b .cmn_tit {
		margin-bottom: 20px;
	}
	#sec01b .cmn_dl {
		display: block;
	}
	#sec01b .cmn_dl > div {
		display: flex;
		width: 100%;
		padding: 15px 0;
	}
	#sec01b .cmn_dl dt {
		margin: 0;
	}
	#sec01b .cmn_dl > div.full {
		display: block;
	}
	#sec01b .cmn_dl > div.full dt {
		width: auto;
		margin: 0 0 5px;
	}
	#sec01b .img {
		display: block;
	}
	#sec01b .img p:not(.note) {
		max-width: none;
	}
	#sec01b .img p + p {
		margin: 5px 0 0;
	}
}

/* sec01c */
#sec01c {
	display: flex;
	padding: 95px 0 0;
}
#sec01c .txt .cmn_tit {
	margin: 0 0 40px;
}
#sec01c .txt .cmn_btn {
	width: 280px;
	margin: 40px 0 0;
}
#sec01c .map {
	width: 670px;
	margin: 0 0 0 auto;
}
#sec01c .map iframe {
	min-width: 718px;
	max-width: max(calc(100% + ((100vw - 1200px) / 2)), calc(100% + 4vw));
}

@media screen and (max-width: 600px) {
	#sec01c {
		display: block;
		padding-top: 60px;
	}
	#sec01c .txt .cmn_tit {
		margin-bottom: 25px;
	}
	#sec01c .txt .cmn_btn {
		display: flex;
		width: 280px;
		margin: 20px auto 0;
	}
	#sec01c .map {
		width: 100%;
		margin: 25px 0 0;
	}
	#sec01c .map iframe {
		width: calc(100% + 7vw);
		min-width: 0;
		max-width: none;
		height: 60vw;
	}
}

/* ---------------------------------------------------
#sec02
------------------------------------------------------ */
#sec02 {
	padding: 0 0 150px;
}
#sec02 .cmn_lead .cap {
	font-size: 38px;
}
#sec02 .cmn_lead div {
	margin: 60px 0 0;
}

@media screen and (max-width: 600px) {
	#sec02 {
		padding-bottom: 60px;
	}
	#sec02 .cmn_lead {
		padding-bottom: 30px;
	}
	#sec02 .cmn_lead .cap {
		font-size: 24px;
	}
	#sec02 .cmn_lead div {
		margin-top: 25px;
	}
}

/* sec02a */
#sec02a {
	padding: 0 0 100px;
	color: #3a3527;
	border-image-source: linear-gradient(#faf6e8, #faf6e8); /* 色 */
	border-image-slice: 0 fill; /* 変更しない */
	border-image-outset: min(calc(60px + 165px), calc(60px + 12vw)) 100vw 0; /* どれだけはみ出すか上下左右 */
}
#sec02a h3 {
	margin: 0 0 40px;
	font-size: 28px;
	font-weight: bold;
	text-align: center;
}
#sec02a .service_col > div {
	display: flex;
	align-items: center;
	padding: 50px 70px 50px 0;
	background: #fff;
}
#sec02a .service_col > div + div {
	margin: 25px 0 0;
}
#sec02a .service_col dt {
	flex-shrink: 0;
	width: 270px;
	font-size: 23px;
	font-weight: bold;
	line-height: 1.4;
	text-align: center;
}
#sec02a .service_col dd .list_dot {
	display: flex;
	flex-wrap: wrap;
}
#sec02a .service_col dd .list_dot li {
	width: 340px;
}
#sec02a .service_col dd .list_dot li:nth-last-child(-n + 2) {
	margin: 0;
}
#sec02a .service_col + p {
	margin: 50px 0 0;
}

@media screen and (max-width: 600px) {
	#sec02a {
		padding-bottom: 45px;
	}
	#sec02a h3 {
		margin-bottom: 20px;
		font-size: 20px;
		line-height: 1.6;
	}
	#sec02a .service_col > div {
		display: block;
		padding: 20px 25px;
	}
	#sec02a .service_col dt {
		width: auto;
		margin: 0 0 10px;
		font-size: 18px;
		line-height: 1.6;
	}
	#sec02a .service_col dd .list_dot {
		display: block;
	}
	#sec02a .service_col dd .list_dot li {
		width: auto;
	}
	#sec02a .service_col + p {
		margin-top: 25px;
	}
}

/* ---------------------------------------------------
#sec03
------------------------------------------------------ */
#sec03 {
	padding: 0 0 150px;
}
#sec03 .cmn_lead .cap {
	font-size: 38px;
}

@media screen and (max-width: 600px) {
	#sec03 {
		padding-bottom: 100px;
	}
	#sec03 .cmn_lead .cap {
		font-size: 24px;
	}
}

/* sec03a */
#sec03a {
	padding: 60px 0 65px;
	color: #3a3527;
	border-image-source: linear-gradient(#faf6e8, #faf6e8); /* 色 */
	border-image-slice: 0 fill; /* 変更しない */
	border-image-outset: 0 100vw; /* どれだけはみ出すか上下左右 */
}
#sec03a h3 {
	margin: 0 0 45px;
	font-size: 28px;
	font-weight: bold;
	text-align: center;
}
#sec03a .flex_box {
	display: flex;
	justify-content: space-between;
}
#sec03a .flex_box .txt {
	width: 585px;
	margin: 15px 0 0;
}
#sec03a .flex_box .img img {
	width: 100%;
}

@media screen and (max-width: 600px) {
	#sec03a {
		padding: 45px 0;
	}
	#sec03a h3 {
		margin-bottom: 15px;
		font-size: 20px;
		line-height: 1.6;
	}
	#sec03a .flex_box {
		display: block;
	}
	#sec03a .flex_box .txt {
		width: auto;
		margin: 0 0 25px;
	}
}

/* sec03b */
#sec03b {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	padding: 120px 0 20px;
}
#sec03b .txt {
	width: 565px;
	max-width: calc((100% - 40px) * 565 / 1115);
}
#sec03b .txt .cmn_tit {
	margin: 0 0 35px;
}
#sec03b .txt .list_dot {
	margin: 0 0 30px;
}
#sec03b .img {
	position: relative;
	z-index: 0;
	width: 550px;
	max-width: calc((100% - 40px) * 550 / 1115);
}
#sec03b .img::before {
	position: absolute;
	top: 20px;
	left: -20px;
	z-index: -1;
	width: 671px;
	min-width: 593px;
	max-width: max(calc(100% + ((100vw - 1160px) / 2)), calc(100% + 4vw + 20px));
	height: 100%;
	content: "";
	background: #f5cb6d;
}
#sec03b .img .ofi {
	width: auto;
	min-width: 573px;
	max-width: max(calc(100% + ((100vw - 1200px) / 2)), calc(100% + 4vw));
}

@media screen and (max-width: 600px) {
	#sec03b {
		display: block;
		padding: 45px 0 15px;
	}
	#sec03b .txt {
		width: auto;
		max-width: none;
		margin: 0 0 25px;
	}
	#sec03b .txt .cmn_tit {
		margin-bottom: 20px;
	}
	#sec03b .txt .list_dot {
		margin-bottom: 20px;
	}
	#sec03b .img {
		width: auto;
		max-width: none;
	}
	#sec03b .img::before {
		top: 10px;
		left: -10px;
		width: calc(100% + 7vw + 10px);
		min-width: 0;
		max-width: none;
		content: "";
	}
	#sec03b .img .ofi {
		width: calc(100% + 7vw);
		min-width: 0;
		max-width: none;
	}
}

/* ---------------------------------------------------
#sec04
------------------------------------------------------ */
#sec04 {
	padding: 0 0 100px;
}

@media screen and (max-width: 600px) {
	#sec04 {
		padding-bottom: 45px;
	}
}

/* sec04a */
#sec04a .cap {
	padding: 5px 0 5px 15px;
	margin: 40px 0 15px;
	border-left: 3px solid #9c988a;
}
#sec04a table {
	width: 100%;
	table-layout: fixed;
}
#sec04a th,
#sec04a td {
	padding: 20px;
	text-align: center;
	border: 1px solid #d2d2d2;
}
#sec04a th {
	font-weight: normal;
}
#sec04a thead th {
	background: #faf6e8;
}
#sec04a tbody th {
	background: #f3f3f3;
}

@media screen and (max-width: 600px) {
	#sec04a .cap {
		padding: 0 0 0 10px;
		margin: 25px 0 10px;
	}
	#sec04a table {
		width: 1000px;
	}
	#sec04a th,
	#sec04a td {
		padding: 10px;
	}
	#sec04a .table_col::-webkit-scrollbar {
		height: 5px;
	}
	#sec04a .table_col::-webkit-scrollbar-track {
		background: #ccc;
	}
	#sec04a .table_col::-webkit-scrollbar-thumb {
		background: #e5ac34;
	}
}

/* ---------------------------------------------------
#sec05
------------------------------------------------------ */
#sec05 {
	padding: 55px 0 85px;
	color: #3a3527;
	text-align: center;
	border-image-source: linear-gradient(#faf6e8, #faf6e8); /* 色 */
	border-image-slice: 0 fill; /* 変更しない */
	border-image-outset: 0 100vw; /* どれだけはみ出すか上下左右 */
}
#sec05 h2 {
	margin: 0 0 20px;
	font-size: 28px;
	font-weight: bold;
}
#sec05 ul {
	display: flex;
	justify-content: space-between;
	margin: 30px 0 0;
}
#sec05 li {
	width: 520px;
	padding: 35px 20px 45px;
	background: #fff;
}
#sec05 li .cap {
	margin: 0 0 15px;
	font-size: 20px;
}
#sec05 li .tel-link .tel {
	font-size: 29px;
	font-weight: bold;
	line-height: 1;
}
#sec05 li .tel-link .tel span {
	font-size: 16px;
}
#sec05 li .tel-link .time {
	font-size: 14px;
}
#sec05 li .btn_mail::before {
	margin: 0 10px 0 0;
	line-height: 1;
	content: url(../img/icon_mail_gry.svg);
}

@media screen and (hover: hover) and (min-width: 601px) {
	#sec05 li .btn_mail:hover::before {
		content: url(../img/icon_mail_wht.svg);
	}
}
@media screen and (max-width: 600px) {
	#sec05 {
		padding-top: 45px;
		text-align: left;
	}
	#sec05 h2 {
		margin-bottom: 15px;
		font-size: 20px;
		line-height: 1.6;
		text-align: center;
	}
	#sec05 ul {
		display: block;
		margin-top: 25px;
		text-align: center;
	}
	#sec05 li {
		width: auto;
		padding: 20px 25px;
	}
	#sec05 li + li {
		margin: 25px 0 0;
	}
	#sec05 li .cap {
		margin-bottom: 10px;
		font-size: 18px;
	}
	#sec05 li .tel-link .tel {
		font-size: 29px;
		line-height: 1;
	}
	#sec05 li .tel-link .tel span {
		font-size: 16px;
	}
	#sec05 li .tel-link .time {
		font-size: 14px;
	}
	#sec05 li .btn_mail {
		padding: 8px 10px 8px 15px;
	}
	#sec05 li .btn_mail::before {
		margin-right: 5px;
	}
	#sec05 li .btn_mail::after {
		margin-left: 10px;
	}
}
