@charset "utf-8";
/*
  breakpoint：640/1025
*/
/*=================================*/
/* basic element */
/*=================================*/
html {
  font-size: 62.5%;
}
body {
  width: 100%;
  background: #fff;
  color: #333;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.6rem;
  line-height: 1.5;
  position: relative;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}
html.fixed body {
  height: 100%;
  overflow: hidden;
}
*, *:before, *:after {
	box-sizing: border-box;
}
a {
  transition: all .3s;
  text-decoration: none;
  color: #333;
}
a img {
  border: none;
  transition: all .3s;
}
@media all and (min-width: 640px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
p {
  line-height: 1.8125;
}
sup {
  font-size: 0.6em;
  vertical-align: super;
}
sub {
  font-size: 0.6em;
  vertical-align: text-bottom;
}
b {
  font-weight: 700;
}
select {
  color: #333;
}
button {
	padding: 0;
  font-family: inherit;
  background: inherit;
  border: 0;
}
img {
  width: 100%;
}
ul,ol {
	padding: 0;
	margin: 0;
	list-style-type: none;
}
hr {
	border: 0;
}
fieldset {
  min-width: 0;
  margin: 0;
  border: 0;
  padding: 0;
}
legend {
  width: 100%;
  margin: 0;
  padding: 0;
}
small {
	font-size: 100%;
}
:root {
	--header: 48px;
  --color-main01: #D95846;
  --color-main02: #FEEBD8;
  --font16: clamp(14px, 1.23vw, 1.6rem);
  --font18: clamp(16px, 1.38vw, 1.8rem);
  --font20: clamp(16px, 1.53vw, 2.0rem);
  --font22: clamp(17px, 1.69vw, 2.2rem);
  --font24: clamp(18px, 1.84vw, 2.4rem);
  --font26: clamp(20px, 2vw, 2.6rem);
  --font28: clamp(22px, 2.15vw, 2.8rem);
  --font32: clamp(22px, 2.46vw, 3.2rem);
  --font40: clamp(24px, 3.07vw, 4.0rem);
  --font42: clamp(24px, 3.23vw, 4.2rem);
  --font48: clamp(26px, 3.69vw, 4.8rem);
  --font50: clamp(26px, 3.69vw, 5.0rem);
  --fontZen: "Zen Kaku Gothic New", sans-serif;
  --fontAlbert: "Albert Sans", sans-serif;
  --lineheight: 1.8125;
  --width: 89.333333%;
  --m10: clamp(7px, 0.76vw, 10px);
  --m15: clamp(10px, 1.15vw, 15px);
  --m20: clamp(15px, 1.53vw, 20px);
  --m23: clamp(15px, 1.76vw, 23px);
  --m24: clamp(15px, 1.84vw, 24px);
  --m25: clamp(15px, 1.92vw, 25px);
  --m30: clamp(20px, 2.3vw, 30px);
  --m35: clamp(20px, 2.69vw, 35px);
  --m40: clamp(20px, 3.07vw, 40px);
  --m45: clamp(25px, 3.46vw, 45px);
  --m50: clamp(30px, 3.84vw, 50px);
  --m55: clamp(30px, 4.23vw, 55px);
  --m60: clamp(30px, 4.61vw, 60px);
  --m65: clamp(30px, 5vw, 65px);
  --m70: clamp(35px, 5.38vw, 70px);
  --m75: clamp(40px, 5.76vw, 75px);
  --m80: clamp(40px, 6.15vw, 80px);
  --m85: clamp(40px, 6.53vw, 85px);
  --m90: clamp(40px, 6.92vw, 90px);
  --m95: clamp(40px, 7.3vw, 95px);
  --m100: clamp(50px, 7.69vw, 100px);
  --m105: clamp(50px, 8.07vw, 105px);
  --m110: clamp(50px, 8.46vw, 110px);
  --m115: clamp(50px, 8.84vw, 115px);
  --m120: clamp(60px, 9.23vw, 120px);
  --m125: clamp(60px, 9.61vw, 125px);
  --m130: clamp(60px, 10vw, 130px);
  --m135: clamp(60px, 10.38vw, 135px);
  --m140: clamp(70px, 10.76vw, 140px);
  --m145: clamp(70px, 11.15vw, 145px);
  --m150: clamp(70px, 11.53vw, 150px);
  --m160: clamp(80px, 12.3vw, 160px);
  --m170: clamp(80px, 13.07vw, 170px);
}
@media (min-width: 1280px) {
	:root {
		--header: 100px;
	}
}
/*============================================*/
/* basic style */
/*============================================*/
/* box 
----------------------------------------------*/
.c-content {
  width: 89.333333%;
  max-width: 1200px;
  margin-inline: auto;
  position: relative;
}
/* display:none 
---------------------------------------------*/
@media (min-width: 640px) {
  .sp {
    display: none;
  }
}
.tab {
    display: none;
  }
@media (min-width: 640px) and (max-width: 1024px) {
  .tab {
    display: block;
  }
}
@media (max-width: 1024px) {
  .pc {
    display: none;
  }
}
/* margin 
---------------------------------------------*/
/* margin-bottom */
.mb0 {margin-bottom: 0 !important;}
.mb5 {margin-bottom: 5px !important;}
.mb10 {margin-bottom: clamp(5px, 0.76vw, 10px) !important;}
.mb15 {margin-bottom: clamp(10px, 1.15vw, 15px) !important;}
.mb20 {margin-bottom: clamp(15px, 1.53vw, 20px) !important;}
.mb25 {margin-bottom: clamp(15px, 1.92vw, 25px) !important;}
.mb30 {margin-bottom: clamp(20px, 2.3vw, 30px) !important;}
.mb35 {margin-bottom: clamp(20px, 2.69vw, 35px) !important;}
.mb40 {margin-bottom: clamp(20px, 3.07vw, 40px) !important;}
.mb45 {margin-bottom: clamp(25px, 3.46vw, 45px) !important;}
.mb50 {margin-bottom: clamp(30px, 3.84vw, 50px) !important;}
.mb55 {margin-bottom: clamp(30px, 4.23vw, 55px) !important;}
.mb60 {margin-bottom: clamp(30px, 4.61vw, 60px) !important;}
.mb65 {margin-bottom: clamp(35px, 5vw, 65px) !important;}
.mb70 {margin-bottom: clamp(35px, 5.38vw, 70px) !important;}
.mb75 {margin-bottom: clamp(40px, 5.76vw, 75px) !important;}
.mb80 {margin-bottom: clamp(40px, 6.15vw, 80px) !important;}
.mb85 {margin-bottom: clamp(40px, 6.53vw, 85px) !important;}
.mb90 {margin-bottom: clamp(40px, 6.92vw, 90px) !important;}
.mb95 {margin-bottom: clamp(40px, 7.3vw, 95px) !important;}
.mb100 {margin-bottom: clamp(50px, 7.69vw, 100px) !important;}
.mb105 {margin-bottom: clamp(50px, 8.07vw, 105px) !important;}
.mb110 {margin-bottom: clamp(50px, 8.46vw, 110px) !important;}
.mb115 {margin-bottom: clamp(50px, 8.84vw, 115px) !important;}
.mb120 {margin-bottom: clamp(60px, 9.23vw, 120px) !important;}
.mb125 {margin-bottom: clamp(60px, 9.61vw, 125px) !important;}
.mb130 {margin-bottom: clamp(60px, 10vw, 130px) !important;}
.mb135 {margin-bottom: clamp(60px, 10.38vw, 135px) !important;}
.mb140 {margin-bottom: clamp(60px, 10.76vw, 140px) !important;}
.mb145 {margin-bottom: clamp(60px, 11.15vw, 145px) !important;}
.mb150 {margin-bottom: clamp(60px, 11.53vw, 150px) !important;}
.mb155 {margin-bottom: clamp(60px, 11.92vw, 155px) !important;}
.mb160 {margin-bottom: clamp(80px, 12.3vw, 160px) !important;}
/* margin-top */
.mt15 {margin-top: clamp(10px, 1.15vw, 15px) !important;}
.mt20 {margin-top: clamp(15px, 1.53vw, 20px) !important;}
.mt40 {margin-top: clamp(20px, 3.07vw, 40px) !important;}
.mt50 {margin-top: clamp(30px, 3.84vw, 50px) !important;}
.mt60 {margin-top: clamp(30px, 4.61vw, 60px) !important;}
.mt80 {margin-top: clamp(40px, 6.15vw, 80px) !important;}
.mt120 {margin-top: clamp(60px, 9.23vw, 120px) !important;}

/* align 
---------------------------------------------*/
.alignC {
  text-align: center !important;
}
.alignR {
  text-align: right !important;
}
.alignL {
  text-align: left !important;
}
.valignT {
  vertical-align: top !important;
}
.valignM {
  vertical-align: middle !important;
}
.valignB {
  vertical-align: bottom !important;
}
/* text 
---------------------------------------------*/
.txtB {
  font-weight: 700 !important;
}
.txtM {
  font-weight: 500 !important;
}
.txtN {
  font-weight: 400 !important;
}
.indent {
  margin-left: 1em;
  text-indent: -1em;
}
.palt {
  font-feature-settings: "palt";
  letter-spacing: 0.5px;
}
.break {
  word-break: break-word;
}
/* link 
---------------------------------------------*/
.c-link {
	color: #D95846;
	text-decoration: underline;
}
.c-link.-white {
	color: #fff;
}
@media (any-hover: hover) {
  .c-link:hover {
    text-decoration: none;
  }
}
.c-pdf {
}
.c-pdf::before {
}
@media (any-hover: hover) {
  .c-pdf:hover {
    text-decoration: none;
  }
}
.c-tel {
	display: flex;
	align-items: baseline;
	gap: 6px;
	font-size: var(--font24);
	font-weight: 500;
}
.c-tel::before {
	flex-shrink: 0;
	content: "";
	width: clamp(10px, 1.23vw, 16px);
	aspect-ratio: 16 / 21;
	background: url("/assets/images/common/icon_tel_black.svg") center / contain no-repeat;
	position: relative;
	top: 2px;
}
/* list-style 
---------------------------------------------*/
.c-disc {
  padding-left: 1.2em;
  list-style-type: disc;
  line-height: var(--lineheight);
}
.c-dec {
  padding-left: 1.2em;
  list-style-type: decimal;
  line-height: var(--lineheight);
}
.c-dot li {
  padding-left: 1em;
  text-indent: -1em;
  line-height: var(--lineheight);
}
.c-dot li::before {
  content: '・';
}
.c-circle li {
  padding-left: 20px;
  line-height: var(--lineheight);
  position: relative;
}
.c-circle li::before {
  content: "";
  width: 10px;
  height: 10px;
  background: #333;
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: calc(1em - 4px);
}
.c-note li {
  padding-left: 1em;
  text-indent: -1em;
  line-height: var(--lineheight);
}
/* 動画
---------------------------------------------*/
.c-movie iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}
.c-map iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}
/*============================================*/
/* tone & manner */
/*============================================*/
/* Title
----------------------------------------------*/
/* font-size 24 */
.c-ttl {
	font-size: var(--font24);
	font-weight: 700;
}
/* Side Border */
.c-ttl--left {
	margin-bottom: 13px;
	padding-left: 16px;
	font-size: var(--font24);
	font-weight: 700;
	line-height: 1.5;
	position: relative;
}
.c-ttl--left::before {
	content: "";
	width: 3px;
	height: 55.555555%;
	min-height: 20px;
	background: #5DC943;
	position: absolute;
	left: 0;
	top: calc(50% + 1px);
	transform: translateY(-50%);
}
.c-ttl--left.-green::before {
	background: #5DC943;
}
/* ■ */
.c-ttl--square {
	padding-left: 22px;
	font-size: var(--font24);
	line-height: 1.5;
	position: relative;
}
.c-ttl--square::before {
	content: "";
	width: 16px;
	aspect-ratio: 1/1;
	background: #333;
	position: absolute;
	left: 0;
	top: calc(1.5em / 2 + 1px);
	transform: translateY(-50%);
}
.c-ttl--square.-green::before {
	width: 12px;
	background: #5DC943;
}
.c-ttl--square.-color01::before {
	background: var(--color-main01);
}
.c-ttl--square.-white::before {
	background: #fff;
}
.c-ttl--square.-blue::before {
	background: #306291;
}
/* 数字とセット */
.c-ttl-count {
	display: flex;
	align-items: flex-end;
	gap: clamp(20px, 3.84vw, 50px);
}
.c-ttl-count__num {
	align-self: baseline;
	flex-shrink: 0;
	padding-bottom: 8px;
	color: var(--color-main01);
	font-family: var(--fontAlbert);
	font-size: clamp(33px, 6vw, 7.8rem);
	font-weight: 600;
	line-height: 1.16;
	text-align: center;
	position: relative;
}
.c-ttl-count__num::after {
	content: "";
	--size: clamp(4px, 0.61vw, 8px);
	width: calc(var(--size) * 12); 
	height: var(--size);
	background-image: radial-gradient(
		circle,
		var(--color-main01) calc(var(--size) / 2), 
		transparent calc(var(--size) / 2)
	);
	background-position: left center;
	background-size: calc(var(--size) * 2) var(--size);
	background-repeat: repeat-x;
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
}
.c-ttl-count__txt {
	flex: 1;
	padding-bottom: clamp(10px, 1.53vw, 20px);
	border-bottom: 1px solid #B4B4B4;
	font-size: clamp(24px, 3.23vw, 4.2rem);
	font-weight: 500;
	line-height: 1.4;
}
/* Anchor Link 
----------------------------------------------*/
.c-anchorLink ul {
	display: flex;
	flex-wrap: wrap;
	gap: var(--m24) clamp(24px, 4.61vw, 60px);
}
.c-anchorLink ul li {
	display: contents;
}
.c-anchorLink a {
	display: flex;
	align-items: baseline;
	font-size: var(--font18);
	font-weight: 500;
	--height: calc(var(--font18) * 1.5);
}
.c-anchorLink a::before {
	flex-shrink: 0;
	align-self: start;
	content: "";
	width: 30px;
	aspect-ratio: 1 / 1;
	margin-right: clamp(8px, 1.23vw, 16px);
	background: url(/assets/images/common/icon_anchor_off.svg) center / contain no-repeat;
	position: relative;
	top: calc(var(--height) / 2 + 2px);
	transform: translateY(-50%);
}
@media (any-hover: hover) {
	.c-anchorLink a:hover {
		color: var(--color-main01);
	}
	.c-anchorLink a:hover::before {
		background-image: url(/assets/images/common/icon_anchor_on.svg);
	}
}
.c-anchorLink a .-num {
	flex-shrink: 0;
	min-width: 1.3em;
	margin-right: var(--m10);
	color: var(--color-main01);
	font-family: var(--fontAlbert);
	font-size: var(--font20);
	font-weight: 600;
}
/* Flow 
----------------------------------------------*/
.c-flow__list {
	background: #fff;
	counter-reset: step-counter;
	color: #333;
}
.c-flow__list li .-ttl {
	display: flex;
	align-items: center;
	gap: var(--m50);
	padding: var(--m20) var(--m30);
	background: #F9F7F5;
	font-size: var(--font24);
	counter-increment: step-counter;
}
.c-flow__list li .-ttl::before {
	flex-shrink: 0;
	display: flex;
	justify-content: center;
  align-items: center;
	content: counter(step-counter);
  width: clamp(40px, 4.61vw, 60px);
  aspect-ratio: 1 / 1;
  background-color: var(--color-main01);
  border-radius: 12px;
  color: #fff;
  font-family: var(--fontAlbert);
  font-size: var(--font24);
  font-weight: 600;
}
.c-flow__list li .-txt {
	display: flex;
	align-items: center;
	gap: var(--m50);
	padding: clamp(16px, 1.69vw, 22px) var(--m30);
}
.c-flow__list li .-txt::before {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	content: "\e902";
	width: clamp(40px, 4.61vw, 60px);
  aspect-ratio: 1 / 1;
  color: var(--color-main01);
	font-family: 'icomoon' !important;
	font-size: 12px;
}
.c-flow__list li:last-child .-txt::before {
	color: #fff;
}
/* Button 
----------------------------------------------*/
.c-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--m30);
	padding: var(--m20) var(--m20) var(--m20) var(--m30);
	background: var(--color-main01);
	border: 1px solid #fff;
	border-radius: var(--m20);
	color: #fff;
	font-size: var(--font18);
	font-weight: 700;
}
.c-btn::after {
	flex-shrink: 0;
	content: "\e900";
	display: flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	aspect-ratio: 1/1;
	border-radius: 50%;
	background: #fff;
	color: var(--color-main01);
	font-family: 'icomoon' !important;
	font-size: 6px;
}
@media (any-hover: hover) {
	a.c-btn:hover {
		background: #fff;
		border-color: var(--color-main01);
		color: var(--color-main01);
	}
	a.c-btn:hover::after {
		background: var(--color-main01);
		color: #fff;
	}
}
.c-btn.-white {
	background: #fff;
	color: var(--color-main01);
}
.c-btn.-white::after {
	background: var(--color-main01);
	color: #fff;
}
@media (any-hover: hover) {
	a.c-btn.-white:hover {
		background: var(--color-main01);
		border-color: #fff;
		color: #fff;
	}
	a.c-btn.-white:hover::after {
		background: #fff;
		color: var(--color-main01);
	}
}
.c-btn.-sizeL {
	gap: clamp(12px, 1.69vw, 22px);
	padding: var(--m30) var(--m20);
	font-family: var(--fontZen);
	font-size: var(--font18);
}
.c-btn.-sizeL::after {
	width: clamp(30px, 3.3vw, 43px);
}
.c-btn .-blank::after {
	content: "\e903";
  font-family: 'icomoon' !important;
  font-size: 10px;
  margin-left: 7px;
  vertical-align: super;
  position: relative;
  top: 2px;
}
.c-returnBtn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 70%;
  max-width: 300px;
  margin-inline: auto;
  height: clamp(50px, 5.69vw, 74px);
  background: var(--color-main01);
  border: 1px solid var(--color-main01);
  border-radius: 50px;
  color: #fff;
  font-size: var(--font18);
  font-weight: 500;
  text-align: center;
}
@media (any-hover: hover) {
  .c-returnBtn:hover {
    background: #fff;
    color: var(--color-main01);
  }
}
.c-mapBtn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 240px;
	padding: 11px;
	background: var(--color-main01);
	border: 1px solid var(--color-main01);
	border-radius: 30px;
	color: #fff;
	font-size: var(--font16);
	line-height: 1;
	text-align: center;
}
.c-mapBtn::after {
	content: "\e903";
	font-family: 'icomoon' !important;
	font-size: 10px;
}
@media (any-hover: hover) {
	.c-mapBtn:hover {
		background: #fff;
		color: var(--color-main01);
	}
}
/* DL tablelayout
---------------------------------------------*/
.c-dltable {
  display: grid;
  border-top: 1px solid #C9C9C9;
}
.c-dltable > dt,
.c-dltable > dd {
  padding: var(--m25) var(--m20) var(--m25) var(--m40);
  border-bottom: 1px solid #C9C9C9;
  line-height: var(--lineheight);
}
.c-dltable > dt {
  background: #F5F5F5;
}
@media (min-width: 640px) {
  .c-dltable {
    grid-template-columns: 33.333333% 1fr;
  }
  .c-dltable > dt {
    border-right: 1px solid #C9C9C9;
  }
}
.c-dltable dd {
	background: #fff;
}
/* table
---------------------------------------------*/
.c-table {
  width: 100%;
  margin-inline: auto;
  border-bottom: 1px solid #DFDFDF;
}
.c-table tr {
  border-top: 1px solid #DFDFDF;
}
.c-table th, .c-table td {
  padding: var(--m25) var(--m40);
  font-weight: 400;
  line-height: 1.75;
  vertical-align: middle;
}
.c-table th {
  padding: var(--m25) var(--m20);
  background: #FFF6F6;
  font-weight: 500;
}
.c-table th + th,
.c-table td + td {
  border-left: 1px solid #DFDFDF;
}
/* scrollTable
---------------------------------------------*/
@media (max-width: 767px) {
  .js-scrollable {
    overflow-x: scroll;
  }
  .js-scrollable::-webkit-scrollbar{
    height: 5px;
  }
  .js-scrollable::-webkit-scrollbar-track{
    background: #F1F1F1;
  }
  .js-scrollable::-webkit-scrollbar-thumb {
    background: #BCBCBC;
  }
  .js-scrollable table {
    width: clamp(590px, 92.3vw, 1200px) !important;
  }
  .js-scrollable > img {
  	min-width: 640px;
  }
}
/* etc
---------------------------------------------*/