
/* all
-------------------------------------------------------------------*/
:root {
	--black: #282828;
	--white: #fff;
	--yellow: #ffff00;
	--yellow02: #fad126;
	--beige: #fff5d3;
	--beige02: #f6f3e8;
	--pink: #d22157;
	--pink02: #f5858a;
	--orange: #ed6d00;
	--skyblue: #01c6c1;
	--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%;
	min-width: 1200px;
	text-size-adjust: none;
	font-feature-settings: 'palt';
	-webkit-text-size-adjust: none;
}
main {
	overflow: clip;
	width: 100%;
}
.rock{
  font-family: "RocknRoll One", sans-serif;
  font-weight: 400;
  font-style: normal;
}
.jost {
  font-family: "Jost", sans-serif;
}
main>*:first-child {
	padding-top: 95px;
}
.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: 62px;
	}
	body:not(.home):not(:has(.about)):not(:has(.service)) main{
		padding-bottom:6em;
	}
	.sitewrap>* {
		padding-left: 15px;
		padding-right: 15px;
	}
}
/* header
-------------------------------------------------------------------*/
header#fix_menu {
	position: fixed;
	z-index: 999;
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	inset: 0 0 auto;
	background: var(--white);
	transition: filter 0.3s;
}
header.fixedMenu {
	filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.15));
}
header #site_ttl {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0.5em 2.5em;
	white-space: nowrap;
}
header #site_ttl a {
	display: inline-block;
	vertical-align: middle;
	width: 218px;
}
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;
	gap: 1.75em;
	margin-right: 2.5em;
	padding: 0;
	margin-bottom: 0;
}
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: 600;
	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 li span::after{
	position: absolute;
	z-index: 0;
	content: "";
	display:inline-block;
	inset: auto 0em 1em;
	width: calc(100%);
	height: 2px;
	background: var(--orange);
	transition: all .3s;
	transform: scale(0, 1);
	transform-origin: center top;
}
header .drop_menu #NavWrap .contact-btn_box {
	display: inline-flex;
	justify-content: flex-start;
	align-items: center;
	gap: 0.5em;
	height: 100%;
	margin-right: 1em;
}
header .drop_menu #NavWrap .contact-btn a {
	position: relative;
	z-index: 10;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-width: 19em;
	width: fit-content;
	min-height: 3.25em;
	text-align: center;
	font-size: 0.875rem;
	font-weight: 500;
	letter-spacing: 0.5px;
	color: var(--white);
	background: var(--skyblue);
	padding: 0.6em 1.25em;
	margin: auto;
	text-decoration: none;
	gap: 0;
	transition: transform 0.3s;
	border-radius: 5px;
	border: 3px solid #fff;
	filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.2));
}
header .drop_menu #NavWrap .contact-btn.head-session-btn a{
	background: #dd0a2d;
}
header .drop_menu #NavWrap .contact-btn a span {
	position: relative;
	z-index: 0;
	color: #ffff00;
	font-weight: 600;
}
header .drop_menu #NavWrap .contact-btn a span::before,
header .drop_menu #NavWrap .contact-btn a span::after{
    display: block;
    position: absolute;
    z-index: 1;
    content: "";
    width: 1px;
    height: 1em;
    transform: rotate(-30deg);
    background: #ffff00;
    margin: auto;
    inset: 3px auto auto -9px;
}
header .drop_menu #NavWrap .contact-btn a span:after{
	transform: rotate(30deg);
    inset: 3px -9px auto auto;
}
header .drop_menu #NavWrap .contact-btn a em b{
	font-size: 1.25rem;
	font-weight: 600;
}
header .drop_menu #switch {
	position: fixed;
	z-index: -999;
	width: 0;
	height: 0;
	opacity: 0;
}
@media (any-hover: hover) {
	header .drop_menu #NavWrap .contact-btn a:hover{
		transform: translateY(3px);
	}
	header .drop_menu #NavWrap li span:hover::after{
	    transform: scale(1, 1);
	}
}
@media screen and (max-width:1600px) {
	header #site_ttl {
		padding: 0.5em 1.5em;
	}
	header #site_ttl a {
		width: 160px;
	}
	header .drop_menu #NavWrap ul:not([class]) {
		gap: 1.25em;
		margin-right: 1em;
	}
	header .drop_menu #NavWrap .contact-btn_box {
		margin-right: 0.5em;
	}
	header .drop_menu #NavWrap .contact-btn a {
		min-width: 12em;
		font-size: 0.75rem;
		padding: 0.6em 1.25em;
	}
	header .drop_menu #NavWrap .contact-btn a em b{
		font-size: 1.125rem;
		font-weight: 600;
	}
}
@media screen and (max-width:1320px) {
	header .drop_menu #NavWrap ul:not([class]) {
		gap: 1em;
		font-size: 0.9rem;
	}
	header .drop_menu #NavWrap .contact-btn a {
		min-width: 10em;
		font-size: 0.75rem;
		padding: 0.6em 1.1em;
	}
	header .drop_menu #NavWrap .contact-btn a em b{
		font-size: 1rem;
	}
}
@media screen and (max-width:1210px) {
	header#fix_menu {
		position: absolute;
	}
	header.fixedMenu {
		filter: unset;
	}
	header #site_ttl {
		padding: 1.25em 1em 1.25em;
	}
	header #site_ttl img {
		height: 40px;
		width: auto;
	}
	header .drop_menu #switch~label {
		position: fixed;
		z-index: 9500;
		display: inline-block;
		text-align: center;
		padding: 12px;
		width: 3.5em;
		aspect-ratio: 1/1;
		background: var(--white);
		border: 2px solid var(--orange);
		border-radius: 100%;
		box-sizing: border-box;
		cursor: pointer;
		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(--orange);
		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(--orange);
		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(--white);
	}
	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: 0.75em 0.75em;
		padding-right:2.5em;
		color: var(--white);
	}
	header .drop_menu #NavWrap ul:not(.drop_child) > li > a::before{
		position:absolute;
		z-index:10;
		display:inline-block;
		content:"";
		top: 50%;
		right:0.5em;
		transform: translateY(-50%);
		transform-origin: left;
		width:1em;
		height: 1em;
		background: url(../img/common/icon_arrow.png);
		background-repeat: no-repeat;
		background-size: contain;
	}


	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{
		align-items: flex-start;
	}
	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(--orange);
		opacity: 0.5;
		transition-delay: .1s;
	}
	header .drop_menu .header-bg_box .header-bg_circle:nth-child(3) {
		z-index: 20;
		background: var(--orange);
		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-start;
		flex-direction: column;
		gap: 1em;
		padding: 5em 1.25em;
	}
	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;
		margin-bottom: 1em;
	}
	header .drop_menu #NavWrap .contact-btn {
		width: 100%;
	}
	header .drop_menu #NavWrap .contact-btn a {
		width: 100%;
		font-size: 1rem;
	}
	header .drop_menu #NavWrap .contact-btn a em b{
		font-size: 1.3rem;
	}
	header .drop_menu #NavWrap li.display_sp{
		display: block;
	}
}
@media screen and (max-width:767px) {
	header #site_ttl {
		padding: 1em .5em;
	}
	header #site_ttl img {
		height: 34px;
		width: auto;
	}
}
/* 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;
	}
}



/* footer
-------------------------------------------------------------------*/
#pageTop{
	position:fixed;
	z-index: 900;
	bottom: 3em;
	right: 2em;
}
#pageTop a{
	transition: opacity 0.3s;
	text-decoration: none;
	background: var(--orange);
	width: 80px;
	height: 80px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.25rem;
	color: #fff;
	font-weight: 600;
	border-radius: 50%;
	filter: drop-shadow(0px 0px 5px rgb(255 255 255 / 35%));
} 
@media screen and (max-width: 767px) {
	#pageTop a{
		width: 60px;
		height: 60px;
	}
}
@media (any-hover: hover) {
	#pageTop a:hover{
		opacity: 0.7;
	}
}
footer {
	position: relative;
	z-index: 100;
	background: #323232;
	padding: 2em 0 2em;
	color: var(	--white);
}
footer .footer-box{
	display:flex;
	justify-content: space-between;
	align-items:flex-start;
	gap:4em;
	margin-bottom: 2em;
}
footer .footer-box .footer-logo a{
	filter: brightness(0) invert(1);
	transition: opacity 0.3s;
}
footer .footer-box .footer-place{
	justify-self: inherit;
	margin-inline: 0 auto;
	line-height: 1.8;
}
footer .footer-box .footer-place p{
	margin-bottom: 0;
	line-height: 1.8;
}
footer .footer-box .footer-place a{
	pointer-events: none;
}
footer .footer-box .footer-links{
	width: 40%;
}
footer .footer-box .footer-links .footer-pages{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 0.5em 1.5em;
	padding: 0;
	margin-bottom: 1.5em;
}
footer .footer-box .footer-links .footer-pages li{
	margin: 0;
}
footer .footer-box .footer-links .footer-pages a{
	text-decoration: none;
	color: unset;
}
footer .footer-box .footer-links .footer-pages a span {
	position: relative;
	z-index: 10;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	width: 100%;
	height: 100%;
}
footer .footer-box .footer-links .footer-pages a span::after{
	position: absolute;
	z-index: 0;
	content: "";
	display:inline-block;
	inset: auto 0em -0.1em;
	width: calc(100%);
	height: 2px;
	background: #fff;
	transition: all .3s;
	transform: scale(0, 1);
	transform-origin: center top;
}
@media (any-hover: hover) {
	footer .footer-box .footer-links .footer-pages a:hover span::after{
	    transform: scale(1, 1);
	}
}


footer .footer-box .footer-sns{
	display: flex;
	gap: 0.5em;
	justify-content: flex-end;
	padding: 0;
	margin: 0;
}
footer .footer-box .footer-sns li{
	padding: 0;
	margin: 0;
}
footer .footer-box .footer-sns a{
	transition: opacity 0.3s;
}
footer .footer-small{
	text-align: center;
}
@media (any-hover: hover) {
	footer .footer-box .footer-logo a:hover,
	footer .footer-box .footer-sns a:hover{
		opacity: 0.7; 
	}
}
@media screen and (max-width: 1440px) {
	footer {
		padding: 2em 0 5em;
	}
}
@media screen and (max-width: 1210px) {
	footer {
		padding: 2em 0 2em;
	}
	footer .footer-box .footer-links{
		display: none;
	}
}

@media screen and (max-width: 767px) {
	#pageTop{
		width:5em;
		bottom: 1.5em;
		right: 1em;
	}
	#fixed_bnr ~ #pageTop{
		bottom: 6em;
	}
	footer {
		padding: 3em 0;
	}
	footer .footer-box{
		flex-direction:column;
		align-items:center;
		gap: 1em;
	}
	footer .footer-box .footer-logo a img{
		max-width: 164px;
	}
}