/*
Theme Name: スグジグ
Author: スグジグ
Author URI: https://sugujigu.com/
Description: スグジグ専用テーマです
Version: 2025.06
*/



/* base ************************************************************************************************************************************************************************************************************************************************************************************************** */
:root {
	--colorText: #222;
	--colorOrange: #fa9900;
	--colorWater: #7ecef4;
	--colorYellow: #fabe00;
	--colorGreen: #a9d06b;
	--colorPink: #ed7a94;
	--colorGray: #797979;
	--colorDiagonal01: #d6d6d4;
	--colorDiagonal02: #787571;
	--colorMarker: #fff000;
	--colorBgGray: #f8f8f8;
	--colorBeige: #fddc9a;
	--colorBeigeLight: #fdf7df;
	--fontMPlusRounded: "M PLUS Rounded 1c", sans-serif;
	--fontNotoSans: "Noto Sans JP", sans-serif;
}
*,::before,::after {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
html {
	scroll-behavior: smooth;
	font-size: calc(10vw / 15);
}
body {
	font-family: var(--fontMPlusRounded);
	font-size: 1.6em;
	line-height: 1;
	text-align: justify;
	color: var(--colorText);
}
main {
}
h1,h2,h3,h4,h5,h6 {
	font-size: 1em;
	font-weight: 400;
}
a {
	color: inherit;
	text-decoration: none;
}
a:hover {
	text-decoration: none;
}
img,video,canvas {
	max-width: 100%;
	vertical-align: bottom;
}
ul,ol {
	list-style: none;
}
address {
	font-style: normal;
}
br.pc {
	display: inline;
}
br.mb {
	display: none;
}
.awesome::before,
.awesome::after {
  font-family: "Font Awesome 5 Free", "Font Awesome 5 Brands";
	font-weight: 900;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	html {
		font-size: calc(10vw / 7.5);
	}
	br.pc {
		display: none;
	}
	br.mb {
		display: inline;
	}
}




/* common ************************************************************************************************************************************************************************************************************************************************************************************************** */
.pageTitle {
}
.pageTitle h1 {
	font-size: 2.5em;
	font-weight: 700;
	color: #fff;
	letter-spacing: .05em;
	line-height: 1.375;
	text-align: justify;
	display: flex;
	justify-content: center;
	padding: 1.125em 3em;
	background: var(--colorOrange);
}
.price .pageTitle h1 {
	background: var(--colorYellow);
}
.company .pageTitle h1 {
	background: var(--colorGreen);
}
.sitemap .pageTitle h1,
.policy .pageTitle h1 {
	background: var(--colorOrange);
}
.pageTitle .breadCrumb {
	width: 75%;
	margin: 1.25em auto;
	display: flex;
}
.pageTitle .breadCrumb li.awesome::before {
	content: "\f015";
	margin-right: .75em;
}
.pageTitle .breadCrumb li:nth-child(n+2)::before {
	content: "＞";
	margin: 0 .25em;
}
.pageTitle .breadCrumb li a:hover {
	color: var(--colorOrange);
	text-decoration: underline;
}
main>section {
	padding: 7.5% 0;
}
main>section h2 {
	display: flex;
	flex-flow: column;
	align-items: center;
	gap: 2.5em;
}
main>section h2 span {
	font-size: 2.75em;
	font-weight: 700;
}
main>section h2::after {
	content: '';
	display: block;
	background: linear-gradient(90deg,var(--colorOrange),var(--colorYellow));
	width: 5.625em;
	height: .3125em;
}
.company main>section:not(.contactSec) h2 {
	flex-flow: row;
	gap: 1em;
	justify-content: center;
	margin-bottom: 3em;
}
.company main>section:not(.contactSec) h2 span {
	font-size: 2.5em;
	letter-spacing: .05em;
}
.company main>section:not(.contactSec) h2::before,
.company main>section:not(.contactSec) h2::after {
	content: '';
	display: block;
	background: linear-gradient(90deg,var(--colorOrange),var(--colorYellow));
	width: 7.5em;
	height: 2px;
}
.company main>section:not(.contactSec) h2::before {
	scale: -1 1;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.pageTitle .breadCrumb {
		width: 90%;
	}
	main>section {
		padding: 12.5% 0;
	}
}




/* commonParts ************************************************************************************************************************************************************************************************************************************************************************************************** */
span.su {
	color: var(--colorWater);
}
span.gu1 {
	color: var(--colorYellow);
}
span.ji {
	color: var(--colorGreen);
}
span.gu2 {
	color: var(--colorPink);
}
ul.ask {
	display: flex;
	gap: 1.5em;
}
ul.ask>li {
	display: flex;
}
ul.telNum {
	display: flex;
	flex-flow: column;
	align-items: flex-end;
	gap: .25em;
}
ul.telNum li:nth-child(1) {
	font-size: 2.625em;
	font-weight: 700;
}
ul.telNum li:nth-child(2) {
	font-size: .8125em;
}
.linkBtn {
	display: flex;
	justify-content: center;
	align-items: center;
	background: var(--colorOrange);
	color: #fff;
	border-radius: 9999px;
	position: relative;
}
.linkBtn:hover {
	background: var(--colorYellow);
}
ul.ask>li:nth-child(2) a::before {
	content: '';
	display: block;
	background: url(http://sugujigu.com/wp-content/uploads/icon_pc.webp) no-repeat center/contain;
	aspect-ratio: 96/93;
}
.linkBtn::after {
	content: '';
	display: block;
	width: .5em;
	aspect-ratio: 1/1;
	border-right: 2px solid #fff;
	border-bottom: 2px solid #fff;
	position: absolute;
	right: 2em;
	top: calc(50% - .25em);
	rotate: -45deg;
}
header ul.ask>li:nth-child(2) a {
	padding: 0 4em;
	gap: .5em;
}
header ul.ask>li:nth-child(2) a::before {
	width: 1.5em;
}
header ul.ask>li:nth-child(2) a span {
	font-size: .9375em;
}
.contactSec ul.ask>li:nth-child(2) a {
	padding: 0 6em;
	gap: 1em;
}
.contactSec ul.ask>li:nth-child(2) a::before {
	width: 2em;
}
.contactSec ul.ask>li:nth-child(2) a span {
	font-size: 1.25em;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
  .contactSec ul.ask>li:nth-child(2) a {
		padding: 1.5em 0;
		gap: 1em;
		width: 100%;
		font-size: 1.25em;
	}
}




/* header ************************************************************************************************************************************************************************************************************************************************************************************************** */
header {
	padding: 1em 2.5em 0;
	background: #fff;
	position: relative;
}
header>div {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}
header .logo {
	display: flex;
	align-items: flex-end;
	gap: 1em;
}
header .logo::before {
	content: '';
	display: block;
	background: url(http://sugujigu.com/wp-content/uploads/logo.svg) no-repeat center/contain;
	width: 10em;
	aspect-ratio: 158/105;
}
header .logo>span {
	font-size: 1.625em;
	line-height: 1.15;
}
header .logo>span>span {
	font-weight: 700;
}
header nav {
	margin-top: 2em;
}
header nav ul {
	display: flex;
	justify-content: center;
	gap: 3em;
}
header nav ul li {
	border-bottom: .25em solid #fff;
}
.front header nav ul li:nth-child(1),
body:not(.front) header nav ul li:nth-child(1):hover {
	border-bottom-color: var(--colorWater);
}
.price header nav ul li:nth-child(2),
body:not(.price) header nav ul li:nth-child(2):hover {
	border-bottom-color: var(--colorYellow);
}
.company header nav ul li:nth-child(3),
body:not(.company) header nav ul li:nth-child(3):hover {
	border-bottom-color: var(--colorGreen);
}
header nav ul li a {
	display: block;
	font-size: 1.125em;
	font-weight: 700;
	padding-bottom: 1.25em;
}
header nav ul li:hover a {
	color: var(--colorOrange);
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	header {
		padding: 1em 2.5em;
		position: sticky;
		top: 0;
		z-index: 9999;
	}
	header .logo>span {
		font-size: 1.4375em;
	}
	header .logo::before {
		width: 8.75em;
	}
	header>div ul.ask,
	header nav {
		display: none;
	}
}
/* min-aspect-ratio 16/9 **************************************************************************************************************************** */
@media (min-aspect-ratio: 16/9) {
	header {
		padding: 1em 2.5em;
	}
	header>div {
		font-size: .75em;
	}
	header .logo::before {
		width: auto;
		height: 3.75em;
	}
	header nav {
		position: absolute;
		bottom: 0;
		left: 50%;
		translate: -50% 0;
	}
	header nav ul li a {
		padding-bottom: .625em;
	}
}




/* animation ************************************************************************************************************************************************************************************************************************************************************************************************** */
#animation_container,
canvas {
	width: 100% !important;
	height: auto !important;
	aspect-ratio: 2/1 !important;
}
#dom_overlay_container {
	width: 0 !important;
	height: 0 !important;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	#animation_container,
	canvas {
		aspect-ratio: 15/19 !important;
	}
}




/* .read ************************************************************************************************************************************************************************************************************************************************************************************************** */
.read {
	position: relative;
	background: #fff;
	padding: 10% 0 7.5%;
}
.read::before,
.read::after {
	content: '';
	display: block;
	position: absolute;
	background: var(--colorDiagonal01);
	width: 16%;
	top: 0;
	bottom: 0;
	opacity: .5;
}
.read::before {
	left: 0;
	clip-path: polygon(0 0,100% 0,0 80%);
}
.read::after {
	right: 0;
	clip-path: polygon(100% 20%,100% 100%,0 100%);
}
.read hgroup {
	text-align: center;
}
.read hgroup::before,
.read hgroup::after {
	content: '';
	display: block;
	position: absolute;
	background: var(--colorDiagonal02);
	width: 9%;
	top: 0;
	bottom: 0;
	opacity: .4;
}
.read hgroup::before {
	left: 0;
	clip-path: polygon(0 30%,100% 100%,0 100%);
}
.read hgroup::after {
	right: 0;
	clip-path: polygon(0 0,100% 0,100% 70%);
}
.read hgroup h2 {
	font-size: 2.8125em;
}
span.marker {
	position: relative;
	display: inline-block;
	margin-right: .25em;
}
span.marker::before {
	content: '';
	display: block;
	background: var(--colorMarker);
	width: 100%;
	height: .375em;
	position: absolute;
}
span.marker span {
	position: relative;
	z-index: 1;
}
.read hgroup h2 span.marker::before {
	bottom: -.125em;
}
.read hgroup h2>span[class]:nth-of-type(n+2) {
	position: relative;
	display: inline-block;
}
.read hgroup h2>span[class]:nth-of-type(n+2)::before {
	content: '';
	display: block;
	width: .125em;
	aspect-ratio: 1/1;
	border-radius: 9999px;
	position: absolute;
	left: calc(50% - .0625em);
	top: -.25em;
}
.read hgroup h2>span[class="su"]::before {
	background: var(--colorWater);
}
.read hgroup h2>span[class="gu1"]::before {
	background: var(--colorYellow);
}
.read hgroup h2>span[class="ji"]::before {
	background: var(--colorGreen);
}
.read hgroup h2>span[class="gu2"]::before {
	background: var(--colorPink);
}
.read hgroup p {
	font-size: 2.25em;
	line-height: 2;
	margin-top: 1.5em;
}
.read hgroup p span {
}
.read hgroup p span.marker::before {
	bottom: .375em;
}
.read ul {
	display: flex;
	justify-content: center;
	gap: 2.25em;
	width: 65%;
	margin: 7em auto 4em;
}
.read ul li {
	width: calc((100% - 4.5em) / 3);
	display: flex;
	flex-flow: column;
	justify-content: space-between;
	align-items: center;
	gap: 1em;
	padding: 1.25em 0 2em;
	transform: skew(-15deg);
}
.read ul li:nth-child(1) {
	background: linear-gradient(90deg,#7ecef4,#c6edff);
}
.read ul li:nth-child(2) {
	background: linear-gradient(90deg,#faa319,#ededed);
}
.read ul li:nth-child(3) {
	background: linear-gradient(90deg,#a9d06b,#e9ffc6);
}
.read ul li::before {
	content: '';
	display: block;
	width: 7em;
	aspect-ratio: 115/112;
	transform: skew(15deg);
}
.read ul li:nth-child(1)::before {
	background: url(http://sugujigu.com/wp-content/uploads/read01.webp) no-repeat center/contain;
}
.read ul li:nth-child(2)::before {
	background: url(http://sugujigu.com/wp-content/uploads/read02.webp) no-repeat center/contain;
}
.read ul li:nth-child(3)::before {
	background: url(http://sugujigu.com/wp-content/uploads/read03.webp) no-repeat center/contain;
}
.read ul li span {
	color: #fff;
	font-weight: 700;
	text-shadow: 0 0 .1875em #000;
	line-height: 1.25;
	transform: skew(15deg);
}
.read ul li span:nth-child(1) {
}
.read ul li:nth-child(1) span:nth-child(1) {
	font-size: 1.875em;
}
.read ul li:nth-child(2) span:nth-child(1) {
	font-size: 1.5em;
}
.read ul li:nth-child(3) span:nth-child(1) {
	font-size: 2.25em;
}
.read ul li span:nth-child(2) {
	font-size: 3.125em;
}
.read>p {
	font-size: 2.25em;
	line-height: 2;
	text-align: center;
}
.read>p span {
}
.read>p span.marker::before {
	bottom: .375em;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.read hgroup h2 {
		line-height: 2;
	}
	.read hgroup h2 span.marker::before {
		bottom: .375em;
	}
	.read hgroup h2>span[class]:nth-of-type(n+2)::before {
		top: .125em;
	}
	.read ul {
			display: flex;
			justify-content: center;
			gap: 2.25em;
			width: 65%;
			margin: 7em auto 4em;
		flex-flow: column;
	}
	.read ul li {
		width: 100%;
	}
	.read>p {
		font-size: 1.5em;
	}
}




/* .about ************************************************************************************************************************************************************************************************************************************************************************************************** */
.about {
	background: var(--colorBgGray);
	padding: 10% 0;
}
.about ul {
	display: flex;
	flex-flow: column;
}
.about ul li {
	position: relative;
	width: 87.5%;
	display: flex;
	flex-flow: row-reverse;
	justify-content: space-between;
	align-items: center;
	margin-top: 7.5%;
}
.about ul li:nth-child(even) {
	align-self: flex-end;
	flex-flow: row;
}
.about ul li::before,
.about ul li::after {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
}
.about ul li::before {
	background: var(--colorDiagonal01);
	width: 16%;
	opacity: .5;
	clip-path: polygon(0 0,100% 0,0 80%);
}
.about ul li::after {
	background: var(--colorDiagonal02);
	width: 9%;
	opacity: .4;
	clip-path: polygon(0 30%,100% 100%,0 100%);
}
.about ul li:nth-child(even)::before,
.about ul li:nth-child(even)::after {
	scale: -1 1;
	left: auto;
	right: 0;
}
.about ul li hgroup {
	background: #fff;
	width: 42.75%;
	padding: 3.75% 5%;
	box-shadow: .5em .5em 0 #0008;
	z-index: 1;
}
.about ul li hgroup h3 {
	font-size: 2.125em;
	font-weight: 700;
	margin-bottom: 1em;
}
.about ul li:nth-child(1) hgroup h3 {
	color: var(--colorWater);
}
.about ul li:nth-child(2) hgroup h3 {
	color: var(--colorOrange);
}
.about ul li:nth-child(3) hgroup h3 {
	color: var(--colorGreen);
}
.about ul li hgroup p {
	line-height: 2;
	letter-spacing: .03em;
}
.about ul li div {
	background: #fff;
	padding: 3.75% 12.5%;
	width: 65%;
	margin-right: -7.75%;
}
.about ul li:nth-child(even) div {
	margin-right: 0;
	margin-left: -7.75%;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.about ul li {
		flex-flow: column;
		width: 100%;
	}
	.about ul li:nth-child(even) {
		flex-flow: column;
	}
	.about ul li::before,
	.about ul li::after {
		z-index: 1;
	}
	.about ul li hgroup {
		padding: 7.5% 5% 0 12.5%;
		position: static;
		z-index: 0;
		width: 100%;
		box-shadow: none;
		display: flex;
		flex-flow: column;
		align-items: center;
		font-size: 1.25em;
	}
	.about ul li:nth-child(even) hgroup {
		padding: 7.5% 12.5% 0 5%;
	}
	.about ul li div {
		padding: 3.75% 5% 3.75% 12.5%;
		margin-right: 0;
		width: 100%;
	}
	.about ul li:nth-child(even) div {
		padding: 3.75% 12.5% 3.75% 5%;
		margin-left: 0;
	}
	.about ul li div img {
		width: 100%;
	}
}




/* .simple ************************************************************************************************************************************************************************************************************************************************************************************************** */
.simple ul {
	width: 75%;
	margin: 7.5% auto 0;
	display: flex;
	justify-content: space-between;
}
.simple ul li {
	width: 32%;
}
.simple ul li figure {
}
.simple ul li figure img {
	margin-bottom: 1.5em;
}
.simple ul li figure figcaption {
}
.simple ul li figure figcaption a {
	display: block;
	width: 75%;
	margin: 0 auto;
	font-size: 1.875em;
	color: #fff;
	text-align: center;
	background: var(--colorOrange);
	border-radius: 9999px;
	padding: .5em 0;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.simple ul {
		width: 90%;
		flex-flow: column;
		gap: 3em;
	}
	.simple ul li {
		width: 100%;
	}
	.simple ul li figure img {
		margin-bottom: 1em;
		width: 100%;
		aspect-ratio: 2/1;
		object-fit: cover;
	}
}




/* .flow ************************************************************************************************************************************************************************************************************************************************************************************************** */
.flow {
	background: var(--colorBgGray);
}
.flow ol {
	width: 75%;
	margin: 7.5% auto 0;
	display: flex;
	justify-content: space-between;
	counter-reset: flowNum 0;
}
.flow ol li {
	position: relative;
	width: 32%;
	aspect-ratio: 36/31;
	background: #fff;
	box-shadow: .5em .5em 0 #0008;
	display: flex;
	flex-flow: column;
	align-items: center;
	justify-content: flex-end;
	background-repeat: no-repeat;
	background-position: center 40%;
	background-size: 50% auto;
	counter-increment: flowNum 1;
}
.flow ol li::before,
.flow ol li::after {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
}
.flow ol li::before {
	background: var(--colorDiagonal01);
	width: 16%;
	opacity: .5;
	clip-path: polygon(0 0,100% 0,0 80%);
}
.flow ol li::after {
	background: var(--colorDiagonal02);
	width: 9%;
	opacity: .4;
	clip-path: polygon(0 30%,100% 100%,0 100%);
}
.flow ol li:nth-child(1) {
	color: var(--colorWater);
	background-image: url(http://sugujigu.com/wp-content/uploads/flow01.webp);
}
.flow ol li:nth-child(2) {
	color: var(--colorYellow);
	background-image: url(http://sugujigu.com/wp-content/uploads/flow02.webp);
}
.flow ol li:nth-child(3) {
	color: var(--colorGreen);
	background-image: url(http://sugujigu.com/wp-content/uploads/flow03.webp);
}
.flow ol li span {
	font-size: 2.5em;
	font-weight: 700;
	letter-spacing: .03em;
	margin-bottom: .75em;
}
.flow ol li span::before {
	content: counter(flowNum,decimal-leading-zero);
	display: block;
	font-family: "Roboto", sans-serif;
	font-size: 2em;
	letter-spacing: 0;
	position: absolute;
	left: .75em;
	top: .25em;
}
.flow p {
	position: relative;
	width: 75%;
	display: flex;
	flex-flow: row-reverse;
	margin: 3.75% auto 0;
	font-family: "Roboto", "Noto Sans JP", sans-serif;
	font-weight: 700;
}
.flow p::before {
	content: '';
	display: block;
	background: var(--colorPink);
	position: absolute;
	inset: 0 0 0 0;
	clip-path: polygon(0 0,100% 100%,0 100%);
	opacity: .4;
}
.flow p span {
}
.flow p>span {
	position: relative;
	z-index: 1;
	font-size: 4.5em;
	margin-bottom: -.1875em;
}
.flow p>span>span {
	color: var(--colorPink);
}
.flow p>span>span>span {
	font-size: 2.25em;
	vertical-align: -.0625em;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.flow ol {
		width: 90%;
		flex-flow: column;
		gap: 2em;
	}
	.flow ol li {
		width: 100%;
		aspect-ratio: 3/2;
		align-items: flex-end;
		font-size: 1.75em;
		text-shadow: 0 0 .5em #fff, 0 0 .5em #fff, 0 0 .5em #fff, 0 0 .5em #fff, 0 0 .5em #fff, 0 0 .5em #fff, 0 0 .5em #fff, 0 0 .5em #fff;
	}
	.flow ol li span {
		padding-right: .5em;
		margin-bottom: .5em;
	}
	.flow p {
		width: 90%;
	}
}




/* .news ************************************************************************************************************************************************************************************************************************************************************************************************** */
.news ul {
	border-top: 1px solid var(--colorBeige);
	width: 75%;
	margin: 3.75% auto 0;
}
.news ul li {
	border-bottom: 1px solid var(--colorBeige);
	padding: 2.25em 0;
	display: flex;
	align-items: baseline;
	line-height: 1.75;
}
.news ul li a {
	width: calc(100% - 8em);
}
.news ul li a:hover {
  color: var(--colorOrange);
  text-decoration: underline;
}
.news ul li time {
  order: -1;
	width: 8em;
  font: inherit;
}
/* .news ul li dl {
	display: flex;
	align-items: baseline;
	line-height: 1.75;
}
.news ul li dl dt {
	width: 8em;
}
.news ul li dl dd {
	width: calc(100% - 8em);
}
.news ul li dl dd a:hover {
  color: var(--colorOrange);
  text-decoration: underline;
} */
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.news ul {
		width: 90%;
	}
	.news ul li dl {
		flex-flow: column;
		font-size: 1.25em;
	}
	.news ul li dl dt {
		width: 100%;
	}
	.news ul li dl dd {
		width: 100%;
	}
}




/* .readPrice ************************************************************************************************************************************************************************************************************************************************************************************************** */
.readPrice {
	width: 87.5%;
	margin: 3em 0 5.5em auto;
	display: flex;
}
.readPrice div {
	width: 38.5%;
	padding: 3em 0 0;
	position: relative;
	z-index: 1;
}
.readPrice div h2 {
	font-size: 2.125em;
	line-height: 1.7;
	letter-spacing: .03em;
	width: 125%;
	text-shadow: 0 0 .25em #fff, 0 0 .25em #fff, 0 0 .25em #fff, 0 0 .25em #fff;
}
.readPrice div p {
	font-family: var(--fontNotoSans);
	line-height: 2;
	letter-spacing: .03em;
	margin: 1.5em 3em 0 0;
}
.readPrice figure {
	width: 61.5%;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.readPrice {
		width: 90%;
		margin: 3em auto 5.5em;
		flex-flow: column;
	}
	.readPrice div {
		width: 100%;
	}
	.readPrice div h2 {
		font-size: 1.875em;
		width: 100%;
	}
	.readPrice div p {
		font-size: 1.25em;
		margin: 1.5em 0;
	}
	.readPrice figure {
		width: 100%;
	}
}




/* .priceWrap ************************************************************************************************************************************************************************************************************************************************************************************************** */
.priceWrap {
	background: var(--colorBgGray);
	padding: 4.5em 0 10em;
}
.priceWrap nav {
	width: 75%;
	margin: 0 auto;
}
.priceWrap nav ul {
	display: flex;
	justify-content: space-between;
}
.priceWrap nav ul li {
	width: 32.5%;
}
.priceWrap nav ul li a {
	font-size: 2.75em;
	letter-spacing: .03em;
	padding: .375em 0;
}
.priceWrap nav ul li .linkBtn::after {
	width: .375em;
	border-right-width: .1em;
	border-bottom-width: .1em;
	top: calc(50% - .375em * .75);
	rotate: 45deg;
}
.priceWrap section {
	width: 75%;
	margin: 7em auto 0;
}
.priceWrap section h2 {
	display: flex;
	align-items: center;
	margin-bottom: 3em;
}
.priceWrap section h2 span {
	font-size: 2.5em;
	font-weight: 700;
	letter-spacing: .03em;
	margin-right: .5em;
}
.priceWrap section h2::after {
	content: '';
	display: block;
	background: var(--colorBeige);
	flex-grow: 1;
	height: 2px;
}
.priceWrap section>div {
	background: #fff;
	display: flex;
	flex-flow: column;
	gap: 2.25em;
	padding: 3.75em;
}
.priceWrap section>div>div {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.priceWrap section>div>div img {
	width: 50%;
}
.priceWrap section>div>div dl {
	font-family: var(--fontNotoSans);
	letter-spacing: .03em;
	padding: 0 1.75em;
}
.priceWrap section>div>div dl dt {
	color: var(--colorOrange);
	font-size: 1.25em;
	margin-bottom: .25em;
	margin-top: .5em;
}
.priceWrap section>div>div dl dt:nth-of-type(n+2) {
	margin-top: 1.5em;
}
.priceWrap section>div>div dl dt::before {
	content: "■";
}
.priceWrap section>div>div dl dd {
	line-height: 1.5;
}
.priceWrap section>div>ul {
	letter-spacing: .03em;
	display: flex;
}
.priceWrap section>div>ul>li {
	width: 50%;
}
.priceWrap section>div>ul>li:nth-child(1) {
	background: #f8f8f8;
}
.priceWrap section>div>ul>li:nth-child(2) {
	background: #fddc9a;
}
.priceWrap section>div>ul>li h3 {
	color: #fff;
	font-size: 1.25em;
	padding: 1em;
}
.priceWrap section>div>ul>li:nth-child(1) h3 {
	background: #a2a2a1;
}
.priceWrap section>div>ul>li:nth-child(2) h3 {
	background: var(--colorOrange);
}
.priceWrap section>div>ul>li div {
	padding: 1em 1.5em 1.5em;
	line-height: 2;
}
.priceWrap section>div>ul>li div p {
}
.priceWrap section>div>ul>li div ul {
	list-style: disc;
}
.priceWrap section>div>ul>li div ul li {
	margin-left: 1.25em;
}
.priceWrap section>div>ul>li div dl {
}
.priceWrap section>div>ul>li div dl dt {
}
.priceWrap section>div>ul>li div dl dt::before {
	content: "【";
}
.priceWrap section>div>ul>li div dl dt::after {
	content: "】";
}
.priceWrap section>div>ul>li div dl dd {
	display: list-item;
	list-style: disc;
	margin-left: 1.25em;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.priceWrap nav {
		width: 90%;
	}
	.priceWrap nav ul li a {
		font-size: 2em;
	}
	.priceWrap nav ul li .linkBtn::after {
		right: .75em;
	}
	.priceWrap section {
		width: 90%;
	}
	.priceWrap section>div>div {
		flex-flow: column;
		font-size: 1.25em;
	}
	.priceWrap section>div>div img {
		width: 100%;
	}
	.priceWrap section>div>div dl {
		padding: 1em 0 0;
	}
	.priceWrap section>div>ul {
		flex-flow: column;
	}
	.priceWrap section>div>ul>li {
		width: 100%;
	}
}




/* .outline ************************************************************************************************************************************************************************************************************************************************************************************************** */
.outline table {
	font-family: var(--fontNotoSans);
	width: 75%;
	margin: 0 auto;
	letter-spacing: .05em;
	border-collapse: collapse;
}
.outline table tr {
}
.outline table tr>* {
	border-bottom: 1px solid var(--colorText);
	padding: 2.5em 0;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.outline table {
		width: 90%;
		font-size: 1.25em;
	}
	.outline table tr th {
		width: 15%;
	}
	.outline table tr td {
		width: 85%;
	}
}




/* .access ************************************************************************************************************************************************************************************************************************************************************************************************** */
.access {
	background: var(--colorBgGray);
}
.access ul {
	width: 75%;
	margin: 0 auto;
	display: flex;
	flex-flow: column;
	align-items: center;
	gap: 2em;
	font-family: var(--fontNotoSans);
}
.access ul li:has(iframe) {
	width: 100%;
}
.access ul li iframe {
	width: 100%;
	aspect-ratio: 1120/500;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.access ul {
		width: 90%;
	}
	.access ul li:nth-child(1) {
		font-size: 1.25em;
	}
	.access ul li iframe {
		aspect-ratio: 4/3;
	}
}




/* .policy ************************************************************************************************************************************************************************************************************************************************************************************************** */
.policy main {
}
.policyWrap {
	width: 75%;
	margin: 7.5% auto;
	line-height: 1.75;
}
.policyWrap>p {
}
.policyWrap>ol {
	border-bottom: 1px dotted var(--colorOrange);
	margin-bottom: 5%;
	padding-bottom: 5%;
	counter-reset: policyNum 0;
}
.policyWrap>ol>li {
	border-top: 1px dotted var(--colorOrange);
	margin-top: 5%;
	padding-top: 5%;
	counter-increment: policyNum 1;
}
.policyWrap>ol>li h2 {
	font-size: 1.125em;
	font-weight: 700;
}
.policyWrap>ol>li h2::before {
	content: counter(policyNum) ".";
	margin-right: .5em;
}
.policyWrap>ol>li>p {
	margin-top: .75em;
}
.policyWrap>ol>li>ol {
	counter-reset: policyInNum 0;
}
.policyWrap>ol>li>ol>li {
	counter-increment: policyInNum 1;
	margin-top: .75em;
}
.policyWrap>ol>li>ol>li::before {
	content: "(" counter(policyInNum) ")";
	margin-right: .5em;
}
.policyWrap>dl {
}
.policyWrap>dl dt {
	font-size: 1.125em;
	font-weight: 700;
}
.policyWrap>dl dd {
	display: list-item;
	list-style: disc;
	margin-left: 1.25em;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.policyWrap {
		width: 90%;
		font-size: 1.5em;
	}
}




/* .sitemap ************************************************************************************************************************************************************************************************************************************************************************************************** */
.siteTree {
	margin: 10% auto;
	font-size: 1.25em;
	width: 15em;
}
.siteTree li {
	margin-left: 1.25em;
}
.siteTree li:nth-child(n+2) {
	margin-top: 2em;
}
.siteTree>li {
	list-style: disc;
}
.siteTree>li:has(>ul) {
	list-style: none;
}
.siteTree>li a {
}
.siteTree>li a:hover {
	color: var(--colorOrange);
}
.siteTree>li>a {
}
.siteTree>li>ul {
}
.siteTree>li>ul>li {
	list-style: circle;
}
.siteTree>li>ul>li>a {
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.siteTree {
		font-size: 1.5em;
	}
}




/* .contact ************************************************************************************************************************************************************************************************************************************************************************************************** */
body[class*="contact"] main {
	padding: 4.5em 0 0;
}
body[class*="contact"] main>dl {
	background: var(--colorBeigeLight);
	width: 60%;
	margin: 0 auto 6em;
	padding: 3.5em 5.5em;
	display: flex;
	justify-content: space-between;
	align-items: center;
	letter-spacing: .03em;
}
body[class*="contact"] main>dl dt {
	font-family: var(--fontNotoSans);
	display: flex;
}
body[class*="contact"] main>dl dt span {
	background: var(--colorGray);
	color: #fff;
	font-size: 1.25em;
	font-weight: 700;
	display: flex;
	align-items: center;
	padding: 0 .75em 0 1.5em;
}
body[class*="contact"] main>dl dt::after {
	content: '';
	display: block;
	border-left: 1.5em solid var(--colorGray);
	border-top: 2em solid transparent;
	border-bottom: 2em solid transparent;
}
body[class*="contact"] main>dl dd {
}
body[class*="contact"] main>dl dd ul.telNum {
	align-items: center;
}
body[class*="contact"] main>dl dd ul.telNum li:nth-child(1) {
	font-size: 3.5em;
}
body[class*="contact"] main>p {
	font-family: var(--fontNotoSans);
	text-align: center;
}
body[class*="contact"] main>p:has(+.contactSec) {
  margin-bottom: 7.5%;
}
body[class*="contact"] main form {
}
body[class*="contact"] main form table {
	font-family: var(--fontNotoSans);
	border-top: 1px solid var(--colorText);
	border-collapse: collapse;
	width: 60%;
	margin: 3em auto;
}
body[class*="contact"] main form table tr {
}
body[class*="contact"] main form table tr>* {
	border-bottom: 1px solid var(--colorText);
	padding: 2em 0;
}
body[class*="contact"] main form table tr th {
	vertical-align: center;
	width: 30%;
	padding-right: 1.5em;
}
body[class*="contact"] main form table tr th:has(+td .wpcf7-radio),
body[class*="contact"] main form table tr th:has(+td textarea) {
	vertical-align: top;
}
body[class*="contact"] main form table tr th>* {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
body[class*="contact"] main form table tr th:has(+td [required])>*::after,
body[class*="contact"] main form table tr th:has(+td [type="radio"])>*::after,
body[class*="contact"] main form table tr th:has(+td [aria-required="true"])>*::after {
	content: "必須";
	display: block;
	font-size: .6875em;
	letter-spacing: .05em;
	color: #fff;
	background: var(--colorOrange);
	padding: .5em .875em;
}
body[class*="contact"] main form table tr td {
}
body[class*="contact"] main form table tr td ul,
.wpcf7-radio {
	display: flex;
	flex-flow: column;
	gap: 1em;
}
.wpcf7-list-item {
  margin: 0;
}
body[class*="contact"] main form ul li>label {
	cursor: pointer;
	position: relative;
}
body[class*="contact"] main form ul li>label input {
	display: none;
}
body[class*="contact"] main form ul li>label::before,
body[class*="contact"] main form ul li>label::after {
	content: "";
	display: block;
	position: absolute;
	transform: translateY(-50%);
	top: 50%;
}
body[class*="contact"] main form ul li>label::before {
	background: #fff;
	border: 1px solid #e3e3e3;
	width: 1.25em;
	aspect-ratio: 1 / 1;
	left: 0;
}
body[class*="contact"] main form ul li>label::after {
	background: var(--colorOrange);
	opacity: 0;
	width: .75em;
	aspect-ratio: 1 / 1;
	left: .25em;
}
body[class*="contact"] main form ul li>label:has([type="radio"])::before,
body[class*="contact"] main form ul li>label:has([type="radio"])::after {
	border-radius: 50%;
}
body[class*="contact"] main form ul li>label:has([type="checkbox"])::after {
	background: none;
	aspect-ratio: 2/3;
	border-right: 3px solid var(--colorOrange);
	border-bottom: 3px solid var(--colorOrange);
	rotate: 45deg;
	top: calc(50% - .375em);
	left: 0;
}
body[class*="contact"] main form ul li>label:has(input:checked)::after {
	opacity: 1;
}
body[class*="contact"] main form ul li>label span {
	margin-left: 1.5em;
}
body[class*="contact"] main form table tr td input:not([type="radio"]),
body[class*="contact"] main form table tr td textarea {
	background: #f7f7f7;
	border: 1px solid #e3e3e3;
	font: inherit;
	line-height: 1.5;
	width: 100%;
	padding: .875em 1em;
}
body[class*="contact"] main form table tr td ::placeholder {
	color: #cccccc;
}
body[class*="contact"] main form input[type="checkbox"]+span {
  display: none;
}
body[class*="contact"] main form table tr td textarea {
	resize: vertical;
	height: 12.5em;
}
body[class*="contact"] main form>ul {
	display: flex;
	flex-flow: column;
	align-items: center;
	gap: 3em;
	margin-bottom: 10em;
}
body[class*="contact"] main form>ul li {
}
body[class*="contact"] main form>ul li a {
	color: var(--colorOrange);
}
body[class*="contact"] main form>ul li a:hover {
	text-decoration: underline;
}
body[class*="contact"] main form>ul li input[type="submit"],
body[class*="contact"] main form>ul li input[type="reset"],
body[class*="contact"] main form>ul li input[type="button"] {
	-webkit-appearance: none;
	appearance: none;
	border: none;
	background: none;
	color: #fff;
	padding: 1.5em 7em;
	border-radius: 9999px;
}
.wpcf7-spinner {
	display: none;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
  body[class*="contact"] main>dl {
		width: 90%;
		padding: 1.5em 2em;
	}
  body[class*="contact"] main>dl dt span {
		padding: 0 .5em 0 1em;
		line-height: 1.25;
	}
  body[class*="contact"] main>p {
		font-size: 1.25em;
	}
  body[class*="contact"] main form table,
  body[class*="contact"] main form table tbody,
  body[class*="contact"] main form table tr,
  body[class*="contact"] main form table th,
  body[class*="contact"] main form table td {
		display: block;
		width: 100% !important;
	}
  body[class*="contact"] main form table {
		width: 90% !important;
		font-size: 1.25em;
	}
  body[class*="contact"] main form table th {
		border-bottom: none;
		padding-bottom: 0;
	}
  body[class*="contact"] main form table td {
		padding-top: 1em;
	}
  body[class*="contact"] main form table tr td ul {
		flex-flow: row;
		gap: 1.5em;
	}
  body[class*="contact"] main form>ul {
		font-size: 1.25em;
	}
  body[class*="contact"] main form>ul li input[type="submit"],
  body[class*="contact"] main form>ul li input[type="reset"],
  body[class*="contact"] main form>ul li input[type="button"] {
		font-size: 1.25em;
	}
}




/* .newsPage ************************************************************************************************************************************************************************************************************************************************************************************************** */
.newsPage .contents,
.newsPage .footer {
  width: 75%;
  margin: 4.5em auto;
}
.newsPage .contents {
  font-size: 1.25em;
  line-height: 1.875;
}
.newsPage .contents>*:nth-child(n+2) {
  margin-top: 1.5em;
}
.newsPage .nav-links {
  display: flex;
  justify-content: space-between;
}
.newsPage .nav-links:has(>div.nav-next:only-child) {
  justify-content: flex-end;
}
.newsPage .nav-links>div {
  width: 45%;
  line-height: 1.5;
}
.newsPage .nav-links>div.nav-next {
  text-align: right;
}
.newsPage .nav-links>div a:hover {
  color: var(--colorOrange);
  text-decoration: underline;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
  .newsPage .contents,
  .newsPage .footer {
    width: 90%;
  }
}




/* .contactSec ************************************************************************************************************************************************************************************************************************************************************************************************** */
.contactSec {
	background: url(http://sugujigu.com/wp-content/uploads/footer_bg.webp) no-repeat center 30%/cover;
	display: flex;
	flex-flow: column;
	justify-content: space-between;
	width: 100%;
	aspect-ratio: 1500/536;
	padding: 5.5em 12.5%;
}
.contactSec ul.ask {
	background: #ffffffe8;
	justify-content: space-between;
	padding: 3.75em;
}
.contactSec ul.ask li dl {
	display: flex;
	gap: 3em;
}
.contactSec ul.ask li dl dt {
	display: flex;
}
.contactSec ul.ask li dl dt span {
	background: var(--colorGray);
	color: #fff;
	font-weight: 700;
	line-height: 1.375;
	padding: 1em 0 1em 1em;
}
.contactSec ul.ask li dl dt::after {
	content: '';
	display: block;
	border-left: 1.25em solid var(--colorGray);
	border-top: 2.375em solid transparent;
	border-bottom: 2.375em solid transparent;
}
.contactSec ul.ask li dl dd {
	display: flex;
	align-items: center;
}
.contactSec ul.ask li dl dd ul.telNum {
	gap: .75em;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
  .contactSec {
		aspect-ratio: auto;
		padding: 5.5em 5%;
	}
  .contactSec h2 {
		background: #ffffffe8;
		padding: 3.75em 0 0;
	}
  .contactSec ul.ask {
		flex-flow: column;
	}
}




/* footer ************************************************************************************************************************************************************************************************************************************************************************************************** */
footer {
}
footer div {
	padding: 3em 30% 3em 12.5%;
	display: flex;
	gap: 4em;
}
footer div h2 {
	width: 11.625em;
}
footer div nav {
	flex-grow: 1;
}
#Nav,
#Nav+label {
	display: none;
}
footer div nav ul {
	display: flex;
	flex-flow: wrap;
	justify-content: space-between;
	align-content: flex-start;
	gap: 2em 0;
	margin-top: 1em;
}
footer div nav ul li {
	width: calc(100% / 3);
	display: flex;
	align-items: center;
	gap: .75em;
}
footer div nav ul li::before {
	content: '';
	display: block;
	width: .25em;
	aspect-ratio: 1/1;
	border-right: .125em solid var(--colorYellow);
	border-bottom: .125em solid var(--colorYellow);
	rotate: -45deg;
}
footer div nav ul li a {
	font-size: .8125em;
}
footer div nav ul li a:hover {
	color: var(--colorOrange);
	text-decoration: underline;
}
footer small {
	display: block;
	background: var(--colorGray);
	color: #fff;
	font-size: .75em;
	padding: 2em 0;
	text-align: center;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	footer div {
		padding: 3em 0;
		gap: 0;
		justify-content: center;
	}
	footer div nav {
		flex-grow: 0;
		position: fixed;
		top: 0;
		left: 100%;
		z-index: 10000;
		width: 100%;
		background: #fff;
		padding: 7.5em 0 0;
		transition: .5s;
	}
	footer div nav:has(#Nav:checked) {
		left: 0;
	}
	#Nav+label {
		display: flex;
		align-items: center;
		width: 2.5em;
		aspect-ratio: 40/23;
		position: fixed;
		right: 2.5em;
		top: 3em;
		z-index: 1;
	}
	#Nav+label span,
	#Nav+label span::before,
	#Nav+label span::after {
		width: 100%;
		height: 1px;
		background: var(--colorText);
		transition: .5s;
	}
	#Nav+label span::before,
	#Nav+label span::after {
		content: '';
		display: block;
		position: absolute;
	}
	#Nav+label span::before {
		top: 0;
	}
	#Nav+label span::after {
		bottom: 0;
	}
	#Nav:checked+label span {
		background: transparent;
	}
	#Nav:checked+label span::before {
		top: calc(50% - .5px);
		rotate: 45deg;
	}
	#Nav:checked+label span::after {
		bottom: calc(50% - .5px);
		rotate: -45deg;
	}
	footer div nav ul {
		flex-flow: column;
		align-content: stretch;
		gap: 0;
		margin-top: 0;
		width: 100%;
		border-bottom: 1px solid var(--colorDiagonal01);
	}
	footer div nav ul li {
		display: block;
		width: 100%;
		border-top: 1px solid var(--colorDiagonal01);
		position: relative;
	}
	footer div nav ul li:nth-child(1),
	footer div nav ul li:nth-child(4) {
		order: -1;
	}
	footer div nav ul li:nth-child(3),
	footer div nav ul li:nth-child(6) {
		order: 1;
	}
	footer div nav ul li::before {
		width: .75em;
		border-right-width: .25em;
		border-bottom-width: .25em;
		position: absolute;
		left: 2em;
		top: calc(50% - .375em);
	}
	footer div nav ul li a {
		display: block;
		font-size: 1.5em;
		text-align: center;
		padding: 1.5em 0;
	}
	footer div nav ul li a:hover {
		color: inherit;
		text-decoration: inherit;
	}
	footer div nav ul li a:active {
		color: var(--colorOrange);
		text-decoration: underline;
	}
}




/* .mbBottom ************************************************************************************************************************************************************************************************************************************************************************************************** */
.mbBottom {
	display: none;
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
	.mbBottom {
		display: block;
		position: sticky;
		bottom: 0;
		z-index: 9999;
	}
	.mbBottom ul {
		display: flex;
		gap: 1rem;
		padding: 1rem;
		background: #ededed;
	}
	.mbBottom ul li {
		width: 50%;
	}
	.mbBottom ul li a {
		display: block;
		color: #fff;
		border-radius: .75rem;
	}
	.mbBottom ul li:nth-child(1) a {
		background: #8dbc42;
	}
	.mbBottom ul li:nth-child(2) a {
		background: var(--colorOrange);
	}
	.mbBottom ul li a dl {
		display: flex;
		flex-flow: column;
		align-items: center;
		gap: 1em;
		padding: 1.75em 0;
	}
	.mbBottom ul li a dl dt {
		font-size: 2em;
		font-weight: 700;
	}
	.mbBottom ul li a dl dd {
		font-size: 1.125em;
	}
}




/* .div ************************************************************************************************************************************************************************************************************************************************************************************************** */
.div {
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
}




/* .div ************************************************************************************************************************************************************************************************************************************************************************************************** */
.div {
}
/* max 750px **************************************************************************************************************************** */
@media (max-width: 750px) {
}