@charset "UTF-8";

/* base */

/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

/* HTML5 display-role reset for older browsers */

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
	display: block;
}

body {
	line-height: 1;
}

ol,
ul {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: "";
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

:root {
	--scrollbar: 0;
}

html {
	font-size: 62.5%;
	scroll-behavior: smooth;
}

html:has(#navi[aria-hidden=false]) {
	overflow: hidden;
}

body {
	font-family: YakuHanRP, "Zen Maru Gothic", sans-serif;
	font-size: 1.4rem;
	font-weight: 500;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	color: #343434;
	word-wrap: break-word;
}

a {
	color: inherit;
}

div[id],
section[id],
article[id] {
	scroll-margin-top: 80px;
}

img {
	max-width: 100%;
	height: auto;
}

input,
textarea,
select,
button {
	font: inherit;
	color: inherit;
	outline: none;
}

button,
a {
	cursor: pointer;
}

button:focus-visible,
a:focus-visible {
	outline: auto;
}

/* for development */

pre {
	padding: 15px;
	background: #eee;
	font-size: 1.2rem;
	line-height: 1.2;
}

/* Tools */

.text-left {
	text-align: left;
}

.text-center {
	text-align: center;
}

.text-right {
	text-align: right;
}

.d-block {
	display: block;
}

.d-inline-block {
	display: inline-block;
}

.is-hidden {
	display: none !important;
}

.clearfix::before,
.clearfix::after {
	content: "";
	display: table;
}

.clearfix::after {
	clear: both;
}

.clear {
	clear: both;
}

/* show only  SP/PC
-------------------------------*/

.sp-only {
	display: none !important;
}

.sp-only-2 {
	display: none !important;
}

.pc-only {
	display: block !important;
}

.pc-only-2 {
	display: inline-block !important;
}

/* font
-------------------------------*/

.fw-700 {
	font-weight: 700;
}

/* margin
-------------------------------*/

.mt-0 {
	margin-top: 0px !important;
}

.mb-0 {
	margin-bottom: 0px !important;
}

.mr-0 {
	margin-right: 0px !important;
}

.ml-0 {
	margin-left: 0px !important;
}

.mx-0 {
	margin-left: 0px !important;
	margin-right: 0px !important;
}

.my-0 {
	margin-top: 0px !important;
	margin-bottom: 0px !important;
}

.mt-5 {
	margin-top: 5px !important;
}

.mb-5 {
	margin-bottom: 5px !important;
}

.mr-5 {
	margin-right: 5px !important;
}

.ml-5 {
	margin-left: 5px !important;
}

.mx-5 {
	margin-left: 5px !important;
	margin-right: 5px !important;
}

.my-5 {
	margin-top: 5px !important;
	margin-bottom: 5px !important;
}

.mt-10 {
	margin-top: 10px !important;
}

.mb-10 {
	margin-bottom: 10px !important;
}

.mr-10 {
	margin-right: 10px !important;
}

.ml-10 {
	margin-left: 10px !important;
}

.mx-10 {
	margin-left: 10px !important;
	margin-right: 10px !important;
}

.my-10 {
	margin-top: 10px !important;
	margin-bottom: 10px !important;
}

.mt-15 {
	margin-top: 15px !important;
}

.mb-15 {
	margin-bottom: 15px !important;
}

.mr-15 {
	margin-right: 15px !important;
}

.ml-15 {
	margin-left: 15px !important;
}

.mx-15 {
	margin-left: 15px !important;
	margin-right: 15px !important;
}

.my-15 {
	margin-top: 15px !important;
	margin-bottom: 15px !important;
}

.mt-20 {
	margin-top: 20px !important;
}

.mb-20 {
	margin-bottom: 20px !important;
}

.mr-20 {
	margin-right: 20px !important;
}

.ml-20 {
	margin-left: 20px !important;
}

.mx-20 {
	margin-left: 20px !important;
	margin-right: 20px !important;
}

.my-20 {
	margin-top: 20px !important;
	margin-bottom: 20px !important;
}

.mt-25 {
	margin-top: 25px !important;
}

.mb-25 {
	margin-bottom: 25px !important;
}

.mr-25 {
	margin-right: 25px !important;
}

.ml-25 {
	margin-left: 25px !important;
}

.mx-25 {
	margin-left: 25px !important;
	margin-right: 25px !important;
}

.my-25 {
	margin-top: 25px !important;
	margin-bottom: 25px !important;
}

.mt-30 {
	margin-top: 30px !important;
}

.mb-30 {
	margin-bottom: 30px !important;
}

.mr-30 {
	margin-right: 30px !important;
}

.ml-30 {
	margin-left: 30px !important;
}

.mx-30 {
	margin-left: 30px !important;
	margin-right: 30px !important;
}

.my-30 {
	margin-top: 30px !important;
	margin-bottom: 30px !important;
}

.mt-35 {
	margin-top: 35px !important;
}

.mb-35 {
	margin-bottom: 35px !important;
}

.mr-35 {
	margin-right: 35px !important;
}

.ml-35 {
	margin-left: 35px !important;
}

.mx-35 {
	margin-left: 35px !important;
	margin-right: 35px !important;
}

.my-35 {
	margin-top: 35px !important;
	margin-bottom: 35px !important;
}

.mt-40 {
	margin-top: 40px !important;
}

.mb-40 {
	margin-bottom: 40px !important;
}

.mr-40 {
	margin-right: 40px !important;
}

.ml-40 {
	margin-left: 40px !important;
}

.mx-40 {
	margin-left: 40px !important;
	margin-right: 40px !important;
}

.my-40 {
	margin-top: 40px !important;
	margin-bottom: 40px !important;
}

.mt-45 {
	margin-top: 45px !important;
}

.mb-45 {
	margin-bottom: 45px !important;
}

.mr-45 {
	margin-right: 45px !important;
}

.ml-45 {
	margin-left: 45px !important;
}

.mx-45 {
	margin-left: 45px !important;
	margin-right: 45px !important;
}

.my-45 {
	margin-top: 45px !important;
	margin-bottom: 45px !important;
}

.mt-50 {
	margin-top: 50px !important;
}

.mb-50 {
	margin-bottom: 50px !important;
}

.mr-50 {
	margin-right: 50px !important;
}

.ml-50 {
	margin-left: 50px !important;
}

.mx-50 {
	margin-left: 50px !important;
	margin-right: 50px !important;
}

.my-50 {
	margin-top: 50px !important;
	margin-bottom: 50px !important;
}

.mt-55 {
	margin-top: 55px !important;
}

.mb-55 {
	margin-bottom: 55px !important;
}

.mr-55 {
	margin-right: 55px !important;
}

.ml-55 {
	margin-left: 55px !important;
}

.mx-55 {
	margin-left: 55px !important;
	margin-right: 55px !important;
}

.my-55 {
	margin-top: 55px !important;
	margin-bottom: 55px !important;
}

.mt-60 {
	margin-top: 60px !important;
}

.mb-60 {
	margin-bottom: 60px !important;
}

.mr-60 {
	margin-right: 60px !important;
}

.ml-60 {
	margin-left: 60px !important;
}

.mx-60 {
	margin-left: 60px !important;
	margin-right: 60px !important;
}

.my-60 {
	margin-top: 60px !important;
	margin-bottom: 60px !important;
}

.mt-65 {
	margin-top: 65px !important;
}

.mb-65 {
	margin-bottom: 65px !important;
}

.mr-65 {
	margin-right: 65px !important;
}

.ml-65 {
	margin-left: 65px !important;
}

.mx-65 {
	margin-left: 65px !important;
	margin-right: 65px !important;
}

.my-65 {
	margin-top: 65px !important;
	margin-bottom: 65px !important;
}

.mt-70 {
	margin-top: 70px !important;
}

.mb-70 {
	margin-bottom: 70px !important;
}

.mr-70 {
	margin-right: 70px !important;
}

.ml-70 {
	margin-left: 70px !important;
}

.mx-70 {
	margin-left: 70px !important;
	margin-right: 70px !important;
}

.my-70 {
	margin-top: 70px !important;
	margin-bottom: 70px !important;
}

.mt-75 {
	margin-top: 75px !important;
}

.mb-75 {
	margin-bottom: 75px !important;
}

.mr-75 {
	margin-right: 75px !important;
}

.ml-75 {
	margin-left: 75px !important;
}

.mx-75 {
	margin-left: 75px !important;
	margin-right: 75px !important;
}

.my-75 {
	margin-top: 75px !important;
	margin-bottom: 75px !important;
}

.mt-80 {
	margin-top: 80px !important;
}

.mb-80 {
	margin-bottom: 80px !important;
}

.mr-80 {
	margin-right: 80px !important;
}

.ml-80 {
	margin-left: 80px !important;
}

.mx-80 {
	margin-left: 80px !important;
	margin-right: 80px !important;
}

.my-80 {
	margin-top: 80px !important;
	margin-bottom: 80px !important;
}

.mt-85 {
	margin-top: 85px !important;
}

.mb-85 {
	margin-bottom: 85px !important;
}

.mr-85 {
	margin-right: 85px !important;
}

.ml-85 {
	margin-left: 85px !important;
}

.mx-85 {
	margin-left: 85px !important;
	margin-right: 85px !important;
}

.my-85 {
	margin-top: 85px !important;
	margin-bottom: 85px !important;
}

.mt-90 {
	margin-top: 90px !important;
}

.mb-90 {
	margin-bottom: 90px !important;
}

.mr-90 {
	margin-right: 90px !important;
}

.ml-90 {
	margin-left: 90px !important;
}

.mx-90 {
	margin-left: 90px !important;
	margin-right: 90px !important;
}

.my-90 {
	margin-top: 90px !important;
	margin-bottom: 90px !important;
}

.mt-95 {
	margin-top: 95px !important;
}

.mb-95 {
	margin-bottom: 95px !important;
}

.mr-95 {
	margin-right: 95px !important;
}

.ml-95 {
	margin-left: 95px !important;
}

.mx-95 {
	margin-left: 95px !important;
	margin-right: 95px !important;
}

.my-95 {
	margin-top: 95px !important;
	margin-bottom: 95px !important;
}

.mt-100 {
	margin-top: 100px !important;
}

.mb-100 {
	margin-bottom: 100px !important;
}

.mr-100 {
	margin-right: 100px !important;
}

.ml-100 {
	margin-left: 100px !important;
}

.mx-100 {
	margin-left: 100px !important;
	margin-right: 100px !important;
}

.my-100 {
	margin-top: 100px !important;
	margin-bottom: 100px !important;
}

.mt-auto {
	margin-top: auto !important;
}

.mb-auto {
	margin-bottom: auto !important;
}

.mr-auto {
	margin-right: auto !important;
}

.ml-auto {
	margin-left: auto !important;
}

.mx-auto {
	margin-left: auto !important;
	margin-right: auto !important;
}

.my-auto {
	margin-top: auto !important;
	margin-bottom: auto !important;
}

/* padding
-------------------------------*/

.p-0 {
	padding: 0px !important;
}

.pt-0 {
	padding-top: 0px !important;
}

.pb-0 {
	padding-bottom: 0px !important;
}

.pr-0 {
	padding-right: 0px !important;
}

.pl-0 {
	padding-left: 0px !important;
}

.px-0 {
	padding-left: 0px !important;
	padding-right: 0px !important;
}

.py-0 {
	padding-top: 0px !important;
	padding-bottom: 0px !important;
}

.p-5 {
	padding: 5px !important;
}

.pt-5 {
	padding-top: 5px !important;
}

.pb-5 {
	padding-bottom: 5px !important;
}

.pr-5 {
	padding-right: 5px !important;
}

.pl-5 {
	padding-left: 5px !important;
}

.px-5 {
	padding-left: 5px !important;
	padding-right: 5px !important;
}

.py-5 {
	padding-top: 5px !important;
	padding-bottom: 5px !important;
}

.p-10 {
	padding: 10px !important;
}

.pt-10 {
	padding-top: 10px !important;
}

.pb-10 {
	padding-bottom: 10px !important;
}

.pr-10 {
	padding-right: 10px !important;
}

.pl-10 {
	padding-left: 10px !important;
}

.px-10 {
	padding-left: 10px !important;
	padding-right: 10px !important;
}

.py-10 {
	padding-top: 10px !important;
	padding-bottom: 10px !important;
}

.p-15 {
	padding: 15px !important;
}

.pt-15 {
	padding-top: 15px !important;
}

.pb-15 {
	padding-bottom: 15px !important;
}

.pr-15 {
	padding-right: 15px !important;
}

.pl-15 {
	padding-left: 15px !important;
}

.px-15 {
	padding-left: 15px !important;
	padding-right: 15px !important;
}

.py-15 {
	padding-top: 15px !important;
	padding-bottom: 15px !important;
}

.p-20 {
	padding: 20px !important;
}

.pt-20 {
	padding-top: 20px !important;
}

.pb-20 {
	padding-bottom: 20px !important;
}

.pr-20 {
	padding-right: 20px !important;
}

.pl-20 {
	padding-left: 20px !important;
}

.px-20 {
	padding-left: 20px !important;
	padding-right: 20px !important;
}

.py-20 {
	padding-top: 20px !important;
	padding-bottom: 20px !important;
}

.p-25 {
	padding: 25px !important;
}

.pt-25 {
	padding-top: 25px !important;
}

.pb-25 {
	padding-bottom: 25px !important;
}

.pr-25 {
	padding-right: 25px !important;
}

.pl-25 {
	padding-left: 25px !important;
}

.px-25 {
	padding-left: 25px !important;
	padding-right: 25px !important;
}

.py-25 {
	padding-top: 25px !important;
	padding-bottom: 25px !important;
}

.p-30 {
	padding: 30px !important;
}

.pt-30 {
	padding-top: 30px !important;
}

.pb-30 {
	padding-bottom: 30px !important;
}

.pr-30 {
	padding-right: 30px !important;
}

.pl-30 {
	padding-left: 30px !important;
}

.px-30 {
	padding-left: 30px !important;
	padding-right: 30px !important;
}

.py-30 {
	padding-top: 30px !important;
	padding-bottom: 30px !important;
}

.p-35 {
	padding: 35px !important;
}

.pt-35 {
	padding-top: 35px !important;
}

.pb-35 {
	padding-bottom: 35px !important;
}

.pr-35 {
	padding-right: 35px !important;
}

.pl-35 {
	padding-left: 35px !important;
}

.px-35 {
	padding-left: 35px !important;
	padding-right: 35px !important;
}

.py-35 {
	padding-top: 35px !important;
	padding-bottom: 35px !important;
}

.p-40 {
	padding: 40px !important;
}

.pt-40 {
	padding-top: 40px !important;
}

.pb-40 {
	padding-bottom: 40px !important;
}

.pr-40 {
	padding-right: 40px !important;
}

.pl-40 {
	padding-left: 40px !important;
}

.px-40 {
	padding-left: 40px !important;
	padding-right: 40px !important;
}

.py-40 {
	padding-top: 40px !important;
	padding-bottom: 40px !important;
}

.p-45 {
	padding: 45px !important;
}

.pt-45 {
	padding-top: 45px !important;
}

.pb-45 {
	padding-bottom: 45px !important;
}

.pr-45 {
	padding-right: 45px !important;
}

.pl-45 {
	padding-left: 45px !important;
}

.px-45 {
	padding-left: 45px !important;
	padding-right: 45px !important;
}

.py-45 {
	padding-top: 45px !important;
	padding-bottom: 45px !important;
}

.p-50 {
	padding: 50px !important;
}

.pt-50 {
	padding-top: 50px !important;
}

.pb-50 {
	padding-bottom: 50px !important;
}

.pr-50 {
	padding-right: 50px !important;
}

.pl-50 {
	padding-left: 50px !important;
}

.px-50 {
	padding-left: 50px !important;
	padding-right: 50px !important;
}

.py-50 {
	padding-top: 50px !important;
	padding-bottom: 50px !important;
}

.p-55 {
	padding: 55px !important;
}

.pt-55 {
	padding-top: 55px !important;
}

.pb-55 {
	padding-bottom: 55px !important;
}

.pr-55 {
	padding-right: 55px !important;
}

.pl-55 {
	padding-left: 55px !important;
}

.px-55 {
	padding-left: 55px !important;
	padding-right: 55px !important;
}

.py-55 {
	padding-top: 55px !important;
	padding-bottom: 55px !important;
}

.p-60 {
	padding: 60px !important;
}

.pt-60 {
	padding-top: 60px !important;
}

.pb-60 {
	padding-bottom: 60px !important;
}

.pr-60 {
	padding-right: 60px !important;
}

.pl-60 {
	padding-left: 60px !important;
}

.px-60 {
	padding-left: 60px !important;
	padding-right: 60px !important;
}

.py-60 {
	padding-top: 60px !important;
	padding-bottom: 60px !important;
}

.p-65 {
	padding: 65px !important;
}

.pt-65 {
	padding-top: 65px !important;
}

.pb-65 {
	padding-bottom: 65px !important;
}

.pr-65 {
	padding-right: 65px !important;
}

.pl-65 {
	padding-left: 65px !important;
}

.px-65 {
	padding-left: 65px !important;
	padding-right: 65px !important;
}

.py-65 {
	padding-top: 65px !important;
	padding-bottom: 65px !important;
}

.p-70 {
	padding: 70px !important;
}

.pt-70 {
	padding-top: 70px !important;
}

.pb-70 {
	padding-bottom: 70px !important;
}

.pr-70 {
	padding-right: 70px !important;
}

.pl-70 {
	padding-left: 70px !important;
}

.px-70 {
	padding-left: 70px !important;
	padding-right: 70px !important;
}

.py-70 {
	padding-top: 70px !important;
	padding-bottom: 70px !important;
}

.p-75 {
	padding: 75px !important;
}

.pt-75 {
	padding-top: 75px !important;
}

.pb-75 {
	padding-bottom: 75px !important;
}

.pr-75 {
	padding-right: 75px !important;
}

.pl-75 {
	padding-left: 75px !important;
}

.px-75 {
	padding-left: 75px !important;
	padding-right: 75px !important;
}

.py-75 {
	padding-top: 75px !important;
	padding-bottom: 75px !important;
}

.p-80 {
	padding: 80px !important;
}

.pt-80 {
	padding-top: 80px !important;
}

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

.pr-80 {
	padding-right: 80px !important;
}

.pl-80 {
	padding-left: 80px !important;
}

.px-80 {
	padding-left: 80px !important;
	padding-right: 80px !important;
}

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

.p-85 {
	padding: 85px !important;
}

.pt-85 {
	padding-top: 85px !important;
}

.pb-85 {
	padding-bottom: 85px !important;
}

.pr-85 {
	padding-right: 85px !important;
}

.pl-85 {
	padding-left: 85px !important;
}

.px-85 {
	padding-left: 85px !important;
	padding-right: 85px !important;
}

.py-85 {
	padding-top: 85px !important;
	padding-bottom: 85px !important;
}

.p-90 {
	padding: 90px !important;
}

.pt-90 {
	padding-top: 90px !important;
}

.pb-90 {
	padding-bottom: 90px !important;
}

.pr-90 {
	padding-right: 90px !important;
}

.pl-90 {
	padding-left: 90px !important;
}

.px-90 {
	padding-left: 90px !important;
	padding-right: 90px !important;
}

.py-90 {
	padding-top: 90px !important;
	padding-bottom: 90px !important;
}

.p-95 {
	padding: 95px !important;
}

.pt-95 {
	padding-top: 95px !important;
}

.pb-95 {
	padding-bottom: 95px !important;
}

.pr-95 {
	padding-right: 95px !important;
}

.pl-95 {
	padding-left: 95px !important;
}

.px-95 {
	padding-left: 95px !important;
	padding-right: 95px !important;
}

.py-95 {
	padding-top: 95px !important;
	padding-bottom: 95px !important;
}

.p-100 {
	padding: 100px !important;
}

.pt-100 {
	padding-top: 100px !important;
}

.pb-100 {
	padding-bottom: 100px !important;
}

.pr-100 {
	padding-right: 100px !important;
}

.pl-100 {
	padding-left: 100px !important;
}

.px-100 {
	padding-left: 100px !important;
	padding-right: 100px !important;
}

.py-100 {
	padding-top: 100px !important;
	padding-bottom: 100px !important;
}

/* gap
-------------------------------*/

/* grid
-------------------------------*/

.grid-1col > *,
.grid-2col > *,
.grid-3col > *,
.grid-4col > * {
	min-width: 0;
}

.grid-1col {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
}

.grid-2col {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}

.grid-3col {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

.grid-4col {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
}

/* Layout */

.l-body {
	width: 100%;
	overflow: clip;
}

.l-body.is-fixed {
	position: fixed;
}

.l-wrapper {
	position: relative;
	width: calc(100% - 50px);
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}

/* Module */

.noscript {
	font-size: 16px;
	line-height: 1.4;
	text-align: center;
	padding: 1em;
	border: 3px solid red;
}

.noscript span {
	color: red;
}

/*
#styleguide
heading-primary

SP 20px / PC 26px
デフォルトは左寄せ
```
<p class="heading-primary">見出し２です</p>
```
*/

/*
#styleguide
heading-secondary

SP 20px / PC 26px
デフォルトは左寄せ
```
<p class="heading-secondary">見出し２です</p>
```
*/

/*
#styleguide
heading-tertiary

SP 20px / PC 26px
デフォルトは左寄せ
```
<p class="heading-tertiary">見出し２です</p>
```
*/

/*
#styleguide
text-base

SP 16px / PC 18px
デフォルトは左寄せ
```
<p class="text-base">ベースフォントですベースフォントですベースフォントですベースフォントですベースフォントですベースフォントですベースフォントですベースフォントですベースフォントですベースフォントですベースフォントです</p>
```
*/

.text-base {
	font-size: 1.6rem;
	line-height: 1.8;
}

.text-base p,
.text-base ol,
.text-base ul {
	margin-bottom: 1.8em;
}

/*
#styleguide
text-lg

SP 16px / PC 18px
デフォルトは左寄せ
```
<p class="text-lg">大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです</p>
```
*/

.text-lg {
	font-size: 2rem;
	line-height: 1.8;
}

.text-lg p,
.text-lg ol,
.text-lg ul {
	margin-bottom: 1.8em;
}

/*
#styleguide
text-sm

SP 16px / PC 18px
デフォルトは左寄せ
```
<p class="text-sm">小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです</p>
```
*/

.text-sm {
	font-size: 1.4rem;
	line-height: 1.8;
}

.text-sm p,
.text-sm ol,
.text-sm ul {
	margin-bottom: 1.8em;
}

/*
#styleguide
text-note

米印の下にテキストの回り込みが内容にします。
```
<p class="text-note">※テキストですテキストです。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。</p>
```
*/

.text-note {
	padding-left: 1em;
	text-indent: -1em;
}

.buttons-wrap {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	gap: 20px;
	margin-top: 30px;
}

.button-1 {
	position: relative;
	display: block;
	width: 100%;
	max-width: 290px;
	height: 73px;
	text-decoration: none;
	font-size: 1.9rem;
	font-weight: 900;
	border: 1px solid #343434;
	border-radius: 4px;
	-webkit-box-shadow: 4px 4px 0px rgba(0, 0, 0, 0.2);
	box-shadow: 4px 4px 0px rgba(0, 0, 0, 0.2);
	background-image: repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0px, rgba(255, 255, 255, 0.1) 2px, rgba(255, 255, 255, 0) 2px, rgba(255, 255, 255, 0) 4px);
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.button-1::before,
.button-1::after {
	content: "";
	position: absolute;
	width: calc(100% - 12px);
	height: calc(100% - 12px);
	pointer-events: none;
}

.button-1::before {
	top: 2px;
	left: 2px;
	background: url(../img/frame_btn_white_long_sp.svg) no-repeat center/100% 100%;
}

.button-1::after {
	bottom: 2px;
	right: 2px;
	background-repeat: no-repeat;
	background-position: center;
	background-size: 100% 100%;
	mix-blend-mode: multiply;
}

.button-1--sp-sm {
	height: 62px;
}

.button-1--pink {
	color: #FFFFFF;
	background-color: #ff84af;
}

.button-1--pink::after {
	background-image: url(../img/frame_btn_pink_long_sp.svg);
}

.button-1--green {
	color: #FFFFFF;
	background-color: #00ac93;
}

.button-1--green::before {
	background-image: url(../img/frame_btn_white_md_sp.svg);
}

.button-1--green::after {
	background-image: url(../img/frame_btn_green_long_sp.svg);
}

.button-1--yellow {
	color: #343434;
	background-color: #ffd375;
}

.button-1--yellow::before {
	background-image: url(../img/frame_btn_white_md_sp.svg);
}

.button-1--yellow::after {
	background-image: url(../img/frame_btn_yellow_long_sp.svg);
}

.button-1 span:not([class]) {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	gap: 20px;
	padding: 0 30px 2px 36px;
	background: url(../img/icon_arrow.svg) no-repeat center right 12px/20px;
}

.button-1 span:not([class])::before {
	position: absolute;
	top: 50%;
	left: 15px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.button-1--icon-phone span:not([class])::before {
	content: "";
	display: inline-block;
	width: 23px;
	height: 33px;
	background: url(../img/icon_phone.svg) no-repeat center center/contain;
}

.button-1--icon-set span:not([class])::before {
	content: "";
	display: inline-block;
	width: 21px;
	height: 26px;
	background: url(../img/icon_set.svg) no-repeat center center/contain;
}

.button-1--icon-document span:not([class])::before {
	content: "";
	display: inline-block;
	width: 21px;
	height: 17px;
	background: url(../img/icon_document.svg) no-repeat center center/contain;
}

/*
#styleguide
button-2

SP 20px / PC 26px
デフォルトは左寄せ
```
<div class="buttons-wrap">
	<a href="#" class="button-2">ボタン</a>
	<button type="button" class="button-2">ボタン</button>
</div>
```
*/

.button-2 {
	position: relative;
	display: inline-block;
	background: #00ac93;
	min-width: 290px;
	color: #FFF;
	border: none;
	text-decoration: none;
	padding: 0.6em 2em;
	-webkit-box-shadow: none;
	box-shadow: none;
	border-radius: 0;
	font: 700 1.5rem "Zen Kaku Gothic New", sans-serif;
	line-height: 1.5;
	border-radius: 10px;
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.button-2::after {
	content: "";
	background: url("../img/icon_arrow_simple.svg") no-repeat center/contain;
	width: 5px;
	height: 8px;
	position: absolute;
	top: 50%;
	right: 16px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.bg-green {
	background: #d1eae1;
}

.bg-pale-pink {
	background: #e9c3b4;
}

.button-head-1 {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 2px;
	width: 100%;
	max-width: 289px;
	margin-bottom: 12px;
}

.button-head-1::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 54px;
	height: 44px;
	background: url(../img/deco_track.svg) no-repeat center center/contain;
}

.button-head-1__balloon {
	width: 54px;
}

.button-head-1__main {
	color: #ff84af;
	font-size: 1.9rem;
	line-height: 1.4736;
	font-weight: 900;
	font-size: clamp(1.4rem, 0.9428571429rem + 1.4285714286vw, 1.5rem);
}

.header-logo {
	position: absolute;
	top: 15px;
	right: 10px;
	width: 120px;
	z-index: 1;
}

.header-logo a {
	display: block;
}

.header-logo img {
	display: block;
	width: 100%;
}

.footer {
	position: relative;
	padding: 45px 0 107px;
	background: #d1eae1;
}

.footer::after {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 100vw;
	height: 100%;
	background: url(../img/bg_footer_sp.svg) no-repeat top center/100%;
}

.footer .l-wrapper {
	position: relative;
	z-index: 10;
}

.footer__logo {
	text-align: center;
}

.footer__logo img {
	height: 25px;
}

.footer__address {
	margin-top: 15px;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
	text-align: center;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

.footer__button {
	margin-top: 43px;
	text-align: center;
}

.footer__sns {
	margin-top: 30px;
	margin-right: 15px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	gap: 27px;
}

.footer__sns__item img {
	height: 33px;
}

.copyright {
	margin-top: 23px;
	display: block;
	font-size: 1rem;
	text-align: center;
	line-height: 1.4;
	width: 100vw;
	position: relative;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}

.fixed-cta {
	position: fixed;
	bottom: 8px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 94.9%;
	z-index: 100;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 5px;
	opacity: 0;
	-webkit-transition: 0.4s;
	transition: 0.4s;
	pointer-events: none;
}

.fixed-cta.is-visible {
	opacity: 1;
	pointer-events: auto;
}

.fixed-cta.is-clear {
	opacity: 0;
	pointer-events: none;
}

.fixed-cta__item {
	position: relative;
	-webkit-box-flex: 1;
	-ms-flex-positive: 1;
	flex-grow: 1;
	height: 60px;
}

.fixed-cta__item::after {
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	width: 100%;
	height: 100%;
	display: block;
	background-image: repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.1) 2px, transparent 2px, transparent 5px);
	pointer-events: none;
}

.fixed-cta__item a {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	gap: 8px;
	height: 100%;
	text-decoration: none;
	font-weight: 900;
	letter-spacing: 0.045em;
	line-height: 1.32;
	border: 1px solid #343434;
	border-radius: 5px;
	color: #FFF;
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.fixed-cta__item a::before,
.fixed-cta__item a::after {
	position: absolute;
	content: "";
	width: calc(100% - 8px);
	height: calc(100% - 8px);
	display: block;
	background-repeat: no-repeat;
	background-position: center;
	background-size: 100% 100%;
	pointer-events: none;
}

.fixed-cta__item a::before {
	top: 2px;
	left: 2px;
	background-image: url(../img/frame_btn_white.svg);
}

.fixed-cta__item a::after {
	bottom: 2px;
	right: 2px;
	mix-blend-mode: multiply;
}

.fixed-cta__item:first-child a {
	background: #ff84af;
}

.fixed-cta__item:first-child a::after {
	background-image: url(../img/frame_btn_pink.svg);
}

.fixed-cta__item:nth-child(2) a {
	background: #00ac93;
}

.fixed-cta__item:nth-child(2) a::after {
	background-image: url(../img/frame_btn_green.svg);
}

.fixed-cta__item:nth-child(3) a {
	background: #ffd375;
	color: #343434;
}

.fixed-cta__item:nth-child(3) a::after {
	background-image: url(../img/frame_btn_yellow.svg);
}

.fixed-cta__icon {
	width: 17px;
	-webkit-transform: translateY(2px);
	transform: translateY(2px);
	position: relative;
	z-index: 20;
}

.fixed-cta__icon--lg {
	width: 20px;
}

.fixed-cta__balloon {
	position: absolute;
	bottom: calc(100% - 7px);
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: -webkit-max-content;
	width: -moz-max-content;
	width: max-content;
	background: #ffff46;
	color: #343434;
	font-size: 1.215rem;
	font-weight: 700;
	letter-spacing: 0.075em;
	border-radius: 5px;
	padding: 4px 14px;
}

.mainvisual {
	position: relative;
	overflow: hidden;
	padding: 0 0 55px;
}

.mainvisual::before {
	position: absolute;
	top: 6%;
	left: 48%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 118.3%;
	height: 94%;
	display: block;
	background: url(../img/bg_mv_sp.svg) no-repeat center/contain;
}

.mainvisual__inner {
	position: relative;
}

.mainvisual__head {
	position: relative;
	padding: 33.2% 0 25.4%;
	opacity: 0;
	-webkit-transform: translate(0, 70px);
	transform: translate(0, 70px);
}

.mainvisual__head.is-visible {
	opacity: 1;
	-webkit-transform: translate(0, 0);
	transform: translate(0, 0);
	-webkit-transition: 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	transition: 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.mainvisual__title {
	position: relative;
	width: 99.6%;
	margin-left: -5%;
	z-index: 1;
}

.mainvisual__title img {
	width: 100%;
}

.mainvisual__image-circle {
	aspect-ratio: 1/1;
	border-radius: 50%;
	overflow: hidden;
}

.mainvisual__image-circle img {
	display: block;
	width: 100%;
}

.mainvisual__image-1 {
	position: absolute;
	top: -5.8vw;
	left: 4.2%;
	width: 50.5%;
}

.mainvisual__image-2 {
	position: absolute;
	top: 20.2vw;
	right: 20.6vw;
	width: 17.1%;
}

.mainvisual__image-3 {
	position: absolute;
	bottom: 0;
	left: 8%;
	width: 31.8%;
}

.mainvisual__image-4 {
	position: absolute;
	bottom: 3.5%;
	right: 13%;
	width: 26%;
}

.mainvisual__image-5 {
	position: relative;
	left: 50.5%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 106%;
	margin-top: -4.5%;
}

.mainvisual__main {
	position: relative;
	margin-top: -2.9%;
	opacity: 0;
	-webkit-transform: translate(0, 70px);
	transform: translate(0, 70px);
}

.mainvisual__main.is-visible {
	opacity: 1;
	-webkit-transform: translate(0, 0);
	transform: translate(0, 0);
	-webkit-transition: 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	transition: 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.mainvisual__main::before {
	position: absolute;
	top: -11.5%;
	left: 47%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 7.5%;
	height: 18.5%;
	display: block;
	background: url(../img/deco_mv_sp.svg) no-repeat center/contain;
}

.mainvisual__main__heading {
	position: relative;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 101.5%;
}

.mainvisual__main__heading img {
	width: 100%;
}

.mainvisual__text {
	position: relative;
	background: rgba(255, 255, 255, 0.7);
	border-radius: 10px;
	padding: 30px 37px 33px 32px;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 2;
	text-align: justify;
	width: 87.2%;
	margin-left: auto;
	margin-right: auto;
	margin-top: -8%;
}

.mainvisual__text::before,
.mainvisual__text::after {
	position: absolute;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 100%;
	height: 27px;
	display: block;
	border: 1.5px solid #343434;
}

.mainvisual__text::before {
	top: 0;
	border-bottom: none;
	border-radius: 10px 10px 0 0;
}

.mainvisual__text::after {
	bottom: 0;
	border-top: none;
	border-radius: 0 0 10px 10px;
}

.mainvisual__text span {
	background: linear-gradient(to top, #ffd0cc 7px, transparent 7px);
}

.voice__heading {
	position: relative;
	text-align: center;
	background: url(../img/deco_voice_head_01.svg) no-repeat center/auto 100%;
	padding: 33px 0 43px;
	margin-bottom: 24px;
}

.voice__heading::before {
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 100vw;
	height: 100%;
	display: block;
	background: url(../img/deco_voice_head_02_sp.svg) no-repeat center/425px auto;
}

.voice__heading__en {
	display: block;
	font: 700 4.1rem "Montserrat", sans-serif;
	letter-spacing: 0.05em;
	margin-bottom: 4px;
}

.voice__heading__jp {
	font-size: 2.8rem;
	font-weight: 900;
	letter-spacing: 0.18em;
	line-height: 1.39;
	background: url(../img/deco_voice_head_03.svg) no-repeat center bottom -2px/223px auto;
}

.voice__item {
	position: relative;
	padding-bottom: 62px;
}

.voice__item:first-child {
	z-index: 3;
}

.voice__item:not(:last-child) {
	margin-bottom: 55px;
}

.voice__item::before {
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 100vw;
	height: 100%;
	display: block;
	background: url(../img/bg_voice_01_sp.svg) no-repeat center top 10px/114% auto;
	z-index: -1;
}

.voice__item::after {
	position: absolute;
	bottom: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 100%;
	height: 100%;
	display: block;
	background: url(../img/border_voice_horizontal.svg) no-repeat center bottom/100% auto;
}

.voice__item--yellow::before {
	background: url(../img/bg_voice_02_sp.svg) no-repeat center top 8px/121% auto;
}

.voice__item--yellow .voice__text {
	background: #fff6e3;
}

.voice__item--yellow .voice__text span {
	background: linear-gradient(to top, #ffe985 10px, transparent 10px);
}

.voice__item__heading {
	position: relative;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 377px;
	margin-bottom: 12px;
}

.voice__item__heading img {
	display: block;
	width: 100%;
}

.voice__lead {
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 2;
	text-align: justify;
	margin-bottom: 45px;
}

.voice__main__item {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	gap: 18px;
}

.voice__main__item:nth-child(even) {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}

.voice__main__item:nth-child(even) .voice__text {
	background: #FFF;
}

.voice__main__item:nth-child(even) .voice__text::before {
	right: auto;
	left: calc(100% - 10px);
	-webkit-transform: rotate(20deg);
	transform: rotate(20deg);
}

.voice__main__item:not(:last-child) {
	margin-bottom: 30px;
}

.voice__main__item::before {
	position: absolute;
	content: "";
	display: block;
	z-index: -1;
}

.voice__main__item--01::before {
	bottom: 2px;
	left: 25px;
	width: 69px;
	height: 106px;
	background: url(../img/deco_voice_01.svg) no-repeat left top/55px auto, url(../img/deco_voice_02.svg) no-repeat right bottom/57px auto;
}

.voice__main__item--02::before {
	bottom: -10px;
	right: 10px;
	width: 58px;
	height: 35px;
	background: url(../img/deco_voice_03.svg) no-repeat center/contain;
}

.voice__main__item--03::before {
	bottom: -17px;
	left: 30px;
	width: 50px;
	height: 48px;
	background: url(../img/deco_voice_04.svg) no-repeat center/contain;
}

.voice__main__item--04::before {
	bottom: -15px;
	right: 40px;
	width: 44px;
	height: 56px;
	background: url(../img/deco_voice_05.svg) no-repeat center/contain;
}

.voice__main__item--05::before {
	bottom: -10px;
	left: 5px;
	width: 90px;
	height: 48px;
	background: url(../img/deco_voice_06.svg) no-repeat left top/37px auto, url(../img/deco_voice_07.svg) no-repeat right bottom/39px auto;
}

.voice__main__item--06::before {
	bottom: -18px;
	left: 40px;
	width: 51px;
	height: 61px;
	background: url(../img/deco_voice_08.svg) no-repeat center/contain;
}

.voice__main__item--07::before {
	bottom: -18px;
	right: 48px;
	width: 43px;
	height: 38px;
	background: url(../img/deco_voice_09.svg) no-repeat center/contain;
}

.voice__main__item--08::before {
	bottom: -10px;
	left: 28px;
	width: 56px;
	height: 54px;
	background: url(../img/deco_voice_10.svg) no-repeat center/contain;
}

.voice__main__item--09::before {
	bottom: -10px;
	right: 30px;
	width: 57px;
	height: 48px;
	background: url(../img/deco_voice_11.svg) no-repeat center/contain;
}

.voice__main__item--10::before {
	bottom: -18px;
	left: 45px;
	width: 41px;
	height: 62px;
	background: url(../img/deco_voice_12.svg) no-repeat center/contain;
}

.voice__main__item--11::before {
	bottom: -35px;
	right: 50px;
	width: 40px;
	height: 56px;
	background: url(../img/deco_voice_13.svg) no-repeat center/contain;
}

.voice__image {
	width: 86px;
	-ms-flex-negative: 0;
	flex-shrink: 0;
}

.voice__image img {
	display: block;
}

.voice__text {
	position: relative;
	-webkit-box-flex: 1;
	-ms-flex-positive: 1;
	flex-grow: 1;
	background: #fbf3f0;
	border-radius: 10px;
	-webkit-filter: drop-shadow(2px 2px 0 rgb(52, 52, 52));
	filter: drop-shadow(2px 2px 0 rgb(52, 52, 52));
	font-size: 1.5rem;
	line-height: 1.67;
	padding: 15px 20px 20px;
	text-align: justify;
}

.voice__text::before {
	position: absolute;
	top: 30px;
	right: calc(100% - 10px);
	content: "";
	width: 24px;
	height: 7px;
	display: block;
	background: inherit;
	-webkit-transform: rotate(-20deg);
	transform: rotate(-20deg);
	z-index: -1;
}

.voice__text span {
	background: linear-gradient(to top, #ffd0cc 10px, transparent 10px);
}

.about-wrap {
	overflow: hidden;
}

.about {
	padding: 70px 0 156px;
}

.about__head {
	position: relative;
	margin-bottom: 65px;
}

.about__head::before {
	position: absolute;
	top: -40px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 134.4%;
	height: 160vw;
	display: block;
	background: url(../img/deco_about_head_03_sp.svg) no-repeat center/contain;
}

.about__heading {
	position: relative;
	font-size: 2.562rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1.52;
	text-align: center;
	padding: 54px 0 0;
	margin-bottom: 57px;
}

.about__heading::before {
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 255px;
	height: 410px;
	display: block;
	background: url(../img/deco_about_head_01.svg) no-repeat center/contain;
	z-index: -1;
}

.about__heading::after {
	position: absolute;
	bottom: -20px;
	right: calc(50% + 58px);
	content: "";
	width: 113px;
	height: 70px;
	display: block;
	background: url(../img/txt_about_head.svg) no-repeat center/contain;
}

.about__heading span {
	background: url(../img/deco_about_head_02.svg) no-repeat center bottom/110px auto;
	padding-bottom: 5px;
}

.about__lead {
	position: relative;
	background: rgba(255, 255, 255, 0.7);
	border-radius: 10px;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 2;
	text-align: justify;
	padding: 30px 38px 30px 32px;
}

.about__lead::before,
.about__lead::after {
	position: absolute;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 100%;
	height: 27px;
	display: block;
	border: 2px solid rgba(52, 52, 52, 0.85);
}

.about__lead::before {
	top: 0;
	border-bottom: none;
	border-radius: 10px 10px 0 0;
}

.about__lead::after {
	bottom: 0;
	border-top: none;
	border-radius: 0 0 10px 10px;
}

.about__lead span {
	background: linear-gradient(to top, #ffd0cc 8px, transparent 8px);
	padding: 0 0.5em;
}

.about__contents {
	position: relative;
}

.about__contents::before {
	position: absolute;
	top: 110px;
	left: 57%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 121.2%;
	height: 437vw;
	display: block;
	background: url(../img/deco_about_contents_sp.svg) no-repeat center/contain;
}

.about__item {
	position: relative;
}

.about__item::before {
	position: absolute;
	top: 41%;
	left: 52%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	content: "";
	width: 69px;
	height: 69px;
	display: block;
	background: url(../img/deco_about_connect.svg) no-repeat center/contain;
	z-index: 1;
}

.about__item:not(:last-child) {
	padding-bottom: 50px;
	margin-bottom: 30px;
}

.about__item:not(:last-child)::after {
	position: absolute;
	top: calc(100% - 23px);
	left: 0;
	content: "";
	width: 100%;
	height: 1px;
	display: block;
	border-bottom: 1px dashed #343434;
	-webkit-transform: rotate(-7deg);
	transform: rotate(-7deg);
}

.about__item:nth-child(even)::before {
	-webkit-transform: translate(-50%, -50%) scale(-1, 1);
	transform: translate(-50%, -50%) scale(-1, 1);
}

.about__item:nth-child(even)::after {
	-webkit-transform: rotate(7deg);
	transform: rotate(7deg);
}

.about__item:nth-child(even) .about__before__image {
	margin-left: 0;
	margin-right: auto;
}

.about__item:nth-child(even) .about__before__text {
	right: auto;
}

.about__item:nth-child(even) .about__after__image {
	margin-right: 0;
	margin-left: auto;
}

.about__item:nth-child(even) .about__after__text {
	left: auto;
}

.about__item--01 .about__before__text {
	background-image: url(../img/frame_about_01_sp.svg);
}

.about__item--01 .about__before__text::before {
	position: absolute;
	top: 0;
	left: 25px;
	content: "";
	width: 27px;
	height: 45px;
	display: block;
	background: url(../img/deco_about_01.svg) no-repeat center/contain;
}

.about__item--01 .about__after__text::before {
	background-image: url(../img/txt_check_01.svg);
}

.about__item--02 .about__before__text {
	top: 50%;
	left: calc(50% - 20px);
	padding: 40px;
	background-image: url(../img/frame_about_02_sp.svg);
}

.about__item--02 .about__before__text::before {
	position: absolute;
	top: -40px;
	right: 0;
	content: "";
	width: 46px;
	height: 41px;
	display: block;
	background: url(../img/deco_about_02.svg) no-repeat center/contain;
}

.about__item--02 .about__after__text {
	right: calc(50% - 20px);
	padding-bottom: 0;
}

.about__item--02 .about__after__text::before {
	top: -2px;
	right: auto;
	left: -5px;
	background-image: url(../img/txt_check_02.svg);
}

.about__item--03 .about__before__text {
	top: 47%;
	right: calc(50% - 15px);
	background-image: url(../img/frame_about_03_sp.svg);
}

.about__item--03 .about__before__text::before {
	position: absolute;
	top: -22px;
	left: -15px;
	content: "";
	width: 59px;
	height: 54px;
	display: block;
	background: url(../img/deco_about_03.svg) no-repeat center/contain;
}

.about__item--03 .about__after__text {
	right: calc(50% - 20px);
	padding-bottom: 0;
}

.about__item--03 .about__after__text::before {
	top: -3px;
	background-image: url(../img/txt_check_03.svg);
}

.about__before {
	position: relative;
}

.about__before__image {
	width: 51%;
	margin-left: auto;
	border-radius: 10px;
	overflow: hidden;
}

.about__before__image img {
	display: block;
	width: 100%;
}

.about__before__text {
	position: absolute;
	top: 55%;
	right: calc(50% - 35px);
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	font-size: 1.7rem;
	font-weight: 700;
	line-height: 1.7;
	letter-spacing: 0.05em;
	text-align: center;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	padding: 40px 50px 45px 40px;
	width: -webkit-max-content;
	width: -moz-max-content;
	width: max-content;
}

.about__after {
	position: relative;
	margin-top: 52px;
}

.about__after__image {
	width: 62.9%;
	border-radius: 10px;
	overflow: hidden;
}

.about__after__image img {
	display: block;
	width: 100%;
}

.about__after__text {
	position: absolute;
	top: 50%;
	left: calc(50% - 15px);
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	font-size: 1.8rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.61;
	text-align: center;
	background: #e9c3b4;
	aspect-ratio: 1/1;
	width: 188px;
	border-radius: 50%;
	padding-bottom: 15px;
}

.about__after__text::before {
	position: absolute;
	top: -13px;
	right: 3px;
	content: "";
	width: 46px;
	height: 46px;
	display: block;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
}

.about__message {
	position: relative;
	font-size: 2.396rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 2.09;
	text-align: center;
	background: #FFF;
	aspect-ratio: 1/1;
	border-radius: 50%;
	width: 343px;
	max-width: 100%;
	padding: 80px 0 0;
	margin: 108px auto 0;
	z-index: 1;
}

.about__message::before {
	position: absolute;
	bottom: calc(100% - 30px);
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 168px;
	height: 116px;
	display: block;
	background: url(../img/bg_about_message.svg) no-repeat center/contain;
	z-index: -1;
}

.about__message::after {
	position: absolute;
	top: 10px;
	left: 47%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 81px;
	height: 66px;
	display: block;
	background: url(../img/deco_track.svg) no-repeat center top/contain;
}

.about__message span {
	background: url(../img/deco_about_message.svg) no-repeat center bottom/100% auto;
	padding-bottom: 12px;
}

.point-wrap {
	position: relative;
	padding: 0 0 170px;
}

.point-wrap::before {
	content: "";
	background: url("../img/img_head_point.svg") no-repeat center bottom/contain;
	width: 184px;
	height: 58px;
	position: absolute;
	bottom: calc(100% - 1px);
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	z-index: 10;
}

.point-wrap::after {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 100vw;
	height: 100%;
	background: url(../img/bg_point_01_sp.svg) no-repeat top center/100%, url(../img/bg_point_02_sp.svg) no-repeat bottom 82px center/100%;
}

.point-item-wrap {
	position: relative;
	z-index: 1;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin-top: 37px;
}

.point-item {
	position: relative;
}

.point-item--02 {
	margin-top: 49px;
}

.point-item--03 {
	margin-top: 50px;
}

.point-item--04 {
	margin-top: 45px;
}

.point-item__main {
	position: relative;
	padding: 0 28px 18px 0;
}

.point-item__main::before {
	position: absolute;
	bottom: 0;
	left: 0;
	content: "";
	width: 100%;
	height: calc(100% - 15px);
	display: block;
	border-right: 1px dashed #343434;
	border-bottom: 1px dashed #343434;
	border-radius: 0 0 10px 0;
	pointer-events: none;
}

.point-item__head {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	gap: 14px;
	margin-bottom: 24px;
}

.point-item__head__order {
	-ms-flex-negative: 0;
	flex-shrink: 0;
	width: 71px;
	padding-top: 7px;
}

.point-item__head__main {
	font-size: 2rem;
	font-weight: 700;
	line-height: 2;
	letter-spacing: 0.06em;
	text-decoration: underline;
	text-underline-offset: 0.5em;
	text-decoration-color: #343434;
	text-decoration-thickness: 2px;
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
}

.point-item__text {
	font-size: 1.5rem;
	line-height: 2;
	text-align: justify;
}

.point-item__image-sub {
	position: relative;
}

.point-item--01 .point-item__image-sub {
	max-width: 328px;
	margin: 24px auto 0;
}

.point-item--02 .point-item__image-sub {
	max-width: 272px;
	margin: -12px auto 0;
}

.point-item--02 .point-item__image-sub img {
	margin-left: 18px;
}

.point-item--01 .point-item__image-main {
	max-width: 328px;
	margin: -14px auto 0;
}

.point-item--01 .point-item__image-main img {
	margin-left: 5px;
}

.point-item__images {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	gap: 20px;
	margin-top: 36px;
}

.point-item__images__item {
	overflow: hidden;
	border-radius: 10px;
}

.point-item__images__item img {
	display: block;
}

.point-item__image {
	overflow: hidden;
	margin-top: 26px;
	border-radius: 10px;
}

.point-cta {
	position: relative;
	z-index: 1;
	max-width: 290px;
	margin: 55px auto 0;
}

.point-set {
	position: relative;
	z-index: 1;
	margin-top: 60px;
}

.point-set__bg {
	border-radius: 12px;
	padding: 6px;
	background: repeating-linear-gradient(-45deg, #00ac93 0, #00ac93 1.5px, #ffffff 1.5px, #ffffff 3px);
}

.point-set__inner {
	background: #ffffff;
	border-radius: 6px;
	padding: 26px 28px 58px;
}

.point-set__head {
	margin-bottom: 24px;
	padding-bottom: 14px;
	color: #00ac93;
	border-bottom: 2px solid #00ac93;
}

.point-set__head__sub {
	position: relative;
	display: block;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	margin: 0 auto 12px;
	padding: 0 23px;
	font-size: 1.5rem;
	line-height: 1.4333;
	font-weight: 700;
	text-align: center;
}

.point-set__head__sub::before,
.point-set__head__sub::after {
	content: "";
	position: absolute;
	bottom: 0;
	width: 1px;
	height: 100%;
	border-left: 1px dashed #00ac93;
}

.point-set__head__sub::before {
	left: 0;
	-webkit-transform: rotate(-20deg);
	transform: rotate(-20deg);
}

.point-set__head__sub::after {
	right: 0;
	-webkit-transform: rotate(20deg);
	transform: rotate(20deg);
}

.point-set__head__main {
	display: block;
	font-size: 3.35rem;
	line-height: 1.3134;
	font-weight: 900;
	text-align: center;
}

.point-set__text {
	font-size: 1.5rem;
	line-height: 2;
	font-weight: 700;
	text-align: justify;
}

.point-set__list {
	margin-top: 20px;
}

.point-set__list li {
	font-size: 1.3rem;
	line-height: 1.6923;
	position: relative;
	padding-left: 0.9em;
}

.point-set__list li::before {
	content: "●";
	position: absolute;
	top: 1.5em;
	left: 0.2em;
	display: block;
	line-height: 1;
	color: #00ac93;
	font-size: 50%;
}

.point-set__image-wrap {
	margin-bottom: 18px;
}

.point-set__image img {
	display: block;
}

.point-set__note {
	display: block;
	margin-top: 2px;
	font-size: 0.85rem;
	text-align: right;
}

.point-set__button {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin-top: -32px;
}

.flow-wrap {
	position: relative;
	padding: 0 0 125px;
}

.flow-wrap::before {
	content: "";
	background: url("../img/img_head_flow.svg") no-repeat center bottom/contain;
	width: 184px;
	height: 58px;
	position: absolute;
	bottom: calc(100% - 1px);
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	z-index: 10;
}

.flow-wrap::after {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 100vw;
	height: 100%;
	background: url(../img/bg_flow_sp.svg) no-repeat top center/100%;
}

.flow {
	position: relative;
	z-index: 1;
	margin-top: 80px;
}

.flow-item {
	position: relative;
	background: #FFFFFF;
	padding: 35px 30px 30px;
	border-radius: 10px;
	border: 1.5px solid #343434;
}

.flow-item:not(:last-child) {
	margin-bottom: 85px;
}

.flow-item:not(:last-child)::after {
	content: "";
	position: absolute;
	top: calc(100% - 5px);
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 99px;
	height: 45px;
	background: url(../img/icon_arrow_flow.svg) no-repeat center center/contain;
}

.flow-item::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: calc(100% + 4px);
	height: calc(100% - 54px);
	background: #FFFFFF;
}

.flow-item__number {
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	width: 74px;
	height: 74px;
	border-radius: 50%;
	margin: -2px auto 0;
	padding-bottom: 5px;
	background: #FFFFFF;
	border: 1.5px solid #343434;
}

.flow-item__number::after {
	content: "";
	position: absolute;
	bottom: -2px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: calc(100% + 4px);
	height: 50%;
	background: #FFFFFF;
}

.flow-item__number img {
	position: relative;
	z-index: 1;
	display: block;
	width: 31px;
}

.flow-item__inner {
	position: relative;
	z-index: 1;
}

.flow-item__heading {
	margin-bottom: 8px;
	color: #d8a098;
	font-size: 2.25rem;
	line-height: 1.3333;
	font-weight: 900;
	text-align: center;
}

.flow-item__text {
	font-size: 1.5rem;
	line-height: 2;
	text-align: justify;
}

.flow-item__detail {
	margin-top: 18px;
	margin-bottom: 15px;
	padding-top: 18px;
	border-top: 1px dashed #343434;
}

.flow-item__detail__heading {
	margin-bottom: 10px;
	font-size: 1.9rem;
	line-height: 1.3684;
	font-weight: 700;
	text-align: center;
}

.flow-item__detail__text {
	font-size: 1.5rem;
	line-height: 2;
	text-align: justify;
}

.flow-item__button {
	position: relative;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: calc(100% + 12px);
	margin-top: 34px;
	max-width: 289px;
}

.page-head {
	position: relative;
	z-index: 1;
	text-align: center;
}

.page-head__badge {
	display: block;
	font: 500 1.4rem "Montserrat", sans-serif;
	letter-spacing: 0.05em;
	text-align: center;
}

.page-head__lead {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	margin: 29px auto 0;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	padding: 5px 16px 4px;
	background: #FFF;
	font-size: 1.8rem;
	line-height: 1.2;
	letter-spacing: 0.1em;
	border-radius: 10px;
	min-width: 198px;
}

.page-head__lead--multiple {
	padding: 0;
}

.page-head__lead--multiple span {
	padding: 5px 16px 4px;
	border-radius: 10px;
}

.page-head__lead--green {
	background: #d1eae1;
}

.page-head__lead--green span {
	background: #d1eae1;
}

.page-head__lead::after {
	content: "";
	position: absolute;
	top: 100%;
	right: 13%;
	width: 14px;
	height: 23px;
	background: url(../img/line_pagetitle.svg) no-repeat center center/contain;
}

.page-head__title {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin: 17px 0 0;
	font-weight: 900;
	font-size: 2.8rem;
	line-height: 1.3928;
	letter-spacing: 0.12em;
}

.page-head__title--sm {
	margin-top: 22px;
	font-size: 2.6rem;
}

.page-head__title span {
	position: relative;
}

.page-head__title span::before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	z-index: -1;
	width: 103%;
	height: 16px;
	background: url(../img/deco_pagehead_white.svg) no-repeat center center/contain;
}

.page-head__title--pale-pink span::before {
	background: url(../img/deco_pagehead_palepink.svg) no-repeat center center/contain;
}

.page-head__title--line-faq span::before {
	background: url(../img/deco_pagehead_white2.svg) no-repeat center center/contain;
}

.faq-wrap {
	position: relative;
	background: #d1eae1;
	padding-bottom: 55px;
}

.faq-wrap::before {
	content: "";
	background: url("../img/img_head_faq.svg") no-repeat center/contain;
	width: 184px;
	height: 60px;
	position: absolute;
	bottom: 100%;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	z-index: 10;
}

.faq-wrap::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../img/bg_faq_sp_1.png) no-repeat top center/100% auto, url(../img/bg_faq_sp_2.png) no-repeat bottom center/100% auto;
}

.faq-wrap .page-head + .faq {
	margin-top: 24px;
}

.faq {
	position: relative;
	z-index: 10;
	margin-bottom: 10px;
}

.faq__question button {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	gap: 11px;
	width: 100%;
	padding: 18px 2px 18px;
	background: transparent;
	border: 0;
	border-bottom: 1.5px solid #343434;
	text-align: left;
}

.faq .js-accordion-btn[aria-expanded=true] .faq__icon {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.faq__text {
	-webkit-box-flex: 1;
	-ms-flex: 1;
	flex: 1;
	font-size: 1.7rem;
	font-weight: 700;
	line-height: 1.647;
	text-align: left;
}

.faq__label {
	display: block;
	margin-top: 2px;
	color: #00ac93;
	font: 500 1.9rem "Montserrat", sans-serif;
	letter-spacing: 0.05em;
}

.faq__icon {
	width: 18.5px;
	margin-top: auto;
	margin-bottom: auto;
	margin-left: auto;
	-ms-flex-negative: 0;
	flex-shrink: 0;
	-webkit-transition: -webkit-transform 0.3s ease;
	transition: -webkit-transform 0.3s ease;
	transition: transform 0.3s ease;
	transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}

.faq__answer {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 14px;
	padding: 15px 0 0 4px;
	font-size: 1.5rem;
	letter-spacing: 0.1em;
	line-height: 2;
}

.cv {
	padding: 74px 0 57px;
	background: #fff;
}

.cv__top {
	display: grid;
	justify-items: center;
}

.cv__bottom {
	margin-top: 35px;
	display: grid;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	gap: 30px;
}

.cv__item {
	display: grid;
	gap: 12px;
}

.cv__title {
	display: inline-block;
	text-align: center;
}

.cv__title span {
	position: relative;
	padding: 0px 20px;
	font: 700 1.6rem "Zen Kaku Gothic New", sans-serif;
}

.cv__title span::before,
.cv__title span::after {
	content: "";
	position: absolute;
	bottom: 11px;
	width: 24px;
	height: 1px;
	background-image: -webkit-gradient(linear, left top, right top, color-stop(50%, #FFF), color-stop(0, #343434));
	background-image: linear-gradient(to right, #FFF 50%, #343434 0);
	background-size: 6px 1px;
	background-repeat: repeat-x;
}

.cv__title span::before {
	left: -7px;
	-webkit-transform: rotate(-108deg);
	transform: rotate(-108deg);
}

.cv__title span::after {
	right: -7px;
	-webkit-transform: rotate(108deg);
	transform: rotate(108deg);
}

.cv__tel {
	position: relative;
	margin-top: 48px;
	padding: 26px 16px 34px;
	border: 1.5px solid rgba(52, 52, 52, 0.85);
	border-radius: 10px;
	text-align: center;
}

.cv__tel::before,
.cv__tel::after {
	content: "";
	background: #FFF;
	width: 5px;
	height: 70%;
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.cv__tel::before {
	left: -4px;
}

.cv__tel::after {
	right: -4px;
}

.cv__lead {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.5rem;
	letter-spacing: 0.03em;
	line-height: 1.6667;
}

.cv__number {
	margin-top: 10px;
	font: 600 3rem "Montserrat", sans-serif;
	letter-spacing: 0.05em;
}

.cv__number a {
	text-decoration: none;
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.cv__note {
	margin-top: 8px;
	font-size: 1.1rem;
	font-family: "Zen Kaku Gothic New", sans-serif;
	letter-spacing: 0.04em;
}

.scrollin {
	opacity: 0;
	-webkit-transform: translate(0, 70px);
	transform: translate(0, 70px);
}

.scrollin.is-visible {
	opacity: 1;
	-webkit-transform: translate(0, 0);
	transform: translate(0, 0);
	-webkit-transition: 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	transition: 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/*
#styleguide
タブ
```
<div class="js-accordion">
	<button type="button" aria-expanded="false" aria-controls="【コンテンツとボタンを紐付けするid名】" class="js-accordion-btn">トリガーボタンテキスト <img src="img/icon_arrow_red.svg" alt="開く" class="js-accordion-icon"></button>
	<div id="【コンテンツとボタンを紐付けするid名】" class="js-accordion-content" aria-hidden="true">
		ここが開閉により表示が変わるテキストです。
	</div>
</div>
```
*/

.js-accordion-content {
	display: none;
}

@media (hover: hover) {

.button-1--pink:hover {
	background-color: #ff639d;
}

.button-1--green:hover {
	background-color: #00967b;
}

.button-1--yellow:hover {
	background-color: #ffc559;
}

.button-1:hover {
	-webkit-box-shadow: 0 0 0 rgba(0, 0, 0, 0.2);
	box-shadow: 0 0 0 rgba(0, 0, 0, 0.2);
}

.button-2:hover {
	background: #00967b;
}

.fixed-cta__item:first-child a:hover {
	background: #ff639d;
}

.fixed-cta__item:nth-child(2) a:hover {
	background: #00967b;
}

.fixed-cta__item:nth-child(3) a:hover {
	background: #ffc559;
}

.cv__number a:hover {
	opacity: 0.6;
}

}

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

html { /* pc */
	min-width: 920px;
}

.text-left-pc { /* pc */
	text-align: left;
}

.text-center-pc { /* pc */
	text-align: center;
}

.text-right-pc { /* pc */
	text-align: right;
}

.l-wrapper { /* pc */
	max-width: 1200px;
}

.l-wrapper--sm { /* pc */
	max-width: 996px;
}

.button-1 { /* pc */
	max-width: 792px;
	height: 116px;
	border-width: 2px;
	border-radius: 10px;
	font-size: 3.2rem;
	letter-spacing: 0.04em;
	-webkit-box-shadow: 8px 8px 0px rgba(0, 0, 0, 0.2);
	box-shadow: 8px 8px 0px rgba(0, 0, 0, 0.2);
	background-image: repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0px, rgba(255, 255, 255, 0.1) 3px, rgba(255, 255, 255, 0) 3px, rgba(255, 255, 255, 0) 7px);
}

.cv__item .button-1 {
	font-size: clamp(20px, 5vw, 32px);
}

.button-1::before,
.button-1::after { /* pc */
	width: calc(100% - 22px);
	height: calc(100% - 22px);
}

.button-1::before { /* pc */
	top: 5px;
	left: 5px;
	background-image: url(../img/frame_btn_white_long_pc.svg);
}

.button-1::after { /* pc */
	bottom: 3px;
	right: 3px;
	background-image: url(../img/frame_btn_pink_long_pc.svg);
}

.button-1--pink::after { /* pc */
	background-image: url(../img/frame_btn_pink_long_pc.svg);
}

.button-1--green::before { /* pc */
	top: 4px;
	left: 4px;
	background-image: url(../img/frame_btn_white_md_pc.svg);
}

.button-1--green::after { /* pc */
	background-image: url(../img/frame_btn_green_long_pc.svg);
}

.button-1--yellow::before { /* pc */
	top: 4px;
	left: 4px;
	background-image: url(../img/frame_btn_white_md_pc.svg);
}

.button-1--yellow::after { /* pc */
	background-image: url(../img/frame_btn_yellow_long_pc.svg);
}

.button-1 span:not([class]) { /* pc */
	padding: 0 92px 2px 40px;
	background: url(../img/icon_arrow.svg) no-repeat center right 40px/40px;
}

.button-1 span:not([class])::before { /* pc */
	position: relative;
	top: 0;
	left: 0;
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

.button-1--icon-phone span:not([class])::before { /* pc */
	width: 38px;
	height: 56px;
}

.button-1--icon-set span:not([class])::before { /* pc */
	width: 42px;
	height: 51px;
}

.button-1--icon-document span:not([class])::before { /* pc */
	width: 42px;
	height: 34px;
}

.button-2 { /* pc */
	font-size: 2.2rem;
	padding: 1.2em 3em;
	width: 636px;
	max-width: 100%;
}

.button-2::after { /* pc */
	width: 8px;
	height: 14px;
	right: 35px;
}

.button-head-1 { /* pc */
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	gap: 0px;
	margin-bottom: 20px;
	max-width: 792px;
	padding-right: 140px;
}

.button-head-1::after { /* pc */
	top: 30px;
	right: 12px;
	width: 126px;
	height: 102px;
}

.button-head-1--2::after { /* pc */
}

.button-head-1__balloon { /* pc */
	width: 133px;
}

.button-head-1__main { /* pc */
	font-size: 3rem;
	line-height: 1.6666;
	text-align: center;
}

.header-logo { /* pc */
	top: 22px;
	right: 5px;
	width: clamp(120px, 16.3%, 200px);
}

.footer::after { /* pc */
	width: 1920px;
	background: url(../img/bg_footer_pc.svg) no-repeat top center/100%;
}

.footer { /* pc */
	padding: 66px 0 30px;
}

.footer__logo img { /* pc */
	height: 50px;
}

.footer__address { /* pc */
	margin-top: 32px;
	font-size: 2rem;
}

.footer__sns { /* pc */
	margin-top: 49px;
	margin-right: 0;
	gap: 43px;
}

.footer__sns__item img { /* pc */
	height: 48px;
}

.copyright { /* pc */
	margin-top: 103px;
	text-align: left;
	font-size: 1.3rem;
	font-family: "Montserrat", sans-serif;
	font-weight: 300;
	letter-spacing: 0.06em;
	width: 100%;
}

.fixed-cta { /* pc */
	left: auto;
	right: 10px;
	bottom: 10px;
	-webkit-transform: translateX(0);
	transform: translateX(0);
	max-width: 518px;
	gap: 7px;
}

.fixed-cta__item { /* pc */
	height: 84px;
}

.fixed-cta__item a { /* pc */
	gap: 12px;
	font-size: 1.96rem;
	line-height: 1.32;
}

.fixed-cta__icon { /* pc */
	width: 23px;
}

.fixed-cta__icon--lg { /* pc */
	width: 26px;
}

.fixed-cta__balloon { /* pc */
	font-size: 1.701rem;
	padding: 5px 20px;
}

.mainvisual { /* pc */
	padding: 0 0 20px;
}

.mainvisual::before { /* pc */
	top: auto;
	bottom: 10px;
	left: 50%;
	width: 1920px;
	height: 108%;
	background: url(../img/bg_mv_pc.svg) no-repeat center bottom/contain;
}

.mainvisual__inner { /* pc */
	width: 89.956%;
	max-width: 1227px;
	margin-left: auto;
	margin-right: auto;
}

.mainvisual__head { /* pc */
	padding: 2.9% 0 0;
}

.mainvisual__title { /* pc */
	left: 47%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 57%;
	margin-left: 0;
}

.mainvisual__image-1 { /* pc */
	top: 4%;
	left: -10%;
	width: 32.8%;
}

.mainvisual__image-2 { /* pc */
	top: auto;
	bottom: 0;
	right: -5%;
	width: 10.8%;
}

.mainvisual__image-3 { /* pc */
	bottom: 4%;
	left: auto;
	right: 10%;
	width: 13.7%;
}

.mainvisual__image-4 { /* pc */
	bottom: auto;
	top: 29%;
	right: -1%;
	width: 12.6%;
}

.mainvisual__image-5 { /* pc */
	position: static;
	-webkit-transform: translateX(-5px);
	transform: translateX(-5px);
	width: 100%;
	margin-top: -35px;
}

.mainvisual__main { /* pc */
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin-top: 33px;
}

.mainvisual__main::before { /* pc */
	top: -4%;
	left: 18.5%;
	width: 140px;
	height: 54px;
	background-image: url(../img/deco_mv_pc.svg);
}

.mainvisual__main__head { /* pc */
	width: 55.4%;
}

.mainvisual__text { /* pc */
	border-radius: 20px;
	padding: 40px 4%;
	font-size: clamp(1.6rem, 0.4848484848rem + 1.2121212121vw, 2rem);
	width: 43.2%;
	margin: 0 15px 0 0;
}

.mainvisual__text::before,
.mainvisual__text::after { /* pc */
	height: 54px;
	border-width: 2px;
}

.mainvisual__text::before { /* pc */
	border-radius: 20px 20px 0 0;
}

.mainvisual__text::after { /* pc */
	border-radius: 0 0 20px 20px;
}

.voice { /* pc */
	padding: 60px 0 0;
}

.voice__heading { /* pc */
	padding: 38px 0 54px;
	margin-bottom: 77px;
}

.voice__heading::before { /* pc */
	top: -90px;
	left: 53%;
	width: 1150px;
	height: calc(100% + 60px + 77px);
	background: url(../img/deco_voice_head_02_pc.svg) no-repeat center/100% auto;
}

.voice__heading__en { /* pc */
	font-size: 4.8rem;
}

.voice__heading__jp { /* pc */
	font-size: 3.3rem;
}

.voice__contents { /* pc */
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 105px;
}

.voice__contents::before {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 1326px;
	height: 100%;
	background: url(../img/bg_voice_03_pc.svg) no-repeat top 210px center/contain;
}

.voice__item { /* pc */
	width: calc(50% - 52.5px);
	padding-bottom: 2px;
}

.voice__item:not(:last-child) { /* pc */
	margin-bottom: 0;
}

.voice__item:not(:last-child)::after {
	position: absolute;
	top: 0;
	left: 55px;
	-webkit-transform: translateX(0);
	transform: translateX(0);
	content: "";
	width: 100%;
	height: 100%;
	display: block;
	background: url(../img/border_voice_vertical.svg) no-repeat right center/auto 100%;
	pointer-events: none;
}

.voice__item::before { /* pc */
	top: -40px;
	left: 51%;
	width: 284px;
	height: 100%;
	background: url(../img/bg_voice_01_pc.svg) no-repeat center top/100% auto;
}

.voice__item::after { /* pc */
	content: none;
}

.voice__item--yellow::before { /* pc */
	width: 284px;
	left: 52%;
	background-image: url(../img/bg_voice_02_pc.svg);
	background-position: center top;
}

.voice__item__heading { /* pc */
	width: 523px;
	max-width: 100%;
	margin-bottom: 15px;
}

.voice__lead { /* pc */
	font-size: 2rem;
	margin-bottom: 42px;
}

.voice__main__item { /* pc */
	gap: 30px;
}

.voice__main__item:not(:last-child) { /* pc */
	margin-bottom: 33px;
}

.voice__main__item--01::before { /* pc */
	bottom: -15px;
	left: 0;
	width: 106px;
	height: 92px;
}

.voice__main__item--02::before { /* pc */
	bottom: -25px;
	right: 35px;
}

.voice__main__item--03::before { /* pc */
	bottom: -25px;
	left: 60px;
}

.voice__main__item--04::before { /* pc */
	bottom: -20px;
	right: 60px;
}

.voice__main__item--05::before { /* pc */
	bottom: -35px;
	left: 25px;
}

.voice__main__item--06::before { /* pc */
	bottom: -15px;
	left: 45px;
}

.voice__main__item--07::before { /* pc */
	right: 60px;
}

.voice__main__item--08::before { /* pc */
	bottom: -20px;
	left: 55px;
	width: 50px;
	height: 49px;
}

.voice__main__item--09::before { /* pc */
	bottom: -15px;
	right: 55px;
}

.voice__main__item--10::before { /* pc */
	bottom: -25px;
	left: 70px;
	width: 37px;
	height: 56px;
}

.voice__main__item--11::before { /* pc */
	bottom: -18px;
	right: 65px;
}

.voice__text { /* pc */
	border-radius: 20px;
	font-size: 1.6rem;
	line-height: 2;
	padding: 22px 30px;
}

.voice__text::before { /* pc */
	width: 30px;
	height: 9px;
}

.about { /* pc */
	padding: 70px 0 205px;
}

.about { /* pc */
	position: relative;
}

.about::before {
	position: absolute;
	top: 30px;
	left: 48%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	content: "";
	width: 1655px;
	height: 1348px;
	background: url(../img/deco_about_contents_pc.svg) no-repeat center top/contain;
}

.about__head { /* pc */
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	gap: 14%;
	margin-bottom: 100px;
}

.about__head::before { /* pc */
	content: none;
}

.about__heading { /* pc */
	font-size: clamp(3rem, 0.1342222222rem + 3.5822222222vw, 4.612rem);
	-ms-flex-negative: 0;
	flex-shrink: 0;
	padding: 90px 0 0;
}

.about__heading::before { /* pc */
	width: 168.7%;
	height: 200%;
	background-size: 100% auto;
}

.about__heading::after { /* pc */
	bottom: -40px;
	right: 90.5%;
	width: 73.5%;
	height: 34.3%;
}

.about__heading span { /* pc */
	background-size: 190px;
	padding-bottom: 10px;
}

.about__lead { /* pc */
	font-size: clamp(1.5rem, 0.7033195021rem + 1.0373443983vw, 2rem);
	letter-spacing: 0.05em;
	width: 49%;
	padding: 42px 50px;
}

.about__lead::before,
.about__lead::after { /* pc */
	height: 54px;
}

.about__lead::before { /* pc */
	border-radius: 20px 20px 0 0;
}

.about__lead::after { /* pc */
	border-radius: 0 0 20px 20px;
}

.about__lead span { /* pc */
	padding: 0;
}

.about__contents::before { /* pc */
	content: none;
}

.about__main { /* pc */
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	z-index: 2;
}

.about__item { /* pc */
	width: 28.3%;
}

.about__item::before { /* pc */
	top: 46%;
	left: 47%;
	-webkit-transform: translate(-50%, -50%) rotate(-15deg);
	transform: translate(-50%, -50%) rotate(-15deg);
	width: 30.9%;
	height: 30.9%;
}

.about__item:not(:last-child) { /* pc */
	padding-bottom: 0;
	margin-bottom: 0;
}

.about__item:not(:last-child)::after { /* pc */
	top: 0;
	left: 112%;
	width: 1px;
	height: 100%;
	border-bottom: none;
	border-right: 2px dashed #343434;
	-webkit-transform: rotate(0);
	transform: rotate(0);
}

.about__item--01 .about__before__text { /* pc */
	background-image: url(../img/frame_about_01_pc.svg);
}

.about__item--01 .about__before__text::before { /* pc */
	left: 23px;
	width: 12.6%;
	height: 26.5%;
}

.about__item--02 { /* pc */
	width: 30.6%;
}

.about__item--02::before {
	top: 40%;
	left: 49%;
	width: 19.1%;
	height: 19.1%;
}

.about__item--02 .about__before__image { /* pc */
	width: 47.4%;
}

.about__item--02 .about__before__text { /* pc */
	left: calc(50% - 30px);
	padding: 11%;
	background-image: url(../img/frame_about_02_pc.svg);
}

.about__item--02 .about__before__text::before { /* pc */
	top: -30px;
	right: -15px;
	width: 22.6%;
	height: 24.5%;
}

.about__item--02 .about__after { /* pc */
	margin-top: 55px;
}

.about__item--02 .about__after__image { /* pc */
	width: 58.3%;
}

.about__item--02 .about__after__text { /* pc */
	top: 60%;
	right: calc(50% - 15px);
	width: 51.2%;
}

.about__item--02 .about__after__text::before { /* pc */
	top: -45px;
}

.about__item--03 { /* pc */
}

.about__item--03::before {
	left: 52%;
}

.about__item--03 .about__before__text { /* pc */
	top: 50%;
	background-image: url(../img/frame_about_03_pc.svg);
	padding: 13.4%;
}

.about__item--03 .about__before__text::before { /* pc */
	top: -15px;
	width: 32.8%;
	height: 30.3%;
}

.about__item--03 .about__after__text::before { /* pc */
	top: -57px;
}

.about__before__text { /* pc */
	top: 43%;
	right: calc(50% - 30px);
	font-size: clamp(1.4rem, 1.2rem + 0.2604166667vw, 1.7rem);
	padding: 11.8% 14.7% 13% 11.8%;
}

.about__after { /* pc */
	margin-top: 115px;
}

.about__after__text { /* pc */
	font-size: clamp(1.5rem, 1.3rem + 0.2604166667vw, 1.8rem);
	width: 55.3%;
	min-width: 125px;
}

.about__after__text::before { /* pc */
	top: -45px;
	width: 40.4%;
	height: 40.4%;
}

.about__message { /* pc */
	font-size: clamp(2.4rem, 1.7333333333rem + 0.8680555556vw, 3.4rem);
	line-height: 1.73;
	width: auto;
	aspect-ratio: auto;
	background: none;
	padding: 0;
	margin: 130px 0 0;
}

.about__message::before { /* pc */
	bottom: auto;
	top: 20%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 296px;
	height: 296px;
	border-radius: 50%;
	background: #FFF;
}

.about__message::after { /* pc */
	top: auto;
	bottom: calc(100% + 6px);
	left: 50%;
	width: 145px;
	height: 190px;
	background: url(../img/deco_track.svg) no-repeat left 35% bottom/96px auto, url(../img/bg_about_message.svg) no-repeat center top/100% auto;
}

.point-wrap { /* pc */
	padding: 0 0 230px;
}

.point-wrap::before { /* pc */
	width: 305px;
	height: 100px;
}

.point-wrap::after { /* pc */
	width: 100%;
	width: 1440px;
	margin-left: 30px;
	background: url(../img/bg_point_01_pc.svg) no-repeat top 134px center/100%, url(../img/bg_point_02_pc.svg) no-repeat bottom 180px center/97%;
}

.point-item-wrap { /* pc */
	margin-top: 51px;
}

.point-item--01 { /* pc */
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.point-item--02 { /* pc */
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin-top: 58px;
}

.point-item--03 { /* pc */
	width: 44.8%;
	margin-top: 70px;
}

.point-item--04 { /* pc */
	width: 44.8%;
	margin-top: 70px;
}

.point-item--01 .point-item__wrap { /* pc */
	width: 50%;
	-ms-flex-negative: 0;
	flex-shrink: 0;
}

.point-item--02 .point-item__wrap { /* pc */
	width: 38%;
	-ms-flex-negative: 0;
	flex-shrink: 0;
}

.point-item__main { /* pc */
	padding: 0 28px 42px 0;
}

.point-item__main::before { /* pc */
	height: calc(100% - 20px);
	border-width: 2px;
	border-radius: 0 0 20px 0;
}

.point-item__head { /* pc */
	gap: 25px;
	margin-bottom: 38px;
}

.point-item__head__order { /* pc */
	width: 112px;
}

.point-item__head__main { /* pc */
	font-size: 3.2rem;
}

.point-item__text { /* pc */
	font-size: 1.8rem;
}

.point-item__text span { /* pc */
	font-size: 1.6rem;
}

.point-item--01 .point-item__image-sub { /* pc */
	max-width: 100%;
	width: 100%;
	margin: 50px auto 0;
}

.point-item--02 .point-item__image-sub { /* pc */
	max-width: 100%;
	width: 82%;
	margin: -34px auto 0;
}

.point-item--01 .point-item__image-main { /* pc */
	max-width: 100%;
	margin: -23px 0 0;
	width: 45%;
}

.point-item--01 .point-item__image-main img { /* pc */
	margin-left: 0;
}

.point-item__images { /* pc */
	grid-template-columns: repeat(2, 1fr);
	width: 58%;
	margin-top: 20px;
}

.point-item__image { /* pc */
	margin-top: 60px;
}

.point-cta { /* pc */
	max-width: 792px;
	margin-top: 73px;
}

.point-set { /* pc */
	margin-top: 100px;
}

.point-set__bg { /* pc */
	border-radius: 30px;
	padding: 10px;
	background: repeating-linear-gradient(-45deg, #00ac93 0, #00ac93 3px, #ffffff 3px, #ffffff 6px);
}

.point-set__inner { /* pc */
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
	gap: 3.2%;
	border-radius: 20px;
	padding: 56px 56px 92px;
}

.point-set__head { /* pc */
	margin-bottom: 20px;
	padding-bottom: 8px;
	border-width: 4px;
}

.point-set__head__sub { /* pc */
	margin-bottom: 6px;
	font-size: 2.2rem;
	line-height: 1.2;
}

.point-set__head__main { /* pc */
	margin-left: -10px;
	margin-right: -10px;
	font-size: 3.8rem;
}

.point-set__text { /* pc */
	font-size: 1.8rem;
}

.point-set__list li { /* pc */
	font-size: 1.6rem;
	line-height: 1.875;
}

.point-set__image-wrap { /* pc */
	-ms-flex-negative: 0;
	flex-shrink: 0;
	width: 48%;
	margin-bottom: 0;
}

.point-set__note { /* pc */
	margin-top: 8px;
	font-size: 1.4rem;
}

.point-set__button { /* pc */
	max-width: 580px;
	margin: -62px auto 0;
}

.flow-wrap { /* pc */
	padding: 0 0 220px;
}

.flow-wrap::before { /* pc */
	width: 305px;
	height: 100px;
}

.flow-wrap::after { /* pc */
	width: 1270px;
	background: url(../img/bg_flow_pc.svg) no-repeat top 90px center/100%;
}

.flow { /* pc */
	margin: 100px auto 0;
	max-width: 996px;
}

.flow-item { /* pc */
	padding: 50px 10% 52px;
	border-radius: 20px;
	border-width: 2px;
}

.flow-item:not(:last-child) { /* pc */
	margin-bottom: 115px;
}

.flow-item::before { /* pc */
	height: calc(100% - 100px);
}

.flow-item__number { /* pc */
	width: 120px;
	height: 120px;
	padding-bottom: 12px;
	border-width: 2px;
}

.flow-item__number img { /* pc */
	width: 51px;
}

.flow-item__heading { /* pc */
	margin-bottom: 14px;
	font-size: 3.6rem;
}

.flow-item__text { /* pc */
	font-size: 1.8rem;
}

.flow-item__detail { /* pc */
	margin-top: 30px;
	padding-top: 28px;
	border-width: 2px;
}

.flow-item__detail__heading { /* pc */
	margin-bottom: 18px;
	font-size: 3rem;
	line-height: 1.6666;
}

.flow-item__detail__text { /* pc */
	font-size: 1.8rem;
}

.flow-item__button { /* pc */
	width: 100%;
	max-width: 100%;
	margin-top: 30px;
}

.page-head__badge { /* pc */
	font-size: 2.4rem;
}

.page-head__lead { /* pc */
	display: block;
	margin: 50px auto 0;
	padding: 12px 50px;
	border-radius: 20px;
	font-size: 3.2rem;
}

.page-head__lead--multiple span { /* pc */
	padding: 0;
	border-radius: 0;
}

.page-head__lead--green { /* pc */
	background: #d1eae1;
}

.page-head__lead::after { /* pc */
	right: 50px;
	width: 22px;
	height: 36px;
}

.page-head__title { /* pc */
	margin-top: 16px;
	font-size: 5.6rem;
	line-height: 1.5222;
}

.page-head__title--sm { /* pc */
	margin-top: 27px;
	font-size: 5.2rem;
}

.page-head__title span::before { /* pc */
	bottom: -5px;
	height: 30px;
}

.faq-wrap { /* pc */
	padding-bottom: 100px;
}

.faq-wrap::before { /* pc */
	width: 305px;
	height: 100px;
}

.faq-wrap::after { /* pc */
	background: url(../img/bg_faq_pc_1.png) no-repeat top center/1420px auto, url(../img/bg_faq_pc_2.png) no-repeat bottom center/1490px auto;
}

.faq-wrap .page-head + .faq { /* pc */
	margin-top: 50px;
}

.faq { /* pc */
	margin-bottom: 12px;
}

.faq__question button { /* pc */
	padding: 12px 2px 12px;
	gap: 35px;
	border-width: 2px;
}

.faq__text { /* pc */
	font-size: 2.2rem;
}

.faq__label { /* pc */
	font-size: 2.7rem;
}

.faq__icon { /* pc */
	width: 30px;
}

.faq__answer { /* pc */
	gap: 38px;
	font-size: 1.8rem;
	padding: 12px 0 0 4px;
}

.cv { /* pc */
	padding: 78px 0 97px;
}

.cv__bottom { /* pc */
	margin-top: 70px;
	grid-template-columns: repeat(2, 1fr);
}

.cv__item { /* pc */
	gap: 20px;
}

.cv__title span { /* pc */
	font-size: clamp(18px, 2.4vw, 28px);
	padding: 0 39px;
}

.cv__title span::before,
.cv__title span::after { /* pc */
	width: 40px;
	height: 2px;
	background-size: 8px 2px;
	bottom: 17px;
}

.cv__title span::before { /* pc */
	left: -10px;
}

.cv__title span::after { /* pc */
	right: -10px;
}

.cv__tel { /* pc */
	margin-top: 85px;
	border-width: 3px;
	border-radius: 20px;
	padding: 54px 16px 70px;
}

.cv__lead { /* pc */
	font-size: 2.4rem;
}

.cv__number { /* pc */
	margin-top: 8px;
	font-size: 6rem;
}

.cv__note { /* pc */
	margin-top: 20px;
	font-size: 2.2rem;
}

}

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

.text-left-sp { /* sp */
	text-align: left;
}

.text-center-sp { /* sp */
	text-align: center;
}

.text-right-sp { /* sp */
	text-align: right;
}

.sp-only { /* sp */
	display: block !important;
}

.sp-only-2 { /* sp */
	display: inline-block !important;
}

.pc-only { /* sp */
	display: none !important;
}

.pc-only-2 { /* sp */
	display: none !important;
}

/* sp */

.mt-0-sp {
	margin-top: 0px !important;
}

.mb-0-sp {
	margin-bottom: 0px !important;
}

.mr-0-sp {
	margin-right: 0px !important;
}

.ml-0-sp {
	margin-left: 0px !important;
}

.mx-0-sp {
	margin-left: 0px !important;
	margin-right: 0px !important;
}

.my-0-sp {
	margin-top: 0px !important;
	margin-bottom: 0px !important;
}

/* sp */

.mt-5-sp {
	margin-top: 5px !important;
}

.mb-5-sp {
	margin-bottom: 5px !important;
}

.mr-5-sp {
	margin-right: 5px !important;
}

.ml-5-sp {
	margin-left: 5px !important;
}

.mx-5-sp {
	margin-left: 5px !important;
	margin-right: 5px !important;
}

.my-5-sp {
	margin-top: 5px !important;
	margin-bottom: 5px !important;
}

/* sp */

.mt-10-sp {
	margin-top: 10px !important;
}

.mb-10-sp {
	margin-bottom: 10px !important;
}

.mr-10-sp {
	margin-right: 10px !important;
}

.ml-10-sp {
	margin-left: 10px !important;
}

.mx-10-sp {
	margin-left: 10px !important;
	margin-right: 10px !important;
}

.my-10-sp {
	margin-top: 10px !important;
	margin-bottom: 10px !important;
}

/* sp */

.mt-15-sp {
	margin-top: 15px !important;
}

.mb-15-sp {
	margin-bottom: 15px !important;
}

.mr-15-sp {
	margin-right: 15px !important;
}

.ml-15-sp {
	margin-left: 15px !important;
}

.mx-15-sp {
	margin-left: 15px !important;
	margin-right: 15px !important;
}

.my-15-sp {
	margin-top: 15px !important;
	margin-bottom: 15px !important;
}

/* sp */

.mt-20-sp {
	margin-top: 20px !important;
}

.mb-20-sp {
	margin-bottom: 20px !important;
}

.mr-20-sp {
	margin-right: 20px !important;
}

.ml-20-sp {
	margin-left: 20px !important;
}

.mx-20-sp {
	margin-left: 20px !important;
	margin-right: 20px !important;
}

.my-20-sp {
	margin-top: 20px !important;
	margin-bottom: 20px !important;
}

/* sp */

.mt-25-sp {
	margin-top: 25px !important;
}

.mb-25-sp {
	margin-bottom: 25px !important;
}

.mr-25-sp {
	margin-right: 25px !important;
}

.ml-25-sp {
	margin-left: 25px !important;
}

.mx-25-sp {
	margin-left: 25px !important;
	margin-right: 25px !important;
}

.my-25-sp {
	margin-top: 25px !important;
	margin-bottom: 25px !important;
}

/* sp */

.mt-30-sp {
	margin-top: 30px !important;
}

.mb-30-sp {
	margin-bottom: 30px !important;
}

.mr-30-sp {
	margin-right: 30px !important;
}

.ml-30-sp {
	margin-left: 30px !important;
}

.mx-30-sp {
	margin-left: 30px !important;
	margin-right: 30px !important;
}

.my-30-sp {
	margin-top: 30px !important;
	margin-bottom: 30px !important;
}

/* sp */

.mt-35-sp {
	margin-top: 35px !important;
}

.mb-35-sp {
	margin-bottom: 35px !important;
}

.mr-35-sp {
	margin-right: 35px !important;
}

.ml-35-sp {
	margin-left: 35px !important;
}

.mx-35-sp {
	margin-left: 35px !important;
	margin-right: 35px !important;
}

.my-35-sp {
	margin-top: 35px !important;
	margin-bottom: 35px !important;
}

/* sp */

.mt-40-sp {
	margin-top: 40px !important;
}

.mb-40-sp {
	margin-bottom: 40px !important;
}

.mr-40-sp {
	margin-right: 40px !important;
}

.ml-40-sp {
	margin-left: 40px !important;
}

.mx-40-sp {
	margin-left: 40px !important;
	margin-right: 40px !important;
}

.my-40-sp {
	margin-top: 40px !important;
	margin-bottom: 40px !important;
}

/* sp */

.mt-45-sp {
	margin-top: 45px !important;
}

.mb-45-sp {
	margin-bottom: 45px !important;
}

.mr-45-sp {
	margin-right: 45px !important;
}

.ml-45-sp {
	margin-left: 45px !important;
}

.mx-45-sp {
	margin-left: 45px !important;
	margin-right: 45px !important;
}

.my-45-sp {
	margin-top: 45px !important;
	margin-bottom: 45px !important;
}

/* sp */

.mt-50-sp {
	margin-top: 50px !important;
}

.mb-50-sp {
	margin-bottom: 50px !important;
}

.mr-50-sp {
	margin-right: 50px !important;
}

.ml-50-sp {
	margin-left: 50px !important;
}

.mx-50-sp {
	margin-left: 50px !important;
	margin-right: 50px !important;
}

.my-50-sp {
	margin-top: 50px !important;
	margin-bottom: 50px !important;
}

/* sp */

.mt-55-sp {
	margin-top: 55px !important;
}

.mb-55-sp {
	margin-bottom: 55px !important;
}

.mr-55-sp {
	margin-right: 55px !important;
}

.ml-55-sp {
	margin-left: 55px !important;
}

.mx-55-sp {
	margin-left: 55px !important;
	margin-right: 55px !important;
}

.my-55-sp {
	margin-top: 55px !important;
	margin-bottom: 55px !important;
}

/* sp */

.mt-60-sp {
	margin-top: 60px !important;
}

.mb-60-sp {
	margin-bottom: 60px !important;
}

.mr-60-sp {
	margin-right: 60px !important;
}

.ml-60-sp {
	margin-left: 60px !important;
}

.mx-60-sp {
	margin-left: 60px !important;
	margin-right: 60px !important;
}

.my-60-sp {
	margin-top: 60px !important;
	margin-bottom: 60px !important;
}

/* sp */

.mt-65-sp {
	margin-top: 65px !important;
}

.mb-65-sp {
	margin-bottom: 65px !important;
}

.mr-65-sp {
	margin-right: 65px !important;
}

.ml-65-sp {
	margin-left: 65px !important;
}

.mx-65-sp {
	margin-left: 65px !important;
	margin-right: 65px !important;
}

.my-65-sp {
	margin-top: 65px !important;
	margin-bottom: 65px !important;
}

/* sp */

.mt-70-sp {
	margin-top: 70px !important;
}

.mb-70-sp {
	margin-bottom: 70px !important;
}

.mr-70-sp {
	margin-right: 70px !important;
}

.ml-70-sp {
	margin-left: 70px !important;
}

.mx-70-sp {
	margin-left: 70px !important;
	margin-right: 70px !important;
}

.my-70-sp {
	margin-top: 70px !important;
	margin-bottom: 70px !important;
}

/* sp */

.mt-75-sp {
	margin-top: 75px !important;
}

.mb-75-sp {
	margin-bottom: 75px !important;
}

.mr-75-sp {
	margin-right: 75px !important;
}

.ml-75-sp {
	margin-left: 75px !important;
}

.mx-75-sp {
	margin-left: 75px !important;
	margin-right: 75px !important;
}

.my-75-sp {
	margin-top: 75px !important;
	margin-bottom: 75px !important;
}

/* sp */

.mt-80-sp {
	margin-top: 80px !important;
}

.mb-80-sp {
	margin-bottom: 80px !important;
}

.mr-80-sp {
	margin-right: 80px !important;
}

.ml-80-sp {
	margin-left: 80px !important;
}

.mx-80-sp {
	margin-left: 80px !important;
	margin-right: 80px !important;
}

.my-80-sp {
	margin-top: 80px !important;
	margin-bottom: 80px !important;
}

/* sp */

.mt-85-sp {
	margin-top: 85px !important;
}

.mb-85-sp {
	margin-bottom: 85px !important;
}

.mr-85-sp {
	margin-right: 85px !important;
}

.ml-85-sp {
	margin-left: 85px !important;
}

.mx-85-sp {
	margin-left: 85px !important;
	margin-right: 85px !important;
}

.my-85-sp {
	margin-top: 85px !important;
	margin-bottom: 85px !important;
}

/* sp */

.mt-90-sp {
	margin-top: 90px !important;
}

.mb-90-sp {
	margin-bottom: 90px !important;
}

.mr-90-sp {
	margin-right: 90px !important;
}

.ml-90-sp {
	margin-left: 90px !important;
}

.mx-90-sp {
	margin-left: 90px !important;
	margin-right: 90px !important;
}

.my-90-sp {
	margin-top: 90px !important;
	margin-bottom: 90px !important;
}

/* sp */

.mt-95-sp {
	margin-top: 95px !important;
}

.mb-95-sp {
	margin-bottom: 95px !important;
}

.mr-95-sp {
	margin-right: 95px !important;
}

.ml-95-sp {
	margin-left: 95px !important;
}

.mx-95-sp {
	margin-left: 95px !important;
	margin-right: 95px !important;
}

.my-95-sp {
	margin-top: 95px !important;
	margin-bottom: 95px !important;
}

/* sp */

.mt-100-sp {
	margin-top: 100px !important;
}

.mb-100-sp {
	margin-bottom: 100px !important;
}

.mr-100-sp {
	margin-right: 100px !important;
}

.ml-100-sp {
	margin-left: 100px !important;
}

.mx-100-sp {
	margin-left: 100px !important;
	margin-right: 100px !important;
}

.my-100-sp {
	margin-top: 100px !important;
	margin-bottom: 100px !important;
}

/* sp */

.mt-auto-sp {
	margin-top: auto !important;
}

.mb-auto-sp {
	margin-bottom: auto !important;
}

.mr-auto-sp {
	margin-right: auto !important;
}

.ml-auto-sp {
	margin-left: auto !important;
}

.mx-auto-sp {
	margin-left: auto !important;
	margin-right: auto !important;
}

.my-auto-sp {
	margin-top: auto !important;
	margin-bottom: auto !important;
}

/* sp */

.p-0-sp {
	padding: 0px !important;
}

.pt-0-sp {
	padding-top: 0px !important;
}

.pb-0-sp {
	padding-bottom: 0px !important;
}

.pr-0-sp {
	padding-right: 0px !important;
}

.pl-0-sp {
	padding-left: 0px !important;
}

.px-0-sp {
	padding-left: 0px !important;
	padding-right: 0px !important;
}

.py-0-sp {
	padding-top: 0px !important;
	padding-bottom: 0px !important;
}

/* sp */

.p-5-sp {
	padding: 5px !important;
}

.pt-5-sp {
	padding-top: 5px !important;
}

.pb-5-sp {
	padding-bottom: 5px !important;
}

.pr-5-sp {
	padding-right: 5px !important;
}

.pl-5-sp {
	padding-left: 5px !important;
}

.px-5-sp {
	padding-left: 5px !important;
	padding-right: 5px !important;
}

.py-5-sp {
	padding-top: 5px !important;
	padding-bottom: 5px !important;
}

/* sp */

.p-10-sp {
	padding: 10px !important;
}

.pt-10-sp {
	padding-top: 10px !important;
}

.pb-10-sp {
	padding-bottom: 10px !important;
}

.pr-10-sp {
	padding-right: 10px !important;
}

.pl-10-sp {
	padding-left: 10px !important;
}

.px-10-sp {
	padding-left: 10px !important;
	padding-right: 10px !important;
}

.py-10-sp {
	padding-top: 10px !important;
	padding-bottom: 10px !important;
}

/* sp */

.p-15-sp {
	padding: 15px !important;
}

.pt-15-sp {
	padding-top: 15px !important;
}

.pb-15-sp {
	padding-bottom: 15px !important;
}

.pr-15-sp {
	padding-right: 15px !important;
}

.pl-15-sp {
	padding-left: 15px !important;
}

.px-15-sp {
	padding-left: 15px !important;
	padding-right: 15px !important;
}

.py-15-sp {
	padding-top: 15px !important;
	padding-bottom: 15px !important;
}

/* sp */

.p-20-sp {
	padding: 20px !important;
}

.pt-20-sp {
	padding-top: 20px !important;
}

.pb-20-sp {
	padding-bottom: 20px !important;
}

.pr-20-sp {
	padding-right: 20px !important;
}

.pl-20-sp {
	padding-left: 20px !important;
}

.px-20-sp {
	padding-left: 20px !important;
	padding-right: 20px !important;
}

.py-20-sp {
	padding-top: 20px !important;
	padding-bottom: 20px !important;
}

/* sp */

.p-25-sp {
	padding: 25px !important;
}

.pt-25-sp {
	padding-top: 25px !important;
}

.pb-25-sp {
	padding-bottom: 25px !important;
}

.pr-25-sp {
	padding-right: 25px !important;
}

.pl-25-sp {
	padding-left: 25px !important;
}

.px-25-sp {
	padding-left: 25px !important;
	padding-right: 25px !important;
}

.py-25-sp {
	padding-top: 25px !important;
	padding-bottom: 25px !important;
}

/* sp */

.p-30-sp {
	padding: 30px !important;
}

.pt-30-sp {
	padding-top: 30px !important;
}

.pb-30-sp {
	padding-bottom: 30px !important;
}

.pr-30-sp {
	padding-right: 30px !important;
}

.pl-30-sp {
	padding-left: 30px !important;
}

.px-30-sp {
	padding-left: 30px !important;
	padding-right: 30px !important;
}

.py-30-sp {
	padding-top: 30px !important;
	padding-bottom: 30px !important;
}

/* sp */

.p-35-sp {
	padding: 35px !important;
}

.pt-35-sp {
	padding-top: 35px !important;
}

.pb-35-sp {
	padding-bottom: 35px !important;
}

.pr-35-sp {
	padding-right: 35px !important;
}

.pl-35-sp {
	padding-left: 35px !important;
}

.px-35-sp {
	padding-left: 35px !important;
	padding-right: 35px !important;
}

.py-35-sp {
	padding-top: 35px !important;
	padding-bottom: 35px !important;
}

/* sp */

.p-40-sp {
	padding: 40px !important;
}

.pt-40-sp {
	padding-top: 40px !important;
}

.pb-40-sp {
	padding-bottom: 40px !important;
}

.pr-40-sp {
	padding-right: 40px !important;
}

.pl-40-sp {
	padding-left: 40px !important;
}

.px-40-sp {
	padding-left: 40px !important;
	padding-right: 40px !important;
}

.py-40-sp {
	padding-top: 40px !important;
	padding-bottom: 40px !important;
}

/* sp */

.p-45-sp {
	padding: 45px !important;
}

.pt-45-sp {
	padding-top: 45px !important;
}

.pb-45-sp {
	padding-bottom: 45px !important;
}

.pr-45-sp {
	padding-right: 45px !important;
}

.pl-45-sp {
	padding-left: 45px !important;
}

.px-45-sp {
	padding-left: 45px !important;
	padding-right: 45px !important;
}

.py-45-sp {
	padding-top: 45px !important;
	padding-bottom: 45px !important;
}

/* sp */

.p-50-sp {
	padding: 50px !important;
}

.pt-50-sp {
	padding-top: 50px !important;
}

.pb-50-sp {
	padding-bottom: 50px !important;
}

.pr-50-sp {
	padding-right: 50px !important;
}

.pl-50-sp {
	padding-left: 50px !important;
}

.px-50-sp {
	padding-left: 50px !important;
	padding-right: 50px !important;
}

.py-50-sp {
	padding-top: 50px !important;
	padding-bottom: 50px !important;
}

/* sp */

.p-55-sp {
	padding: 55px !important;
}

.pt-55-sp {
	padding-top: 55px !important;
}

.pb-55-sp {
	padding-bottom: 55px !important;
}

.pr-55-sp {
	padding-right: 55px !important;
}

.pl-55-sp {
	padding-left: 55px !important;
}

.px-55-sp {
	padding-left: 55px !important;
	padding-right: 55px !important;
}

.py-55-sp {
	padding-top: 55px !important;
	padding-bottom: 55px !important;
}

/* sp */

.p-60-sp {
	padding: 60px !important;
}

.pt-60-sp {
	padding-top: 60px !important;
}

.pb-60-sp {
	padding-bottom: 60px !important;
}

.pr-60-sp {
	padding-right: 60px !important;
}

.pl-60-sp {
	padding-left: 60px !important;
}

.px-60-sp {
	padding-left: 60px !important;
	padding-right: 60px !important;
}

.py-60-sp {
	padding-top: 60px !important;
	padding-bottom: 60px !important;
}

/* sp */

.p-65-sp {
	padding: 65px !important;
}

.pt-65-sp {
	padding-top: 65px !important;
}

.pb-65-sp {
	padding-bottom: 65px !important;
}

.pr-65-sp {
	padding-right: 65px !important;
}

.pl-65-sp {
	padding-left: 65px !important;
}

.px-65-sp {
	padding-left: 65px !important;
	padding-right: 65px !important;
}

.py-65-sp {
	padding-top: 65px !important;
	padding-bottom: 65px !important;
}

/* sp */

.p-70-sp {
	padding: 70px !important;
}

.pt-70-sp {
	padding-top: 70px !important;
}

.pb-70-sp {
	padding-bottom: 70px !important;
}

.pr-70-sp {
	padding-right: 70px !important;
}

.pl-70-sp {
	padding-left: 70px !important;
}

.px-70-sp {
	padding-left: 70px !important;
	padding-right: 70px !important;
}

.py-70-sp {
	padding-top: 70px !important;
	padding-bottom: 70px !important;
}

/* sp */

.p-75-sp {
	padding: 75px !important;
}

.pt-75-sp {
	padding-top: 75px !important;
}

.pb-75-sp {
	padding-bottom: 75px !important;
}

.pr-75-sp {
	padding-right: 75px !important;
}

.pl-75-sp {
	padding-left: 75px !important;
}

.px-75-sp {
	padding-left: 75px !important;
	padding-right: 75px !important;
}

.py-75-sp {
	padding-top: 75px !important;
	padding-bottom: 75px !important;
}

/* sp */

.p-80-sp {
	padding: 80px !important;
}

.pt-80-sp {
	padding-top: 80px !important;
}

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

.pr-80-sp {
	padding-right: 80px !important;
}

.pl-80-sp {
	padding-left: 80px !important;
}

.px-80-sp {
	padding-left: 80px !important;
	padding-right: 80px !important;
}

.py-80-sp {
	padding-top: 80px !important;
	padding-bottom: 80px !important;
}

/* sp */

.p-85-sp {
	padding: 85px !important;
}

.pt-85-sp {
	padding-top: 85px !important;
}

.pb-85-sp {
	padding-bottom: 85px !important;
}

.pr-85-sp {
	padding-right: 85px !important;
}

.pl-85-sp {
	padding-left: 85px !important;
}

.px-85-sp {
	padding-left: 85px !important;
	padding-right: 85px !important;
}

.py-85-sp {
	padding-top: 85px !important;
	padding-bottom: 85px !important;
}

/* sp */

.p-90-sp {
	padding: 90px !important;
}

.pt-90-sp {
	padding-top: 90px !important;
}

.pb-90-sp {
	padding-bottom: 90px !important;
}

.pr-90-sp {
	padding-right: 90px !important;
}

.pl-90-sp {
	padding-left: 90px !important;
}

.px-90-sp {
	padding-left: 90px !important;
	padding-right: 90px !important;
}

.py-90-sp {
	padding-top: 90px !important;
	padding-bottom: 90px !important;
}

/* sp */

.p-95-sp {
	padding: 95px !important;
}

.pt-95-sp {
	padding-top: 95px !important;
}

.pb-95-sp {
	padding-bottom: 95px !important;
}

.pr-95-sp {
	padding-right: 95px !important;
}

.pl-95-sp {
	padding-left: 95px !important;
}

.px-95-sp {
	padding-left: 95px !important;
	padding-right: 95px !important;
}

.py-95-sp {
	padding-top: 95px !important;
	padding-bottom: 95px !important;
}

/* sp */

.p-100-sp {
	padding: 100px !important;
}

.pt-100-sp {
	padding-top: 100px !important;
}

.pb-100-sp {
	padding-bottom: 100px !important;
}

.pr-100-sp {
	padding-right: 100px !important;
}

.pl-100-sp {
	padding-left: 100px !important;
}

.px-100-sp {
	padding-left: 100px !important;
	padding-right: 100px !important;
}

.py-100-sp {
	padding-top: 100px !important;
	padding-bottom: 100px !important;
}

/* sp */

.grid-1col-sp {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
}

.grid-2col-sp {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}

.grid-3col-sp {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

.grid-4col-sp {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
}

.page-head__lead--green.page-head__lead--multiple { /* sp */
	background: transparent;
}

.page-head__title--sp-2line { /* sp */
	display: block;
}

.cv__top .button-1 { /* sp */
	max-width: 290px;
}

.cv__item .button-1 { /* sp */
	width: 290px;
	height: 63px;
}

}

