/* all
-------------------------------------------------------------------*/
:root {
	--hover: background .4s, color .4s, border-color .4s, opacity .4s, text-decoration-color .4s, transform .4s, translate .4s, scale .4s, outline .4s, filter .4s, box-shadow .4s;
	--header: 80px;
	--container: 1200px;
	--wide: 1680px;
	--inner: 2em;
	--fontcolor: #282828;
	--whitecolor: #fff;
	--bgcolor: #f7fafc;
	--bgcolor02: #f0f3f5;
	--keycolor: #008ee6;
	--accent01: #eb1e4a;
	--accent02: #ffa733;
	--accent03: #10b7da;
	--accent04: #031a35;
	--accent05: #d9e6f5;
	--reverse: invert(1);
	--white: brightness(0) invert(1);
	--filtershadow: drop-shadow(0 0 24px rgba(124, 106, 103, 0.1));
	--filteraccent03: brightness(0) saturate(100%) invert(72%) sepia(27%) saturate(7493%) hue-rotate(147deg) brightness(95%) contrast(87%);
}
:root img {
	transition: opacity .4s, filter .4s;
}
:root :is(ul, ol, li) {
	margin: 0;
	padding: 0;
	line-height: 1.4;
}
body.home p {
	margin-bottom: 0;
	line-height: 1.4;
}
:root :is(h1, h2, h3, h4, h5) {
	margin: 0;
}
:root :is(a, button),
:root :is(a, button) :is(span, i),
:root :is(a, button)::before,
:root :is(a, button)::after,
:root :is(a, button) :is(span, i) ::before,
:root :is(a, button) :is(span, i)::after {
	transition: var(--hover);
}
html {
	background: var(--whitecolor);
	color: var(--fontcolor);
	font-family: "Noto Sans JP", sans-serif;
	font-size: 16px;
	line-height: 1.4;
	scroll-padding: var(--header);
	scroll-behavior: smooth;
	font-feature-settings: 'palt';
	font-optical-sizing: auto;
	font-style: normal;
	letter-spacing: 0.1em;
	overflow-x:clip;
}
html :is([lang="en"], .eng) {
	font-family: "Poppins", sans-serif;
}
html .min {
	font-family: "Noto Serif JP", serif;
}
body {
	width: 100%;
	font-size: 100%;
	text-align: center;
	min-width: var(--container);
	position: relative;
	z-index: 2;
	background: var(--whitecolor);
	font-family: "Noto Sans JP", sans-serif;
	overflow-x:clip;
}
body.home{
	background: var(--bgcolor);
}
main {
	overflow: clip;
	width: 100%;
}
body:not(.home) main{
	padding-top: 90px;
}
body img,
body svg {
	max-width: 100%;
	height: auto;
}
.sitewrap,
.widewrap {
	width: var(--container);
	margin: 0 auto;
	text-align: left;
	box-sizing: border-box;
}
.widewrap {
	max-width: 1700px;
	padding-inline: 1em;
	width: auto;
}
*:has(> .sitewrap) {
	width: 100%;
	overflow-x: clip;
}
*:has(>wbr) {
	word-break: keep-all
}
@media screen and (max-width:1270px) {
	:root {
		--container: 100%;
	}
	body,
	.sitewrap {
		width: 100%;
		min-width: 0;
	}
	.sitewrap>* {
		padding-inline: var(--inner);
	}
}
@media screen and (max-width:767px) {
	:root {
		--inner: 1.14rem;
		--header: 60px;
	}
	html {
		font-size: 14px;
	}
	body:not(.home) main{
		padding-top:70px;
	}
}
/* header
-------------------------------------------------------------------*/
header#fix_menu {
	position: fixed;
	z-index: 100;
	top: 0;
	left: 0;
	right: 0;
	height: var(--header);
	display: flex;
	align-items: center;
	transition: top .4s .2s, background .2s;
}
header#fix_menu.fixedMenu::after {
	content: "";
	display: block;
	inset: 0 0 auto;
	height: var(--header);
	background: transparent;
	position: absolute;
	z-index: -1;
	transition: background .2s;
	backdrop-filter: blur(0.25em);
}
body:not(.home) header#fix_menu.fixedMenu::after{
	backdrop-filter: blur(0);
	background:var(--whitecolor)
}
header #site_ttl {
	margin-inline: 1.875em;
}
:is(header #site_ttl, #footer .copy_style) a {
	display: flex;
	justify-content: center;
	align-items: flex-end;
	gap: 0.625em;
	text-decoration: none;
}
:is(header #site_ttl, #footer .copy_style) a img {
	display: block;
	max-width: inherit;
}
:is(header #site_ttl, #footer .copy_style) a span {
	font-size: 0.875em;
	font-weight: 900;
	color: var(--accent04);
	white-space: nowrap;
}
header .drop_menu {
	margin-left: auto;
}
header #NavWrap .scroll_wrap {
	position: relative;
	z-index: 2;
	display: flex;
	gap: 2.5em;
	height: var(--header);
	font-size: 0.875rem;
	font-weight: bold;
	letter-spacing: 0.05em;
	padding: 1.07142857143em 1.28571428571em;
}
header #NavWrap ul {
	flex-basis: 100%;
	display: flex;
	justify-content: flex-end;
	gap: 1.15em;
	white-space: nowrap;
}
header #NavWrap ul li {
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 2;
}
header #NavWrap ul li.head-instagram,
header #NavWrap ul li.head-youtube,,
header #NavWrap ul li.head-podcast,
header #site_ttl .head-instagram,
header #site_ttl .head-youtube,
header #site_ttl .head-podcast{
	display:flex;,
	justify-content:center;
	align-items:center;
}
header #site_ttl .head-instagram,
header #site_ttl .head-youtube,
header #site_ttl .head-podcast{
	display:none;
}
header #site_ttl .head-instagram,
header #NavWrap ul li.head-instagram a{
	transition:.5s opacity;
	filter: brightness(0);
	padding: 0;
}
header #site_ttl .head-youtube,
header #NavWrap ul li.head-youtube a,
header #NavWrap ul li.head-podcast a{
	transition:.5s opacity;
	filter: grayscale(100%);
	padding: 0 0.25em;
	display: flex;
	justify-content: center;
	align-items: center;
}
header #NavWrap ul li.head-instagram a img,
header #NavWrap ul li.head-podcast a img{
	filter: brightness(0) saturate(100%) invert(14%) sepia(5%) saturate(9%) hue-rotate(314deg) brightness(101%) contrast(86%);
}
header #NavWrap ul li.head-instagram,
header #NavWrap ul li.head-youtube,
header #NavWrap ul li.head-podcast{
	display:flex;
}
header #NavWrap ul li.head-instagram a:before,
header #NavWrap ul li.head-instagram a:after,
header #NavWrap ul li.head-youtube a:before,
header #NavWrap ul li.head-youtube a:after,
header #NavWrap ul li.head-podcast a:before,
header #NavWrap ul li.head-podcast a:after{
	display:none;
}
header #NavWrap ul li> :is(p, a) {
	display: flex;
	gap: 0.5em;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	padding: 0.75em 0.5em;
}
header #NavWrap ul li.drop_wrap {
	z-index: 1;
	cursor: pointer;
}
header #NavWrap ul li> :is(p, a) {
	position: relative;
	z-index: 1;
}
header #NavWrap ul li.drop_wrap p span{
	padding-right:1.25em;
	position:relative;
}
header #NavWrap ul li.drop_wrap p span:before{
	content:"";
	width:0.625em;
	height:0.625em;
	border-top: solid 2px var(--fontcolor);
	border-right: solid 2px var(--fontcolor);
	position: absolute;
	inset:-0.25em 0 0 auto;
	transform: rotate(135deg);
	margin:auto;
	transition:.5s transform;
}
header #NavWrap .scroll_content>li> :is(p, a)::before,
header #NavWrap .scroll_content>li> :is(p, a)::after {
	content: "";
	display: block;
	width: 5px;
	height: 5px;
	margin: auto;
	z-index: -1;
	position: absolute;
	border-radius: 50%;
	background: var(--fontcolor);
	top: 0.25em;
	transition: opacity .4s, transform .4s;
	opacity: 0;
}
header #NavWrap .scroll_content>li> :is(p, a) [lang="en"] {
	display: none;
}
header #NavWrap .scroll_content>li> :is(p, a)::before {
	scale: 1;
	opacity: 0.25;
	visibility: hidden;
	transition: opacity .6s .2s, scale .4s;
}
header #NavWrap .scroll_content :is(li.drop_wrap:hover > p, li > a:hover)::before {
	opacity: 0;
	visibility: visible;
	scale: 5;
}
header #NavWrap .scroll_content :is(li.drop_wrap:hover > p, li > a:hover)::after {
	opacity: 1;
}
header #NavWrap ul li.drop_wrap:hover p span:before{
	transform: rotate(135deg) scale(-1);
}
header #NavWrap ul li.drop_wrap ul {
	flex-wrap: wrap;
	z-index: 5;
	justify-content: flex-start;
	gap: 0;
	margin-inline: auto 0;
	max-width: 570px;
}
header #NavWrap ul li.drop_wrap .drop_child {
	position: absolute;
	z-index: -1;
	inset: 0 0 auto;
	top: calc(var(--header) - 1.07142857143em);
	display: flex;
	justify-content: flex-start;
	align-items: flex-end;
	gap: 0;
	background: var(--bgcolor);
	border-radius: 0.5em;
	opacity: 0;
	padding: 1.5em 0.75em;
	margin: 0;
	pointer-events: none;
	cursor: auto;
	transition: .2s;
	filter: var(--filtershadow);
}
header #NavWrap ul li.drop_wrap:hover .drop_child {
	opacity: 1;
	transition: .4s;
	pointer-events: auto;
}
header #NavWrap ul li.drop_wrap ul a {
	white-space: nowrap;
	padding: 0.5em 1em;
	transition: .2s;
}
header #NavWrap ul li.drop_wrap ul a i {
	position: relative;
	width: 1.92857142857em;
	aspect-ratio: 1/1;
	background: var(--accent05);
	border-radius: 0.10714285714em;
	overflow: clip;
}
header #NavWrap ul li.drop_wrap ul a i::before,
header #NavWrap ul li.drop_wrap ul a i::after {
	position: absolute;
	inset: 50% auto auto 50%;
	z-index: 10;
	display: inline-block;
	content: "";
	width: 0.5em;
	aspect-ratio: 1/1;
	background: var(--keycolor);
	border-radius: 100%;
	translate: -50% -50%;
	scale: 1;
	transition: opacity 0.4s .2s, scale .3s;
}
header #NavWrap ul li.drop_wrap ul a:hover i::before {
	opacity: 0;
	visibility: visible;
	scale: 5;
}
header #NavWrap ul li.drop_wrap ul a i::after {
	width: 1.0625em;
	aspect-ratio: 17/13;
	mask: url(../img/common/icon-arrow.svg) no-repeat;
	border-radius: 0;
	opacity: 0;
	visibility: hidden;
}
header #NavWrap ul li.drop_wrap ul a:hover i::after {
	opacity: 1;
	visibility: visible;
}
header #switch {
	position: absolute;
	width: 0;
	height: 0;
	opacity: 0;
	z-index: -1;
}
header label[for="switch"] {
	display: none;
}
header #NavWrap ul li :is(a, p) {
	transition: var(--hover);
	font-weight: inherit;
	margin-bottom: 0;
}
header .submenu {
	display: flex;
}
:is(header, footer) .submenu>a {
	--subcolor: var(--whitecolor);
	--icon: invert(-1);
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.65em;
	width: 194px;
	color: var(--subcolor);
	background: var(--keycolor);
	border: 1px solid var(--keycolor);
	border-radius: 0.35714285714em;
	text-decoration: none;
}
:is(header, footer) .submenu a img {
	filter: var(--reverse);
	display: block;
}
:is(header, footer) .submenu a span {
	display: block;
	margin: 0;
}
@media (any-hover: hover) {
	:is(header, footer) .submenu a:hover {
		background: var(--subcolor);
		text-decoration: none;
		color: var(--keycolor);
	}
	:is(header, footer) .submenu a:hover img {
		filter: var(--icon);
	}
	header #NavWrap ul li a:hover {
		color: var(--keycolor);
	}
	header #NavWrap ul li.head-instagram a:hover,
	header #NavWrap ul li.head-youtube a:hover,
	header #NavWrap ul li.head-podcast a:hover{
		opacity:0.7;
	}
}
@media screen and (max-width:1470px) {
	header #site_ttl a{
		width:100%;
	}
	header #site_ttl a picture{
		max-width:100%;
		height:auto;
		width:auto;
	}
	header #NavWrap ul{
		gap:0.5em;
	}
	header .submenu>a{
		width:150px;
	}
	header #NavWrap .scroll_wrap{
		gap:1.5em;
	}
}
@media screen and (max-width:1260px) {
	header#fix_menu {
		--slide: 360px;
		padding-right: 6em;
	}
	header #NavWrap {
		position: fixed;
		z-index: 50;
		inset: 0 0 auto 0;
		width: var(--slide);
		background: var(--whitecolor);
		padding: var(--header) 1em 1em;
		transition: transform 1s;
		transform: translateY(-100%);
		height: 100%;
	}
	header #NavWrap .scroll_wrap {
		width: 100%;
		gap: 1.25em;
		max-height: 100%;
		height: 100%;
		font-size: 1rem;
		overflow-x: hidden;
		overflow-y: auto;
		scrollbar-width: thin;
		scrollbar-color: var(--keycolor) var(--accent05);
		overscroll-behavior: contain;
		padding-inline: 0;
		flex-direction:column;
	}
	header #NavWrap ul {
		display: block;
		gap: inherit;
		width: 100%;
		margin: 0;
	}
	header label[for="switch"] {
		position: fixed;
		z-index: 100;
		top: 1em;
		right: 1.25em;
		display: flex;
		justify-content: center;
		align-items: center;
		flex-direction: column;
		gap: 0.25em;
		width: 3em;
		aspect-ratio: 1 / 1;
		background: var(--keycolor);
		border-radius: 0.17857142857em;
		padding: 0.5em;
		transition: right .2s, background .2s, border-color .2s;
	}
	header label[for="switch"] span,
	header label[for="switch"] span::before,
	header label[for="switch"] span::after {
		position: absolute;
		inset: -8px 0 auto;
		content: "";
		display: block;
		width: 1.28571428571em;
		height: 2px;
		background: var(--whitecolor);
		margin: 0 auto;
		transition: transform .2s;
	}
	header label[for="switch"] span {
		position: relative;
		inset: 0;
		display: block;
	}
	header label[for="switch"] span::after {
		top: auto;
		bottom: -8px;
	}
	header:has(#switch:checked) label[for="switch"] {
		background: var(--accent05);
	}
	header:has(#switch:checked) label[for="switch"] span {
		transform: rotate(360deg);
		background: transparent;
	}
	header:has(#switch:checked) label[for="switch"] span::before,
	header:has(#switch:checked) label[for="switch"] span::after {
		transform: rotate(45deg);
		inset: 0;
		background: var(--keycolor);
	}
	header:has(#switch:checked) label[for="switch"] span::after {
		transform: rotate(-45deg);
	}
	header:has(#switch) #NavWrap {
		background: var(--bgcolor);
	}
	header:has(#switch:checked) #NavWrap {
		transform: translateY(0);
	}
	header #NavWrap ul li {
		flex: 1;
		width: 100%;
	}
	header #NavWrap ul.scroll_content>li {
		display: block;
		border-top: solid 1px var(--keycolor);
	}
	header #NavWrap ul.scroll_content>li.display_pc{
		display:none;
	}
	header #NavWrap ul.scroll_content>li:nth-child(7) {
		border-bottom: solid 1px var(--keycolor);
	}
	header #NavWrap ul li> :is(p, a) {
		justify-content: flex-start;
		flex: 1;
	}
	header #NavWrap .scroll_content>li> :is(p, a) {
		font-size: 1.125rem;
		padding-inline: 0;
	}
	header #NavWrap .scroll_content>li>p {
		color: var(--keycolor);
		padding-bottom: 0;
	}
	header #NavWrap ul li.drop_wrap p span:before{
		display:none;
	}
	header #NavWrap .scroll_content>li> :is(p, a)::before,
	header #NavWrap .scroll_content>li> :is(p, a)::after {
		display: none;
	}
	header #NavWrap ul li.drop_wrap .drop_child {
		position: relative;
		z-index: 2;
		inset: 0;
		flex-direction: column;
		align-items: flex-start;
		background: transparent;
		opacity: 1;
		padding: 0;
		filter: none;
	}
	header #NavWrap ul li.drop_wrap ul a {
		padding-inline: 0;
	}
	header .submenu a {
		width: min(88%, 300px);
		min-height: 3.5em;
		font-size: 1.125rem;
		margin-inline: auto;
	}
	header .submenu{
		order: 1;
	}
	header .scroll_content{
		order: 2;
	}
	:root .sns-wrap{
		margin-top: 1em;
		order: 3;
	}
	:root .sns-btn + .sns-btn{
		margin-top:1em;
	}
	:root .sns-btn a{
		--subcolor: var(--whitecolor);
		--icon: invert(-1);
		display: flex;
		justify-content: center;
		align-items: center;
		gap: 0.65em;
		background: var(--subcolor);
		border: 1px solid #cdd0d2;
		border-radius: 0.35714285714em;
		text-decoration: none;
		width: min(88%, 300px);
		min-height: 3.5em;
		font-size: 1rem;
		margin-inline: auto;
		padding: 0.5em;
	}
	:root .sns-btn a span{
		padding-left: 2.75em;
		position:relative;
	}
	:root .sns-btn.btn-instagram a span:before{
		content:"";
		width: 24px;
		height: 24px;
		background:url(../img/common/icon-instagram.svg) no-repeat center / contain;
		position:absolute;
		inset:0 auto 0 0;
		margin:auto;
	}
	:root .sns-btn.btn-youtube a span:before{
		content:"";
		width: 28px;
		height: 20px;
		background:url(../img/common/icon-youtube.svg) no-repeat center / contain;
		position:absolute;
		inset:0 auto 0 0;
		margin:auto;
	}
}
@media screen and (max-width:767px) {
	header#fix_menu {
		padding: 0.5rem;
		align-items: center;
		height: var(--header);
		--slide: 100%;
	}
	header #site_ttl {
		position: fixed;
		z-index: 100;
		text-align: left;
		padding: 0;
		margin: 0;
		display: flex;
		justify-content: space-between;
		align-items: center;
		width: calc(100% - 70px);
	}
	:is(header #site_ttl, #footer .copy_style) a {
		gap: 0.45em;
		flex-direction: column;
		align-items: flex-start;
	}
	header #site_ttl a img {
		width: 178px;
	}
	header #site_ttl .head-sns{
		display:flex;
		gap:0.75em;
	}
	header #site_ttl .head-instagram,
	header #site_ttl .head-youtube,
	header #site_ttl .head-podcast{
		display:flex;
		padding: 0;
	}
	header #site_ttl .head-instagram a,
	header #site_ttl .head-youtube a,
	header #site_ttl .head-podcast a{
		display:block;
		width: auto;
		min-width: 0;
	}
	header #site_ttl .head-instagram img,
	header #site_ttl .head-youtube img,
	header #site_ttl .head-podcast img{
		width: auto;
		height: 27px;
	}
	header #NavWrap {
		justify-content: flex-end;
	}
	header #switch~label {
		top: 0.5em;
		right: 0.5em;
	}
	header #NavWrap ul li.drop_wrap ul a i::before {
		opacity: 0;
		visibility: hidden;
		scale: 0;
	}
	header #NavWrap ul li.drop_wrap ul a i::after {
		opacity: 1;
		visibility: visible;
	}
}
/* contents
-------------------------------------------------------------------*/
.section,
section {
	position: relative;
}
#fixed-requirements_wrap {
	--wide: 60px;
	position: fixed;
	z-index: 99;
	left: calc((-100% + var(--wide)) * -1);
	bottom: 4em;
	transition: left .4s;
}
#fixed-requirements_wrap #fixed-requirements_btn {
	position: absolute;
	z-index: -10;
	width: 0;
	height: 0;
}
#fixed-requirements_wrap .fixed-requirements_btn {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-direction: column;
	gap: 0.5em;
	font-size: 1.5rem;
	font-weight: bold;
	line-height: 1;
	width: 100%;
	padding: 0.875em 0.5em;
	text-decoration: none;
	transition:var(--hover);
	border: 3px solid var(--keycolor);
	border-radius: 0.3125em;
	background: var(--whitecolor);
}
#fixed-requirements_wrap .fixed-requirements_btn i{
	position: relative;
	width: 1.5em;
	aspect-ratio: 1/1;
	background: var(--accent05);
	border-radius: 0.10714285714em;
	overflow: clip;
}
#fixed-requirements_wrap .fixed-requirements_btn i::before,
#fixed-requirements_wrap .fixed-requirements_btn i::after {
	position: absolute;
	inset: 50% auto auto 50%;
	z-index: 10;
	display: inline-block;
	content: "";
	width: 0.375em;
	aspect-ratio: 1/1;
	background: var(--keycolor);
	border-radius: 100%;
	translate: -50% -50%;
	scale: 1;
	transition: opacity 0.4s .2s, scale .3s;
}
#fixed-requirements_wrap .fixed-requirements_btn i::after {
	width: 1em;
	aspect-ratio: 17/13;
	mask: url(../img/common/icon-arrow.svg) no-repeat;
	border-radius: 0;
	opacity: 0;
	visibility: hidden;
}
@media (any-hover: hover) {
	#fixed-requirements_wrap .fixed-requirements_btn:hover{
		transform:translateX(5px);
	}
	#fixed-requirements_wrap .fixed-requirements_btn:hover i::before {
		opacity: 0;
		visibility: visible;
		scale: 5;
	}
	#fixed-requirements_wrap .fixed-requirements_btn:hover i::after {
		opacity: 1;
		visibility: visible;
	}
}
@media screen and (max-width:767px) {
	#fixed-requirements_wrap {
		--wide: 6.25em;
		left:0;
		right:0;
		bottom: calc(var(--wide) * -1);
		border: 2px solid var(--whitecolor);
		border-radius: 0.4em;
		transition: bottom .4s;
		bottom: 0;
	}
	#fixed-requirements_wrap:has(#fixed-requirements_btn:checked) {
		--wide: 2px;
	}
	#fixed-requirements_wrap .fixed-requirements_btn {
		width: 100%;
		flex-direction: row-reverse;
		font-size: 1.35714285714rem;
		color: var(--whitecolor);
		border-radius: 0.3125em 0.3125em 0 0;
		border-bottom: none;
		background: var(--keycolor);
	}
	#fixed-requirements_wrap .fixed-requirements_btn i {
		background: var(--whitecolor);
	}	
	#fixed-requirements_wrap .fixed-requirements_btn i::before {
		opacity: 0;
		visibility: hidden;
	}
	#fixed-requirements_wrap .fixed-requirements_btn i::after {
		opacity: 1;
		visibility: visible;
		width: 0.75em;
	}
	#fixed-requirements_wrap .fixed-requirements_box dd {
		flex-direction: row;
		gap: 0.3em;
		width:100%;
	}
	#fixed-requirements_wrap .fixed-requirements_box a {
		flex-direction:column;
		gap: 0.5em;
		width: auto;
		flex:1;
		height: 5em;
		border-color:var(--subcolor);
	}
}
/* footer
-------------------------------------------------------------------*/
#footer {
	position: relative;
	z-index: 100;
	background: var(--whitecolor);
	padding-block: 8.125em 6.25em;
	border-top:1px solid #cdd0d2;
}
body.home #footer{
	border-top:none;
}
#footer :is(.footer-menu, .foot_links) {
	display: flex;
	justify-content: flex-start;
}
#footer .footer-menu{
	flex-wrap:wrap;
	justify-content:center;
}
#footer .foot_left {
	display: flex;
	justify-content: flex-start;
	align-items: stretch;
	flex-direction: column;
	margin-bottom: 4em;
}
#footer .foot_left small {
	font-size: 0.75rem;
	margin-top: auto;
}
#footer .submenu>a {
	width: min(100%, 248px);
	min-height: 3.75em;
	margin-top: 2.25em;
}
#footer .foot_links {
	align-items: center;
	flex-direction: column;
	flex-grow: 1;
	box-sizing: content-box;
}
#footer .foot_links>ul {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-template-rows: repeat(4, 1fr);
	grid-template-rows: 2.07272727273fr repeat(3, 1fr);
	gap: 0 2.5em;
	width: min(100%, 700px);
	padding: 0;
	margin: 0;
}
#footer .foot_links :is(a, p) {
	font-weight: 500;
	margin-bottom: 0;
}
#footer .foot_links>ul>li {
	min-width: 0;
	display: flex;
	justify-content: unset;
	flex-direction: column;
	gap: 0.75em;
	border-top: solid 1px var(--keycolor);
	padding-block: 1em;
	margin-block: 0;
}
#footer .foot_links>ul>li:not([class]){
	justify-content:center;
}
#footer .foot_links>ul>li:nth-child(2) {
	grid-area: 2 / 1 / 5 / 2;
}
#footer .foot_links>ul>li:nth-child(3) {
	grid-area: 1 / 2;
}
#footer .foot_links>ul>li:nth-child(4) {
	grid-area: 2;
}
#footer .foot_links>ul>li:nth-child(5) {
	grid-area: 3 / 2;
}
#footer .foot_links>ul>li:nth-child(6) {
	justify-content:unset;
}
#footer .foot_links>ul>li:last-child {
	border-bottom: solid 1px var(--keycolor);
}
#footer .foot_links .drop_wrap .drop_child {
	display: flex;
	align-items: flex-start;
	flex-direction: column;
	flex-wrap: wrap;
	gap: 0.625em;
}
#footer .foot_links .drop_wrap .drop_child a {
	display: flex;
	justify-content: flex-start;
	;
	align-items: center;
	gap: 0.75em;
	font-size: 0.875rem;
}
#footer .foot_links .drop_wrap .drop_child a i {
	width: .35em;
	height: 1px;
	border-top: 1px solid;
}
#footer .foot_links .submenu {
	width: 100%;
	justify-content: flex-end;
	font-size: var(--f14);
}
#footer .foot_sns{
	width:100%;
	border-top:1px solid #cdd0d2;
	padding-top:2em;
	margin-bottom: 2em;
}
#footer .foot_copyright{
	width:100%;
	text-align:center;
	border-top:1px solid #cdd0d2;
	padding-top:2.5em;
}
#footer .sns-wrap{
	display:flex;
	justify-content: space-between;
	align-items:stretch;
	gap:1em;
	max-width:1000px;
	margin:0 auto;
}
#footer .sns-btn{
	width:calc(33% - 0.5em);
	max-width:320px;
}
#footer .sns-btn + .sns-btn{
	margin-top:0;
}
#footer .sns-btn a{
	--subcolor: var(--whitecolor);
	--icon: invert(-1);
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.65em;
	background: var(--subcolor);
	border: 1px solid #cdd0d2;
	border-radius: 0.35714285714em;
	text-decoration: none;
	width: 100%;
	min-height: 3.75em;
	font-size: 1rem;
	margin-inline: auto;
	font-weight: bold;
	line-height: 1.2;
	box-shadow: 0 0 10px rgba(0,0,0,0.1);
	transition: .5s transform;
}
:root .sns-btn a span{
	padding-left: 2.75em;
	position:relative;
}
:root .sns-btn.btn-instagram a span:before{
	content:"";
	width: 24px;
	height: 24px;
	background:url(../img/common/icon-instagram.svg) no-repeat center / contain;
	position:absolute;
	inset:0 auto 0 0;
	margin:auto;
}
:root .sns-btn.btn-youtube a span:before{
	content:"";
	width: 28px;
	height: 20px;
	background:url(../img/common/icon-youtube.svg) no-repeat center / contain;
	position:absolute;
	inset:0 auto 0 0;
	margin:auto;
}
:root .sns-btn.btn-podcast a span:before{
	content:"";
	width: 25px;
	height: 25px;
	background:url(../img/common/icon-podcast.svg) no-repeat center / contain;
	position:absolute;
	inset:0 auto 0 0;
	margin:auto;
}

:root a.pagetop {
	position: fixed;
	bottom: 4.25em;
	right: 1em;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	font-size: 1.5rem;
	font-weight: bold;
	color: var(--keycolor);
	letter-spacing: 0.03em;
	gap: 0.5em;
	padding: 0.5em;
	padding-left: 4.125em;
	transition: var(--hover);
	rotate: 90deg;
	z-index: 5000;
}
:root a.pagetop::before,
:root a.pagetop::after {
	position: absolute;
	z-index: 10;
	top: 50%;
	left: 0;
	display: inline-block;
	content: "";
	width: 3.75em;
	height: 4px;
	background: var(--accent05);
	translate: 0 -50%;
}
:root a.pagetop::after {
	scale: 0.3333 1;
	background: var(--keycolor);
	transform-origin: left;
	transition: var(--hover);
}
:root a.pagetop span {
	display: block;
}
@media (any-hover: hover) {
	:root a.pagetop:hover {
		transform: translateX(-0.5em);
		text-decoration-color: transparent;
		color: var(--fontcolor);
	}
	:root a.pagetop:hover::after {
		scale: 1 1;
	}
	#footer .sns-btn a:hover{
		transform:translateY(5px);
	}
}
@media screen and (max-width:1100px) {
	#footer .foot_links>ul {
		grid-template-columns: repeat(2, 1fr);
		grid-template-rows: 1fr repeat(2, 1fr);
	}
	#footer .foot_links>ul>li:not([class]){
		justify-content:center;
	}
	#footer .foot_links>ul>li:nth-child(2) {
		grid-area: 2 / 1 / 3 / 2;
	}
	#footer .foot_links>ul>li:nth-child(3) {
		grid-area: 3 / 1;
	}
	#footer .foot_links>ul>li:nth-child(4) {
		grid-area: 4 / 1;
		justify-content:flex-start;
	}
	#footer .foot_links>ul>li:nth-child(5) {
		grid-area: 1 / 2;
	}
	#footer .foot_links>ul>li:nth-child(6) {
		justify-content:center;
		grid-area: 2 / 2;
	}
	#footer .foot_links>ul>li:nth-child(7) {
		justify-content:center;
		grid-area: 3 / 2;
	}
	#footer .foot_links>ul>li:nth-child(8) {
		justify-content:unset;
		grid-area: 4 / 2;
	}
}
@media screen and (max-width:767px) {
	#footer {
		padding-block: 4em 5em;
		z-index: 90;
	}
	body:not(.home) #footer{
		padding-block: 2em 5em;
	}
	#fixed-requirements_wrap:has(#fixed-requirements_btn:checked) ~ #footer {
		padding-bottom: 11em;
	}
	#footer .foot_left{
		width:100%;
		text-align:center;
		margin-bottom: 0;
	}
	#footer .copy_style,
	#footer .foot_links,
	#footer .submenu,
	#footer .foot_sns{
		display: none;
	}
	#footer .foot_copyright{
		padding-top: 0;
		border-top: 0;
	}
	:root a.pagetop{
		right: -1.5em;
		bottom: 6em;
		text-decoration:none;
		z-index:15000000000;
		filter: drop-shadow(0px 0px 1px #fff) drop-shadow(0px 0px 2px #fff);
		padding-left: 3em;
		font-size: 1.25rem;
	}
	:root a.pagetop::before,
	:root a.pagetop::after{
		width: 2.5em;
		height: 2px;
	}
}
/* print
-------------------------------------------------------------------*/
@media print{
	html body {
		zoom: 40%;
	}
	html body.home {
		zoom: 40%;
	}
	header#fix_menu,
	:root a.pagetop,
	#fixed-requirements_wrap{
		position:absolute;
	}
}