@charset "utf-8";

/* ----------------------------------------------
    reset
---------------------------------------------- */
*, ::before, ::after {
	box-sizing: border-box;
	border-width: 0;
	border-style: solid;
}
html {
	/*line-height: 1.15;
	-webkit-text-size-adjust: 100%;
	-webkit-tap-highlight-color: transparent;*/
}
body {
	margin: 0;
}
main {
	display: block;
}
p, table, blockquote, address, pre, iframe, form, figure, dl {
	margin: 0;
} 
h1, h2, h3, h4, h5, h6 {
	margin: 0;
	font-size: inherit;
	font-weight: inherit;
}
ul, ol {
	margin: 0;
	padding: 0;
	list-style: none;
}
dd {
	margin-left: 0;
}
hr {
	height: 0;
	margin: 0;
	color: inherit;
	border-top-width: 1px;
	box-sizing: content-box;
	clear: both;
	overflow: visible;
}
pre {
	font-size: inherit;
	font-family: monospace, monospace;
}
address {
	font-style: inherit;
}
a {
	color: inherit;
	word-break: break-all;
	text-decoration: none;
	background-color: transparent;
}
abbr[title] {
	text-decoration: underline dotted;
}
b, strong {
	font-weight: bolder;
}
code, kbd, samp {
	font-size: inherit;
	font-family: monospace, monospace;
}
small {
	font-size: 80%;
}
sub, sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}
sub {
	bottom: -0.25em;
}
sup {
	top: -0.5em;
}
svg, img, embed, object, iframe {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}
button, input, optgroup, select, textarea {
	margin: 0;
	padding: 0;
	color: inherit;
	background: transparent;
	border-radius: 0;
	font: inherit;
	text-align: inherit;
	text-transform: inherit;
	vertical-align: middle;
	appearance: none;
	-webkit-appearance: none;
}
button, [type="button"], [type="reset"], [type="submit"] {
	cursor: pointer;
}
button:disabled, [type="button"]:disabled, [type="reset"]:disabled, [type="submit"]:disabled {
	cursor: default;
}
:-moz-focusring {
	outline: auto;
}
select:disabled {
	opacity: inherit;
}
option {
	padding: 0;
}
fieldset {
	margin: 0;
	padding: 0;
	min-width: 0;
}
legend {
	padding: 0;
}
progress {
	vertical-align: baseline;
}
textarea {
	overflow: auto;
}
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}
[type="search"] {
	outline-offset: -2px;
}
[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}
::-webkit-file-upload-button {
	font: inherit;
	-webkit-appearance: button;
}
[type="number"] {
	/*-moz-appearance: textfield;*/
}
label[for] {
	cursor: pointer;
}
details {
	display: block;
}
summary {
	display: list-item;
}
[contenteditable]:focus {
	outline: auto;
}
table {
	border-color: inherit;
	border-collapse: collapse;
}
caption {
	text-align: left;
}
td, th {
	vertical-align: top;
	padding: 0;
}
i {
    display: flex;
}

/* ----------------------------------------------
    base
---------------------------------------------- */
:root {
	--color-Black:  #2e2e2e;
	--color-Black2: #3e3a39;
	--color-GrayB:  #646464;
	--color-GrayN:  #c8c8c8;
	--color-GrayL:  #f4f4f0;
	--color-Brown:  #c2ae83;
	--color-Red:    #c52840;
	--color-BlueB:  #22529b;
	--color-BlueN:  #0081c5;
	--color-BlueL:  #d4e9ff;
    --color-Green:  #3bb557;
	--color-Yellow: #ffeb2c;
	--color-Cream:  #F4F5F0;
	--color-Beige:  #f0d5a8;
	--font-Sans:    "Noto Sans JP", sans-serif;
	--font-Mincho:  "dnp-shuei-mincho-pr6n", sans-serif;
	--font-Inter:   "Inter", sans-serif;
}
html {
	font-size: 62.5%;
    scroll-behavior: smooth;
    touch-action: manipulation;
}
body {
	color: var(--color-Black);
	font: 600 2.0rem / 1.75 var(--font-Sans);
	letter-spacing: .05em;
	font-feature-settings: "path";
}
#wrap {
	width: 100%;
    max-width: 1920px;
    min-width: 1200px;
    margin: 0 auto;
    padding: 200px 0 0;
    overflow: hidden;
}
@media (hover: hover) {
	a {
		transition: opacity ease .3s;
	}
	a:hover {
		opacity: .6;
	}
}
@media screen and (max-width: 768px) {
	body {
		font-size: 1.4rem;
	}
	#wrap {
	    min-width: 100%;
	    padding: 60px 0 50px;
	}
}
/* ------------------------------------------- */
.w-90 {
	width: 90%;
}
.w-100 {
	width: 100%;
}
.max-w-840 {
	max-width: 840px;
}
.max-w-1160 {
	max-width: 1160px;
}
.mx-auto {
	margin-left: auto;
	margin-right: auto;
}
.mb-1 {
	margin-bottom: 1em;
}
.mb-2 {
	margin-bottom: 2em;
}
.mb-3 {
	margin-bottom: 3em;
}
.mb-4 {
	margin-bottom: 4em;
}
.pt-2 {
	padding-top: 2em;
}
.pb-2 {
	padding-bottom: 2em;
}
.pt-4 {
	padding-top: 4em;
}
.pb-4 {
	padding-bottom: 4em;
}
.text-12 {
	font-size: 1.2rem;
}
.text-14 {
	font-size: 1.4rem;
}
.text-16 {
	font-size: 1.6rem;
}
.text-18 {
	font-size: 1.8rem;
}
.text-22 {
	font-size: 2.2rem;
}
.text-24 {
	font-size: 2.4rem;
}
.text-26 {
	font-size: 2.6rem;
}
.text-28 {
	font-size: 2.8rem;
}
.text-30 {
	font-size: 3.0rem;
}
.text-32 {
	font-size: 3.2rem;
}
.text-34 {
	font-size: 3.4rem;
}
.text-36 {
	font-size: 3.6rem;
}
.text-38 {
	font-size: 3.8rem;
}
.text-40 {
	font-size: 4.0rem;
}
.text-42 {
	font-size: 4.2rem;
}
.text-48 {
	font-size: 4.8rem;
}
.text-52 {
	font-size: 5.2rem;
}
.text-56 {
	font-size: 5.6rem;
}
.text-60 {
	font-size: 6.0rem;
}
.text-70 {
	font-size: 7.0rem;
}
.text-80 {
	font-size: 8.0rem;
}
.text-110 {
	font-size: 11.0rem;
}
.text-center {
	text-align: center;
}
.text-white {
	color: #fff;
}
.text-red {
	color: var(--color-Red);
}
.text-yellow {
	color: var(--color-Yellow);
}
.text-brown {
	color: var(--color-Brown);
}
.text-bluen {
	color: var(--color-BlueN);
}
.text-green {
	color: var(--color-Green);
}
.text-gray {
	color: var(--color-GrayB);
}
.fw-700 {
	font-weight: 700;
}
.fw-800 {
	font-weight: 800;
}
.font-inter {
    font-family: var(--font-Inter);
}
.font-mincho {
    font-family: var(--font-Mincho);
}
.bg-white {
	background: #fff;
}
.bg-black {
	background: var(--color-Black);
}
.bg-black2 {
	background: var(--color-Black2);
}
.bg-grayl {
	background: var(--color-GrayL);
}
.bg-brown {
	background: var(--color-Brown);
}
.bg-red {
	background: var(--color-Red);
}
.bg-blueb {
	background: var(--color-BlueB);
}
.bg-bluen {
	background: var(--color-BlueN);
}
.bg-bluel {
	background: var(--color-BlueL);
}
.bg-green {
	background: var(--color-Green);
}
.bg-cream {
	background: var(--color-Cream);
}
.bg-beige {
	background: var(--color-Beige);
}
.pos-relative {
	position: relative;
}
@media screen and (max-width: 768px) {
	.text-10-sm {
		font-size: 1.0rem;
	}
	.text-12-sm {
		font-size: 1.2rem;
	}
	.text-14-sm {
		font-size: 1.4rem;
	}
	.text-16-sm {
		font-size: 1.6rem;
	}
	.text-18-sm {
		font-size: 1.8rem;
	}
	.text-20-sm {
		font-size: 2.0rem;
	}
	.text-22-sm {
		font-size: 2.2rem;
	}
	.text-24-sm {
		font-size: 2.4rem;
	}
	.text-26-sm {
		font-size: 2.6rem;
	}
	.text-28-sm {
		font-size: 2.8rem;
	}
	.text-30-sm {
		font-size: 3.0rem;
	}
}
/* ------------------------------------------- */
.title01 {
	padding: 0 0 1em;
    display: grid;
    justify-content: center;
}
.title01::after {
    content: "";
    width: 5em;
    height: 2px;
    background: var(--color-Red);
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
}
.title01 .en {
    letter-spacing: .2em;
}
.title01 .jp {
    line-height: 1.4;
}
.title02 span {
    width: fit-content;
    min-width: 360px;
    margin: 0 auto;
    padding: .3em 1em;
    box-shadow: .15em .15em 0 var(--color-GrayN);
    letter-spacing: 0;
    display: grid;
    place-items: center;
}
.title02 span::before,
.title02 span::after {
    content: "";
    width: 1em;
    aspect-ratio: 1;
    position: absolute;
}
.title02 span::before {
    border-top: 2px solid var(--color-Red);
    border-left: 2px solid var(--color-Red);
    top: 0;
    left: 0;
}
.title02 span::after {
    border-right: 2px solid var(--color-Red);
    border-bottom: 2px solid var(--color-Red);
    right: 0;
    bottom: 0;
}
.title03 {
    padding: 0 0 .2em;
    border-bottom: 3px solid var(--color-Brown);
}
.title04 {
    padding: .3em .5em;
    background: var(--color-Cream);
}
.title04::first-letter {
    color: var(--color-Brown);
}
.title05 {
	margin: 0 0 .5em;
    padding: 0 0 0 .5em;
    border-left: .4em solid var(--color-Brown);
}
@media screen and (max-width: 768px) {
	.title02 span {
	    min-width: 100%;
	}
}
/* ------------------------------------------- */
.btn01 a {
    width: 100%;
    max-width: 340px;
    height: 60px;
    border-radius: 100vmax;
    display: grid;
    place-items: center;
}
.btn01 a i {
    position: absolute;
    right: 1em;
}
@media screen and (max-width: 768px) {
	.btn01 a {
	    max-width: 240px;
	    height: 50px;
	}
}
/* ------------------------------------------- */
@media screen and (min-width: 769px) {
	.desk-hidden {
		display: none !important;
	}
}
@media screen and (max-width: 768px) {
	.mobile-hidden {
		display: none !important;
	}
}
/* ------------------------------------------- */
.anime.fade {
    transition: opacity .8s cubic-bezier(.4, 0, .6, 1);
    -webkit-transition: opacity .8s cubic-bezier(.4, 0, .6, 1);
    opacity: 0;
}
.anime.fade.active {
    opacity: 1;
}

/* ----------------------------------------------
    header
---------------------------------------------- */
#header header {
    width: 100%;
    background: #fff;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
}
#header header .inner {
	padding: 0 0 0 5%;
    display: flex;
    gap: 1em;
    align-items: center;
    justify-content: space-between;
}
#header header .inner .logo {
    display: flex;
    gap: 1em;
    align-items: center;
}
#header header .inner .logo h1 {
    padding: 0 1em 0 0;
    border-right: 1px solid var(--color-Brown);
}
#header header .inner .menu {
    display: flex;
    gap: 2em;
    align-items: center;
}
#header header .inner .menu .tel a {
	line-height: 1;
    display: flex;
    gap: .5em;
}
#header header .inner .menu .btn {
	height: 118px;
	display: grid;
    grid-template-columns: 1fr 1fr;
    position: relative;
    z-index: 1;
}
#header header .inner .menu .btn .line,
#header header .inner .menu .btn .mail {
	width: 130px;
    padding: 1em 0;
    line-height: 1.4;
    display: grid;
    gap: .5em;
    grid-row: span 2;
    place-content: center;
    grid-template-rows: subgrid;
}
@media (hover: hover) {
	#header header .inner .menu .btn a:hover {
	    opacity: 1;
	}
}
#header header .inner .menu .btn .line {
    border-radius: 0 0 0 1em;
}
#header header .inner .menu .btn .line i,
#header header .inner .menu .btn .mail i {
	justify-content: center;
	filter: grayscale(1) brightness(5);
}
#header header .inner .hamburger {
    display: none;
}
#header header .gnav {
    border-top: 1px solid var(--color-Brown);
    border-bottom: 1px solid var(--color-Brown);
}
#header header .gnav nav ul {
    display: flex;
}
#header header .gnav nav ul li {
    width: 100%;
    position: relative;
}
#header header .gnav nav ul li:nth-child(1)::before,
#header header .gnav nav ul li::after {
    content: "";
    height: 40px;
    width: 1px;
    background: var(--color-Brown);
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
#header header .gnav nav ul li:nth-child(1)::before {
    left: 0;
}
#header header .gnav nav ul li::after {
    right: 0;
}
#header header .gnav nav ul li a {
	    height: 80px;
    line-height: 1.4;
    display: grid;
    place-items: center;
}
@media screen and (max-width: 768px) {
	#header header {
	    position: fixed;
	    top: 0;
	    left: 0;
	    z-index: 9999;
	}
	#header header .inner {
		height: 60px;
	}
	#header header .inner .logo h1 a img {
	    width: auto;
	    height: 30px;
	}
	#header header .inner .logo h1 + a img {
	    width: auto;
	    height: 25px;
	}
	#header header .inner .menu {
	    width: 100%;
	    display: grid;
	    gap: 0;
	    align-items: stretch;
        grid-template-columns: 1fr 2fr;
	    position: fixed;
	    left: 0;
	    bottom: 0;
	    z-index: 9999;
	}
	#header header .inner .menu a {
        width: 100% !important;
        height: 50px;
        padding: 0 !important;
        color: #fff;
        border-radius: 0 !important;
        text-align: left;
        line-height: 1.3 !important;
        letter-spacing: 0;
        display: flex !important;
        gap: 10px !important;
        place-items: center;
        align-content: center;
        justify-content: center;
    }
	#header header .inner .menu .tel a {
	    background: var(--color-Black2);
	}
	#header header .inner .menu a i {
	    filter: grayscale(1) brightness(5);
	}
	#header header .inner .menu a i img {
	    width: 100%;
	    max-width: 30px;
	    height: auto;
	    max-height: 25px;
	}
	#header header .inner .menu .btn {
	    height: auto;
	    display: flex;
	}
	#header header .inner .hamburger {
	    height: 60px;
	    aspect-ratio: 1;
	    border: none;
	    cursor: pointer;
	    display: flex;
        gap: 8px;
	    flex-shrink: 0;
        align-items: center;
	    flex-direction: column;
        justify-content: center;
	}
	#header header .inner .hamburger .bar {
	    width: 30px;
	    height: 2px;
	    background: #fff;
	    border-radius: 100vmax;
	    display: block;
	    transition: transform 0.3s ease, opacity 0.3s ease;
	}
	#header header .inner .hamburger.open .bar:nth-child(1) {
	    transform: rotate(45deg) translate(7px, 7px);
	}
	#header header .inner .hamburger.open .bar:nth-child(2) {
	    opacity: 0;
	}
	#header header .inner .hamburger.open .bar:nth-child(3) {
	    transform: rotate(-45deg) translate(7px, -7px);
	}
	#header header .gnav {
	    width: 100%;
	    height: calc(100dvh - 60px);
	    padding: 2em 5% 4em;
	    background: var(--color-Cream);
        backdrop-filter: blur(.5em);
	    position: fixed;
	    top: 60px;
	    left: 0;
	    transform: translateX(100vw);
	    transition: transform 0.3s ease, opacity 0.3s ease;
	}
	#header header .gnav.open {
	    transform: translateX(0);
	}
	#header header .gnav nav ul {
        display: grid;
	}
	#header header .gnav nav ul li {
	    border-bottom: 1px solid var(--color-Brown);
	}
	#header header .gnav nav ul li:nth-child(1)::before,
	#header header .gnav nav ul li::after {
		display: none;
	}
	#header header .gnav nav ul li a {
	    height: auto;
	    padding: 1em 0;
	}
}

/* ----------------------------------------------
    pagehead
---------------------------------------------- */
#pagehead {
    height: 350px;
    background: url(../img/common/pagehead.jpg) center bottom 35% / cover no-repeat;
    display: grid;
    place-items: center;
}
#pagehead::after {
    content: "";
    width: 100%;
    height: 100%;
    background: var(--color-Black);
    mix-blend-mode: multiply;
    opacity: .65;
    position: absolute;
    top: 0;
    left: 0;
}
#pagehead h2 {
    display: grid;
    z-index: 1;
}
#pagehead h2 .en {
    letter-spacing: .1em;
}
@media screen and (max-width: 768px) {
	#pagehead {
	    height: 250px;
	}
}

/* ----------------------------------------------
    breadcrumb
---------------------------------------------- */
#breadcrumb nav ol {
    margin-top: .5em;
    display: flex;
    gap: 0 .8em;
    flex-wrap: wrap;
    align-items: center;
}
#breadcrumb nav ol li {
    display: flex;
    gap: 0 .5em;
    align-items: center;
}
#breadcrumb nav ol li:not(:last-child)::after {
	content: "";
	display: block;
	width: .5em;
	aspect-ratio: 1;
	margin: .1em 0 0;
	border-top: 1px solid;
	border-right: 1px solid;
	transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
	#breadcrumb nav ol li:not(:last-child)::after {
		border-top: 1px solid;
		border-right: 1px solid;
	}
}

/* ----------------------------------------------
    pager
---------------------------------------------- */
#pager ul {
    display: flex;
    align-items: center;
    justify-content: center;
}
#pager ul li a {
    padding: .2em 1em;
    display: flex;
    align-items: center;
    justify-content: center;
}
#pager ul li.act a {
	opacity: .3;
    pointer-events: none;
}
@media screen and (max-width: 768px) {
}

/* ----------------------------------------------
    footer
---------------------------------------------- */
#wrap:has(#contact) #footer {
    border-top: 1px solid;
}
#footer footer .inner .fnav {
    display: flex;
    gap: 2em 3em;
    justify-content: space-between;
}
#footer footer .inner .fnav nav {
	line-height: 2;
    display: flex;
    gap: 0 3em;
    flex-shrink: 0;
}
#footer footer .inner .fnav fieldset {
    padding: .5em 1em 1em;
    border: 1px solid var(--color-Red);
}
#footer footer .inner .fnav fieldset legend {
    padding: 0 .5em;
}
#footer footer .inner .fnav fieldset p {
	line-height: 2;
}
#footer footer .inner .contact {
    display: flex;
}
#footer footer .inner .contact .privacy {
    display: flex;
    gap: 1em;
    flex-shrink: 0;
    align-items: center;
}
#footer footer .inner .contact .btn01 {
    width: 100%;
}
#footer footer .copy {
    padding: 2em 0;
    letter-spacing: 0;
}
@media screen and (max-width: 768px) {
	#footer footer .inner .fnav {
	    flex-direction: column-reverse;
	}
	#footer footer .inner .fnav nav {
	    display: flex;
	    flex-wrap: wrap;
	    flex-direction: column;
	}
	#footer footer .inner .fnav nav ul {
	    width: 100%;
	    display: flex;
	    gap: 0 1em;
	    flex-wrap: wrap;
	    justify-content: center;
	}
	#footer footer .inner .contact {
	    gap: 1em;
	    flex-direction: column-reverse;
	}
}

/* ----------------------------------------------
    home
---------------------------------------------- */
#home .bg-cream.pos-relative::before {
    content: "";
    width: 100%;
    height: 160px;
    background: #fff;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
}
@media screen and (max-width: 768px) {
	#home .bg-cream.pos-relative::before {
	    height: 110px;
	}
}
/* ------------------------------------------- */
#home .sec01 {
    border-bottom: 4em solid var(--color-Black2);
}
#home .sec01 .inner .box .left {
    width: 90%;
    max-width: 1540px;
    height: 820px;
}
#home .sec01 .inner .box .left .logo {
	padding: 1em;
}
#home .sec01 .inner .box .left .logo,
#home .sec01 .inner .box .left .logo img {
    width: auto;
    height: 100%;
}
#home .sec01 .inner .box .right {
    max-width: 1800px;
    margin: 0 0 0 auto;
    position: absolute;
    top: 0;
    right: 0;
}
#home .sec01 .inner .box .right .text {
    height: 100%;
    display: grid;
    gap: 2em;
    align-content: center;
    position: absolute;
    top: 0;
    left: 0;
}
#home .sec01 .inner .box .right .text .text01 {
    text-shadow: 0 0 .3em #441a1a;
    letter-spacing: .1em;
}
#home .sec01 .inner .box .right .text .text02 {
    display: grid;
    gap: .5em;
}
#home .sec01 .inner .box .right .text .text02 > span {
    width: fit-content;
    min-height: 95px;
    padding: .2em .5em;
    line-height: 1;
    letter-spacing: 0;
    display: flex;
    align-items: center;
}
#home .sec01 .inner .box .right .text .text02 > span > span {
    display: inline-block;
}
#home .sec01 .inner .box .right .text .text02 > span .text-red {
    background: linear-gradient(transparent 80%, var(--color-Yellow) 80%);
    display: inline-block;
}
#home .sec01 .inner .box .right .text ul {
    width: fit-content;
    margin: .5em 0 0;
    display: grid;
    gap: 1.5em;
    grid-template-columns: repeat(4, 1fr);
}
#home .sec01 .inner .box .right .text ul li {
    aspect-ratio: 1;
    padding: 1em 2em;
    background: var(--color-Black2);
    border: none;
    border-radius: 100vmax;
    line-height: 1.3;
	display: grid;
    place-items: center;
}
#home .sec01 .inner .box .right .text ul li i {
    justify-content: center;
}
#home .sec01 .inner .box .right .text ul li i img {
    width: 100%;
    max-width: 80px;
    height: auto;
    max-height: 60px;
}
#home .sec01 .inner .box .right .img {
	width: 95%;
    max-width: 1300px;
    margin: 0 0 0 auto;
}
#home .sec01 .inner .box .right .img img {
	width: 100%;
    height: 820px;
    object-fit: cover;
    object-position: left;
}
@media screen and (max-width: 768px) {
	#home .sec01 .inner .box .left {
	    height: 360px;
	}
	#home .sec01 .inner .box .left .logo {
	    padding: 0;
	}
	#home .sec01 .inner .box .right {
	    width: 90%;
	    background: none;
	}
	#home .sec01 .inner .box .right .text {
	    width: 100%;
	    gap: 1em;
	}
	#home .sec01 .inner .box .right .text .text02 {
	    gap: .3em;
	}
	#home .sec01 .inner .box .right .text .text02 > span {
        min-height: auto;
        padding: 0;
        background: none;
        display: grid;
        gap: .3em;
	}
	#home .sec01 .inner .box .right .text .text02 > span > span {
	    width: fit-content;
	    padding: .2em .5em;
	    display: inline-block;
	}
	#home .sec01 .inner .box .right .text ul {
		width: 95%;
		margin: 0;
	    gap: .5em;
        overflow: hidden;
	}
	#home .sec01 .inner .box .right .text ul li {
	    padding: .5em;
	    gap: .2em;
	}
	#home .sec01 .inner .box .right .text ul li i img {
	    max-width: 30px;
	    max-height: 25px;
	}
	#home .sec01 .inner .box .right .img img {
	    height: 360px;
	    object-position: 45%;
	}
}
/* ------------------------------------------- */
#home .sec02 .inner .box01 {
    display: grid;
    gap: 2em 3em;
    grid-template-columns: 1fr 1.2fr;
}
#home .sec02 .inner .box02 h2 {
    display: flex;
    gap: 1em;
    align-items: center;
    justify-content: center;
}
/*#home .sec02 .inner .box02 h2::before,
#home .sec02 .inner .box02 h2::after {
    content: "";
	width: 3px;
    height: 2em;
    background: var(--color-Black2);
}
#home .sec02 .inner .box02 h2::before {
	argin: 0 .5em 0 0;
    rotate: -30deg;
}
#home .sec02 .inner .box02 h2::after {
    rotate: 30deg;
}*/
#home .sec02 .inner .box02 ul {
    display: grid;
    gap: 2em;
    grid-template-columns: repeat(4, 1fr);
}
#home .sec02 .inner .box02 ul li fieldset {
    height: 100%;
    padding: 0 1em 1.5em;
}
#home .sec02 .inner .box02 ul li fieldset legend {
    padding: 0 .5em;
}
#home .sec02 .inner .box02 ul li fieldset .item {
    height: 100%;
    display: grid;
    gap: 1em;
    align-content: space-between;
}
#home .sec02 .inner .box02 ul li fieldset .item .title {
    line-height: 1.4;
}
#home .sec02 .inner .box02 ul li fieldset .item .btn01 a {
    max-width: 190px;
    height: 40px;
}
@media screen and (max-width: 768px) {
	#home .sec02 .inner .box01 {
	    display: flex;
	    flex-direction: column-reverse;
	}
	#home .sec02 .inner .box02 ul {
	    gap: 0 1em;
	    grid-template-columns: repeat(2, 1fr);
	}
	#home .sec02 .inner .box02 ul li fieldset .item .img img {
	    width: auto;
	    height: 70px;
	}
	#home .sec02 .inner .box02 ul li fieldset .item .btn01 a {
	    height: 35px;
	}
}
/* ------------------------------------------- */
#home .sec03 .inner .box01 {
    padding: 2em 5%;
}
#home .sec03 .inner .box01::before {
    content: "";
    width: 8em;
    aspect-ratio: 2.5 / cos(30deg);
    clip-path: polygon(50% 0, 100% 100%, 0 100%);
    background: var(--color-Black2);
    position: absolute;
    bottom: calc(100% - 1px);
    left: 50%;
    transform: translateX(-50%);
}
#home .sec03 .inner .box01 p span {
    background: linear-gradient(transparent 80%, var(--color-Red) 80%);
    line-height: 1.2;
    display: inline-block;
}
#home .sec03 .inner .box02 fieldset {
    padding: 0 0 1em;
    border: 2px solid;
}
#home .sec03 .inner .box02 fieldset legend {
    padding: 0 1em;
    letter-spacing: .1em;
    position: relative;
}
#home .sec03 .inner .box02 fieldset legend::before,
#home .sec03 .inner .box02 fieldset legend::after {
    content: "";
    width: 2px;
    height: .8em;
    background: var(--color-Black);
    position: absolute;
    top: 45%;
    transform: translateY(-50%);
}
#home .sec03 .inner .box02 fieldset legend::before {
    left: .15em;
    rotate: -30deg;
}
#home .sec03 .inner .box02 fieldset legend::after {
    right: .15em;
    rotate: 30deg;
}
#home .sec03 .inner .box02 fieldset h2 span {
    background: linear-gradient(transparent 80%, #ffdfcc 80%);
    line-height: 1.2;
    display: inline-block;
}
#home .sec03 .inner .box02 ul li {
    padding: 1em 0;
    border-bottom: 1px solid;
    display: flex;
    gap: 1em;
    align-items: baseline;
}
#home .sec03 .inner .box02 ul li .num {
    width: 1.3em;
    aspect-ratio: 1;
    border-radius: 100vmax;
    line-height: 1;
    display: grid;
    flex-shrink: 0;
    place-items: center;
}
#home .sec03 .inner .box03 {
    background: url(../img/home/solution.jpg) center / cover no-repeat;
    overflow: hidden;
}
#home .sec03 .inner .box03::after {
    content: "";
    width: 100%;
    height: 100%;
    backdrop-filter: blur(.5em);
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
}
#home .sec03 .inner .box03 .item {
    padding: 1.5em 15% 1.5em 1em;
    box-shadow: 0 .5em 0 rgb(0 0 0 / 20%);
    line-height: 1.4;
    z-index: 1;
}
#home .sec03 .inner .box03 .item .pic {
    position: absolute;
    right: 15%;
    bottom: -1.15em;
}
@media screen and (max-width: 768px) {
	#home .sec03 .inner .box03 .item .pic {
	    width: 20%;
	    max-width: 70px;
	    right: 1em;
	}
}
/* ------------------------------------------- */
#home .sec04 .inner .box {
    display: grid;
    gap: 2em;
    grid-template-columns: repeat(2, 1fr);
}
#home .sec04 .inner .box .left .logo {
    padding: 1em 0 0;
    border-top: 1px solid var(--color-Red);
}
#home .sec04 .inner .box .left .name {
    display: flex;
    gap: 1em;
    flex-wrap: wrap;
    align-items: center;
}
#home .sec04 .inner .box .right {
    display: grid;
    gap: 2em;
    align-content: flex-start;
}
#home .sec04 .inner .box .right .item {
    padding: 1em;
}
#home .sec04 .inner .box .right .item h3 {
    margin: 0 0 .5em;
    border-bottom: 1px solid var(--color-Red);
}
#home .sec04 .inner .box .right .item .list01 li {
    display: flex;
    gap: 1em;
}
#home .sec04 .inner .box .right .item .list02 {
    display: flex;
    gap: 0 .5em;
    flex-wrap: wrap;
}
#home .sec04 .inner .box .right .item .list02 li {
    display: flex;
    gap: 0 .5em;
}
#home .sec04 .inner .box .right .item .list02 li:not(:last-child)::after {
    content: "/";
}
@media screen and (max-width: 768px) {
	#home .sec04 .inner .box {
	    grid-template-columns: repeat(1, 1fr);
	}
	#home .sec04 .inner .box .left .logo img {
	    max-width: 220px;
	}
	#home .sec04 .inner .box .right {
	    gap: 1em;
	}
}
/* ------------------------------------------- */
#home .sec05 .inner ul {
    display: grid;
    gap: 2em;
    grid-template-columns: repeat(3, 1fr);
}
#home .sec05 .inner ul li {
    padding: 2em 1.5em;
    display: grid;
    gap: 1em;
    grid-row: span 3;
    align-content: flex-start;
    grid-template-rows: subgrid;
}
#home .sec05 .inner ul li .num {
    line-height: 1;
    position: absolute;
    top: -.5em;
    left: .5em;
}
#home .sec05 .inner ul li .num::after {
    content: "";
    width: .5em;
    height: 2px;
    background: var(--color-Red);
    position: absolute;
    left: 50%;
    bottom: -.15em;
    transform: translateX(-50%);
}
#home .sec05 .inner ul li .title {
    line-height: 1.5;
    letter-spacing: 0;
}
#home .sec05 .inner ul li .title .text-red {
    line-height: 1;
}
#home .sec05 .inner ul li .text {
    letter-spacing: 0;
}
@media screen and (max-width: 768px) {
	#home .sec05 .inner ul {
	    grid-template-columns: repeat(1, 1fr);
	}
}
/* ------------------------------------------- */
#home .sec06 .inner .swiper.example .swiper-slide .img img {
    aspect-ratio: 360 / 280;
    object-fit: cover;
    background: #fff;
    display: block;
}
#home .sec06 .inner .swiper.example .swiper-slide .text {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 2;
}
@media screen and (min-width: 769px) {
	#home .sec06 .inner .swiper.example .swiper-wrapper {
	    display: grid;
	    gap: 2em;
	    grid-template-columns: repeat(3, 1fr);
	}
}
@media screen and (max-width: 768px) {
	#home .sec06 .inner .swiper.example {
	    width: 100vw;
	    margin-right: calc(50% - 50vw);
	    margin-left: calc(50% - 50vw);
	    padding: 0 5%;
	}
}
/* ------------------------------------------- */
#home .sec07 .inner .swiper.column .swiper-slide .img img {
    aspect-ratio: 360 / 280;
    object-fit: cover;
    background: #fff;
    display: block;
}
#home .sec07 .inner .swiper.column .swiper-slide .text {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 2;
}
@media screen and (min-width: 769px) {
	#home .sec07 .inner .swiper.column .swiper-wrapper {
	    display: grid;
	    gap: 2em;
	    grid-template-columns: repeat(3, 1fr);
	}
}
@media screen and (max-width: 768px) {
	#home .sec07 .inner .swiper.column {
	    width: 100vw;
	    margin-right: calc(50% - 50vw);
	    margin-left: calc(50% - 50vw);
	    padding: 0 5%;
	}
}

/* ----------------------------------------------
    about
---------------------------------------------- */
@media screen and (max-width: 768px) {
	#about .sec01 .inner > p.text-center {
	    text-align: left;
	}
}
/* ------------------------------------------- */
@media screen and (max-width: 768px) {
	#about .sec02 {
	    padding: 2em 0;
	}
}
/* ------------------------------------------- */
#about .sec03 .inner .title {
    margin: 0 0 1.5em;
    padding: .5em 0;
}
#about .sec03 .inner table {
    width: 100%;
    table-layout: fixed;
    border: 1px solid var(--color-BlueN);
    letter-spacing: 0;
}
#about .sec03 .inner table th,
#about .sec03 .inner table td {
	padding: .5em;
    border: 1px solid var(--color-BlueN);
    vertical-align: middle;
}
#about .sec03 .inner table thead th.bg-red {
    border: 3px solid var(--color-Red);
}
#about .sec03 .inner table tbody td.text-red {
	background: #f8efdd;
    border: 1px solid var(--color-Red);
    border-right: 3px solid var(--color-Red);
    border-left: 3px solid var(--color-Red);
}
#about .sec03 .inner table tbody tr:last-child td.text-red {
    border-bottom: 3px solid var(--color-Red);
}
@media screen and (max-width: 768px) {
	#about .sec03 .inner > p.text-center {
	    text-align: left;
	}
}
/* ------------------------------------------- */
#about .sec04 .inner .box {
	max-width: 730px;
    border: 1px solid var(--color-BlueN);
}
#about .sec04 .inner .box .title {
    padding: .5em;
}
#about .sec04 .inner .box .item {
    padding: 1.5em;
}
#about .sec04 .inner .box .item .block {
    padding: 1.5em;
    background: #ffffe4;
    border-top: 2px solid var(--color-BlueN);
    border-bottom: 2px solid var(--color-BlueN);
    display: flex;
    gap: 3em;
}
#about .sec04 .inner .box .item .block + .block {
    padding-bottom: 0;
    background: none;
    border-top: none;
    border-bottom: none;
}
#about .sec04 .inner .box .item .block .left {
    display: flex;
    gap: 1em;
    flex-shrink: 0;
    align-items: center;
}
#about .sec04 .inner .box .item .block .left p {
    writing-mode: vertical-rl;
}
#about .sec04 .inner .box .item .block .left .arrow {
    width: 4px;
    height: 100%;
    background: var(--color-BlueN);
}
#about .sec04 .inner .box .item .block .left .arrow::before,
#about .sec04 .inner .box .item .block .left .arrow::after {
    content: "";
    width: 1.2em;
    aspect-ratio: 1;
    transform: rotate(45deg);
    position: absolute;
    left: 50%;
    transform: translateX(-50%) rotate(45deg);
}
#about .sec04 .inner .box .item .block .left .arrow::before {
    border-top: 4px solid var(--color-BlueN);
    border-left: 4px solid var(--color-BlueN);
    top: -.5em;
}
#about .sec04 .inner .box .item .block .left .arrow::after {
    border-right: 4px solid var(--color-BlueN);
    border-bottom: 4px solid var(--color-BlueN);
    bottom: -.5em;
}
#about .sec04 .inner .box .item .block .right {
	width: 100%;
    max-width: 440px;
    margin: 0 0 0 auto;
}
#about .sec04 .inner .box .item .block .right ol {
    display: grid;
    gap: 1.5em;
}
#about .sec04 .inner .box .item .block .right ol li {
    padding: .5em 1em;
    line-height: 1;
    letter-spacing: 0;
    display: flex;
    gap: .5em;
    align-items: center;
}
@media screen and (max-width: 768px) {
	#about .sec04 .inner > p.text-center {
	    text-align: left;
	}
	#about .sec04 .inner .box .item {
	    padding: 1em;
	}
	#about .sec04 .inner .box .item .block {
		padding: 1em;
	    gap: 1em;
	}
	#about .sec04 .inner .box .item .block .left {
	    gap: .5em;
	}
	#about .sec04 .inner .box .item .block .left .arrow {
	    width: 2px;
	}
	#about .sec04 .inner .box .item .block .left .arrow::before,
	#about .sec04 .inner .box .item .block .left .arrow::after {
	    width: 1em;
    }
	#about .sec04 .inner .box .item .block .left .arrow::before {
	    border-top: 2px solid var(--color-BlueN);
	    border-left: 2px solid var(--color-BlueN);
	}
	#about .sec04 .inner .box .item .block .left .arrow::after {
	    border-right: 2px solid var(--color-BlueN);
	    border-bottom: 2px solid var(--color-BlueN);
	}
	#about .sec04 .inner .box .item .block .right {
	    max-width: 220px;
	}
}
/* ------------------------------------------- */
#about .sec05 .inner .box .pic01 {
    position: absolute;
    right: 5%;
    bottom: .5em;
}
#about .sec05 .inner .box .pic02 {
    position: absolute;
    left: 5%;
    bottom: .5em;
}
#about .sec05 .inner .box .title {
    padding: .5em;
}
#about .sec05 .inner .box .text {
    padding: 1em;
}
#about .sec05 .inner ul {
    display: grid;
    gap: 1em;
    grid-template-columns: repeat(2, 1fr);
}
#about .sec05 .inner ul li {
    border: 1px solid var(--color-BlueN);
}
#about .sec05 .inner ul li .title {
    padding: .5em 1em;
    letter-spacing: 0;
    display: flex;
    gap: 1em;
    align-items: center;
}
#about .sec05 .inner ul li .title .num {
    padding: 0 .5em 0 0;
    border-right: 1px solid;
    line-height: 1;
    position: relative;
}
#about .sec05 .inner ul li .title h4 span {
    line-height: 1;
}
#about .sec05 .inner ul li .text {
    padding: 1em;
    overflow: hidden;
}
#about .sec05 .inner ul li .text i {
    margin: 0 0 0 1em;
    float: right;
}
@media screen and (max-width: 768px) {
	#about .sec05 .inner .box .pic01,
	#about .sec05 .inner .box .pic02 {
	    display: none;
	}
	#about .sec05 .inner ul {
	    grid-template-columns: repeat(1, 1fr);
	}
	#about .sec05 .inner ul li .text i {
	    width: auto;
	    max-width: 80px;
	    height: auto;
	    max-height: 60px;
	}
}
/* ------------------------------------------- */
#about .sec06 .inner > fieldset {
    border: 1px solid #008b4e;
}
#about .sec06 .inner > fieldset > legend {
    padding: 0 1em;
}
#about .sec06 .inner > fieldset > .item {
    padding: 1em 2em 2em;
}
#about .sec06 .inner > fieldset fieldset {
    border: 1px solid #008b4e;
}
#about .sec06 .inner > fieldset fieldset legend {
    padding: 0 1em;
    color: #008b4e;
}
#about .sec06 .inner > fieldset fieldset .item {
    padding: .5em 1em 1em;
}
@media screen and (max-width: 768px) {
	#about .sec06 .inner > fieldset > .item {
	    padding: 1em;
	}
	#about .sec06 .inner > fieldset fieldset p {
	    text-align: left;
	}
}
/* ------------------------------------------- */
#about .sec07 .inner .title h4 {
    padding: .3em 0;
}
#about .sec07 .inner .title h4::after {
    content: "";
    width: 1em;
    aspect-ratio: 1 / cos(50deg);
    clip-path: polygon(50% 100%, 100% 0, 0 0);
    background: var(--color-BlueN);
    position: absolute;
    top: calc(100% - 1px);
    left: 50%;
    transform: translateX(-50%);
}
#about .sec07 .inner .box {
	padding: 0 0 0 1em;
    display: grid;
    gap: 1.5em;
}
#about .sec07 .inner .box .item {
    background: #ffffe4;
    display: flex;
}
#about .sec07 .inner .box .item ol {
    width: 100%;
    display: grid;
    gap: 1.5em;
}
#about .sec07 .inner .box .item ol li {
	padding: .2em 0 .2em 3em;
    background: var(--color-BlueL);
    position: relative;
}
#about .sec07 .inner .box .item ol li .num {
    width: 2em;
    aspect-ratio: 1;
    background: var(--color-BlueN);
    border-radius: 100vmax;
    line-height: 1;
    display: grid;
    place-content: center;
    position: absolute;
    top: 50%;
    left: -.8em;
    transform: translateY(-50%);
}
#about .sec07 .inner .box .item .period {
    width: 220px;
    display: grid;
    flex-shrink: 0;
    place-content: center;
}
@media screen and (max-width: 768px) {
	#about .sec07 .inner > p.text-center {
	    text-align: left;
	}
	#about .sec07 .inner .box {
	    padding: 0;
	}
	#about .sec07 .inner .box .item {
		padding: 1em;
        gap: 1em;
	    flex-direction: column-reverse;
	}
	#about .sec07 .inner .box .item .period {
	    width: 100%;
	}
	#about .sec07 .inner .box .item ol {
	    gap: 1em;
	}
	#about .sec07 .inner .box .item ol li {
	    min-height: 4em;
	    padding: .2em 1em .2em 3em;
	    display: grid;
	    align-items: center;
	}
}
/* ------------------------------------------- */
#about .sec08 .inner dl {
    display: grid;
    gap: 2em;
}
#about .sec08 .inner dl > div {
    border: 2px solid var(--color-Black2);
    border-radius: .5em;
    overflow: hidden;
}
#about .sec08 .inner dl > div dt,
#about .sec08 .inner dl > div dd {
    padding: 1em;
    display: flex;
    gap: 1em;
    align-items: baseline;
}
#about .sec08 .inner dl > div dt .mark,
#about .sec08 .inner dl > div dd .mark {
    width: 1.5em;
    aspect-ratio: 1;
    border-radius: 100vmax;
    line-height: 1;
    letter-spacing: 0;
    display: grid;
    flex-shrink: 0;
    place-items: center;
}
#about .sec08 .inner dl > div dd .mark {
    background: #929292;
}
@media screen and (max-width: 768px) {
	#about .sec08 .inner dl {
	    gap: 1em;
	}
}

/* ----------------------------------------------
    service
---------------------------------------------- */
#service .cta .text-white.bg-black2 p span {
    background: linear-gradient(transparent 90%, var(--color-Red) 90%);
}
#service .cta ul {
    display: grid;
    gap: 1em 2em;
    grid-template-columns: repeat(3, 1fr);
}
#service .cta ul li a {
    height: 100%;
    padding: 1em 0;
    border: 1px solid #fff;
    box-shadow: rgba(99, 99, 99, 0.4) 0px 2px 8px 0px;
    line-height: 1;
    display: grid;
    gap: .5em;
    align-content: center;
}
#service .cta ul li a.tel .num,
#service .cta ul li a.line,
#service .cta ul li a.mail {
    display: flex;
    gap: .5em;
    align-items: center;
    justify-content: center;
}
#service .cta ul li a.tel i {
    filter: grayscale(1) brightness(5);
}
@media screen and (max-width: 768px) {
	#service .cta .bg-cream {
	    padding: 3em 0;
	}
	#service .cta ul {
	    grid-template-columns: repeat(1, 1fr);
	}
	#service .cta ul li a.line,
	#service .cta ul li a.mail {
	    padding: 1.5em 0;
	}
}
/* ------------------------------------------- */
#service .sec01 .inner .box {
    display: flex;
}
#service .sec01 .inner .box .item01 {
	padding: 1em;
    display: grid;
    flex-shrink: 0;
    align-content: center;
    z-index: 2;
}
#service .sec01 .inner .box .item02 {
	width: 100%;
}
/*#service .sec01 .inner .box .item02::after {
    content: "";
    width: calc(100% + 2em);
    height: 100%;
    background: var(--color-Cream);
    position: absolute;
    top: 2em;
    right: 0;
    z-index: -4;
}*/
#service .sec01 .inner .box .item02 .text {
    width: 90%;
    height: 100%;
    padding: 2em;
    display: grid;
    align-content: center;
    position: absolute;
    top: 0;
    left: 0;
}
#service .sec01 .inner .box .item02 .text .text01 {
    margin: 0 0 .5em;
    text-shadow: 0 0 .3em var(--color-Brown),
			     0 0 .3em var(--color-Brown),
			     0 0 .3em var(--color-Brown);
}
#service .sec01 .inner .box .item02 .text .text02 {
    display: grid;
    gap: .4em;
}
#service .sec01 .inner .box .item02 .text .text02 > span {
    width: fit-content;
    padding: 0 .2em;
    line-height: 1.2;
    display: flex;
    align-items: center;
}
#service .sec01 .inner .box .item02 .text .text02 > span span {
    background: linear-gradient(transparent 90%, var(--color-Yellow) 90%);
}
#service .sec01 .inner .box .item02 .text ul {
    max-width: 600px;
    margin: 3em 0 0;
    display: grid;
    gap: 1.5em;
    grid-template-columns: repeat(3, 1fr);
}
#service .sec01 .inner .box .item02 .text ul li {
    aspect-ratio: 1;
    border-radius: 100vmax;
    display: grid;
    gap: .5em;
    align-content: center;
}
#service .sec01 .inner .box .item02 .text ul li i {
    justify-content: center;
}
#service .sec01 .inner .box .item02 .text .label {
    width: fit-content;
    margin: 0 0 0 auto;
}
#service .sec01 .inner .box .item02 .img img {
    width: 100%;
    height: 900px;
    object-fit: cover;
    object-position: left;
}
@media screen and (max-width: 768px) {
	#service .sec01,
	#service .sec01 .inner {
	    padding: 0;
	}
	#service .sec01 .inner .box {
	    flex-direction: column;
	}
	#service .sec01 .inner .box .item01 {
	    padding: 0;
	    background: var(--color-Black);
	    display: flex;
	    align-items: center;
	    justify-content: center;
	}
	#service .sec01 .inner .box .item01 .img {
	    width: 100px;
	}
	#service .sec01 .inner .box .item01 p {
	    text-align: left;
	}
	#service .sec01 .inner .box .item02 {
	    transform: translateY(0);
	}
	#service .sec01 .inner .box .item02::after {
		display: none;
	}
	#service .sec01 .inner .box .item02 .text {
	    width: 100%;
	    padding: 0 5%;
	}
	#service .sec01 .inner .box .item02 .text ul {
        width: fit-content;
        max-width: 270px;
        margin: 1em 0 0;
		gap: .5em;
        overflow: hidden;
	}
	#service .sec01 .inner .box .item02 .text ul li {
		padding: .5em;
	    line-height: 1.4;
	    gap: .3em;
	}
	#service .sec01 .inner .box .item02 .text ul li i img {
	    width: 2em;
	}
	#service .sec01 .inner .box .item02 .text .label {
	    width: 40%;
	    max-width: 130px;
	    margin: .5em 0 0 auto;
	}
	#service .sec01 .inner .box .item02 .img img {
	    height: 310px;
	    object-position: 20%;
	}
}
/* ------------------------------------------- */
#service .sec02 .box01 dl dt::after {
    content: "";
    width: 3em;
    aspect-ratio: 2.5 / cos(30deg);
	clip-path: polygon(50% 100%,100% 0,0 0);
    background: var(--color-BlueB);
    position: absolute;
    top: calc(100% - 1px);
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
}
#service .sec02 .box01 dl dd {
    padding: 2em;
    border: .5em solid var(--color-GrayL);
}
#service .sec02 .box01 dl dd ul {
    display: grid;
    gap: .3em;
}
#service .sec02 .box01 dl dd ul li {
	padding: 0 0 .2em;
    display: flex;
    gap: .5em;
    align-items: flex-start;
    position: relative;
}
#service .sec02 .box01 dl dd ul li::before {
    content: "";
    width: .8em;
    aspect-ratio: 24 / 17;
    margin: .7em 0 0;
    background: url(../img/service/icon-check.svg) center / cover no-repeat;
}
#service .sec02 .box01 dl dd ul li::after {
    content: "";
    width: 100%;
    height: 2px;
    background-color: #ffffff;
    background-image: radial-gradient(circle, #2e2e2e 1px, transparent 1px);
    background-position: -3px 12px;
    background-size: 8px 22px;
    position: absolute;
    left: 0;
    bottom: 0;
}
#service .sec02 .box01 dl dd .pic {
    position: absolute;
    top: 50%;
    right: 5%;
    transform: translateY(-50%);
}
#service .sec02 .box02::before {
    content: "";
    width: 7em;
    aspect-ratio: 2.5 / cos(30deg);
    clip-path: polygon(50% 0, 100% 100%, 0 100%);
    background: var(--color-Black2);
    position: absolute;
    bottom: calc(100% - 1px);
    left: 50%;
    transform: translateX(-50%);
}
#service .sec02 .box02 p span {
    background: linear-gradient(transparent 90%, var(--color-Red) 90%);
}
#service .sec02 .box03 fieldset {
    padding: 0 0 1em;
    border: 2px solid;
}
#service .sec02 .box03 fieldset legend {
    padding: 0 1em;
    letter-spacing: .1em;
    position: relative;
}
#service .sec02 .box03 fieldset legend::before,
#service .sec02 .box03 fieldset legend::after {
    content: "";
    width: 2px;
    height: .8em;
    background: var(--color-Black);
    position: absolute;
    top: 45%;
    transform: translateY(-50%);
}
#service .sec02 .box03 fieldset legend::before {
    rotate: -30deg;
    left: .15em;
}
#service .sec02 .box03 fieldset legend::after {
    rotate: 30deg;
    right: .15em;
}
#service .sec02 .box03 fieldset h3 span {
    background: linear-gradient(transparent 80%, #ffbba2 80%);
}
#service .sec02 .box03 ul li {
    padding: 1em 0;
    border-bottom: 1px solid;
    display: flex;
    gap: 1em;
    align-items: baseline;
}
#service .sec02 .box03 ul li .num {
    width: 1.3em;
    aspect-ratio: 1;
    border-radius: 100vmax;
    line-height: 1;
    display: grid;
    place-items: center;
}
#service .sec02 .box04 {
	background: url(../img/service/back-price.jpg) center / cover no-repeat;
    overflow: hidden;
}
#service .sec02 .box04::after {
	content: "";
	width: 100%;
	height: 100%;
	backdrop-filter: blur(.5em);
	position: absolute;
	top: 0;
	left: 0;
}
#service .sec02 .box04 .item {
    padding: 1em 15% 1em 1em;
    box-shadow: 0 .5em 0 rgb(0 0 0 / 20%);
    z-index: 1;
}
#service .sec02 .box04 .item .pic {
    position: absolute;
    right: 15%;
    bottom: -1.15em;
}
@media screen and (max-width: 768px) {
	#service .sec02 .box01 dl dd .pic {
	    width: 40%;
	    max-width: 120px;
	    top: 85%;
	    right: 0;
	    transform: translateY(0);
	}
	#service .sec02 .box04 .item {
	    padding: 1em 20% 1em 1em;
	}
	#service .sec02 .box04 .item .pic {
	    width: 20%;
	    max-width: 70px;
	    right: 1em;
	}
}
/* ------------------------------------------- */
#service .sec03 .inner .box01 {
    margin: 5em 0 0;
}
#service .sec03 .inner .box01 .item {
    display: flex;
    gap: 0 2em;
    align-items: flex-start;
}
#service .sec03 .inner .box01 .item .text .title {
    display: flex;
    gap: 1em;
    align-items: center;
}
#service .sec03 .inner .box01 .item .text .title .num {
	padding: 0 0 .2em;
    line-height: 1;
    position: relative;
    transform: translateY(-.05em);
}
#service .sec03 .inner .box01 .item .text .title .num::after {
    content: "";
    width: 60px;
    height: 8px;
    background: var(--color-Red);
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
}
#service .sec03 .inner .box01 .item .text .title .text {
    line-height: 1.3;
}
#service .sec03 .inner .box01 .item .img {
	width: 100%;
    max-width: 520px;
    aspect-ratio: 5 / 6;
	margin: -2em 0 0;
	flex-shrink: 0;
}
#service .sec03 .inner .box01 .item .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 85%;
}
#service .sec03 .inner .box02 {
	background: var(--color-GrayL) url(../img/service/back-table.jpg) center / cover no-repeat;
    overflow: hidden;
}
#service .sec03 .inner .box02::after {
	content: "";
	width: 100%;
	height: 100%;
	backdrop-filter: blur(.5em);
	position: absolute;
	top: 0;
	left: 0;
}
#service .sec03 .inner .box02 table {
    z-index: 1;
}
#service .sec03 .inner .box02 table th,
#service .sec03 .inner .box02 table td {
    padding: 1em;
    vertical-align: middle;
}
#service .sec03 .inner .box02 table thead th .logo {
    filter: grayscale(1) invert(1) brightness(5) drop-shadow(0 0 .2em rgb(0 0 0 / 30%));
}
#service .sec03 .inner .box02 table thead th.back-gray {
    padding: 2% 0 0;
    background: linear-gradient(0deg, rgba(199, 199, 199, 1) 80%, rgba(199, 199, 199, 0) 80%);
}
#service .sec03 .inner .box02 table tbody tr:not(:last-child) {
    border-bottom: 1px solid var(--color-Brown);
}
#service .sec03 .inner .box02 table tbody th {
    width: 280px;
}
#service .sec03 .inner .box02 table tbody td .item {
    display: flex;
    gap: 1em;
    align-items: center;
}
#service .sec03 .inner .box02 table tbody td .item i {
    flex-shrink: 0;
}
#service .sec03 .inner .box02 table tbody td .item p {
    word-break: auto-phrase;
}
#service .sec03 .inner .box03 .item {
    display: grid;
    gap: 2em;
    grid-template-columns: repeat(2, 1fr);
}
#service .sec03 .inner .box03 .item .left .aff {
    margin: 0 0 .5em;
    border-bottom: 1px solid var(--color-Red);
}
#service .sec03 .inner .box03 .item .left .name {
    display: flex;
    gap: 1em;
    align-items: center;
}
#service .sec03 .inner .box03 .item .left .name .text02 {
    letter-spacing: .2em;
}
#service .sec03 .inner .box03 .item .right dl {
    display: grid;
    gap: 2em;
}
#service .sec03 .inner .box03 .item .right dl > div {
    padding: 1em;
}
#service .sec03 .inner .box03 .item .right dl > div dt {
    margin: 0 0 .5em;
    border-bottom: 1px solid var(--color-Red);
}
#service .sec03 .inner .box03 .item .right dl > div dd .list01 li {
    display: flex;
    gap: 1em;
}
#service .sec03 .inner .box03 .item .right dl > div dd .list02 {
    display: flex;
    gap: 0 .5em;
    flex-wrap: wrap;
}
#service .sec03 .inner .box03 .item .right dl > div dd .list02 li {
    display: flex;
    gap: 0 .5em;
}
#service .sec03 .inner .box03 .item .right dl > div dd .list02 li:not(:last-child)::after {
    content: "/";
}
#service .sec03 .inner .box03 .item .right .list03 {
    display: grid;
    gap: 1.5em;
    grid-template-columns: repeat(3, 1fr);
}
#service .sec03 .inner .box03 .item .right .list03 li {
    padding: .8em .5em 1.3em;
    background: var(--color-Yellow);
    border: 1px solid;
    line-height: 1.4;
    display: grid;
    place-items: center;
    position: relative;
}
#service .sec03 .inner .box03 .item .right .list03 li::after {
    content: "";
    width: 100%;
    height: .5em;
    background: var(--color-GrayM);
    opacity: .3;
    position: absolute;
    left: 0;
    bottom: 0;
}
#service .sec03 .inner .box03 .item .right .list03 li .num {
    padding: 0 .2em;
    background: linear-gradient(transparent 80%, #ffbba2 80%);
    line-height: 1.1;
}
@media screen and (max-width: 768px) {
	#service .sec03 .inner .box01 {
	    margin: 4em 0 0;
	    padding: 0 0 4em;
	}
	#service .sec03 .inner .box01 .item {
	    flex-direction: column-reverse;
	}
	#service .sec03 .inner .box01 .item .img {
	    width: 50%;
	    max-width: 200px;
	    margin-left: auto;
	}
    #service .sec03 .inner .box01 .item .text .title {
    	margin-top: -3em;
        padding: 0;
        align-items: flex-start;
        flex-direction: column;
    }
    #service .sec03 .inner .box01 .item .text .title .num::after {
	    width: 1em;
	    height: 4px;
	}
	#service .sec03 .inner .box02 .scroll {
	    padding: 0 5%;
	    overflow-x: scroll;
	}
	#service .sec03 .inner .box02 table {
	    width: 540px;
	}
	#service .sec03 .inner .box02 table th,
	#service .sec03 .inner .box02 table td {
	    padding: .5em;
	}
	#service .sec03 .inner .box02 table td {
		width: 40%;
	}
	#service .sec03 .inner .box02 table tbody th {
	    width: 20%;
	}
	#service .sec03 .inner .box02 table tbody td .item {
	    gap: .5em;
	}
	#service .sec03 .inner .box02 table tbody td .item i {
	    width: 1.5em;
	}
	#service .sec03 .inner .box03 .item {
	    grid-template-columns: repeat(1, 1fr);
	}
	#service .sec03 .inner .box03 .item .right dl {
	    gap: 1em;
	}
	#service .sec03 .inner .box03 .item .right .list03 {
	    gap: .5em;
	}
}
/* ------------------------------------------- */
#service .sec04 .inner .box {
    padding: 2em;
    border: 2px solid var(--color-BlueB);
}
#service .sec04 .inner .box .item01 {
    display: flex;
    gap: 1.5em;
    align-items: center;
}
#service .sec04 .inner .box .item01 .img {
    flex-shrink: 0;
}
#service .sec04 .inner .box .item01 .text .cate {
    width: fit-content;
    padding: 0 .5em;
    display: block;
}
#service .sec04 .inner .box .item02 {
    padding: 1em;
}
@media screen and (max-width: 768px) {
	#service .sec04 .inner .box .item01 {
	    flex-direction: column;
	}
	#service .sec04 .inner .box .item01 .text {
	    display: grid;
	    gap: .5em;
	}
}
/* ------------------------------------------- */
#service .sec05 .inner .box {
	padding-bottom: 10em;
	background: var(--color-Brown) url(../img/service/back-price.jpg) center / cover no-repeat;
    overflow: hidden;
}
#service .sec05 .inner .box::before,
#service .sec05 .inner .box::after {
    content: "";
    width: 100%;
    height: 100%;
    background: var(--color-Brown);
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
}
#service .sec05 .inner .box::before {
    background: #fff;
    opacity: .2;
}
#service .sec05 .inner .box::after {
    background: var(--color-Brown);
    opacity: 1;
    mix-blend-mode: overlay;
    backdrop-filter: blur(.5em) grayscale(.5) brightness(1);
}
#service .sec05 .inner .box .item {
    z-index: 1;
}
#service .sec05 .inner ul {
    margin-top: -6em;
    display: grid;
    gap: 2em;
    grid-template-columns: repeat(3, 1fr);
    z-index: 2;
}
#service .sec05 .inner ul li {
    padding: 1em;
    border: 2px solid var(--color-Brown);
    box-shadow: 0 .5em 0 #d7d7c0;
    line-height: 1;
    display: grid;
    gap: .5em;
    align-content: flex-start;
}
@media screen and (max-width: 768px) {
	#service .sec05 .inner ul {
	    gap: .5em;
	}
	#service .sec05 .inner ul li {
	    padding: .5em;
    }
    #service .sec05 .inner ul li .text01,
    #service .sec05 .inner ul li .text03 {
	    line-height: 1.2;
	}
}
/* ------------------------------------------- */
#service .sec06 .inner ol {
    display: grid;
    gap: 4em;
}
#service .sec06 .inner ol li {
    padding: 2em;
    border: 2px solid var(--color-BlueB);
    display: flex;
    gap: 1.5em 2em;
    position: relative;
}
#service .sec06 .inner ol li:not(:last-child)::after {
    content: "";
    width: 5px;
    height: 4em;
    background-color: #ffffff;
    background-image: radial-gradient(circle, #22529e 2.5px, transparent 2.5px);
    background-position: 11px -2px;
    background-size: 17px 17px;
    position: absolute;
    top: calc(100% + 2px);
    left: 50%;
    transform: translateX(-50%);
}
#service .sec06 .inner ol li .left {
    width: 100%;
    max-width: 430px;
    flex-shrink: 0;
}
#service .sec06 .inner ol li .left h3 {
    display: flex;
    gap: 1em;
    align-items: center;
}
#service .sec06 .inner ol li .left h3 .num {
    width: 1.3em;
    aspect-ratio: 1;
    border-radius: 100vmax;
    line-height: 1;
    display: grid;
    flex-shrink: 0;
    place-items: center;
}
#service .sec06 .inner ol li .right {
    padding: 1em;
}
#service .sec06 .inner .box {
    padding: 2em;
    display: grid;
    gap: .5em;
}
#service .sec06 .inner .box::after {
    content: "";
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    border: 1px solid var(--color-Brown);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
}
@media screen and (max-width: 768px) {
	#service .sec06 .inner ol {
	    gap: 2em;
	}
	#service .sec06 .inner ol li {
	    flex-direction: column;
	}
	#service .sec06 .inner ol li:not(:last-child)::after {
	    height: 2em;
	}
	#service .sec06 .inner ol li .left .img img {
	    width: auto;
	    max-width: 100%;
	    height: auto;
	    max-height: 80px;
	}
	#service .sec06 .inner .box p {
	    text-align: left;
	}
}
/* ------------------------------------------- */
#service .sec07 .inner dl {
    display: grid;
    gap: 2em;
}
#service .sec07 .inner dl > div {
    border: 2px solid var(--color-Black2);
    border-radius: .5em;
    overflow: hidden;
}
#service .sec07 .inner dl > div dt,
#service .sec07 .inner dl > div dd {
    padding: 1em;
    display: flex;
    gap: 1em;
    align-items: baseline;
}
#service .sec07 .inner dl > div dt .mark,
#service .sec07 .inner dl > div dd .mark {
    width: 1.5em;
    aspect-ratio: 1;
    border-radius: 100vmax;
    line-height: 1;
    letter-spacing: 0;
    display: grid;
    flex-shrink: 0;
    place-items: center;
}
#service .sec07 .inner dl > div dd .mark {
    background: #929292;
}
@media screen and (max-width: 768px) {
	#service .sec07 .inner dl {
	    gap: 1em;
	}
}

/* ----------------------------------------------
    staff
---------------------------------------------- */
#staff .sec01 .inner ul {
    display: grid;
    gap: 2.5em;
}
#staff .sec01 .inner ul li {
    border-radius: .5em;
    box-shadow: 0 .3em 1em rgb(149 157 165 / 10%);
    display: flex;
    overflow: hidden;
}
#staff .sec01 .inner ul li .img {
    flex-shrink: 0;
}
#staff .sec01 .inner ul li .img img {
    width: 300px;
    height: 100%;
    object-fit: cover;
}
#staff .sec01 .inner ul li .text {
    padding: 1em 2em;
}
#staff .sec01 .inner ul li .text .head {
    display: flex;
    gap: 0 1em;
    flex-wrap: wrap;
    align-items: center;
}
@media screen and (max-width: 768px) {
	#staff .sec01 .inner ul li {
	    padding: 2em;
	    gap: 2em;
	    flex-direction: column;
	}
	#staff .sec01 .inner ul li .img img {
	    width: 220px;
	    margin: 0 auto;
	    display: block;
	}
	#staff .sec01 .inner ul li .text {
	    padding: 0;
	}
	#staff .sec01 .inner ul li .text .head {
		text-align: center;
	    flex-direction: column;
	}
}

/* ----------------------------------------------
    faq
---------------------------------------------- */
#faq .sec01 .inner dl {
    display: grid;
    gap: 2em;
}
#faq .sec01 .inner dl > div {
    border: 2px solid var(--color-Brown);
    border-radius: .5em;
    overflow: hidden;
}
#faq .sec01 .inner dl > div dt,
#faq .sec01 .inner dl > div dd {
    padding: 1em;
    display: flex;
    gap: 1em;
    align-items: baseline;
}
#faq .sec01 .inner dl > div dt .mark,
#faq .sec01 .inner dl > div dd .mark {
    width: 1.5em;
    aspect-ratio: 1;
    border-radius: 100vmax;
    line-height: 1;
    letter-spacing: 0;
    display: grid;
    flex-shrink: 0;
    place-items: center;
}
#faq .sec01 .inner dl > div dd .mark {
    background: #929292;
}
@media screen and (max-width: 768px) {
	#faq .sec01 .inner dl {
	    gap: 1em;
	}
}

/* ----------------------------------------------
    case
---------------------------------------------- */
#case .sec01 .inner .list ul {
    display: grid;
    gap: 2em;
    grid-template-columns: repeat(3, 1fr);
}
#case .sec01 .inner .list ul li a {
    height: 100%;
    padding: 1em;
	border: 1px solid var(--color-Brown);
    display: flex;
    gap: 1em;
    flex-direction: column;
}
#case .sec01 .inner .list ul li a .img {
    aspect-ratio: 3 / 1.5;
    background: var(--color-GrayL);
    overflow: hidden;
}
#case .sec01 .inner .list ul li a .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
#case .sec01 .inner .list ul li a .text {
    display: grid;
    gap: .5em;
    flex-grow: 1;
    align-content: space-between;
}
#case .sec01 .inner .list ul li a .text .title {
	min-height: 3.5em;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 2;
}
#case .sec01 .inner .list ul li a .text p {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 3;
}
#case .sec01 .inner .list ul li a .text .more {
    padding: .5em;
    display: flex;
    gap: .5em;
    align-items: center;
    justify-content: center;
}
#case .sec01 .inner .detail .title04,
#case .sec01 .inner .detail .title05 {
    margin-top: 1.5em;
}
#case .sec01 .inner .detail p,
#case .sec01 .inner .detail ul {
	margin: 0 0 1em;
}
#case .sec01 .inner .detail .counselor {
    border: 1px solid var(--color-GrayN);
    padding: 1em;
}
#case .sec01 .inner .detail .point {
    padding: 1em;
    background: var(--color-GrayL);
}
#case .sec01 .inner .detail .point li {
    display: flex;
    gap: .5em;
    align-items: baseline;
}
#case .sec01 .inner .detail .point li::before {
    content: "";
    width: 1em;
    aspect-ratio: 24 / 17;
    background: url(../img/common/icon-check.svg) center / cover no-repeat;
    display: block;
}
#case .sec01 .inner .detail .number {
    padding: 0 0 0 1.3em;
    text-indent: -1.3em;
    list-style: auto;
    list-style-position: inside;
}
@media screen and (max-width: 768px) {
	#case .sec01 .inner .list ul {
	    gap: 1em;
	    grid-template-columns: repeat(1, 1fr);
	}
	#case .sec01 .inner .list ul li a .text .title {
	    min-height: auto;
	}
}

/* ----------------------------------------------
    column
---------------------------------------------- */
#column .sec01 .inner .cate {
    display: flex;
    gap: 1em 2em;
}
#column .sec01 .inner .cate h3 {
    flex-shrink: 0;
}
#column .sec01 .inner .cate ul {
    display: flex;
    gap: .5em;
    flex-wrap: wrap;
}
#column .sec01 .inner .cate ul li a {
    padding: 0 1em;
    color: var(--color-BlueB);
    border: 1px solid;
    border-radius: .3em;
    display: block;
}
#column .sec01 .inner .cate ul li.act a {
    color: #fff;
    background: var(--color-BlueB);
}
#column .sec01 .inner .list ul {
    display: grid;
    gap: 1.5em;
}
#column .sec01 .inner .list ul li {
    border-bottom: 1px solid var(--color-GrayL);
}
#column .sec01 .inner .list ul li a {
    padding: 0 0 1.5em;
    display: flex;
    gap: 1em 1.5em;
    align-items: flex-start;
}
#column .sec01 .inner .list ul li a .img {
    width: 300px;
    aspect-ratio: 3 / 2;
    background: var(--color-GrayL);
    flex-shrink: 0;
}
#column .sec01 .inner .list ul li a .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
#column .sec01 .inner .list ul li a .text {
    display: grid;
    gap: .5em;
    align-content: flex-start;
}
#column .sec01 .inner .list ul li a .text .data {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
#column .sec01 .inner .list ul li a .text .data .cate span {
    width: 180px;
    text-align: center;
}
#column .sec01 .inner .list ul li a .text .data .date {
    display: flex;
    gap: .3em;
}
#column .sec01 .inner .list ul li a .text .title,
#column .sec01 .inner .list ul li a .text p {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 2;
}
#column .sec01 .inner .detail .data {
    display: flex;
    gap: 1em;
    align-items: center;
}
#column .sec01 .inner .detail .data .cate {
    padding: 0 1em;
    line-height: 1.5;
}
#column .sec01 .inner .detail .title04,
#column .sec01 .inner .detail .title05 {
    margin-top: 1.5em;
}
#column .sec01 .inner .detail p,
#column .sec01 .inner .detail ul {
	margin: 0 0 1em;
}
@media screen and (max-width: 768px) {
	#column .sec01 .inner .cate {
	    flex-direction: column;
	}
	#column .sec01 .inner .list ul li a {
	    flex-direction: column;
	}
	#column .sec01 .inner .list ul li a .img {
	    width: 100%;
	}
	#column .sec01 .inner .list ul li a .text .data .cate span {
	    width: 140px;
	}
	#column .sec01 .inner .list ul li a .text .title {
	    -webkit-line-clamp: initial;
	}
}

/* ----------------------------------------------
    news
---------------------------------------------- */
#news .sec01 .inner .cate ul {
    display: flex;
    gap: .5em;
    flex-wrap: wrap;
}
#news .sec01 .inner .cate ul li a {
    padding: 0 1em;
    color: var(--color-BlueB);
    border: 1px solid;
    border-radius: .3em;
    display: block;
}
#news .sec01 .inner .cate ul li.act a {
    color: #fff;
    background: var(--color-BlueB);
}
#news .sec01 .inner .list ul {
    display: grid;
    gap: 1.5em;
}
#news .sec01 .inner .list ul li {
    border-bottom: 1px solid var(--color-GrayL);
}
#news .sec01 .inner .list ul li a {
    padding: 0 0 1.5em;
    display: flex;
    gap: 1em 1.5em;
    align-items: flex-start;
}
#news .sec01 .inner .list ul li a .time,
#news .sec01 .inner .list ul li a .cate {
    flex-shrink: 0;
}
#news .sec01 .inner .list ul li a .cate span {
    width: 180px;
    text-align: center;
    display: block;
}
#news .sec01 .inner .detail .data {
    display: flex;
    gap: 1em;
    align-items: center;
}
#news .sec01 .inner .detail .data .cate {
    padding: 0 1em;
    line-height: 1.5;
}
#news .sec01 .inner .detail .title04,
#news .sec01 .inner .detail .title05 {
    margin-top: 1.5em;
}
#news .sec01 .inner .detail p,
#news .sec01 .inner .detail ul {
	margin: 0 0 1em;
}
@media screen and (max-width: 768px) {
	#news .sec01 .inner .cate {
	    flex-direction: column;
	}
	#news .sec01 .inner .list ul li a {
	    flex-wrap: wrap;
	}
	#news .sec01 .inner .list ul li a .cate span {
	    width: 140px;
	}
}

/* ----------------------------------------------
    company
---------------------------------------------- */
#company .sec01 .inner table,
#company .sec01 .inner table th,
#company .sec01 .inner table td {
	padding: 1em;
    border: 1px solid var(--color-Brown);
}
#company .sec01 .inner table th {
    width: 260px;
    text-align: left;
}
@media screen and (max-width: 768px) {
	#company .sec01 .inner table th {
	    width: 100px;
	}
}
/* ------------------------------------------- */
#company .sec02 .inner #map {
    width: 100%;
    height: 500px;
}
@media screen and (max-width: 768px) {
	#company .sec02 .inner #map {
	    height: 300px;
	}
}

/* ----------------------------------------------
    contact
---------------------------------------------- */
#contact .sec01 .inner form dl {
	margin: 0 0 .5em;
    display: grid;
    gap: .5em;
}
#contact .sec01 .inner form dl > div {
    display: flex;
    gap: .5em;
}
#contact .sec01 .inner form dl > div dt {
    width: 380px;
    padding: 1em 1.5em;
    background: #faf1df;
    font-weight: 600;
    display: flex;
    gap: .5em;
    flex-wrap: wrap;
    flex-shrink: 0;
    align-items: baseline;
    align-content: flex-start;
    justify-content: space-between;
}
#contact .sec01 .inner form dl > div dt .label {
    padding: 0 .5em;
    display: grid;
}
#contact .sec01 .inner form dl > div dt .required {
    background: var(--color-Red);
}
#contact .sec01 .inner form dl > div dt .any {
    background: var(--color-GrayB);
}
#contact .sec01 .inner form dl > div dd {
    width: 100%;
    padding: .5em;
    background: var(--color-GrayL);
}
#contact .sec01 .inner form input,
#contact .sec01 .inner form textarea {
    width: 100%;
    height: 60px;
    padding: .5em 1em;
    background: #fff;
	border: 1px solid var(--color-GrayM);
    cursor: pointer;
}
#contact .sec01 .inner form textarea {
    min-height: 300px;
}
#contact .sec01 .inner form input:focus-visible,
#contact .sec01 .inner form textarea:focus-visible {
    outline: none;
    border: 1px solid var(--color-GrayB);
}
#contact .sec01 .inner form input::placeholder,
#contact .sec01 .inner form textarea::placeholder {
	color: var(--color-GrayM);
	opacity: .5;
}
#contact .sec01 .inner form .check,
#contact .sec01 .inner form .radio {
	padding: .5em;
    display: grid;
    gap: .5em;
}
#contact .sec01 .inner form .check li input[type="checkbox"],
#contact .sec01 .inner form .radio li input[type="radio"] {
	display: none;
}
#contact .sec01 .inner form .check li label,
#contact .sec01 .inner form .radio li label {
	display: flex;
	gap: 0 .5em;
    align-items: center;
	cursor: pointer;
}
#contact .sec01 .inner form .check li label span,
#contact .sec01 .inner form .radio li label span {
	width: 1em;
    aspect-ratio: 1;
    background: #fff;
    border: 1px solid var(--color-GrayN);
    display: grid;
    flex-shrink: 0;
    place-items: center;
    transition: border 0.2s linear;
    -webkit-transition: border 0.2s linear;
	transition: background 0.2s linear;
	-webkit-transition: background 0.2s linear;
}
#contact .sec01 .inner form .radio li label span {
	border-radius: 100vmax;
}
#contact .sec01 .inner form .check li label span::before,
#contact .sec01 .inner form .radio li label span::before {
    content: "";
    width: .5em;
    aspect-ratio: 7 / 10;
    border-right: 4px solid #fff;
    border-bottom: 4px solid #fff;
    transform: rotate(45deg) translate(-.05em, -.05em);
    -ms-transform: rotate(45deg) translate(-.05em, -.05em);
    -webkit-transform: rotate(45deg) translate(-.05em, -.05em);
    transition: opacity 0.2s linear;
    -webkit-transition: opacity 0.2s linear;
    opacity: 0;
}
#contact .sec01 .inner form .radio li label span::before {
    aspect-ratio: 1;
    background: #fff;
    border-right: none;
    border-bottom: none;
	border-radius: 100vmax;
    transform: rotate(0deg) translate(0);
    -ms-transform: rotate(0deg) translate(0);
    -webkit-transform: rotate(0deg) translate(0);
    transition: opacity 0.2s linear;
    -webkit-transition: opacity 0.2s linear;
    opacity: 0;
}
#contact .sec01 .inner form .check li input:checked + label span,
#contact .sec01 .inner form .radio li input:checked + label span {
	background: var(--color-Brown);
	border-color: var(--color-Brown);
}
#contact .sec01 .inner form .check li input:checked + label span::before,
#contact .sec01 .inner form .radio li input:checked + label span::before {
	opacity: 1.0;
}
#contact .sec01 .inner form .privacy .policy {
    max-height: 360px;
    padding: 1em;
    overflow-y: scroll;
}
#contact .sec01 .inner form .privacy .policy ul li {
    padding: 0 0 0 1em;
    text-indent: -1em;
}
#contact .sec01 .inner form .privacy .check {
    justify-content: center;
}
#contact .sec01 .inner form .privacy .check li label span {
    width: 1.5em;
    border: 2px solid var(--color-Brown);
}
#contact .sec01 .inner form .submit ul {
    display: flex;
    gap: 0 2em;
    align-items: center;
    justify-content: center;
}
#contact .sec01 .inner form .submit ul li button {
    width: 550px;
    height: 110px;
    color: #fff;
    background: var(--color-Red);
    box-shadow: 0 .2em 0 #cecece;
    border-radius: 100vmax;
    display: grid;
    place-items: center;
}
#contact .sec02 .inner p {
    letter-spacing: 0;
}
@media screen and (max-width: 768px) {
	#contact .sec .inner p {
	    text-align: left;
	}
	#contact .sec01 .inner form dl > div {
	    flex-direction: column;
	}
	#contact .sec01 .inner form dl > div dt {
	    width: 100%;
	}
	#contact .sec01 .inner form input,
	#contact .sec01 .inner form textarea {
	    height: 50px;
	}
	#contact .sec01 .inner form textarea {
	    min-height: 240px;
	}
	#contact .sec01 .inner form .privacy .policy {
	    max-height: 260px;
	}
	#contact .sec01 .inner form .check li label span::before {
	    border-right: 2px solid #fff;
	    border-bottom: 2px solid #fff;
    }
	#contact .sec01 .inner form .submit ul li button {
	    width: 250px;
	    height: 65px;
    }
}


