/*
----------------------------------------

footer

----------------------------------------
*/

footer {
	margin-top: var( --wp--preset--spacing--70 );
	position: relative;
}

footer .sp-logo {
	display: none;
}

footer a:where(:not(.wp-element-button)):hover {
	display: inline-block;
	border-bottom: solid 1px transparent;
}

footer .custom-logo-link {
	border: none !important;
}

footer .custom-logo-link img {
	transition: all .4s;
}

.btn-wrap:has( > #page-top ) {
	position: absolute;
	top: 0;
	right: 0;
	color: var( --wp--preset--color--contrast);
	font-weight: 600;
	line-height: 1.5;
	opacity: 0;
	visibility: hidden;
	z-index: -1;
	transition: all .2s;
}

.btn-wrap:has( > #page-top ).active {
	opacity: 1;
	visibility: visible;
	z-index: 99;
}

.btn-wrap:has( > #page-top ).fixed {
	position: fixed;
	top: auto;
	bottom: 0;
}

#page-top {
	padding-top: 64px;
	position: relative;
	top: -28px;
	right: 2rem;
	cursor: pointer;
}

#page-top::before {
	content: '\e5d8';
	display: inline-block;
	width: 56px;
	height: 56px;
	border: solid 2px var(--wp--preset--color--primary);
	border-radius: 50%;
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	font-family: "Material Symbols Outlined";
	font-size: var( --wp--preset--font-size--24-px );
	line-height: 56px;
	text-align: center;
	position: absolute;
	top: 0;
	left: calc( 50% - 28px );
	transition: all .2s;
}

#sp-fix {
	display: none;
	position: fixed;
	right: 0;
	bottom: 0;
	left: 0;
	opacity: 0;
	visibility: hidden;
	z-index: -99;
	transform: translateY( 100% );
	transition: all .2s;
}

#sp-fix .is-style-mail-btn .wp-element-button,
#sp-fix .is-style-tel-btn .wp-element-button {
	display: block;
	width: 100%;
	padding-right: 0;
	padding-left: 0;
}

#sp-fix .wp-block-buttons>.wp-block-button {
	width: calc( ( 100% - var( --wp--preset--spacing--20 ) ) / 2 );
}

#sp-fix .is-style-mail-btn .wp-element-button::before,
#sp-fix .is-style-tel-btn .wp-element-button::before {
	transform: translateY( 4px );
}

#sp-fix .is-style-tel-btn .wp-element-button {
	background: var( --wp--preset--color--base );
	color: var( --wp--preset--color--primary );
}

#sp-fix .is-style-tel-btn .wp-element-button::before {
	color: var( --wp--preset--color--primary );
}


@media screen and ( max-width: 1000px ) {

	footer .has-global-padding > .alignfull {
		gap: 1em;
	}

}


@media screen and ( max-width: 750px ) {

	footer {
		padding-top:
	}

	footer > .wp-block-group {
		padding:  var( --wp--preset--spacing--30 ) 0 0 !important;
	}

	footer .has-global-padding > .alignfull {
		margin-right: 0;
		margin-left: 0;
		gap: 0;
	}

	footer .logo {
		display: none;
	}

	footer .sp-logo {
		display: block;
		padding: var( --wp--preset--spacing--30 ) !important;
		margin-bottom: var( --wp--preset--spacing--30 );
	}

	.bottom-head {
		flex-direction: column;
		gap: var( --wp--preset--spacing--30 );
	}

	.bottom-head .wp-block-template-part {
		width: 100%;
	}

	footer .wp-block-template-part .btn-set {
		width: 100%;
		flex-direction: column;
		align-items: stretch;
		padding: 0 var( --wp--preset--spacing--30 ) !important;
		gap: var( --wp--preset--spacing--30 );
	}

	footer .btn-set > div {
		flex: 1;
	}

	footer .btn-set .tel-link {
		padding: var( --wp--preset--spacing--20) var( --wp--preset--spacing--20) var( --wp--preset--spacing--30 );
		border: solid 1px var( --wp--preset--color--primary );
		background: var( --wp--preset--color--base );
		position: relative;
		transition: all .2s;
	}

	footer .btn-set .wp-block-button {
		width: 100%;
		height: 100%;
	}

	footer .btn-set .is-style-mail-btn .wp-block-button__link {
		display: flex;
		width: 100%;
		height: 100%;
		justify-content: center;
		align-items: center;
	}

	footer .btn-set .is-style-mail-btn .wp-block-button__link::before {
		transform: translateY( 0 );
	}

	.nav-wrap {
		gap: var( --wp--preset--spacing--30 ) !important;
	}

	.bottom-nav {
		border-top-color: var( --wp--preset--color--gray ) !important;
	}

	.bottom-nav > .wp-block-group {
		flex-direction: column;
		gap: 0;
		padding: 0 !important;
	}

	.bottom-nav > .wp-block-group > * {
		width: 100%;
		border-bottom: solid 1px var( --wp--preset--color--gray );
	}

	.bottom-nav a {
		display: block;
		width: 100%;
		text-align: center;
		padding: var( --wp--preset--spacing--40 ) !important;
		background: var( --wp--preset--color--base );
		position: relative;
	}

	.bottom-nav a::after {
		font-family: 'Material Symbols Outlined';
		content: '\e5cc';
		line-height: 20px;
		position: absolute;
		top: calc( 50% - 10px );
		right: 16px;
		color: var( --wp--preset--color--primary );
		transition: all .2s;
	}

	footer .has-global-padding > .alignfull {
		margin-top: var( --wp--preset--spacing--30 );
	}

	.copyright {
		padding-bottom: 80px !important;
	}

	#sp-fix {
		display: block;
	}

	#sp-fix.active {
		opacity: 1;
		visibility: visible;
		z-index: 99;
		transform: none;
	}

	#page-top {
		width: 56px;
		overflow: hidden;
		padding-top: 56px;
		top: -80px;
		right: 1em;
	}

	#page-top p {
		position: absolute;
		left: -9999px;
	}

}


/*
----------------------------------------

footer-02

----------------------------------------
*/

.footer-02 .nav-menu-wrap {
	flex: 1;
}

.footer-02 .group {
	pointer-events: none;
}

.footer-02 .sub-menu {
	list-style: none;
	padding-left: var( --wp--preset--spacing--30 );
}

.footer-02 .sub-menu li {
	padding-left: var( --wp--preset--spacing--30 );
	position: relative;
}

.footer-02 .sub-menu li::before {
	content: '';
	width: var( --wp--preset--spacing--20 );
	height: 2px;
	background: var( --wp--preset--color--primary );
	position: absolute;
	top: 14px;
	left: 0;
}

.footer-02 .sub-menu li + li {
	margin-top: 5px;
}

@media screen and ( max-width: 750px ) {

	.footer-02 .group {
		margin: 0 !important;
		padding: 0 !important;
		border: none !important;
	}

	.footer-02 .group {
		pointer-events: auto;
	}

	.footer-02 .bottom-nav {
		margin-top: 0 !important;
		margin-bottom: 0 !important;
	}

	.footer-02 .group a {
		background: var( --wp--preset--color--primary );
		color: var( --wp--preset--color--base );
	}

	.footer-02 .group a::after {
		content: '\e145';
		color: var( --wp--preset--color--base );
	}

	.footer-02 .group a.open {
		background: var( --wp--preset--color--contrast) !important;
	}

	.footer-02 .group a.open::after {
		content: '\e15b';
	}

	.footer-02 .nav-menu {
		display: none;
		padding: 0 !important;
		gap: 0 !important;
		font-size: var(--wp--preset--font-size--16-px) !important;
	}

	.footer-02 .parent {
		border-top: solid 1px var( --wp--preset--color--gray );
		width: 100%;
	}

	.footer-02 .parent a {
		background: var( --wp--preset--color--light-gray );
		text-align: left;
	}

	.footer-02 .sub-menu {
		width: 100%;
		padding-left: 0;
	}

	.footer-02 .sub-menu li {
		border-top: solid 1px var( --wp--preset--color--gray );
		padding-left: 0;
	}

	.footer-02 .sub-menu li::before {
		left: var( --wp--preset--spacing--30 );
		top: calc( 50% - 1px );
		z-index: 99;
	}

	.footer-02 .sub-menu li + li {
		margin-top: 0;
	}

	.footer-02 .sub-menu a {
		text-align: left;
		padding-left: var( --wp--preset--spacing--50 ) !important;
	}

}


/*
----------------------------------------

hover

----------------------------------------
*/

@media screen and ( min-width: 780px ) {

	footer .custom-logo-link:hover img {
		transform: scale( 1.05 );
	}

	footer a:where(:not(.wp-element-button)):hover {
		border-color: var( --wp--preset--color--contrast);
	}

	#page-top:hover {
		color: var(--wp--preset--color--primary);
	}

	#page-top:hover::before {
		background: var(--wp--preset--color--base);
		color: var(--wp--preset--color--primary);
		line-height: 50px;
	}

}
