/* ==========================================================
# foundation
========================================================== */

/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/

/* reset css
----------------------------------------------- */

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

body {
	line-height: 1;
}

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

nav,
ul,
ol {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

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

a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
	text-decoration: none;
}

/* change colours to suit your needs */

ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none;
}

/* change colours to suit your needs */

mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: bold;
}

del {
	text-decoration: line-through;
}

abbr[title],
dfn[title] {
	border-bottom: 1px dotted;
	cursor: help;
}

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

/* change border colour to suit your needs */

hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #cccccc;
	margin: 1em 0;
	padding: 0;
}

input,
select {
	vertical-align: middle;
}

img {
	vertical-align: bottom;
}

html,
body {
	font-size: 62.5%;
}

body {
	width: 100%;
}

* {
	box-sizing: border-box;
}

/* form */

input[type=text],
input[type=email],
input[type=tel],
input[type=password] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	padding: 0;
	border: none;
	border-radius: 0;
	outline: none;
	background: none;
}

button,
input[type=submit],
input[type=button] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	border-radius: 0;
}

select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	padding: 0;
	border: none;
	outline: none;
	background: transparent;
	background: none;
}

input[type=radio],
input[type=checkbox] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border-radius: 0;
}

textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	resize: none;
	padding: 0;
	border: 0;
	border-radius: 0;
	outline: none;
	background: transparent;
}

@font-face {
	font-family: "line-re";
	src: url(../font/LINESeedJP_TTF_Rg.eot) format("eot"), url(../font/LINESeedJP_OTF_Rg.woff2) format("woff2");
}

@font-face {
	font-family: "line-b";
	src: url(../font/LINESeedJP_TTF_Bd.eot) format("eot"), url(../font/LINESeedJP_OTF_Bd.woff2) format("woff2");
}

@font-face {
	font-family: "line-eb";
	src: url(../font/LINESeedJP_TTF_Eb.eot) format("eot"), url(../font/LINESeedJP_OTF_Eb.woff2) format("woff2");
}

@font-face {
	font-family: "line-th";
	src: url(../font/LINESeedJP_TTF_Th.eot) format("eot"), url(../font/LINESeedJP_OTF_Th.woff2) format("woff2");
}

body {
	font-family: "line-re";
	font-weight: 400;
	color: #262319;
}

body.is-open {
	overflow: hidden;
}

.hidden {
	overflow: hidden;
}

.sp {
	display: none;
}

.tb {
	display: none;
}

.pc {
	display: block;
}

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

.relative {
	position: relative;
}

/* ==========================================================
# layout
========================================================== */

.l-header {
	background-color: #fff;
	border-top: 0.6rem solid #0072CE;
	box-shadow: 0 0.3rem 0.6rem rgba(0, 0, 0, 0.16);
	position: relative;
}

.l-header__inner {
	max-width: 145rem;
	width: 100%;
	margin: 0 auto;
}

.l-inner {
	max-width: 124rem;
	width: 100%;
	padding-left: 2.5rem;
	padding-right: 2.5rem;
	margin: 0 auto;
}

.l-inner--p-fv {
	height: 100%;
}

/* ==========================================================
# component
========================================================== */

.c-cta {
	text-align: center;
	margin-top: 4.5rem;
}

.c-cta__head {
	font-size: 2.4rem;
	font-family: "line-b";
}

.c-cta__txt {
	font-size: 1.6rem;
	margin-top: 1.5rem;
}

.c-cta__btn {
	width: 48rem;
	height: 6.7rem;
	margin: 2.5rem auto 0;
}

.c-cta__link {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	font-size: 2.3rem;
	font-family: "line-b";
	color: #262319;
	background-color: #FFD500;
	border-radius: 5.8rem;
	box-shadow: 0 0.3rem 0 #ECC222;
	transition: all 0.3s;
}

.c-cta__link::after {
	content: "";
	background-image: url(../img/arrow_black_right.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	display: inline-block;
	width: 0.9rem;
	height: 1.5rem;
	margin-left: 1.1rem;
}

.c-ttl-wrap {
	text-align: center;
}

.c-ttl {
	display: inline-block;
	font-size: 2rem;
	font-family: "line-b";
	color: #0072CE;
	position: relative;
}

.c-ttl::before,
.c-ttl::after {
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 6.3rem;
	height: 0.1rem;
	background-color: #0072CE;
}

.c-ttl::before {
	left: -8.3rem;
}

.c-ttl::after {
	right: -8.3rem;
}

.c-ttl--none::before,
.c-ttl--none::after {
	content: none;
}

/* ==========================================================
# project
========================================================== */

.p-about {
	margin-top: 4.5rem;
}

.p-about__info {
	width: 113rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin: 0 auto;
}

.p-about__info-wrap {
	width: 72rem;
}

.p-about__info-flex {
	display: flex;
}

.p-about__info-ttl {
	font-size: 2.2rem;
	font-family: "line-b";
	line-height: 1.45;
	color: #0072CE;
	margin-left: 2.8rem;
	letter-spacing: -0.01em;
}

.p-about__info-pic {
	width: 20.1rem;
}

.p-about__info-txt {
	font-size: 1.5rem;
	line-height: 1.6;
	font-family: "Noto Sans JP", serif;
	margin-top: 1rem;
}

.p-about__features-items {
	width: 34rem;
	padding: 1.4rem 1.6rem;
	background-color: #DEF4FA;
	border-radius: 1.3rem;
}

.p-about__features-item {
	font-size: 1.6rem;
	font-family: "line-b";
	color: #0072CE;
	text-align: center;
	line-height: 1.3;
	padding: 1.2rem 0;
	background-color: #fff;
	border: 0.2rem solid #0072CE;
	border-radius: 1.5rem;
}

.p-about__features-item:nth-of-type(n+2) {
	margin-top: 0.5rem;
}

.p-about__link {
	text-align: center;
	margin-top: 1.7rem;
}

.p-about__link a {
	font-size: 1.5rem;
	color: #262319;
}

.p-about__link a::before {
	content: "";
	background-image: url(../img/arrow_blue_right.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	display: inline-block;
	width: 1.6rem;
	height: 1.6rem;
	margin-right: 0.6rem;
	transform: translateY(0.25rem);
}

.p-about__items {
	display: flex;
	justify-content: space-between;
	width: 106rem;
	margin: 3.5rem auto 0;
}

.p-about__item {
	width: 50rem;
	text-align: center;
}

.p-about__item:nth-of-type(1) img {
	width: 29.8rem;
}

.p-about__item:nth-of-type(2) img {
	width: 30.5rem;
}

.p-about__item:nth-of-type(3) img {
	width: 30rem;
}

.p-about__item-txt {
	font-size: 1.5rem;
	line-height: 1.6;
	margin-top: 2rem;
}

.p-about__sdgs {
	display: flex;
	align-items: center;
	justify-content: space-between;
	background-color: #EFEFEF;
	border-radius: 1.3rem;
	padding: 4.5rem 3.5rem;
	margin-top: 2.8rem;
}

.p-about__sdgs-pic {
	width: 31.7rem;
}

.p-about__sdgs-txt {
	width: 76.5rem;
	font-size: 1.6rem;
	line-height: 1.8;
	margin-top: 0.7rem;
}

.p-burger {
	display: none;
}

.p-burger__bar {
	display: block;
	margin: 0 auto;
	width: 3.6rem;
	height: 0.3rem;
	background-color: #0072CE;
	transition: all 0.3s;
}

.p-burger__bar--top {
	margin-bottom: 0.5rem;
}

.p-burger__bar--bot {
	margin-top: 0.5rem;
}

.p-burger__bar--top.is-open {
	transform: translateY(0.6rem) rotate(45deg);
}

.p-burger__bar--mid.is-open {
	opacity: 0;
}

.p-burger__bar--bot.is-open {
	transform: translateY(-1rem) rotate(-45deg);
}

.p-burger__txt {
	display: block;
	font-size: 1.1rem;
	font-family: "line-b";
	text-align: center;
	color: #0072CE;
	margin-top: 0.2rem;
}

.p-flow {
	padding: 5.1rem 0 6.5rem;
	border-radius: 1.3rem;
	background-color: #DEF4FA;
}

.p-flow__head {
	font-size: 2.5rem;
	font-family: "line-b";
	text-align: center;
	margin-top: 3rem;
}

.p-flow__pic {
	width: 78rem;
	margin: 3rem auto 0;
}

.p-flow__note-wrap {
	width: 78rem;
	margin: 3rem auto 0;
}

.p-flow__note-ttl {
	font-size: 1.7rem;
	font-family: "line-b";
}

.p-flow__note-items {
	margin-top: 1.6rem;
}

.p-flow__note-items--mt {
	margin-top: 1rem;
}

.p-flow__note-item {
	display: flex;
	font-size: 1.2rem;
	line-height: 1.8;
}

.p-flow__note-item-ob {
	flex-shrink: 0;
	width: 2.9rem;
	color: #0072CE;
}

.p-flow__note-item-txt--b {
	font-family: "line-b";
}

#footer {
	margin-bottom: 13rem;
}

#footer a {
	color: #262319;
	text-decoration: none;
}

#footer a:hover {
	text-decoration: underline;
}

#footer > .top {
	background-color: #a0d7f0;
}

#footer > .top .inner {
	margin: 0 auto;
	padding: 3.2rem 0;
	width: 98rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

#footer > .top .inner .txt {
	display: flex;
	align-items: center;
}

#footer > .top .inner .logo {
	width: 14.8rem;
}

#footer > .top .inner .address {
	font-size: 1.3rem;
	font-family: "line-b";
	color: #0072CE;
	padding-left: 2rem;
}

#footer > .top .inner .address .name {
	font-size: 1.6rem;
	margin-bottom: 0.5em;
}

#footer > .top .inner .address p {
	line-height: 1.6;
}

#footer > .top .inner .access {
	margin-left: auto;
}

#footer > .top .inner .access .btn {
	color: #0072CE;
	font-size: 1.4rem;
	font-weight: 700;
	line-height: 1.1;
	border: 1px solid #0072CE;
	border-radius: 10rem;
	background-color: #fff;
	padding: 1.2rem 4rem;
	display: inline-block;
	position: relative;
}

#footer > .top .inner .access .btn:before {
	content: "";
	background: url(../img/ico_access.png) no-repeat;
	background-size: contain;
	margin-right: 1rem;
	width: 1.6rem;
	height: 2rem;
	display: inline-block;
	vertical-align: middle;
}

#footer > .top .inner .access .btn span {
	display: inline-block;
	vertical-align: middle;
}

#footer > .middle .inner {
	margin: 0 auto;
	padding: 3rem 4.5rem;
	width: 98rem;
	display: flex;
	justify-content: space-between;
	box-sizing: border-box;
}

#footer > .middle .inner ul li {
	font-size: 1.2rem;
	line-height: 1.2;
	text-indent: -1.6rem;
	padding-left: 1.6rem;
}

#footer > .middle .inner ul li + li {
	margin-top: 0.9em;
}

#footer > .middle .inner ul li a::before {
	content: "";
	margin-top: -0.2em;
	margin-right: 1rem;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0.3rem 0 0.3rem 0.4rem;
	border-color: transparent transparent transparent #007bff;
	display: inline-block;
	vertical-align: middle;
}

#footer > .bottom {
	border-top: 0.1rem solid #969696;
	padding: 1.5rem 0;
}

#footer > .bottom .copyright {
	font-size: 1.2rem;
	line-height: 2;
	text-align: center;
}

.p-form {
	position: absolute;
	top: 0;
	right: 0;
	display: inline-block;
	min-width: 69.2rem;
	height: 100%;
	z-index: 1;
	background-color: rgba(0, 114, 206, 0.75);
	padding: 3.4rem 5rem 0;
}

.p-form__ttl {
	display: inline-block;
	font-size: 2.4rem;
	font-family: "line-b";
	color: #0072CE;
	border-radius: 1.5rem;
	background-color: #fff;
	padding: 1.4rem;
}

.p-form__txt {
	font-size: 3.2rem;
	font-family: "line-b";
	line-height: 1.5;
	color: #fff;
	margin-top: 1.5rem;
}

.p-form__area {
	border-radius: 1.3rem;
	background-color: #fff;
	padding: 2rem 6rem 1.5rem;
	margin-top: 2rem;
	position: relative;
}

.p-form__pic {
	position: absolute;
	top: 1rem;
	right: 3.6rem;
	width: 8.7rem;
	height: 6.2rem;
}

.p-form__head {
	font-size: 1.8rem;
	font-family: "line-b";
	color: #0072CE;
	margin-bottom: 1rem;
}

.p-form__item-wrap {
	display: flex;
	justify-content: space-between;
}

.p-form__item {
	width: 21.5rem;
	margin-top: 1rem;
}

.p-form__item--full {
	width: 100%;
}

.p-form__label {
	display: flex;
	align-items: center;
	font-size: 1.2rem;
	font-family: "line-b";
	color: #7A7872;
}

.p-form__required {
	display: inline-block;
	font-size: 0.9rem;
	font-family: "line-b";
	color: #fff;
	border-radius: 0.4rem;
	padding: 0.4rem 0.5rem;
	background-color: #0072CE;
	margin-right: 0.8rem;
}

.p-form__any {
	display: inline-block;
	font-size: 0.9rem;
	font-family: "line-b";
	color: #fff;
	border-radius: 0.4rem;
	padding: 0.4rem 0.5rem;
	background-color: #949494;
	margin-right: 0.8rem;
}

input.p-form__parts,
textarea.p-form__parts {
	width: 100%;
	height: 3.1rem;
	font-size: 1.2rem;
	font-family: "line-re";
	padding: 0 1.5rem;
	margin-top: 0.6rem;
	border: 0.1rem solid #AFAFAF;
	border-radius: 0.6rem;
	box-shadow: 0.1rem 0.1rem 0.6rem rgba(0, 0, 0, 0.16);
}

textarea.p-form__parts {
	width: 100%;
	height: 6.1rem;
	padding: 0.5rem 1.5rem;
}

input.p-form__parts::placeholder,
textarea.p-form__parts::placeholder {
	font-family: "line-re";
	color: #CBCBCB;
}

.p-form__txt-sml {
	font-size: 1rem;
	color: #7A7872;
	margin: 0.8rem 0 0 1rem;
}

.p-form__btn {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 30rem;
	height: 3.6rem;
	border-radius: 5.8rem;
	background-color: #FFD500;
	margin: 1.3rem auto 0;
}

.p-form__btn-txt {
	width: 100%;
	height: 100%;
	font-size: 1.5rem;
	font-family: "line-b";
	color: #262319;
	font-weight: 400;
}

.p-form__note {
	font-size: 0.8rem;
	text-align: center;
	margin-top: 0.8rem;
	color: #7A7872;
}

.p-form__link {
	display: inline-block;
	text-decoration: underline;
	color: #7A7872;
	margin: 0 0.3rem;
}

.error {
	display: none;
	font-size: 1.1rem;
	color: red;
	margin-top: 0.3rem;
}

.p-ftg {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	background-color: #fff;
	box-shadow: 0 -0.3rem 0.3rem rgba(0, 0, 0, 0.16);
	z-index: 98;
}

.p-ftg__flex {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 2rem 2.5rem;
}

.p-ftg__txt-wrap {
	margin-right: 3.3rem;
}

.p-ftg__txt {
	font-size: 1.9rem;
	font-family: "Noto Sans JP", serif;
	font-weight: 700;
	text-align: center;
}

.p-ftg__txt-sml {
	font-size: 1.6rem;
	margin-top: 1.5rem;
}

.p-ftg__btn {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 48rem;
	height: 6.7rem;
	font-size: 2.3rem;
	font-family: "line-b";
	color: #262319;
	background-color: #FFD500;
	border-radius: 5.8rem;
	box-shadow: 0 0.3rem 0 #ECC222;
	margin-top: 0.8rem;
	transition: all 0.3s;
}

.p-ftg__btn::after {
	content: "";
	background-image: url(../img/arrow_black_right.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	display: inline-block;
	width: 1.2rem;
	height: 2rem;
	margin-left: 1rem;
	transform: translateY(-0.1rem);
}

.p-ftg__btn-sp {
	display: none;
}

.p-fv {
	background-image: url(../img/fv_pc.jpg?240129_1);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	width: 100%;
	height: 67.1rem;
	max-width: 192rem;
	margin: 0 auto;
}

.p-g-nav__items {
	display: flex;
	align-items: center;
}

.p-g-nav__item {
	margin-left: 2.3rem;
}

.p-g-nav__info {
	display: none;
}

.p-g-nav__info-ttl {
	font-size: 2rem;
	font-family: "Noto Sans JP", serif;
	font-weight: 700;
	line-height: 1.8;
}

.p-g-nav__info-txt {
	font-size: 1.6rem;
	margin-top: 1.5rem;
	line-height: 1.5;
}

.p-g-nav__link {
	display: flex;
	align-items: center;
	font-size: 1.6rem;
	font-family: "line-b";
	color: #262319;
}

.p-g-nav__link::before {
	content: "";
	background-image: url(../img/arrow_blue_right.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	display: inline-block;
	width: 1.6rem;
	height: 1.6rem;
	margin-right: 0.9rem;
}

.p-g-nav__btn {
	justify-content: center;
	width: 22.8rem;
	height: 4.2rem;
	font-size: 1.5rem;
	background-color: #FFD500;
	border-radius: 5.8rem;
	box-shadow: 0 0.3rem 0 #ECC222;
	transition: all 0.3s;
}

.p-g-nav__btn::before {
	content: none;
}

.p-g-nav__btn::after {
	content: "";
	background-image: url(../img/arrow_black_right.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	display: inline-block;
	width: 0.8rem;
	height: 1.2rem;
	margin-left: 0.8rem;
	transform: translateY(-0.1rem);
}

.p-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.8rem 0;
}

.p-header__logo img {
	width: 10.8rem;
}

.p-header__logo-link {
	display: flex;
	align-items: center;
}

.p-header__logo-txt {
	font-size: 1.6rem;
	font-family: "line-b";
	color: #0072CE;
	line-height: 1.3;
	margin-left: 2rem;
}

.p-info {
	display: flex;
	max-width: 113rem;
	width: 100%;
	background-color: #DEF4FA;
	border: 0.1rem solid #E4E4E4;
	margin: 6.5rem auto 0;
}

.p-info__head {
	align-self: center;
	width: 11.5%;
	font-size: 1.3rem;
	font-family: "line-b";
	text-align: center;
	color: #0072CE;
}

.p-info__items {
	width: 88.5%;
	padding: 0.8rem 0 0.8rem 0;
	background-color: #fff;
}

.p-info__item {
	display: flex;
	align-items: center;
	padding-left: 20px;
}

.p-info__item:nth-of-type(n + 2) {
	margin-top: 1rem;
}

.p-info__pic {
	flex-shrink: 0;
	width: 7.5rem;
	text-align: center;
}

.p-info__item:nth-of-type(1) .p-info__pic img {
	width: 5.1rem;
}

.p-info__item:nth-of-type(2) .p-info__pic img {
	width: 4.3rem;
}

.p-info__item:nth-of-type(3) .p-info__pic img {
	width: 5.4rem;
}

.p-info__flex {
	display: flex;
	align-items: center;
}

.p-info__cat {
	display: inline-block;
	width: 21.1rem;
	font-size: 1.3rem;
}

.p-info__cat span {
	display: inline-block;
	padding: 0.4rem 0.6rem;
	border: 0.1rem solid #716f69;
}

.p-info__ttl-wrap {
	color: #262319;
	position: relative;
	width: 69rem;
}

.p-info__ttl-wrap::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 1rem;
	transform: translateY(-50%);
	background-image: url(../img/arrow_blue_right.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	display: inline-block;
	width: 1.6rem;
	height: 1.6rem;
}

.p-info__ttl {
	font-size: 1.3rem;
}

.p-info__ttl .p-info__ttl-blue {
	font-family: "line-b";
	color: #0072CE;
}

.p-info__ttl-bb {
	text-decoration: underline;
}

.p-other {
	padding: 4.2rem 0 5rem;
	margin-top: 11rem;
}

.p-other__items {
	display: flex;
	justify-content: space-between;
	margin-top: 6.5rem;
}

.p-other__item {
	width: 58rem;
	border-radius: 1.3rem;
	padding: 5.4rem 3.8rem 3rem;
	background-color: #fff;
	position: relative;
}

.p-other__item-ttl {
	position: absolute;
	top: -2.6rem;
	left: 0;
	display: flex;
	align-items: center;
	height: 5.1rem;
	font-size: 2.4rem;
	font-family: "line-b";
	color: #fff;
	text-align: center;
	padding: 0 5.9rem 0 4.8rem;
	border-radius: 0 2.6rem 2.6rem 0;
	background-color: #0072CE;
}

.p-other__item-pic {
	width: 30.9rem;
	height: 20.6rem;
	margin: 0 auto;
}

.p-other__item-pic img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.p-other__item-txt {
	font-size: 1.5rem;
	line-height: 1.6;
	margin-top: 3.5rem;
}

.p-other__item-link-wrap {
	text-align: right;
	margin-top: 3rem;
}

.p-other__item-link {
	font-size: 1.5rem;
	color: #262319;
}

.p-other__item-link::before {
	content: "";
	background-image: url(../img/arrow_blue_right.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	display: inline-block;
	width: 1.6rem;
	height: 1.6rem;
	margin-right: 2rem;
	transform: translateY(0.25rem);
}

.p-support {
	padding: 4rem 0 5.5rem;
	margin-top: 0rem;
}

.p-support__head {
	font-size: 2.5rem;
	font-family: "line-b";
	line-height: 1.6;
	text-align: center;
	margin-top: 1.7rem;
}

.p-support__items {
	display: flex;
	justify-content: space-between;
	margin-top: 6rem;
}

.p-support__item {
	width: 58rem;
	border-radius: 1.3rem;
	padding: 4.3rem 3.8rem 3rem;
	background-color: #fff;
	position: relative;
}

.p-support__item-head {
	position: absolute;
	top: -2.6rem;
	left: 0;
	display: flex;
	align-items: center;
	height: 5.1rem;
	font-size: 2.4rem;
	font-family: "line-b";
	color: #fff;
	text-align: center;
	padding: 0 5.9rem 0 4.8rem;
	border-radius: 0 2.6rem 2.6rem 0;
	background-color: #0072CE;
}

.p-support__item-pic {
	margin-bottom: 1rem;
}

.p-support__item-txt {
	font-size: 1.4rem;
	line-height: 1.8;
}

.p-support__item-example {
	font-size: 1.4rem;
	font-family: "line-b";
	color: #0072CE;
	margin: 2rem 0 0.5rem;
}

.p-support__example-ttl {
	font-size: 1.7rem;
	font-family: "line-b";
	line-height: 1.7;
	padding-top: 2.2rem;
	padding-left: 2.2rem;
	position: relative;
}

.p-support__example-ttl::before {
	content: "";
	position: absolute;
	bottom: 0.1rem;
	left: 0;
	width: 0.6rem;
	height: 2.8rem;
	background-color: #0072CE;
}

.p-support__example {
	border-radius: 1.3rem;
	margin-top: 1rem;
}

.p-support__example-item {
	display: flex;
	justify-content: space-between;
	padding: 0.7rem 1.2rem;
}

.p-support__example-item:last-of-type {
	border-bottom: none;
}

.p-support__example-pic {
	width: 17.3rem;
}

.p-support__example-company-wrap {
	width: 27.3rem;
}

.p-support__example-company {
	font-size: 1.5rem;
	font-family: "line-b";
	margin-top: 0.3rem;
}

.p-support__example-txt {
	font-size: 1.2rem;
	line-height: 1.5;
	margin-top: 1.2rem;
}

.p-tax {
	padding: 6rem 0 5.5rem;
}

.p-tax__head {
	font-size: 2.5rem;
	font-family: "line-b";
	line-height: 1.6;
	text-align: center;
	margin-top: 2.3rem;
}

.p-tax__table {
	width: 75rem;
	margin: 3.6rem auto 0;
}

.p-tax__table td {
	font-size: 1.4rem;
	padding: 1.5rem 2rem;
	border: 0.1rem solid #d9d9d6;
}

.p-tax__table td:nth-of-type(1) {
	width: 19rem;
}

.p-tax__table .p-tax__table-bg-blue {
	font-size: 1.6rem;
	text-align: center;
	background-color: #DEF4FA;
}

.p-tax__table-bg-gray {
	background-color: #F2F2F1;
}

.p-tax__table-b {
	font-family: "line-b";
}

.p-tax__txt {
	width: 75rem;
	font-size: 1.2rem;
	margin: 1.5rem auto 0;
}

.p-thanks {
	margin: 15rem 0;
	text-align: center;
}

.p-thanks__txt {
	font-size: 2.5rem;
	font-family: "line-b";
}

.p-thanks__link {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 23rem;
	height: 6.7rem;
	font-size: 2.3rem;
	font-family: "line-b";
	color: #262319;
	background-color: #FFD500;
	border-radius: 5.8rem;
	box-shadow: 0 0.3rem 0 #ECC222;
	margin: 6rem auto 0;
	transition: all 0.3s;
}

.p-thanks__link::after {
	content: "";
	background-image: url(../img/arrow_black_right.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	display: inline-block;
	width: 0.9rem;
	height: 1.5rem;
	margin-left: 1.1rem;
}

/* ==========================================================
# utility
========================================================== */

.u-bg-blue {
	background-color: #DEF4FA;
}

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

.hover {
	transition: opacity 0.3s;
}

.hover:hover {
	opacity: 0.7;
	transition: opacity 0.3s;
}

.c-cta__link:hover {
	text-decoration: none;
	box-shadow: none;
	transform: translateY(0.3rem);
	transition: all 0.3s;
}

.p-g-nav__link:hover {
	text-decoration: underline;
}

.p-g-nav__btn:hover {
	text-decoration: none;
	box-shadow: none;
	transform: translateY(0.3rem);
	transition: all 0.3s;
}

.p-thanks__link:hover {
	text-decoration: none;
	box-shadow: none;
	transform: translateY(0.3rem);
	transition: all 0.3s;
}

}

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

.l-header__inner {
	max-width: 124rem;
}

.p-g-nav__item {
	margin-left: 2rem;
}

.p-g-nav__link {
	font-size: 1.4rem;
}

.p-g-nav__btn {
	width: 21rem;
	font-size: 1.4rem;
}

.p-header__logo img {
	width: 9rem;
}

.p-header__logo-txt {
	font-size: 1.4rem;
	margin-left: 1rem;
}

}

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

html,
body {
	font-size: 0.78125vw;
}

}

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

.pc {
	display: none;
}

.tb {
	display: block;
}

}

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

html,
body {
	font-size: 2.5445292621vw;
}

.tb {
	display: none;
}

.sp {
	display: block;
}

.l-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	border-top: 0.7rem solid #0072CE;
	z-index: 99;
}

.l-header__inner {
	max-width: 100%;
	width: 100%;
	padding: 0 0.5rem 0 1rem;
}

.l-inner {
	max-width: 100%;
	width: 100%;
	padding-left: 1.2rem;
	padding-right: 1.2rem;
}

.l-inner--p-fv {
	padding: 0;
}

.l-inner--p-info {
	padding: 0;
}

.c-cta {
	margin-top: 3rem;
}

.c-cta--none {
	display: none;
}

.c-cta__head {
	font-size: 2rem;
	line-height: 1.8;
}

.c-cta__txt {
	line-height: 1.5;
}

.c-cta__btn {
	width: 34.2rem;
	height: 4.7rem;
	margin: 1.5rem auto 0;
}

.c-cta__link {
	font-size: 1.6rem;
}

.c-ttl--sml::before,
.c-ttl--sml::after {
	width: 3.2rem;
}

.c-ttl--sml::before {
	left: -5rem;
}

.c-ttl--sml::after {
	right: -5rem;
}

.p-about {
	margin-top: 2.2rem;
}

.p-about__info {
	width: 100%;
	align-items: flex-start;
	justify-content: flex-start;
	flex-direction: column;
	position: relative;
}

.p-about__info-wrap {
	width: 100%;
}

.p-about__info-flex {
	flex-direction: column;
}

.p-about__info-ttl {
	font-size: 2rem;
	line-height: 1.6;
	margin-left: 0;
}

.p-about__info-txt {
	margin-top: 26.5rem;
}

.p-about__features-items {
	position: absolute;
	top: 26rem;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
}

.p-about__link {
	text-align: right;
	margin-top: 1rem;
}

.p-about__items {
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	width: 100%;
	margin: 0;
}

.p-about__item {
	width: 32rem;
	margin-top: 4.3rem;
}

.p-about__item:first-of-type {
	margin-top: 5rem;
}

.p-about__sdgs {
	align-items: flex-start;
	justify-content: center;
	flex-direction: column;
	background-color: #EFEFEF;
	padding: 3.5rem 1.3rem 4.2rem;
	margin-top: 2.8rem;
}

.p-about__sdgs-pic {
	margin: 0 auto;
}

.p-about__sdgs-txt {
	width: 100%;
	font-size: 1.5rem;
	line-height: 1.9;
	margin-top: 3rem;
}

.p-burger {
	display: block;
	padding: 1.4rem 1rem 1.1rem 1rem;
	z-index: 10;
}

.p-flow {
	padding: 5rem 0 4rem;
}

.p-flow__head {
	font-size: 2rem;
	line-height: 1.8;
}

.p-flow__pic {
	width: 100%;
	margin: 2rem auto 0;
}

.p-flow__note-wrap {
	width: 100%;
	margin: 2.5rem auto 0;
	padding: 0 1.5rem;
}

#footer {
	margin-bottom: 0;
}

#footer > .top .inner {
	margin: 0 4%;
	padding: 4% 0;
	display: block;
	width: auto;
}

#footer > .top .inner .txt {
	line-height: 1.4;
	justify-content: center;
}

#footer > .top .inner .logo {
	width: 7rem;
}

#footer > .top .inner .address {
	font-size: 1rem;
	padding-left: 1.5rem;
}

#footer > .top .inner .address p {
	font-size: 1rem;
}

#footer > .top .inner .address .name {
	font-size: 1rem;
	margin-bottom: 0.2em;
}

#footer > .top .inner .access {
	text-align: center;
	margin-top: 2.89855%;
	margin-left: 0;
}

#footer > .top .inner .access .btn {
	font-size: 1.1rem;
	border-radius: 10rem;
	padding: 0.8rem 2rem;
}

#footer > .top .inner .access .btn:before {
	margin-right: 1rem;
	width: 1.2rem;
	height: 1.5rem;
}

#footer > .middle .inner {
	margin: 0 4%;
	padding: 8% 0;
	display: block;
	width: auto;
}

#footer > .middle .inner ul + ul {
	margin-top: 0.9rem;
}

#footer > .middle .inner ul li {
	font-size: 1.2rem;
}

#footer > .middle .inner ul li + li {
	margin-top: 0.9rem;
}

#footer > .middle .inner ul li a::before {
	margin-top: -0.2em;
	margin-right: 1.2rem;
	border-width: 0.3rem 0 0.3rem 0.4rem;
}

#footer > .bottom {
	padding: 4.34783% 4%;
}

#footer > .bottom .copyright {
	font-size: 1rem;
	line-height: 1.75;
}

.p-form {
	top: 2.5rem;
	right: auto;
	left: auto;
	min-width: auto;
	height: auto;
	z-index: 1;
	background-color: transparent;
	padding: 0 1.5rem 0;
}

.p-form__ttl {
	font-size: 1.6rem;
}

.p-form__txt {
	font-size: 2.6rem;
	letter-spacing: -0.01em;
}

#formSp .p-form__area {
	display: block;
	border-radius: 0;
	padding: 5.4rem 3.5rem 5.5rem;
	margin-top: 0;
}

.p-form__pic {
	top: 3.5rem;
	right: 0rem;
	width: 9.4rem;
	height: 6.7rem;
	transform: rotate(13deg);
}

.p-form__head {
	margin-bottom: 0;
}

.p-form__item-wrap {
	flex-direction: column;
	justify-content: flex-start;
}

.p-form__item-wrap--mt {
	margin-top: 1rem;
}

.p-form__item {
	width: 100%;
}

.p-form__required {
	font-size: 1.1rem;
	padding: 0.4rem 0.4rem 0.3rem;
}

.p-form__any {
	font-size: 1.1rem;
	padding: 0.4rem 0.4rem 0.3rem;
}

input.p-form__parts,
textarea.p-form__parts {
	height: 3.3rem;
}

textarea.p-form__parts {
	height: 11rem;
}

.p-form__txt-sml {
	font-size: 1.1rem;
}

.p-form__btn {
	width: 24rem;
	height: 4.2rem;
	margin: 1.6rem auto 0;
	position: relative;
}

.p-form__btn::after {
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 1.2rem;
	background-image: url(../img/arrow_black_right.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	display: inline-block;
	width: 0.9rem;
	height: 1.5rem;
	pointer-events: none;
}

.p-form__btn-txt {
	transform: translateX(-0.5rem);
}

.p-form__note {
	font-size: 1.1rem;
	width: 100vw;
	margin: 1rem calc(50% - 50vw);
}

.p-ftg {
	background-color: rgba(255, 255, 255, 0.9);
}

.p-ftg__flex {
	flex-direction: column;
	padding: 1rem 0;
	width: 100%;
}

.p-ftg__txt-wrap {
	margin-right: 0;
}

.p-ftg__txt {
	font-size: 1.1rem;
}

.p-ftg__txt-sml {
	display: none;
}

.p-ftg__btn {
	width: 27.7rem;
	height: 5.1rem;
	font-size: 1.8rem;
	margin: 0.8rem auto 0;
}

.p-ftg__btn::after {
	width: 1rem;
	height: 1.4rem;
	margin-left: 1rem;
}

.p-ftg__btn-sp {
	display: flex;
}

.p-ftg__btn-pc {
	display: none;
}

.p-fv {
	margin-top: 6.9rem;
	background-image: url(../img/fv_sp.jpg?240129_1);
}

.p-g-nav {
	position: fixed;
	top: 6.9rem;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	overflow: auto;
	background-color: #fff;
	height: 0;
	opacity: 0;
	visibility: hidden;
}

.p-g-nav.is-open {
	height: auto;
	opacity: 1;
	visibility: visible;
	transition: opacity 0.3s;
}

.p-g-nav__items {
	align-items: start;
	flex-direction: column;
	margin: 2.5rem 0 10rem;
}

.p-g-nav__item {
	width: 100%;
	margin-left: 0;
	border-bottom: 0.1rem solid #E4E4E4;
}

.p-g-nav__item.p-g-nav__item--bb-none {
	border-bottom: none;
}

.p-g-nav__item--sp-none {
	display: none;
}

.p-g-nav__info {
	display: block;
	text-align: center;
	background-color: #DEF4FA;
	padding: 5.8rem 0 4.5rem;
}

.p-g-nav__link {
	font-size: 2rem;
	padding: 2.5rem 2rem;
}

.p-g-nav__link::before {
	width: 2rem;
	height: 2rem;
	margin-right: 1.2rem;
}

.p-g-nav__btn {
	width: 34.2rem;
	height: 4.7rem;
	font-size: 1.6rem;
	padding: 0;
	margin: 1.1rem auto 0;
}

.p-g-nav__btn::after {
	width: 1rem;
	height: 1.4rem;
	margin-left: 1rem;
}

.p-header {
	padding: 0;
}

.p-header__logo img {
	width: 8.1rem;
}

.p-header__logo-txt {
	line-height: 1.15;
	margin-left: 1.5rem;
}

.p-info {
	flex-direction: column;
	max-width: 100%;
	background-color: transparent;
	border: none;
	margin: 2.5rem auto 0;
}

.p-info__head {
	align-self: auto;
	width: 100%;
	font-size: 2rem;
	padding: 2.5rem 0;
	background-color: #DEF4FA;
}

.p-info__items {
	width: 100%;
	padding: 0;
	margin-top: 1rem;
}

.p-info__item {
	align-items: flex-start;
	padding: 2rem 1.2rem;
}

.p-info__item:nth-of-type(n + 2) {
	border-top: 0.1rem solid #E4E4E4;
}

.p-info__item:nth-of-type(n + 2) {
	margin-top: 0;
}

.p-info__pic {
	width: 11rem;
	text-align: left;
}

.p-info__item:nth-of-type(1) .p-info__pic img {
	width: 9.9rem;
}

.p-info__item:nth-of-type(2) .p-info__pic img {
	width: 9rem;
}

.p-info__item:nth-of-type(3) .p-info__pic img {
	width: 10rem;
}

.p-info__flex {
	width: 33.9rem;
	flex-direction: column;
	align-items: flex-start;
}

.p-info__cat {
	width: 100%;
}

.p-info__ttl-wrap {
	width: 100%;
	line-height: 1.7;
}

.p-info__ttl-wrap::after {
	position: absolute;
	top: 3.5rem;
	right: -2.3rem;
}

.p-info__ttl {
	font-size: 1.4rem;
	margin-top: 1rem;
	position: relative;
}

.p-other {
	padding: 4rem 0 3rem;
	margin-top: 3.2rem;
}

.p-other__items {
	flex-direction: column;
	justify-content: flex-start;
	margin-top: 5rem;
}

.p-other__item {
	width: 100%;
	padding: 5.4rem 3rem 2.5rem;
}

.p-other__item:nth-of-type(n + 2) {
	margin-top: 4.5rem;
}

.p-other__item-ttl {
	top: -2.2rem;
	height: 4.4rem;
	font-size: 2rem;
	padding: 0 2rem 0 3rem;
	border-radius: 0 2.6rem 2.6rem 0;
}

.p-other__item-pic {
	width: 100%;
}

.p-other__item-txt {
	margin-top: 3rem;
}

.p-other__item-link-wrap {
	margin-top: 1.5rem;
}

.p-other__item-link::before {
	margin-right: 0.8rem;
}

.p-support {
	padding: 4rem 0 5rem;
	margin-top: 4.2rem;
}

.p-support__head {
	font-size: 2rem;
}

.p-support__items {
	flex-direction: column;
	justify-content: flex-start;
	margin-top: 4.5rem;
}

.p-support__item {
	width: 100%;
	padding: 4.3rem 1.4rem 3rem;
}

.p-support__item:nth-of-type(n + 2) {
	margin-top: 4.5rem;
}

.p-support__item-head {
	top: -2.2rem;
	height: 4.4rem;
	font-size: 2rem;
	padding: 0 5rem 0 3.5rem;
	border-radius: 0 2.6rem 2.6rem 0;
}

.p-support__item-pic {
	margin-bottom: 1.5rem;
}

.p-support__example {
	padding: 0;
}

.p-support__example-item {
	flex-direction: column;
	justify-content: flex-start;
	padding: 0 1.2rem 1.8rem;
}

.p-support__example-pic {
	margin: 0 auto;
}

.p-support__example-company-wrap {
	width: 100%;
}

.p-support__example-company {
	text-align: center;
}

.p-tax {
	padding: 4rem 0 3rem;
}

.p-tax__head {
	font-size: 2rem;
	line-height: 2;
	margin-top: 3rem;
}

.p-tax__table {
	width: 100%;
	margin: 3rem auto 0;
}

.p-tax__table td {
	padding: 1.5rem 2.5rem;
	line-height: 1.5;
}

.p-tax__table td:nth-of-type(1) {
	width: 8.5rem;
}

.p-tax__txt {
	width: 100%;
	line-height: 1.8;
}

.p-thanks {
	margin: 15rem 0 10rem;
}

.p-thanks__txt {
	font-size: 2rem;
}

.p-thanks__link {
	font-size: 2rem;
	width: 21rem;
	height: 5.1rem;
	margin: 5rem auto 0;
}

}


/*# sourceMappingURL=style.css.map */
