*, *::before, *::after {
	box-sizing: border-box
}
* {
	margin: 0
}

html, body {
  margin: 0;
  padding: 0;
  height: 100%; 
  box-sizing: border-box; 
}

input {
	font: inherit
}

p {
	overflow-wrap: break-word
}

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

a {
	color: inherit;
	text-decoration: none;
	transition: .3s ease
}

ul {
	padding: 0
}

li {
	list-style: none
}

@keyframes moveBtn {
	0% {
		-webkit-transform: translate(0, 0);
		transform: translate(0, 0)
	}
	50% {
		-webkit-transform: translate(0, 10px);
		transform: translate(0, 10px)
	}
	100% {
		-webkit-transform: translate(0, 0);
		transform: translate(0, 0)
	}
}

body {
	-webkit-font-smoothing: antialiased;
	-webkit-font-feature-settings: "palt";
	font-feature-settings: "palt";
	color: #333;
	font-family: "游ゴシック", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic Std", "Hiragino Sans", "ヒラギノ角ゴシック", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	font-size: 13px;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.8;
	margin: 0 auto;
	max-width: 520px;
	overflow-wrap: break-word;
    background-color: #f7f9fa;
}
@media screen and (max-width: 767px) {
	body {
	}
}

body.is-fixed {
	overflow: hidden
}

.l-main {
    min-height: calc(100vh - 200px);
    padding-bottom: 0px;
    box-sizing: border-box;
    position: relative;
}

.thanks-l-main {
	}
@media screen and (max-width: 767px) {
	.thanks-l-main {
		min-height: calc(100vh - 230px);
	}
}

.loading-l-main {
    min-height: calc(100vh - 197px);
}
@media screen and (max-width: 767px) {
	.oading-l-main {
		min-height: calc(100vh - 230px);
	}
}

.l-footer {
    background-color: #f8f9fa;
    padding: 0 0 170px;
    height: 50px;
    text-align: center;
}
@media screen and (max-width: 767px) {
	.l-footer {
		background-color: #f8f9fa;
		padding: 17px 0 10px;
		height: 10px;
	}
}	

.loading-l-footer {
}
@media screen and (max-width: 767px) {
.loading-l-footer {
	background-color: #f8f9fa;
	padding: 0 0 10px;
	height: 160px;
}
}

.thanks-l-footer {
}
@media screen and (max-width: 767px) {
.thanks-l-footer {
    background-color: #f8f9fa;
    padding: 0 0 10px;
    height: 10px;
}
}

.l-footer__inner {
	padding: 0 38px
}
@media screen and (max-width: 767px) {
	.l-footer__inner {
		padding: 0 20px;
	}
}

.p-diagnosis-section {
    padding: 25px 0 140px;
    position: relative;
}
@media screen and (max-width: 767px) {
	.p-diagnosis-section {
	padding: 25px 0 149px;
}
}
@media screen and (max-width: 430px) {
	.p-diagnosis-section {
	padding: 25px 0 171px;
}
}
@media screen and (max-width: 390px) {
	.p-diagnosis-section {
	padding: 25px 0 134px;
}
}

.p-diagnosis-section::before {
    background-image: url(../static/body_bg.webp);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: 100% auto; 
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0; 
    bottom: 0; 
    z-index: -2;
	height: calc(100%);
}
@media screen and (max-width: 767px) {
	.p-diagnosis-section {
		background-image: url(../static/body_bg_content.webp);
		background-size: 100% auto;
		background-repeat: no-repeat;
	}
	.p-diagnosis-section::before {
		background-image: url(../static/body_bg_sp.webp);
		background-size: cover;
	}
}

.questions-p-diagnosis-section {
	padding: 25px 0 120px;
	position: relative;
}

.p-form__question-img{
	margin-bottom: 28px;
}
@media screen and (max-width: 767px) {
	.p-form__question {
		align-items: top;
		display: flex;
		margin: 0 0 17px;
	}
}

.questions-p-diagnosis-section-01::before {
    height: var(--diagnosis-section-height);
    background-image: url(../static/step__section_bg.webp);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: 100% auto;
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: -2;
}
@media screen and (max-width: 767px) {
	.questions-p-diagnosis-section-01::before {
		background-size: cover;
	}
}

.questions-p-diagnosis-section-02::before {
    height: var(--diagnosis-section-height);
    background-image: url(../static/step__section_bg.webp);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: 100% auto;
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: -2;
}
@media screen and (max-width: 767px) {
	.questions-p-diagnosis-section-02::before {
		background-size: cover;
	}
}

.questions-p-diagnosis-section-03::before {
    height: var(--diagnosis-section-height);
    background-image: url(../static/step__section_bg.webp);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: 100% auto;
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: -2;
}
@media screen and (max-width: 767px) {
	.questions-p-diagnosis-section-03::before {
		background-size: cover;
	}
}

.p-loading-p-diagnosis-section::before {
    background-image: url(../static/loading__section_bg.webp);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: 100% auto;
    content: "";
    display: block;
    height: calc(100% - -272px);
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: -2;
}

.p-thanks-p-diagnosis-section::before {
    height: var(--diagnosis-section-height);
    background-image: url(../static/final__section_bg.webp);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: 100% auto;
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: -2;
}

.p-step-btn {
	-webkit-animation: moveBtn 2s ease 0s infinite normal none running;
	animation: moveBtn 2s ease 0s infinite normal none running;
	bottom: 0;
	left: calc(50% - 105px);
	position: fixed;
	z-index: 10
}

.p-step-btn .wrap {
    -webkit-transform: translateX(-50%);
    background-color: transparent;
    background-image: url(../static/btn_bg.webp);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    display: block;
	width: 464px;
    height: 144px;
    left: calc(24.5%);
    position: relative;
}

.p-step-btn-00 .wrap::after {
    -webkit-transform: translateX(-50%);
    background-color: transparent;
    background-image: url(../static/mv__btn_text.webp);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 20px;
    content: "";
    display: block;
	width: 110px;
	height: 80px;
    left: 50%;
    position: absolute;
    transform: translateX(-66%);  
}

.p-step-btn-01 .wrap::after {
    -webkit-transform: translateX(-50%);
    background-color: transparent;
    background-image: url(../static/step-01__btn_text.webp);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 20px;
    content: "";
    display: block;
    height: 80px;
	width: 110px;
    left: 50%;
    position: absolute;
    transform: translateX(-66%);
}
@media screen and (max-width: 767px) {
.p-step-btn-01 .wrap::after {
    bottom: 9px;
    height: 80px;
	width: 110px;
    left: 52%;
    position: absolute;
    transform: translateX(-66%);
}
}

.p-step-btn-02 .wrap::after {
    -webkit-transform: translateX(-50%);
    background-color: transparent;
    background-image: url(../static/step-02__btn_text.webp);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 20px;
    content: "";
    display: block;
    height: 80px;
    left: 56%;
    position: absolute;
    transform: translateX(-66%);
    width: 214.875px;
}
@media screen and (max-width: 767px) {
.p-step-btn-02 .wrap::after {
        bottom: 18px;
        left: 55%;
        width: 214.875px;
}
}

.p-step-btn-03 .wrap::after {
    -webkit-transform: translateX(-50%);
    background-color: transparent;
    background-image: url(../static/step-03__btn_text.webp);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 20px;
    content: "";
    display: block;
    height: 80px;
    left: 56%;
    position: absolute;
    transform: translateX(-66%);
    width: 214.875px;
}
@media screen and (max-width: 767px) {
.p-step-btn-03 .wrap::after {
    bottom: 9px;
    left: 55%;
	height: 90px;
}
}

.p-step-btn input {
	display: none
}
.p-step-btn.is-disabled {
	opacity: .6;
	pointer-events: none
}

.p-step-btn.m-start .wrap::after {
    background-image: url(../static/mv__btn_text.webp);
    height: 74px;
    width: 215px;
    top: 38%;
	margin-left: 6%;
}
@media screen and (max-width: 767px) {
.p-step-btn.m-start .wrap::after {
    height: 86px;
	width: 214px;
    margin-left: 24px;
    margin-top: -23px;
}
}
.p-step-btn.m-1 .wrap::after {
    background-image: url(../static/step-02__btn_text.webp);
    height: 74px;
    width: 215px;
    top: 38%;
    left: 56%;
}
.p-step-btn.m-2 .wrap::after {
    background-image: url(../static/step-03__btn_text.webp);
    bottom: 10px;
    height: 96px;
    width: 210px;
}
.p-mv::after {
	background-position: center 110%
}
.p-mv img {
	width: 100%
}
.p-mv__lead {
    margin-top: -24px;
    margin-bottom: 21px;
    padding-left: 11px;
    width: 420px;
    right: 1px;
}
@media screen and (max-width: 767px) {
	.p-mv__lead {
		width: 81%;
	}
}	
.p-mv__heading-01 {
    margin: -7px auto 21px;
    padding-left: 2px;
    width: 426px;
    right: 1px;
}
@media screen and (max-width: 767px) {
	.p-mv__heading-01 {
		margin: 10px auto 21px;
		width: 82%;
	}
}
.p-mv__heading-02 {
    margin: -15px auto 21px;
    padding-left: 16px;
    width: 474px;
    right: 1px;
}
@media screen and (max-width: 767px) {
	.p-mv__heading-02 {
		margin: -5px auto 21px;
		width: 364px;
		right: 1px;
	}
}
.p-mv__image {
    margin: -11px auto 21px;
    padding-left: 4px;
    left: 1%;
}
@media screen and (max-width: 767px) {
	.p-mv__image {
		margin: 0px auto 21px;
	}
}
.p-mv__image picture {
    display: block;
    margin: 0px auto;
    width: 490px;
}
@media screen and (max-width: 767px) {
	.p-mv__image picture {
		display: block;
		margin: 0 auto;
		width: 94%;
	}
}
.p-mv__point {
    margin: -5px auto 21px;
    width: 495px;
    right: 1px;
}
@media screen and (max-width: 767px) {
	.p-mv__point {
		margin: 35px auto 21px;
		width: 95%;
	}
}
.p-form {
	margin-top: 0;
	padding-top: 40px
}
@media screen and (max-width: 767px) {
.p-form {
	padding-top: 40px;
	padding-bottom: 125px;	
}
.q3-p-form {
	margin-top: 0;
	padding-bottom: 115px;
}
}

.p-form img {
	width: 100%
}
.p-form__title-01 {
	margin: 0 calc(50% - 50vw)
}
.p-form__title-02 {
	margin: 0 calc(50% - 50vw)
}
.p-form__title-01 picture {
    display: block;
    margin: -6px auto;
    width: 217px;
}
@media screen and (max-width: 767px) {
	.p-form__title-01 picture {
		/*display: block;*/
		margin: -18px auto;
		width: 42%;
	}
}
.p-form__title-02 picture {
    display: block;
    margin: 11px auto;
    padding-left: 1%;
    width: 500px;
}
@media screen and (max-width: 767px) {
	.p-form__title-02 picture {
		margin: 21px auto;
		padding-left: 3%;
		width: 96%;
	}
}
.p-form__questions {
    margin: 17px 0 20px;
    padding: 0 26px;
}
@media screen and (max-width: 767px) {
.p-form__questions {
    margin: 10px 0 20px;
    padding: 0 20px;
}
}

.p-form__question-img {
    margin-bottom: 26px;
}
@media screen and (max-width: 767px){
.p-form__question-img {
    margin-bottom: 19px;
}
}

.p-form__item {
    border-bottom: 1px solid #000;
    padding: 26px 0 27px;
}
@media screen and (max-width: 767px){
.p-form__item {
    padding: 23px 0 17px;
}
}

.p-form__question {
    align-items: top;
    display: flex;
    margin: 0 0 27px;
}
@media screen and (max-width: 767px){
.p-form__question {
    margin: 0 0 19px;
}
}
.step-01_04.p-form__question {
    align-items: center;
    display: flex;
    margin: 0 0 23px;
}
.p-form__question .icon {
    flex-shrink: 0;
    width: 51px;
}
@media screen and (max-width: 767px){
	.p-form__question .icon {
    width: 37px;
}
}

.p-form__question .text {
    flex-grow: 1;
    font-size: 26.4px;
    font-weight: bold;
    line-height: 1.25;
    padding: 0 16px;
    align-content: center;
}
@media screen and (max-width: 767px){
	.p-form__question .text {
    font-size: 20px;
    line-height: 1.2;
    padding: 0 0 0 4%;
}
}

.p-form__answer {
	display: flex;
	gap: 4px
}
.p-form__answer-two-column {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.p-form__answer-two {
    display: flex;
    gap: 4px;
}
.p-form__answer-four {
    display: flex;
    gap: 4px;
	margin-bottom: 5px;
}

.p-form__answer label {
	position: relative;
	width: calc(33.33% - 2.6666666667px)
}
.p-form__answer-two label {
	position: relative;
	width: 50%;
}
.p-form__answer-two-column label {
	position: relative;
	width: 100%;
}
.p-form__answer-four label {
	position: relative;
	width: calc(50% - 2.6666666667px)
}

.p-form__answer label input {
	display: none
}
.p-form__answer label input+span {
    background: transparent no-repeat center center;
    border: 3px solid #015ec5;
    background-repeat: no-repeat;
    border-radius: 10px;
    cursor: pointer;
    display: block;
    height: 84px;
    transition: .3s;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span {
    background: transparent no-repeat center center;
    border: 2px solid #015ec5;
    background-repeat: no-repeat;
    border-radius: 8px;
    cursor: pointer;
    display: block;
    height: 64px;
    transition: .3s;
}
}

.p-form__answer label input+span.m-yes {
    background-image: url(../static/answer_01_checked.webp);
    background-size: 49px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-yes {
    background-size: 32% auto;
}
}
.p-form__answer label input+span.q3-m-yes {
    background-image: url(../static/answer_01_checked.webp);
    background-size: 49px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.q3-m-yes {
    background-size: 18% auto;
}
}

.p-form__answer label input+span.m-no {
    background-image: url(../static/answer_03_checked.webp);
    background-size: 72px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-no {
    background-size: 48% auto;
}
}
.p-form__answer label input+span.q3-m-no {
    background-image: url(../static/answer_03_checked.webp);
    background-size: 72px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.q3-m-no {
    background-size: 26% auto;
}
}
.p-form__answer label input+span.m-neither {
    background-image: url(../static/answer_02_checked.webp);
    background-size: 117px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-neither {
    background-size: 80% auto;
}
}

.p-form__answer label input+span.m-row {
	background-image: url(../static/step-03__question-01_answer-01.webp);
	background-size: 124px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-row {
	    background-size: 81% auto;
}
}
.p-form__answer label input+span.m-middle {
	background-image: url(../static/step-03__question-01_answer-02.webp);
	background-size: 137px auto;	
	background-color: #fff;	
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-middle {
    background-size: 94% auto;
}
}
.p-form__answer label input+span.m-high {
	background-image: url(../static/step-03__question-01_answer-03.webp);
	background-size: 123px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-high {
    background-size: 83% auto;
}
}
.p-form__answer label input+span.m-down {
	background-image: url(../static/step-03__question-02_answer-01.webp);
	background-size: 290px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-down {
    background-size: 63% auto;
}
}
.p-form__answer label input+span.m-up {
	background-image: url(../static/step-03__question-02_answer-02.webp);
	background-size: 316px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-up {
    background-size: 69% auto;
}
}
.p-form__answer label input+span.m-continue {
	background-image: url(../static/step-03__question-04_answer-01.webp);
	background-size: 170px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-continue {
    background-size: 75% auto;
}
}
.p-form__answer label input+span.m-timing {
	background-image: url(../static/step-03__question-04_answer-02.webp);
	background-size: 188px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-timing {
    background-size: 84% auto;
}
}
.p-form__answer label input+span.m-old {
	background-image: url(../static/step-03__question-06_answer-01.webp);
	background-size: 90px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-old {
    background-size: 39% auto;
}
}
.p-form__answer label input+span.m-child {
	background-image: url(../static/step-03__question-06_answer-02.webp);
	background-size: 131px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-child {
    background-size: 58% auto;
}
}
.p-form__answer label input+span.m-dream {
	background-image: url(../static/step-03__question-06_answer-03.webp);
	background-size: 170px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-dream {
    background-size: 73% auto;
}
}
.p-form__answer label input+span.m-etc {
	background-image: url(../static/step-03__question-06_answer-04.webp);
	background-size: 62px auto;
	background-color: #fff;
}
@media screen and (max-width: 767px){
.p-form__answer label input+span.m-etc {
    background-size: 29% auto;
}
}
.p-form__answer label input:checked+span {
    -webkit-transform: translateY(3px);
    background-color: #015ec5;
    color: #fff;
    transform: translateY(3px);
}

.p-form__answer label input:checked+span.m-yes {
	background-image: url(../static/answer_1_b.webp);
	background-size: 49px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-yes {
	background-size: 32% auto;
}
}
.p-form__answer label input:checked+span.q3-m-yes {
	background-image: url(../static/answer_1_b.webp);
	background-size: 49px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.q3-m-yes {
	background-size: 18% auto;
}
}

.p-form__answer label input:checked+span.m-no {
	background-image: url(../img/answer_03.webp);
	background-size: 69px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-no {
	background-size: 52% auto;
}
}
.p-form__answer label input:checked+span.q3-m-no {
	background-image: url(../img/answer_03.webp);
	background-size: 69px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.q3-m-no {
	background-size: 26% auto;
}
}
.p-form__answer label input:checked+span.m-neither {
	background-image: url(../img/answer_2_b.webp);
	background-size: 114px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-neither {
	background-size: 80% auto;
}
}


.p-form__answer label input:checked+span.m-row {
	background-image: url(../img/step-03__question-01_answer-01_checked.webp);
	background-size: 122px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-row {
	background-size: 83% auto;
}
}
.p-form__answer label input:checked+span.m-middle {
	background-image: url(../img/step-03__question-01_answer-02_checked.webp);
	background-size: 137px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-middle {
	background-size: 93% auto;
}
}
.p-form__answer label input:checked+span.m-high {
	background-image: url(../img/step-03__question-01_answer-03_checked.webp);
	background-size: 118px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-high {
	background-size: 83% auto;
}
}
.p-form__answer label input:checked+span.m-down {
	background-image: url(../img/step-03__question-02_answer-01_checked.webp);
	background-size: 288px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-down {
	background-size: 62% auto;
}
}
.p-form__answer label input:checked+span.m-up {
	background-image: url(../img/step-03__question-02_answer-02_checked.webp);
    background-size: 316px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-up {
	background-size: 68% auto;
}
}
.p-form__answer label input:checked+span.m-continue {
	background-image: url(../img/step-03__question-04_answer-01_checked.webp);
	background-size: 170px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-continue {
	background-size: 73% auto;
}
}
.p-form__answer label input:checked+span.m-timing {
	background-image: url(../img/step-03__question-04_answer-02_checked.webp);
	background-size: 188px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-timing {
	background-size: 82% auto;
}
}
.p-form__answer label input:checked+span.m-old {
	background-image: url(../img/step-03__question-06_answer-01_checked.webp);
	background-size: 90px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-old {
	background-size: 40% auto;
}
}
.p-form__answer label input:checked+span.m-child {
	background-image: url(../img/step-03__question-06_answer-02_checked.webp);
	background-size: 131px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-child {
	background-size: 58% auto;
}
}
.p-form__answer label input:checked+span.m-dream {
	background-image: url(../img/step-03__question-06_answer-03_checked.webp);
	background-size: 170px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-dream {
	background-size: 71% auto;
}
}
.p-form__answer label input:checked+span.m-etc {
	background-image: url(../img/step-03__question-06_answer-04_checked.webp);
	background-size: 62px auto;
}
@media screen and (max-width: 767px){
.p-form__answer label input:checked+span.m-etc {
	background-size: 29% auto;
}
}

.p-form-pagination {
    display: block;
    display: flex;
    justify-content: space-between;
    margin: 0 auto 3px;
    max-width: 390px;
    padding: 21px 0 4px;
    width: calc(100% - 50px);
}
@media screen and (max-width: 767px){
.p-form-pagination {
    max-width: 299px;
    padding: 16px 0 4px;
    margin-top: -4%;
}
}	
.p-form-pagination>li {
	position: relative;
}

.p-form-pagination>li .circle {
    background: #fff no-repeat center center / 16px auto;
    border-radius: 50%;
    display: block;
    height: 40px;
    width: 40px;
}
@media screen and (max-width: 767px){
.p-form-pagination>li .circle {
    height: 35px;
    width: 35px;
}
}
.p-form-pagination>li .text {
    background: transparent no-repeat center center / contain;
    display: block;
    height: 13px;
    margin: 6px 0 0;
    width: 41px;
}
@media screen and (max-width: 767px){
.p-form-pagination>li .text {
    margin: 0px 0 0;
    width: 32px;
}
}
.p-form-pagination>li:nth-child(1) .circle {
	background-image: url(../img/step_number-01.webp);
}
.p-form-pagination>li.is-active:nth-child(1) .circle {
	background-image: url(../img/step_number-01_checked.webp);
}
.p-form-pagination>li:nth-child(1) .text {
	background-image: url(../img/step-01.webp);
}

.p-form-pagination>li:nth-child(2) .circle {
	background-image: url(../img/step_number_02.webp);
}
.p-form-pagination>li.is-active:nth-child(2) .circle {
	background-image: url(../img/step_number-02_checked.webp);
}
.p-form-pagination>li:nth-child(2) .text {
	background-image: url(../img/step-02.webp);
}

.p-form-pagination>li:nth-child(3) .circle {
	background-image: url(../img/step_number-03.webp);
}
.p-form-pagination>li.is-active:nth-child(3) .circle {
	background-image: url(../img/step_number-03_checked.webp);
}
.p-form-pagination>li:nth-child(3) .text {
	background-image: url(../img/step-03.webp);
}

.p-form-pagination>li:not(:first-child)::before {
    -webkit-transform: translateX(-100%);
    background-image: url(../img/swiper-pagination_line.webp);
    content: "";
    display: block;
    height: 4px;
    left: -23px;
    position: absolute;
    top: 17px;
    transform: translateX(-100%);
    width: 90px;
    width: 91px;
}
@media screen and (max-width: 767px){
.p-form-pagination>li:not(:first-child)::before {
    -webkit-transform: translateX(-100%);
    background-image: url(../img/swiper-pagination_line.webp);
    content: "";
    display: block;
    height: 1px;
    left: -16px;
    background-repeat: no-repeat;
    position: absolute;
    top: 17px;
    transform: translateX(-100%);
    width: 90px;
    width: 71px;
}
}

.p-form-pagination>li.is-active .circle {
	background-color: #015ec5;
}
.p-loading {
    padding: 296px 0 160px;
}
@media screen and (max-width: 767px) {
.p-loading {
    padding: 57% 0 52%;
}	
}

.p-loading__title {
    margin: 0 auto 36px;
    width: 68%;
}
.p-loading__image {
	margin: 0 calc(50% - 50vw);
	text-align: center
}
.p-loading__image img {
	max-width: 520px
}
.p-loading img {
	width: 100%
}

.p-thanks img {
	width: 100%
}

.p-thanks.m-pt-1 {
    padding: 60px 0 380px;
}
@media screen and (max-width: 767px) {
	.p-thanks.m-pt-1 {
		padding: 15% 0 72%;
	}
}

.p-thanks.m-pt-1 .p-thanks__lead {
    margin: -27px auto 12px;
    width: 62%;
}
@media screen and (max-width: 767px) {
	.p-thanks.m-pt-1 .p-thanks__lead {
		margin: -9% auto 12px;
		width: 62%;
	}
}

.p-thanks.m-pt-1 .p-thanks__title-01 {
    margin: 28px auto 10px;
    width: 42%;
}
@media screen and (max-width: 767px) {
	.p-thanks.m-pt-1 .p-thanks__title-01 {
		margin: 5% auto 10px;
		width: 42%;
	}
}

.p-thanks.m-pt-1 .p-thanks__title-02 {
    margin: -15px auto 10px;
    width: 51%;
}
@media screen and (max-width: 767px) {
	.p-thanks.m-pt-1 .p-thanks__title-02 {
		margin: -3% auto 0%;
		width: 51%;
	}
}

.p-thanks.m-pt-1 .p-thanks__image {
    margin: 19px 0 20px 43px;
    width: 86%;
}
@media screen and (max-width: 767px) {
	.p-thanks.m-pt-1 .p-thanks__image {
		margin: 4% 8% 4%;
		width: 86%;
	}
}
.p-thanks.m-pt-1 .p-thanks__guide {
    margin: 90px auto 16px;
    width: 66%;
}
@media screen and (max-width: 767px) {
	.p-thanks.m-pt-1 .p-thanks__guide {
		margin: 17% auto 16px;
		width: 66%;
	}
}
.p-thanks.m-pt-1 .p-thanks__cv {
	text-align: center
}

.p-thanks.m-pt-1 .p-thanks__cv a {
	display: block;
	margin: 0 auto;
	width: 78.6666666667%
}

.form_box {
    position: absolute;
    z-index: 99;
    width: 90%;
    left: 0;
    right: 0;
    top: 56.5%;
    margin: auto;
}
@media screen and (max-width: 767px) {
.form_box {
    top: 56%;
}
}

.mail {
    width: 100%;
    border: solid 2px #818181;
    border-radius: 5px;
    font-size: 2.1em;
    font-weight: 900;
    padding-top: 0.6em;
    padding-bottom: 0.6em;
    text-align: center;
    margin-bottom: 5%;
    margin-left: 0;
}
@media screen and (max-width: 767px) {
.mail {
    font-size: 1.7em;
    padding-top: 0.5em;
    padding-bottom: 0.5em;
}
}

.notice {
    position: absolute;
    color: #fff;
    font-size: 14.1px;
    line-height: 1.36;
    text-align: left;
    font-weight: 400;
    margin-left: 2%;
    margin-top: 1.5%;
}
@media screen and (max-width: 767px) {
.notice {
    font-size: 10.8px;
}
}

.btn {
	animation: anime 0.5s ease 0s infinite alternate;
	transform-origin: center;
}
@media screen and (max-width: 767px) {
.btn {
	width: 102%;
}
}

.btn:hover {
  filter: brightness(115%);
}