
/* all
-------------------------------------------------------------------*/
:root {
	--black: #282828;
	--white: #fff;
	--yellow: #f5c001;
	--yellow02: #fad126;
	--beige: #fff5d3;
	--beige02: #f6f3e8;
	--pink: #d22157;
	--pink02: #f5858a;
	--orange: #f57f01;
	--skyblue: #31bbcf;
	--blue: #0f88ba;
	--red: #d12222;
	--green: #83ca2f;
	--purple: #895fb3;
}
html {
	background: var(--white);
	color: var(--black);
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 16px;
	line-height: 1.4;
	scroll-behavior: smooth;
	scroll-padding-top: 6em;
}
body {
	width: 100%;
	font-size: 100%;
	text-align: center;
	min-width: 1200px;
	text-size-adjust: none;
	font-feature-settings: 'palt';
	-webkit-text-size-adjust: none;
}
main {
	overflow: clip;
	width: 100%;
}
body:not(.home):not(:has(.about)):not(:has(.service)) main{
	padding-bottom:10em;
}
.alata {
	font-family: "Alata", serif;
	font-weight: 400;
	font-style: normal;
}
main>*:first-child {
	padding-top: 80px;
}
.sitewrap {
	width: 1200px;
	min-width: 1200px;
	margin: 0 auto;
	text-align: left;
	box-sizing: border-box;
}
img {
	max-width: 100%;
	height: auto;
}
*:has(>wbr){
	word-break: keep-all;
}
@media screen and (max-width:1270px) {
	body,
	.sitewrap {
		width: 100%;
		min-width: 0;
	}
	.sitewrap>* {
		padding-left: 2%;
		padding-right: 2%;
	}
}
@media screen and (max-width:767px) {
	html {
		font-size: 14px;
	}
	main>*:first-child {
		padding-top: 70px;
	}
	body:not(.home):not(:has(.about)):not(:has(.service)) main{
		padding-bottom:6em;
	}
	.sitewrap>* {
		padding-left: 15px;
		padding-right: 15px;
	}
}
/* header
-------------------------------------------------------------------*/
header {
	position: fixed;
	z-index: 999;
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	inset: 0 0 auto;
}
header.fixedMenu {
	background: var(--white);
}
header #site_ttl {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 10px;
	white-space: nowrap;
}
header #site_ttl a {
	display: inline-block;
	vertical-align: middle;
	width: 207px;
}
header .drop_menu .header-bg_box {
	display: none;
}
header .drop_menu #NavWrap .nav-inner {
	display: inline-flex;
	justify-content: flex-start;
	align-items: stretch;
	height: 100%;
	padding: 0.75em 0;
	white-space: nowrap;
}
header .drop_menu #NavWrap ul:not([class]) {
	display: inline-flex;
	justify-content: flex-start;
	align-items: stretch;
	width: 26.25em;
	margin-right: 1.5em;
}
header .drop_menu #NavWrap ul:not([class])>li {
	flex: 1;
}
header .drop_menu #NavWrap li a,
header .drop_menu #NavWrap li p {
	display: inline;
	font-size: 0.875em;
	font-weight: 500;
	color: var(--black);
	text-decoration: none;
	cursor: pointer;
}
header .drop_menu #NavWrap li span {
	position: relative;
	z-index: 10;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	width: 100%;
	height: 100%;
}
header .drop_menu #NavWrap ul:not([class])>li span::after {
	position: absolute;
	z-index: 10;
	display: inline-block;
	content: "";
	width: 0.5em;
	aspect-ratio: 1/1;
	background: var(--yellow);
	border-radius: 100%;
	bottom: 0;
	left: 50%;
	opacity: 0;
	transform: translate(-50%, -50%);
	transition: opacity .4s ease;
}
header .drop_menu #NavWrap li.drop_wrap {
	position: relative;
	z-index: 10;
}
header .drop_menu #NavWrap li.drop_wrap i {
	display: none;
}
header .drop_menu #NavWrap li ul.drop_child {
	position: absolute;
	z-index: 999;
	min-width: auto;
	background: var(--white);
	border-radius: 1.25em;
	padding: 0.75em;
	opacity: 0;
	visibility: hidden;
	top: 3.3em;
	left: 50%;
	transform: translateX(-50%);
	transition: opacity .4s;
	filter: drop-shadow(0 10px 16px rgba(0, 0, 0, 0.15));
}
header .drop_menu #NavWrap li.drop_wrap p::before {
	position: absolute;
	z-index: -10;
	display: inline-block;
	content: "";
	width: 100%;
	height: 100%;
	left: 0;
	bottom: -2.5em;
}
header .drop_menu #NavWrap ul.drop_child li+li {
	border-top: 1px solid var(--yellow);
}
header .drop_menu #NavWrap ul.drop_child li a {
	min-width: 15em;
	display: block;
	font-size: 0.875em;
	font-weight: 500;
	color: var(--black);
	text-decoration: none;
}
header .drop_menu #NavWrap ul.drop_child li a span {
	position: relative;
	z-index: 10;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-direction: column;
	width: 100%;
	min-height: 3.5em;
	padding-right: 2.5em;
}
header .drop_menu #NavWrap ul.drop_child li a span::before {
	position: absolute;
	z-index: 15;
	display: inline-block;
	content: "";
	width: 2em;
	aspect-ratio: 1/1;
	background: var(--white);
	mask: url(../img/common/icon-arrow.svg) no-repeat;
	mask-size: 0.75em;
	mask-position: center;
	top: 50%;
	right: 0;
	transform: translateY(-50%) scale(1, 1);
	transform-origin: left;
	transition: transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);
}
header .drop_menu #NavWrap ul.drop_child li a span::after {
	position: absolute;
	z-index: 10;
	display: inline-block;
	content: "";
	width: 2em;
	aspect-ratio: 1/1;
	background: var(--yellow);
	border-radius: 50%;
	opacity: 1;
	inset: auto;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
}
header .drop_menu #NavWrap .contact-btn_box {
	display: inline-flex;
	justify-content: flex-start;
	align-items: center;
	gap: 1em;
	height: 100%;
	margin-right: 1.5em;
}
header .drop_menu #NavWrap .contact-btn a {
	position: relative;
	z-index: 10;
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 13em;
	width: fit-content;
	min-height: 3.25em;
	text-align: center;
	font-size: 1em;
	font-weight: 500;
	color: var(--white);
	padding: 0.5em 1.25em;
	margin: auto;
	text-decoration: none;
}
header .drop_menu #NavWrap .contact-btn a::after {
	position: absolute;
	z-index: -10;
	display: inline-block;
	content: "";
	width: 100%;
	height: 100%;
	background: var(--pink);
	border-radius: 5em;
	transition: filter .4s, transform .4s;
}
header .drop_menu #NavWrap .contact-btn a span {
	position: relative;
	z-index: 10;
	padding-left: 1.875em;
}
header .drop_menu #NavWrap .contact-btn a span::after {
	position: absolute;
	z-index: 10;
	display: inline-block;
	content: "";
	width: 1.5em;
	height: 1.125em;
	background: var(--white);
	mask: url(../img/common/icon-mail.svg) no-repeat;
	mask-size: contain;
	top: 0.1em;
	left: 0;
	bottom: 0;
	margin: auto;
}
header .drop_menu #NavWrap .contact-btn.btn_download a::after {
	background: var(--skyblue);
}
header .drop_menu #NavWrap .contact-btn.btn_download a span::after {
	width: 1.25em;
	height: 1.75em;
	mask: url(../img/common/icon-pdf.svg) no-repeat;
}
header .drop_menu #switch {
	position: fixed;
	z-index: -999;
	width: 0;
	height: 0;
	opacity: 0;
}
@media (any-hover: hover) {
	header .drop_menu #NavWrap ul:not([class])>li>*:hover>span::after {
		opacity: 1;
	}
	header .drop_menu #NavWrap li:hover ul.drop_child {
		opacity: 1;
		visibility: visible;
	}
	header .drop_menu #NavWrap ul.drop_child li a:hover span::before {
		transform: translateY(-50%) scale(0, 1);
		transform-origin: right;
	}
	header .drop_menu #NavWrap .contact-btn a:hover::after {
		transform: scale(0.95);
	}
}
@media screen and (max-width:1150px) {
	header #site_ttl a {
		width: 160px;
	}
	header .drop_menu #NavWrap ul {
		font-size: 0.875rem;
	}
	header .drop_menu #NavWrap ul:not([class]) {
		width: 24em;
	}
	header .drop_menu #NavWrap .contact-btn a {
		min-width: 11em;
	}
}
@media screen and (max-width:767px) {
	header {
		position: absolute;
	}
	header #site_ttl {
		padding: 1.715em 0.5em 0.715em;
	}
	header #site_ttl img {
		height: 40px;
		width: auto;
	}
	header .drop_menu #switch~label {
		position: fixed;
		z-index: 950;
		display: inline-block;
		text-align: center;
		padding: 12px;
		width: 4.2865rem;
		aspect-ratio: 1/1;
		background: var(--white);
		border: 2px solid var(--yellow);
		border-radius: 100%;
		box-sizing: border-box;
		cursor: pointer;
		filter: drop-shadow(rgba(245, 192, 1, 0.6) 0px 0px 0.5em);
		top: 0.75em;
		right: 0.75em;
	}
	header .drop_menu #switch~label b {
		display: block;
		width: 100%;
		margin-bottom: 0;
	}
	header .drop_menu #switch~label span {
		position: absolute;
		display: block;
		width: 22px;
		height: 2px;
		background: var(--yellow);
		top: 50%;
		left: 0;
		right: 0;
		margin: auto;
		cursor: -webkit-grabbing;
		transition: transform 0.4s;
	}
	header .drop_menu #switch~label span:before,
	header .drop_menu #switch~label span:after {
		position: absolute;
		z-index: 10;
		display: block;
		content: "";
		width: 22px;
		height: 2px;
		background: var(--yellow);
		margin-top: 0;
	}
	header .drop_menu #switch~label span:before {
		top: -9px;
	}
	header .drop_menu #switch~label span:after {
		top: 9px;
	}
	header .drop_menu #switch:checked~label span {
		transform: rotate(-135deg);
	}
	header .drop_menu #switch:checked~label span:before {
		top: 0;
	}
	header .drop_menu #switch:checked~label span:after {
		transform: rotate(270deg);
		top: 0;
		margin-top: 0;
	}
	header .drop_menu #NavWrap ul:not(.drop_child) > li{
		border-bottom:1px solid var(--black);
	}
	header .drop_menu #NavWrap li a,
	header .drop_menu #NavWrap li p,
	header .drop_menu #NavWrap ul.drop_child li a{
		position: relative;
		z-index: 10;
		display: block;
		font-size: 1.25em;
		padding: 1em 0.75em;
		padding-right:2.5em;
	}
	header .drop_menu #NavWrap ul:not(.drop_child) > li > a::before,
	header .drop_menu #NavWrap ul:not(.drop_child) > li > a::after{
		position:absolute;
		z-index:10;
		display:inline-block;
		content:"";
		width:1.85em;
		aspect-ratio: 1/1;
		background: var(--yellow);
		mask: url(../img/common/icon-arrow.svg) no-repeat;
		mask-size: 0.75em;
		mask-position: center;
		top: 50%;
		right:0.5em;
		transform: translateY(-50%);
		transform-origin: left;
	}
	header .drop_menu #NavWrap ul:not(.drop_child) > li > a::after{
		z-index:5;
		background:var(--white);
		border-radius:100%;
		mask:none;
	}
	header .drop_menu #NavWrap ul:not(.drop_child) > .drop_wrap > a{
		width:fit-content;
		padding-inline: 0.75em;
	}
	header .drop_menu #NavWrap ul:not(.drop_child) > .drop_wrap > a::before,
	header .drop_menu #NavWrap ul:not(.drop_child) > .drop_wrap > a::after{
		display:none;
	}
	header .drop_menu #NavWrap li span,
	header .drop_menu #NavWrap ul.drop_child li a span {
		align-items: flex-start;
	}
	header .drop_menu #NavWrap ul:not([class])>li span::after {
		display:none;
	}
	header .drop_menu #NavWrap li.drop_wrap {
		position: relative;
		z-index: 10;
	}
	header .drop_menu #NavWrap li.drop_wrap i {
		position:absolute;
		z-index:10;
		display: inline-block;
		font-size: 1.25em;
		width: 1.85em;
		aspect-ratio: 1/1;
		top: 0.75em;
		right:0.5em;
	}
	header .drop_menu #NavWrap li.drop_wrap i::before,
	header .drop_menu #NavWrap li.drop_wrap i::after{
		position:absolute;
		z-index:10;
		display:inline-block;
		content:"";
		width:1em;
		height:2px;
		background:var(--white);
		border-radius:1em;
		top:0.85em;
		right:0.35em;
	}
	header .drop_menu #NavWrap li.drop_wrap i::after{
		transform:rotate(270deg);
		transition:transform .4s;
	}
	header .drop_menu #NavWrap li.drop_wrap.opened i::after{
		transform:rotate(0);
	}
	header .drop_menu #NavWrap li ul.drop_child {
		position: relative;
		inset: 0;
		background: transparent;
		border-radius: 0;
		padding: 0;
		opacity: 0;
		max-height:0;
		visibility: hidden;
		transform: none;
		transition: opacity .4s;
		filter: none;
	}
	header .drop_menu #NavWrap li.opened ul.drop_child {
		max-height:100%;
		opacity: 1;
		visibility: visible;
	}
	header .drop_menu #NavWrap li.drop_wrap p::before {
		display:none;
	}
	header .drop_menu #NavWrap ul.drop_child li,
	header .drop_menu #NavWrap ul.drop_child li + li{
		border-top: 1px solid var(--black);
	}
	header .drop_menu #NavWrap ul.drop_child li a span {
		position:static;
		width: 100%;
		min-height: 0;
		padding-right: 0;
	}
	header .drop_menu #NavWrap ul.drop_child li a span::before,
	header .drop_menu #NavWrap ul.drop_child li a span::after {
		width:1.85em;
		right:0.5em;
		background: var(--white);
	}
	header .drop_menu #NavWrap ul.drop_child li a span::before{
		background:var(--yellow);
	}
	header .drop_menu .header-bg_box {
		position: fixed;
		z-index: 890;
		display: block;
		inset: 0;
		overflow: hidden;
		visibility: hidden;
		transition: visibility 1s;
	}
	header .drop_menu .header-bg_box .header-bg_circles {
		position: absolute;
		width: 4.2865rem;
		aspect-ratio: 1/1;
		top: 0.75em;
		right: 0.75em;
	}
	header .drop_menu .header-bg_box .header-bg_circle {
		position: absolute;
		z-index: 10;
		width: max(230vw, 230vh);
		aspect-ratio: 1/1;
		background: var(--white);
		border-radius: 100%;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%) scale(0);
		transition: 1s .2s cubic-bezier(0.76, 0, 0.24, 1) transform;
	}
	header .drop_menu .header-bg_box .header-bg_circle:nth-child(2) {
		z-index: 15;
		background: var(--beige);
		transition-delay: .1s;
	}
	header .drop_menu .header-bg_box .header-bg_circle:nth-child(3) {
		z-index: 20;
		background: var(--yellow);
		transition-delay: 0s;
	}
	header .drop_menu #switch:checked~.header-bg_box {
		visibility: visible;
		transition: visibility 0s;
	}
	header .drop_menu #switch:checked~.header-bg_box .header-bg_circle {
		transform: translate(-50%, -50%) scale(1);
		transition-delay: 0s;
	}
	header .drop_menu #switch:checked~.header-bg_box .header-bg_circle:nth-child(2) {
		transition-delay: .1s;
	}
	header .drop_menu #switch:checked~.header-bg_box .header-bg_circle:nth-child(3) {
		transition-delay: .2s;
	}
	header .drop_menu #NavWrap {
		position: fixed;
		z-index: 930;
		width: 100%;
		height: 100%;
		max-height:100dvh;
		inset: 10px 0 0;
		opacity: 0;
		box-sizing: border-box;
		overscroll-behavior: contain;
		overflow: auto;
		visibility: hidden;
		transition: inset 0s,opacity 0s;
	}
	header .drop_menu #NavWrap::-webkit-scrollbar {
		height: 10px;
		width: 10px;
	}
	header .drop_menu #NavWrap::-webkit-scrollbar-track {
		border-radius: 10px;
		background: #b3b3b3;
	}
	header .drop_menu #NavWrap::-webkit-scrollbar-thumb {
		border-radius: 10px;
	}
	header .drop_menu #switch:checked~#NavWrap {
		inset: 0;
		opacity: 1;
		visibility: visible;
		transition: inset 0.8s 1s,opacity 0.8s 1s;
	}
	header .drop_menu #NavWrap .nav-inner{
		display: flex;
		justify-content: flex-end;
		flex-direction: column-reverse;
		gap: 2em;
		padding: 6em 1.25em;
	}
	header .drop_menu #NavWrap .nav-inner::after{
		display: block;
		content:"";
		width:100%;
		padding-top: 4em;
		order: -1;
	}
	header .drop_menu #NavWrap ul:not([class]) {
		display: block;
		width: 100%;
		margin: 0;
	}
	header .drop_menu #NavWrap .contact-btn_box {
		flex-direction: column;
		gap: 1em;
		width: 100%;
		height: auto;
		background: var(--white);
		border-radius: 1em;
		padding: 1.5em;
		margin-right: 0;
	}
	header .drop_menu #NavWrap .contact-btn {
		width: 100%;
	}
	header .drop_menu #NavWrap .contact-btn a {
		width: 100%;
	}
	header .drop_menu #NavWrap .contact-btn a::after {
		filter: drop-shadow(0 5px 8px rgba(0, 0, 0, 0.15));
	}
}
/* contents
-------------------------------------------------------------------*/
.section,
section {
	position: relative;
	z-index: 10;
}
.slick-slider .slick-arrow:not(.slide-arrow) {
	position: absolute;
	z-index: 100;
	display: block;
	content: "";
	width: 4.5em;
	aspect-ratio: 1/1;
	font-size: 1rem;
	color: transparent;
	background: var(--black);
	border: 2px solid var(--black);
	border-radius: 50%;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	cursor: pointer;
	transition: background .4s;
}
.slick-slider .slick-arrow.slide-arrow{
	position: absolute;
	z-index: 100;
	display: block;
	content: "";
	width: 3em;
	aspect-ratio: 1/1;
	font-size: 1rem;
	color: transparent;
	background: transparent;
	border: none;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	cursor: pointer;
	transition: background .4s;
}
.slick-slider .slick-arrow.slick-disabled {
	display: none !important;
}
.slick-slider .slick-arrow.slick-next,
.slick-slider .slide-arrow.slick-next {
	left: auto;
	right: 0;
}
.slick-slider .slick-arrow:not(.slide-arrow)::before {
	position: absolute;
	z-index: 20;
	display: inline-block;
	content: "";
	width: 34%;
	height: 30%;
	background: #fff;
	mask: url(../img/common/icon-arrow.svg) no-repeat;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	transition: background .4s;
}
.slick-slider .slick-arrow.slide-arrow::before {
	position: absolute;
	z-index: 20;
	display: inline-block;
	content: "";
	width: 40%;
	height: 40%;
	border-top: 3px solid #bfbfbd;
	border-right: 3px solid #bfbfbd;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) rotate(45deg) skew(10deg, 10deg);
	transition: background .4s;
}
.slick-slider .slick-prev.slick-arrow:not(.slide-arrow)::before {
	transform: translate(-50%, -50%) rotate(180deg);
}
.slick-slider .slick-prev.slick-arrow.slide-arrow::before {
	transform: translate(-50%, -50%) rotate(225deg) skew(10deg, 10deg);
}
.slick-slider .slick-arrow:not(.slide-arrow):focus {
	background: var(--white);
}
.slick-slider .slick-arrow:not(.slide-arrow):focus::before {
	background: var(--black);
}
.slick-slider .slick-dots {
  width: 100%;
  text-align: center;
  line-height: 0;
  padding: 0;
  margin: 1em auto;
  list-style: none;
}
.slick-slider .slick-dots li {
  position: relative;
  z-index: 10;
  display: inline-block;
  width: 0.75em;
  height: 0.75em;
  border-radius: 100%;
  line-height: 1;
  margin: 0 0.35em;
  padding: 0;
  cursor: pointer;
  overflow: hidden;
}
.slick-slider .slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}
.slick-slider .slick-dots li button::before {
  position: absolute;
  z-index: 10;
  display: inline-block;
  content: "";
  width: 100%;
  height: 100%;
  background: #bfbfbd;
  top: 0;
  left: 0;
}
.slick-slider .slick-dots li.slick-active button::before {
  background: var(--yellow);
}
@media (any-hover: hover) {
	.slick-slider .slick-arrow:not(.slide-arrow):hover {
		background: var(--white);
	}
	.slick-slider .slick-arrow:not(.slide-arrow):hover::before {
		background: var(--black);
	}
	  .slick-slider .slick-dots li button:hover,
  .slick-slider .slick-dots li button:focus {
    outline: none;
  }
}
@media screen and (max-width: 767px) {
	.slick-slider .slick-arrow:not(.slide-arrow) {
		width: 3.5em;
	}
}
.cta-wrap {
	background: var(--yellow02);
	background: linear-gradient(155deg, var(--yellow02) 40%, var(--orange) 100%);
	padding: 6em 0;
}
.cta-wrap .cta-flex_box {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
	gap: 2em;
	margin-top: 2em;
}
.cta-wrap .cta-flex_box .cta-flex_item {
	flex: 1;
	text-align: center;
	background: #fff;
	border-radius: 1em;
	padding: 2em 1.5em;
}
.cta-wrap .cta-flex_box .cta-ttl_box {
	position: relative;
	z-index: 10;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
}
.cta-wrap .cta-flex_box .cta-ttl_box .cta-ttl_float {
	position: absolute;
	z-index: 10;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	width: 4.1em;
	aspect-ratio: 1/1;
	font-size: 1.25rem;
	font-weight: bold;
	color: var(--white);
	line-height: 1.2;
	background: var(--yellow);
	border-radius: 100%;
	top: -0.75em;
	left: calc(50% - 190px);
	transform: translateX(-50%);
}
.cta-wrap .cta-flex_box .cta-ttl_box .cta-ttl {
	position: relative;
	z-index: 10;
	display: inline-block;
	font-size: 1.5rem;
	font-weight: bold;
	padding-left: 1.75em;
	margin-bottom: 0.75em;
}
.cta-wrap .cta-flex_box .cta-ttl_box .cta-ttl::before {
	position: absolute;
	z-index: 10;
	display: inline-block;
	content: "";
	width: 1.25em;
	height: 1em;
	background: var(--pink);
	mask: url(../img/common/icon-mail.svg) no-repeat;
	mask-size: contain;
	top: 0.275em;
	left: 0;
}
.cta-wrap .cta-flex_box .item_download .cta-ttl_box .cta-ttl::before {
	width: 1em;
	height: 1.3335em;
	background: var(--skyblue);
	mask-image: url(../img/common/icon-pdf.svg);
	top: 0;
	left: 0.45em;
}
.cta-wrap .cta-flex_box .cta-ttl_box .cta-ttl_lead {
	font-size: 1rem;
	line-height: 1.8;
	margin-bottom: 1.5em;
}
#fixed_bnr {
	position: fixed;
	z-index: 900;
	bottom: 10em;
	right: 2em;
	opacity: 0;
	visibility: hidden;
	transition: opacity .4s;
}
#fixed_bnr.fixed_bnr {
	opacity: 1;
	visibility: visible;
}
#fixed_bnr:has(#fixed_bnr_close:checked) {
	display: none;
}
#fixed_bnr #fixed_bnr_close {
	position: absolute;
	z-index: -10;
	width: 0;
	height: 0;
}
#fixed_bnr label {
	position: absolute;
	z-index: 15;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	width: 1.8em;
	aspect-ratio: 1/1;
	font-size: 1.25rem;
	font-weight: bold;
	color: var(--black);
	background: var(--white);
	border: 1px solid var(--pink);
	border-radius: 100%;
	top: -0.15em;
	right: -0.5em;
}
#fixed_bnr a {
	display: block;
	filter: drop-shadow(0 10px 16px rgba(0, 0, 0, 0.15));
	transform: translateY(0);
	transition: filter .4s, transform .4s;
}
@media (any-hover: hover) {
	#fixed_bnr a:hover {
		filter: drop-shadow(0 0 0 rgba(0, 0, 0, 0.15));
		transform: translateY(2px);
	}
}
@media screen and (max-width: 1050px) {
	.cta-wrap .cta-flex_box .cta-ttl_box .cta-ttl_float {
		left: calc(50% - 160px);
	}
}
@media screen and (max-width: 767px) {
	.cta-wrap {
		padding: 4em 0;
	}
	.cta-wrap .cta-flex_box {
		flex-direction: column;
		gap: 2em;
		margin-top: 0;
	}
	.cta-wrap .cta-flex_box .cta-flex_item {
		width: 100%;
		border-radius: 0.75em;
	}
	.cta-wrap .cta-flex_box .cta-ttl_box .cta-ttl_float {
		font-size: 1rem;
		top: -0.75em;
		left: calc(50% - 130px);
	}
	.cta-wrap .cta-flex_box .cta-ttl_box .cta-ttl {
		font-size: 1.35rem;
	}
	.cta-wrap .cta-flex_box .cta-ttl_box .cta-ttl_lead {
		margin-bottom: 1em;
	}
	#fixed_bnr {
		bottom: 0;
		left:0;
		right: 0;
		padding:1em;
	}
	#fixed_bnr label{
		display:none;
	}
	#fixed_bnr a{
		position: relative;
		z-index: 10;
		display: flex;
		align-items: center;
		justify-content: center;
		min-width: 0;
		width: 100%;
		min-height: 3.25em;
		text-align: center;
		font-size: 1.25em;
		font-weight: 500;
		color: var(--white);
		background: var(--pink);
		border-radius: 5em;
		padding: 0.5em 1.25em;
		margin: auto;
		text-decoration: none;
	}
	#fixed_bnr a span {
		position: relative;
		z-index: 10;
		padding-left: 1.875em;
	}
	#fixed_bnr a span::after {
		position: absolute;
		z-index: 10;
		display: inline-block;
		content: "";
		width: 1.5em;
		height: 1.125em;
		background: var(--white);
		mask: url(../img/common/icon-mail.svg) no-repeat;
		mask-size: contain;
		top: 0.1em;
		left: 0;
		bottom: 0;
		margin: auto;
	}
}
/* footer
-------------------------------------------------------------------*/
#pageTop{
	position:fixed;
	z-index: 900;
	bottom: 3em;
	right: 2em;
}
footer {
	position: relative;
	z-index: 100;
	background: var(--beige02);
	padding: 4em 0;
}
footer .footer-box{
	display:flex;
	justify-content:space-between;
	align-items:flex-start;
	gap:2em;
	margin-bottom:4em;
}
footer .footer-nav_box{
	width: min(calc(100% - 207px),570px);
	display:flex;
	justify-content: space-between;
	align-items:flex-start;
	gap:2em;
}
footer .footer-nav_box *{
	font-size:0.875rem;
	font-weight:500;
}
footer .footer-nav_box dl ul{
	margin-top:1.25em;
}
footer .footer-nav_box dl li{
	position:relative;
	z-index:10;
	padding-left:1.25em;
}
footer .footer-nav_box dl li::before{
	position:absolute;
	z-index:10;
	display:inline-block;
	content:"";
	width:0.5em;
	height:1px;
	background:var(--black);
	top:0.875em;
	left:0;
}
footer .footer-nav_box li + li{
	margin-top:1em;
}
footer .footer-nav_box dt a,
footer .footer-nav_box li a,
footer .footer-other_box li a {
	position: relative;
	z-index: 10;
	display: inline-block;
	font-size: 1rem;
	line-height: 1.4;
	color: var(--black);
	text-decoration: none;
}
footer .footer-nav_box dt a::before,
footer .footer-nav_box li a::before,
footer .footer-other_box li a::before {
	position: absolute;
	z-index: 10;
	display: inline-block;
	content: "";
	width: 100%;
	height: 1px;
	background: var(--black);
	left: 0;
	bottom: 0;
	transform: scale(0, 1);
	transform-origin: right;
	transition: transform .4s;
}
footer .footer-other_box {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	gap: 1em;
}
footer .footer-other_box ul {
	position: relative;
	z-index: 10;
	display: flex;
	justify-content: flex-start;
	align-items: stretch;
	gap: 1.5em;
}
footer .footer-other_box ul:not(:has(li:first-child:last-child))::after {
	position: relative;
	z-index: 10;
	content: "";
	width: 1px;
	height: 100%;
	background: var(--black);
	order: 1;
}
footer .footer-other_box li:last-child {
	order: 3;
}
footer .footer-other_box li a {
	font-size: 0.875rem;
}
footer .footer-other_box small {
	font-size: 0.75rem;
}
footer .footer-other_box li a::before {
	transform: scale(1, 1);
	transform-origin: left;
}
@media (any-hover: hover) {
	footer .footer-nav_box li a:hover::before,
	footer .footer-nav_box dt a:hover::before{
		transform: scale(1, 1);
		transform-origin: left;
	}
	footer .footer-other_box li a:hover::before {
		transform: scale(0, 1);
		transform-origin: right;
	}
}
@media screen and (max-width: 767px) {
	#pageTop{
		width:5em;
		bottom: 1.5em;
		right: 1em;
	}
	#fixed_bnr ~ #pageTop{
		bottom: 6em;
	}
	footer {
		padding: 2em 0;
	}
	#fixed_bnr ~ footer{
		padding-bottom:7em;
	}
	footer .footer-box{
		flex-direction:column;
		align-items:center;
		gap: 1em;
		margin-bottom:2em;
	}
	footer .footer-nav_box{
		width: 100%;
		flex-direction:column;
		gap: 0.5em;
	}
	footer .footer-nav_box *{
		font-size:0.875rem;
		font-weight:500;
	}
	footer .footer-nav_box ul{
		display:flex;
		justify-content:flex-start;
		align-items:flex-start;
		flex-wrap:wrap;
		gap:0.25em 3%;
		width: 100%;
	}
	footer .footer-nav_box dl ul{
		margin-top: 0;
	}
	footer .footer-nav_box li{
		min-width: 30%;
	}
	footer .footer-nav_box li + li{
		margin-top:0;
	}
	footer .footer-other_box {
		flex-wrap:wrap;
	}
	footer .footer-other_box ul {
		gap:1em;
		width:100%;
	}
}