@charset "UTF-8";
/*** The new CSS reset - version 1.5.1 (last updated 1.3.2022) ***/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap");
html {
    font-size: 10px;
	line-height: 2em;
    font-family: Noto Sans JP,sans-serif;
    font-weight: 400;
    font-style: normal;
    background: #FFFFFF;
    color: #3f3f3f;
    overflow-x: hidden;
    overscroll-behavior-y: none;
    font-feature-settings: "palt";
}

body {
	margin: 0;
	padding: 0;
}

*,
*::before,
*::after {
    background-repeat: no-repeat;
    box-sizing: inherit;
}

a,
button {
  cursor: revert;
}
a {
	text-decoration: none;
}
a:hover {
	opacity: 0.6;
}
p,
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
}
p {
	font-size: 1.75rem;
	line-height: 3rem;
}
@media screen and (max-width: 766px) {
	p {
		font-size: 1.4rem;
		line-height: 2.5rem;
	}
}
ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

img {
  max-width: 100%;
}

table {
  border-collapse: collapse;
}

textarea {
  white-space: revert;
}

meter {
  -webkit-appearance: revert;
  appearance: revert;
}
.taleft {
	text-align: left;
}
.tacenter {
	text-align: center;
}
.taright {
	text-align: right;
}
.lp_clolor_green {
	color: #007c72;
}
.notion {
    font-size: 50% !important;
    vertical-align: top;
    position: relative;
    top: -0.2em;
    padding-right: 2px;
}
.fs80_ {
	font-size: 80%;
	line-height: 0.5em;
}
.fs110_ {
	font-size: 110%;
}
.mb6_ {
	margin-bottom: 6rem;
}
.white {
	color: #FFFFFF;
}
.w1200 {
	display: block;
	width: 1200px;
	box-sizing: border-box;
	margin: 0 auto;
}
.w1400 {
	display: block;
	width: 1400px;
	box-sizing: border-box;
	margin: 0 auto;
}
.lp_pc {
   display: block;
}
.lp_sp {
   display: none;
}
@media screen and (max-width: 766px) {
  .lp_pc {
    display: none;
  }
  .lp_sp {
    display: block;
  }
}
@media screen and (max-width: 1400px) and (min-width: 767px) {
	.w1200, .w1400 {
		width: 100%;
		max-width: 100%;
		box-sizing: border-box;
	}
}
@media screen and (max-width: 766px) {
	.w1200, .w1400 {
		width: 100%;
		box-sizing: border-box;
	}
}
.lp_block_flex ,.lp_box_flex {
	display: flex;
    align-items: top;
    justify-content: space-between;
}
.lp_cta {
    width: 100%;
    height: auto;
	padding-top: 6rem;
	padding-bottom: 6rem;
}
@media screen and (max-width: 766px) {
	.lp_cta {
		background-repeat: no-repeat;
		width: 100%;
		height: auto;
		padding-top: 4rem;
		padding-bottom: 4rem;
	}	
}
.lp_cta_block {
	display: flex;
	justify-content: center;
}
@media screen and (max-width: 766px) {
	.lp_cta_block {
		display: block;
		width: 90%;
		margin: 0 auto;
	}
}
.lp_cta_block a {
	width: 30%;
    align-items: center;
	text-align: center;
    white-space: nowrap;
    min-height: 2.5em;
    border-radius: 100vmax;
    font-weight: 700;
    font-size: 2.25rem;
    line-height: 1;
    letter-spacing: .05em;
    padding-bottom: 3rem;
	padding: 2.5rem 1rem;
	margin-left: 5rem;
	box-shadow: 0 0.4rem 0.6rem 0.1rem #e9e1d4;
}
@media screen and (max-width: 766px) {
	.lp_cta_block a {
		display: block;
		text-align: center;
		width: 100%;
		align-items: center;
		white-space: nowrap;
		min-height: 2.5em;
		border-radius: 100vmax;
		font-weight: 700;
		font-size: 2rem;
		line-height: 1;
		letter-spacing: .05em;
		padding-bottom: 3rem;
		padding: 2.5rem 1rem;
		margin: 0 auto;
		box-shadow: 0 0.4rem 0.6rem 0.1rem #e9e1d4;
	}
}
.lp_cta_block a:first-child {
	margin-left: 0rem;
}
@media screen and (max-width: 766px) {
	.lp_cta_block a:first-child {
		margin-bottom: 2rem;
		margin-right: 0;
		margin-left: 0;
	}	
}
.lp_cta_block a.lp_cta_download {
	background-color: #bb7540;
    color:#FFFFFF;
	border: 1px solid #FFFFFF;
}
.lp_cta_block a.lp_cta_inq {
	background-color: #FFFFFF;
    color:#bb7540;
	border: 1px solid #bb7540;
}
header {
	background: #FFF;
	width: 96%;
	height: 64px;
	padding: 15px 2%;
	position: fixed;/*fixedで固定*/
    top: 0;
	z-index: 1000;
}
@media screen and (max-width: 766px) {
	header {
		width: 100%;
		height: 120px;
		padding: 15px 0 10px;
		box-sizing: border-box;
	}
	header .lp_block_flex {
		display: block;
	}
}
header .header_left {
	width: 35%;
	vertical-align: middle;
}
@media screen and (max-width: 766px) {
	header .header_left {
		width: 100%;
		text-align: center;
		margin-bottom: 1rem;
	}
}
header .header_left h1 img {
	max-width: 300px;
	width: 100%
}
@media screen and (max-width: 766px) {
	header .header_left h1 img {
		max-width: 180px;
		width: 100%
	}
}
header .header_right {
	display: flex;
}
header .header_right a {
	display: flex;
	justify-content: flex-end;
	align-items: center;
}
@media screen and (max-width: 766px) {
	header .header_right {
		width: 100%;
		align-items: center;
		justify-content: center;
	}
}
.header_right a {
	display: flex;
    align-items: center;
	justify-content: center;
    height: 5rem;
    min-height: 2.5em;
    border-radius: 100vmax;
    font-weight: 700;
    font-size: 1.5rem;
    line-height: 1;
    letter-spacing: .05em;
    padding-bottom: 0.1rem;
	padding-inline: 3.5rem;
	margin-left: 1rem;
}
.header_right a:last-child {
	display: flex;
    align-items: center;
    white-space: nowrap;
    height: 5rem;
    min-height: 2.5em;
    font-weight: 700;
    font-size: 1.5rem;
    line-height: 1;
    letter-spacing: .05em;
    padding-bottom: 0.1rem;
	padding-inline: 3.5rem;
	margin-left: 1rem;
}
@media screen and (max-width: 766px) {
	.header_right a , .header_right a:last-child {
		display: flex;
		height: 2rem;
		min-height: 2.5em;
		border-radius: 100vmax;
		font-weight: 600;
		font-size: 1.25rem;
		line-height: 1;
		letter-spacing: .025em;
		padding-inline: 1rem 5rem 1rem 5rem;
		margin-left: 0.5rem;
	}
}
.header_right a.header_right_demo {
	background-color: #bb7540;
    color:#FFFFFF;
	border: 1px solid #FFFFFF;
	box-shadow: 0 .25rem .5625rem rgba(0, 124, 114, .1);
}
.header_right a.header_right_download {
	background-color: #FFFFFF;
    color:#bb7540;
	border: 1px solid #bb7540;
	box-shadow: 0 .25rem .5625rem rgba(0, 124, 114, .1);
}
.header_right a.header_right_inq {
    color:#423c33;
}
@media screen and (max-width: 766px) {
	.header_right a.header_right_demo,
	.header_right a.header_right_download {
		box-shadow: 0 .25rem .5625rem rgba(0, 124, 114, .1);
	}
}
main {
	width: 100%;
	padding-top: 100px;
}
main img {
	width: 100%;
	margin: 0 auto;
}
@media screen and (max-width: 766px) {
	main {
		padding-top: 90px;
	}
}

.lp_footer {
	background-repeat: no-repeat;
	background-size: cover;
	background-position: top center;
	background-color: #423c33;
	padding: 12rem 0 5rem;
}
@media screen and (max-width: 766px) {
	.lp_footer {
		padding: 6rem 0 2.5rem;
	}
}
.lp_footer_block {
	width: 90%;
}
.footer__card {
    background: rgba(255,255,255,.25);
    box-shadow: 0 0.6rem 1.5rem 0.2rem #423c33;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: 1fr auto;
    grid-template-areas:
        "head head"
        "title title"
        "text icon";
}
@media screen and (min-width: 767px) {
	.footer__card {
		width: 48%;
		min-height: 25rem;
		padding: 3.5rem 4rem 3.3rem;
		border-radius: 2.4rem;
	}
}
@media screen and (max-width: 766px) {
	.lp_footer_block .lp_block_flex {
		display: block;
	}	
	.footer__card {
		width: 100%;
		min-height: 20rem;
		padding: 2.6rem 3rem 2.7rem;
		border-radius: 2rem;
		margin-bottom: 2rem;
	}
}
.lp_footer_block {
	margin-bottom: 5rem;
}
.footer__card__title {
    grid-area: title;
    font-weight: 700;
    color: #FFFFFF;
    letter-spacing: .05em;
    transition-property: color;
    transition-duration: .3s;
    transition-timing-function: ease-out;
    line-height: 1;
}
.footer__card__title {
	font-size: 3rem;
}
@media screen and (max-width: 766px) {
	.footer__card__title {
		font-size: 2.5rem;
	}
}
.footer__card__text {
    height: -moz-fit-content;
    height: fit-content;
    grid-area: text;
    color: #FFFFFF;
    text-align: justify;
    letter-spacing: .1em;
}
@media screen and (min-width: 767px) {
	.footer__card__text {
		white-space: nowrap;
		font-size: 1.5rem;
		line-height: 1.75;
		margin-top: 2.1rem;
		margin-right: 5rem;
	}
}
@media screen and (max-width: 766px) {
	.footer__card__text {
		font-size: 1.3rem;
		line-height: 1.76;
		margin-top: 1.4rem;
	}
}
@media screen and (max-width: 766px) {
	.footer__card__text.footer__card__text__request,
	.footer__card__text.footer__card__text__contanct {
		width: 20rem;
	}
}
.footer__card__icon {
    display: block;
    grid-area: icon;
    margin-top: auto;
}
@media screen and (min-width: 767px) {
	.footer__card__icon {
		margin-bottom: 0.7rem;
	}
}
.arrow-in-circle {
    --circle-color: #FFFFFF;
    --arrow-color: #007C72;
    position: relative;
    display: grid;
    place-items: center;
    aspect-ratio: 1/1;
    border-radius: 50%;
    background-color: #FFFFFF;
    --circle-width: 5rem;
    width: var(--circle-width);
}
.arrow-in-circle:before {
    content: "";
    position: absolute;
    display: block;
    aspect-ratio: 18 / 16;
    -webkit-mask: url(../img/lp/line-arrow-423c33.svg) 50% 50%/contain no-repeat;
    mask: url(../img/lp/line-arrow-423c33.svg) 50% 50%/contain no-repeat;
    --arrow-width: 1.8rem;
    width: 1.8rem;
    background-color: #423c33;
}
.lp_footer_logo {
	display: flex;
	justify-content: center;
	margin-bottom: 5rem;
}
@media screen and (max-width: 766px) {
	.lp_footer_logo {
		margin-bottom: 2.5rem;
	}
}
.lp_footer_logo a {
  display: flex;
}
.lp_footer_logo img {
   width: 30rem;
}
@media screen and (max-width: 766px) {
	.lp_footer_logo img {
	   width: 20rem;
	}
}
.lp_footer_copy {
  text-align: center;
}
.lp_footer_copy p {
	color: #fff;
    font-size: 1.5rem;
    line-height: 2rem;
    letter-spacing: 0em;
    font-weight: 400;
}
@media screen and (max-width: 766px) {
	.lp_footer_copy p {
		font-size: 1rem;
	}
}
.lp_inquary iframe {
	height: 1400px;
}