@charset "utf-8";


/*====================================================================================================
  TOPPAGE
====================================================================================================*/
#toppage {
	position: relative;
	background-image: 
		linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgb(255, 255, 255) 100%),
		url(../../image/bg-pattern.png);
	background-repeat: no-repeat, repeat;
	background-size: 100% 100px, 100px auto;
	background-position: bottom, top;
}
#toppage section { margin-bottom: var(--bottom);}
#toppage .rad10 { border-radius: 10px;}
#toppage h3 {
	position: relative;
	font-weight: 900;
	font-size: clamp(1.5rem, 0.25rem + 1.67vw, 2.25rem); /* 1200:24px, 1920:36px */
	color: var(--violet);
	font-family: "Zen Maru Gothic";
	text-align: center;
	margin-bottom: 5.8125rem;

}
#toppage h3::after {
	position: absolute;
	background-color: var(--violet);
	bottom: -1.875rem;
	content: "";
	height: 3px;
	left: 50%;
	transform: translateX(-50%);
	width: 50px;
}
#toppage .wide1 {
	margin-left: calc((100vw - min(1200px, 100%)) / -2 + 50vw);
    translate: -50% 0;
}
#toppage .wide2 {
	position: relative;
  	left: 50%;
 	transform: translateX(-50%);
  	width: 100vw;
}

/*** mainimg *******************************************************/
#toppage .mainimg {
	position: relative;
	top: 0;
	width: 100%;
	height: auto;
	z-index: 1;
	padding: 0;
}
#toppage h2 {
	position: absolute;
	text-shadow: 0px 0px 12px rgba(88, 91, 191, 1);
	color: #fff;
	font-size: clamp(1.25rem, 0.886rem + 1.55vw, 2.75rem); /* 375:20px, 1920:44px */
	font-family: "Zen Maru Gothic", "Noto Sans JP", sans-serif, system-ui;
	font-weight: 700;
	letter-spacing: 0.05em;
	top: 40%;
	left: 15%;
}

/*====================================================================================================
  #MAIN
====================================================================================================*/

#toppage #main { width: 100%; max-width: 1200px; margin: 0 auto;}

/*** .sch *******************************************************/
#toppage .sch_box {
	display: flex;
	gap: 1.25rem;
	margin-bottom: 1.25rem;
}
#toppage .sch_wrap {
	width: 100%;
	height: 330px;
	max-width: 590px;
	padding: 2.5% 3.7%;
	background-color: #fff;
	margin-inline: auto;
}
#toppage .sch_wrap_3rd { height: auto; margin-bottom: 2.5rem;}
#toppage .sch_wrap h4 {
	text-align: left;
	font-weight: 900;
	font-size: clamp(1.313rem, 0.583rem + 0.97vw, 1.75rem); /* 1200:21px, 1920:28px */
	letter-spacing: 0.05em;
	color: var(--green);
	border-bottom: solid 2px var(--green);
	padding-bottom: 0.875rem;
}
#toppage .sch_wrap_3rd h4 { margin-bottom: 15px;}
#toppage .sch_wrap .sup {
	font-size: clamp(0.75rem, 0.333rem + 0.56vw, 1rem); /* 1200:12px, 1920:16px */
	margin-left: 15px;
	background: var(--green);
	color: #fff;
	padding: 0.25em;	
}
#toppage .sch_inner { width: 100%;}
#toppage tbody { font-weight: 600;}
#toppage .sch_inner table {
	width: 100%;
	table-layout: auto;
	text-align: center;
	font-size: clamp(0.938rem, 0.729rem + 0.28vw, 1.063rem); /* 1200:15px, 1920:17px */
	margin-bottom: 15px;
}
#toppage .sch_inner tbody { display: grid; grid-auto-flow: row;}
#toppage .sch_inner tbody tr {
	display: grid;
	grid-auto-flow: column;
	grid-template-columns: 120px repeat(7, 1fr);
	gap: 1em;
	padding-block: 0.5em;
}
#toppage .sch_inner tr:not(:first-child) {
	border-bottom: 1px solid #ccc;
}
#toppage .sch_inner tbody th {
	background: #f2f2f2;
	border-radius: 3px;
	padding-block: 0.3em;
}
#toppage .sch .note2 { text-align: center;}
#toppage .sch .note2 a {
	font-size: clamp(2rem, 1.583rem + 0.56vw, 2.25rem); /* 1200:15px, 1920:17px */
	font-weight: 700;
	color: var(--green);
}
#toppage .sch img.tel_icon {
	width: auto;
	height: 24px;
	vertical-align: baseline;
	margin-right: 6px;
}
#toppage .sch_msg { position: relative; text-align: center; font-weight: 700;}
#toppage .sch_msg::after {
	position: absolute;
	content: "";
	background-image: url(../../image/bird.png);
	width: 259px;
	background-size: contain;
	aspect-ratio: 259 / 160;
	top: 93px;
	left: -37px;
}
/*** .guid *******************************************************/
#toppage .guid {
	display: flex;
	gap: 20px;
	max-width: 1240px;
	justify-content: center;
}
#toppage .guid_wrap {
	min-width: 400px;
	height: 560px;
	display: grid;
	grid-auto-flow: row;
	background-color: #fff;
	text-align: center;
	align-content: space-between;
	margin: 0 auto;
}
#toppage .guid_wrap h4 {
	margin: 0;
	background-color: var(--green);
	line-height: 71px;
	height: 84px;
	font-size: clamp(1.313rem, 0.583rem + 0.97vw, 1.75rem); /* 1200:21px, 1920:28px */
	color: #fff;
	border-radius: 10px 10px 0 0;
	background-image: url(../../image/bg-guid-tit.svg);
	background-position: bottom -1px center;
}
#toppage .guid_wrap img { width: auto; height: 300px; margin: 0 auto;}
#toppage .guid_link a {
	display: block;
	width: fit-content;
	position: relative;
	text-align: center;
	background: var(--green);
	color: #fff;
	font-weight: 700;
	font-size: clamp(1rem, 0.896rem + 0.14vw, 1.063rem); /* 1200:16px, 1920:17px */
	padding: 16px 92px 16px 70px;
	border-radius: 30px 30px 0 0;
	margin-inline: auto
}
#toppage .guid_link a::after {
	content: "";
	position: absolute;
	display: block;
	background: url(../../image/arrow1.png) no-repeat;
	width: 12px;
	height: 16px;
	top: 1.5rem;
	right: 70px;
}

/*** .access *******************************************************/
#toppage .access { position: relative;}
#toppage .access::before { 
	position: absolute;
	content: "";
	background-image: url(../../image/bird.png);
	aspect-ratio: 259 / 160;
	background-size: contain;
	width: 259px;
 	transform: scale(-1, 1);
	top: -250px;
	right: -6px;
}
#toppage .access_box {
	display: flex;
	flex-direction: column;
	gap: 2.5rem;
	padding: 4.375rem 3.125rem 3.125rem;
	background-color: #fff;
}
#toppage .add_box {
	display: grid;
	column-gap: 2.5rem;
	grid-template-columns: repeat(2, 1fr);
	grid-template-rows: repeat(2, auto) 1fr;
	grid-template-areas:
	"add_item1 add_item3"
	"add_item2 add_item3";
}
#toppage .add_box .logo { width: 428px; height: auto; grid-area: add_item1;}
#toppage .add_box ul { grid-area: add_item2;}
#toppage .add_box .add_pt { grid-area: add_item3;}
#toppage .add_box ul li { margin-bottom: 15px;}

/*** .news *******************************************************/
#toppage .news {
	background: #fff;
	border-radius: 100% 100% 0% 0% / 50% 50% 0% 0%;
	padding-top: 6rem;
}
#toppage .news_area {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 60px;
}
#toppage .news_list {
	position: relative;
	display: flex;
	gap:2.5rem;
	padding-block: 1.5rem;
}
 #toppage li.news_list::before {
	position: absolute;
	content: "";
	width: 100%;
	height: 3px;
	background: url(../../image/dot.svg) repeat-x bottom / 10px auto;
	bottom: 0;
	}
#toppage .b_more {}
#toppage .b_more a {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 0.5rem;
	align-items: center;
	font-weight: 700;
	height: 55px;
	line-height: 55px;
	color: var(--violet);
	text-align: center;
	font-size: clamp(1rem, 0.479rem + 0.69vw, 1.313rem); /* 1200:16px, 1920:21px */
	max-width: 350px;
	background: #fff;
	border: 2px solid var(--violet);
	border-radius: 100vh;
	margin: 2% auto;
	--iconsize: 9px;
	padding-inline: 1rem;
}
#toppage .b_more a:before { content: "";}
#toppage .b_more a:after {
	content: "";
	display: block;
	width: var(--iconsize);
	height: auto;
	aspect-ratio: 9/12;
	background: var(--violet);
	mask: url(../../image/arrow1.png) no-repeat center / contain;
}
#toppage .b_more a:hover { opacity: 0.8;}
