﻿html { 
	overflow-y: scroll;
	font-size: 62.5%;
}
body {
	font-family: "Noto Sans JP", sans-serif;
	font-size: 1.6rem;
	-webkit-text-size-adjust: none;
	line-height: 1.5;
	color: #333;
}

@media screen and (min-width: 768px) and (max-width: 1000px) {
  html {
    font-size: 1vw;
  }
}
@media screen and (max-width: 750px) {
	html { 
		font-size: 1.3333vw;
	}
}
@media screen and (max-width: 374px) {
	html {
		font-size: 2.6667vw;
	}
}

body {
	color: #333;
	font-family: "Noto Sans JP", sans-serif;
	overflow-x: hidden;
}
img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

main {
	max-width: 750px;
	margin: 0 auto;
} 

footer {
  max-width: 525px;
  margin-left: auto;
  margin-right: auto;
  height: 80px;
  background: #0A1F5D;
  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;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 14px;
  margin-bottom: 150px;
}

.dokidoki {
  -webkit-animation: dokidoki 1s ease 0s infinite alternate;
          animation: dokidoki 1s ease 0s infinite alternate;
  -webkit-transform-origin: center;
          transform-origin: center;
  display: inline-block;
}
@-webkit-keyframes dokidoki {
  from {
    -webkit-transform: scale(0.95);
            transform: scale(0.95);
  }
  to {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes dokidoki {
  from {
    -webkit-transform: scale(0.95);
            transform: scale(0.95);
  }
  to {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

a {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
a:hover {
  opacity: 0.7;
}


/* ========================
   お問い合わせフォーム
   ======================== */
.sec_form {
	padding: 7.5rem 0;
	background: #f6f6f6;
	font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
} 
.sec_form .inner {
	padding: 0 4.5rem;
}
.sec_form h2 {
	margin-bottom: 6rem;
	text-align: center;
	line-height: 1;
	color: #fb832b;
	font-style: italic;
	font-weight: 700;
	font-size: 6.5rem;
}
 
.form_heading {
	margin-bottom: 60px;
	text-align: center;
	line-height: 1;
	color: #fb832b;
	font-style: italic;
	font-weight: 700;
	font-size: 65px;
}
.form_group + .form_group {
	margin-top: 28px;
}
.form_group > label {
	display: block;
	margin-bottom: 1.6rem;
	letter-spacing: 0.08em;
	font-weight: 700;
	font-size: 3.2rem;
	font-weight: 700;
}
.sec_form .required {
	display: inline-block;
	padding: 0.4rem 1.5rem 0.3rem;
	margin-left: 1.8rem;
	background: #fd780a;
	line-height: 1;
	letter-spacing: 0.22em;
	color: #f6f6f6;
	font-size: 2.3rem;
}
.sec_form input[type=text],
.sec_form input[type=tel],
.sec_form input[type=email]{
	padding: 0 3.2rem;
	height: 8.5rem;
	width: 100%;
	background: #fff;
	border: 0;
	box-shadow: 0.1rem 0.1rem 1rem rgba(114, 114, 114, 0.11);
	letter-spacing: 0.12em;
	font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
	font-size: 2.9rem;
	font-weight: 500;
}
::-webkit-input-placeholder {
	color: #989494;
}
::-moz-placeholder {
	color: #989494;
}
:-ms-input-placeholder {
	color: #989494;
}
:-moz-placeholder {
	color: #989494;
}

.form_group input,
.form_group select {
  width: 100%;
  padding: 14px 16px;
  font-family: "Noto Serif JP", serif;
  font-size: 16px;
  color: #333;
  background: #fff;
  border: 2px solid #c9a84c;
  border-radius: 6px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  -webkit-transition: border-color 0.3s ease, box-shadow 0.3s ease;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
} 
.form_group input:focus,
.form_group select:focus {
  outline: none;
  border-color: #727272;
  -webkit-box-shadow: 0 0 0 3px rgba(114, 114, 114, 0.11);
          box-shadow: 0 0 0 3px rgba(114, 114, 114, 0.11);
}
.form_group input::-webkit-input-placeholder {
  color: #8f949e;
}
.form_group input::-moz-placeholder {
  color: #8f949e;
}
.form_group input:-ms-input-placeholder {
  color: #8f949e;
}
.form_group input::placeholder {
	color: #8f949e;
}

.form_submit {
	margin-top: 32px;
	text-align: center;
}
.btn_submit {
	display: inline-block;
	width: 100%;
	padding: 18px 0;
	font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
	font-size: 24px;
	font-weight: 700;
	color: #fff;
	background: #fd780a;
	border: none;
	border-radius: 50px;
	cursor: pointer;
	letter-spacing: 0.15em;
	-webkit-transition: opacity 0.3s ease, transform 0.3s ease;
	transition: opacity 0.3s ease, transform 0.3s ease;
}

.sec02 {
	padding: 40px;
	background: linear-gradient(135deg, #fb832b, #fad126);
}
.sec02 .box {
	padding: 26px 20px;
	background: #fff;
	border-radius: 4px;
	box-shadow: 0 1px 19px rgba(135,38,54,0.29);
	text-align: center;
}
.sec02 h2 {
	margin: 0 auto;
	max-width: 586px;
}

.sec_notes {
	text-align: center;
	line-height: 1.6;
	letter-spacing: 0.17em;
	font-size: 20px;
}

.free_btn {
	margin: 26px 0 35px;
}
.free_btn a {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 2;
	height: 138px;
	background: linear-gradient(0deg, #22912a, #68da70);
	border-radius: 10rem;
	border: 4px solid #fff;
	text-align: center;
	color: #fff;
	font-weight: 700;
	font-size: 34px;
}
.free_btn a:before {
	content: "";
	position: absolute;
	left: -11px;
	right: -11px;
	top: -11px;
	bottom: -11px;
	z-index: -1;
	border-radius: 10rem;
	border: 7px solid #5fba64;
}

.sec03 {
	padding: 45px;
}

.sec04 {
	background: url(../img/bg_sec04.webp)no-repeat center;
	background-size: cover;
}
.sec04 .part {
	margin-top: 60px;
}

.sec05 .part {
	margin-top: 10px;
}

.sec06 {
	padding: 90px 32px;
	background: #494949;
}

.sec07 {
	background: url(../img/bg_sec07.webp)no-repeat center top;
	background-size: 100%;
}
.sec07 .bor {
	padding: 80px 32px 28px;
}

.sec08 h2 {
	padding: 40px 0;
}

.sec09 h2 {
	padding: 26px 0 45px;
	text-align: center;
}
.sec09 h2 img {
	max-width: 392px;
}
.sec09 .part {
	padding: 0 0 80px;
}

.sec_reason {
	padding: 90px 0 0;
	background: #fef1ce;
}
.sec_reason h2 {
	margin: 0 auto 6.5rem;
	max-width: 560px;
}
.sec_reason .part {
	padding: 0 0 68px 24px;
}
.sec_reason .part:nth-of-type(even) {
	padding-left: 0;
	padding-right: 24px;
}

.sec_flow {
	padding: 44px 16px 32px;
	background: #fffdf3;
}
.sec_flow h2 {
	margin: 0 auto 45px;
	max-width: 550px;
}

.sec10 {
	padding: 10px 0 0;
	background: #fef1ce;
}
.sec10 .txt {
	padding: 45px 45px 80px;
}

.sec_faq {
	padding: 60px 16px;
	background: #fef1ce;
}
.sec_faq h2 {
	margin: 0 auto 40px;
	max-width: 240px;
}
.sec_faq li + li {
	margin-top: 4px;
}


/* sp */
@media screen and (max-width: 750px) {
	.sec02 {
	    padding: 20px;
	}
	.sec02 .box {
	    padding: 20px 16px;
	}
	.sec_notes {
		font-size: 10px;
	}
	
	.free_btn {
	    margin: 16px 0 18px;
	}
	.free_btn a {
	    height: 70px;
	    border-width: 2px;
	    font-size: 17px;
	}
	.free_btn a:before {
		left: -6px;
		right: -6px;
		top: -6px;
		bottom: -6px;
	    border-width: 3px;
	}
	
	.sec03 {
	    padding: 22px;
	}
	
	.sec04 .part {
	    margin-top: 30px;
	}
	
	.sec06 {
	    padding: 45px 16px;
	}
	
	.sec07 .bor {
	    padding: 40px 16px 16px;
	}
	
	.sec08 h2 {
	    padding: 20px 0;
	}
	
	.sec09 h2 {
	    padding: 16px 0 25px;
	}
	.sec09 h2 img {
	    max-width: 196px;
	}
	.sec09 .part {
	    padding: 0 0 40px;
	}

	.sec_reason {
	    padding: 45px 0 0;
	}
	.sec_reason h2 {
	    max-width: 280px;
	}
	.sec_reason .part {
	    padding: 0 0 34px 12px;
	}
	.sec_reason .part:nth-of-type(even) {
	    padding-left: 0;
	    padding-right: 12px;
	}
	
	.sec_flow {
	    padding: 22px 8px 16px;
	}
	.sec_flow h2 {
	    margin-bottom: 25px;
	    max-width: 275px;
	}
	
	.sec10 .txt {
	    padding: 25px 25px 40px;
	}
	
	.btn_submit {
	    padding: 10px 0;
	    font-size: 18px;
	}
	
	.sec_faq {
	    padding: 30px 8px;
	}
	.sec_faq h2 {
	    margin-bottom: 20px;
	    max-width: 120px;
	}
	
	
}