@charset "UTF-8";
/* CSS Document */

* {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
html {
	font-family: sans-serif;
}
body {
	overflow-x: hidden;
	color: #000;
	text-align: center;
}
a:link,
a:visited {
	text-decoration: underline;
}
a:hover,
a:active {
	text-decoration: none;
	color: #4889c7;
}
a img:hover {
	opacity: 0.8;
}
.pc {
	display: inline-block;
}
.sp {
	display: none;
}
.txt_indent {
	padding-left: 1em;
	text-indent: -1em;
}
ul, li {
	text-align: left;
}
.white {
	color: #fff;
}
.red {
	color: #fe0037;
}

/* header */
#header {
	background-color: #fff;
}
#header .inner {
	max-width: 1080px;
	width: 100%;
	margin: 0 auto;
	padding: 20px 5px;
	box-sizing: border-box;
}
#header .img_box {
	display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: nowrap;
    flex-wrap:nowrap;
    justify-content: space-between;
    align-items: center;
	max-width: 1080px;
	width: 100%;
}


#header .header_logo {
  width: 25%;
  text-align: left;
}
#header .header_logo img {
	width: min(22vw, 224px);
	margin-left: 3%;
}


#header .tel_login {
  width: 75%;
	display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: nowrap;
    flex-wrap:nowrap;
    justify-content: end;
    align-items: center;
}

#header .tel img{
	text-align: right;
	width: min(48vw, 430px);
	padding-left: 2%;
  	padding-right: 5%;
}
#header .login img{
	width: min(25vw, 187px);
	padding-right: 2%;
}

/* main */
#main {
	width: 100%;
	text-align: center;
}
#main .inner {
	width: 100%;
	max-width: 1080px;
	margin: 0 auto 50px;
}
#main .inner img {
	width: 100%;
}
#main .inner.-lg {
	width: 100%;
	max-width: 1202px;
	margin: 0 auto 50px;
}

/* CV */
.CV_area {
	width: 100%;
	max-width: 1080px;
	margin: 0 auto 100px;
	text-align: center;
}

.CV_area .button.-tel {
	margin-top: 30px;
}

/* about */
#about {
	width: 100%;
	text-align: center;
}
#about .inner {
	width: 100%;
	max-width: 1080px;
	margin: 0 auto 50px;
	padding: 50px 0;
	text-align: center;
	background: #fff3e5;
	border-radius: 15px;
}
#about .inner img {
	margin: 0 0 30px;
}
/* movie */
#about .movie_box {
	max-width: 920px;
	width: 100%;
	margin: 0 auto;
}
#about .txt_box {
	max-width: 920px;
	margin: 48px auto 20px;
	padding: 30px 0;
	background: #ffad4a;
	border-radius: 15px;
	border: solid 6px #fff;
	text-align: center;
}
#about .txt_box p {
	font-size: 32px;
	line-height: 48px;
	font-weight: 700;
	margin: 0 0 10px;
}
#about .txt_box .big {
	font-size: 30px;
}
#about .txt_box .small {
	font-size: 24px;
}
#about .txt_box ul {
	margin: 0 auto;
	padding: 0 64px;
	font-size: 12px;
	line-height: 20px;
	width: 570px;
}
#about .img_box {
	width: 450px;
	margin: 0 auto;
}
#about .notion {
	font-size: 18px;
	line-height: 18px;
	font-weight: 700;
	margin: 0 0 30px;
}


/* point */
#point {
	width: 100%;
	text-align: center;
	margin: 86px 0 50px;
}
#point .ttl {
	margin: 0 0 30px;
}
#point .inner {
	width: 100%;
	background: #ffeeda;
}
#point .point_box {
	max-width: 920px;
	margin: 0 auto 80px;
	padding: 0 0 50px;
	background: #fff;
	box-shadow: 0px 0px 20px -5px #ff9300;
	border-radius: 15px;
}
#point .point_box.end {
	margin: 0 auto;
}
#point .point_box img {
	margin: -57px 0 50px;
}
#point .point_box .sub {
	font-size: 32px;
	line-height: 32px;
	font-weight: 700;
	margin: 0 0 30px;
}
#point .point_box .big {
	font-size: 50px;
}
#point .point_box .txt {
	width: 730px;
	margin: 0 auto 20px;
	font-size: 20px;
	line-height: 36px;
	text-align: left;
}
#point .point_box ul {
	width: 660px;
	margin: 0 auto;
	font-size: 14px;
	line-height: 20px;
	font-weight: normal;
}
#point .top {
	width: 100%;
	padding: 100px 0;
	background-image: url(../img/point_bg_top_pc.png);
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
}
#point .bottom {
	width: 100%;
	margin: 0 0 50px;
	padding: 90px 0;
	background-image: url(../img/point_bg_bottom_pc.png);
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: cover;
}
#point ul {
	width: 100%;
	max-width: 1080px;
	margin: 0 auto;
	font-size: 16px;
	line-height: 24px;
	font-weight: 700;
}


/* faq */
#faq {
	width: 100%;
	margin: 0 0 68px;
	text-align: center;
}
#faq .inner {
	width: 100%;
	max-width: 1080px;
	margin: 0 auto;
}
#faq .ttl {
	margin: 0 0 50px;
}
#faq section {
	width: 100%;
	margin: 0 auto 30px;
	padding: 15px 0;
	background: #ececec;
}
#faq dl.accordion {
	max-width: 920px;
	margin: 0 auto;
}
#faq dl.accordion dt {
	background-image: url(../img/faq_close_pc.png);
	background-repeat: no-repeat;
	background-size: contain;
	cursor: pointer;
}
#faq dl.accordion dt.open {
	background-image: url(../img/faq_open_pc.png);
	background-repeat: no-repeat;
	background-size: contain;
}
#faq dl.accordion dd {
	display: none;
	padding: 15px 0;
	font-size: 22px;
	line-height: 34px;
	text-align: center;
}
#faq dl.accordion dd .txt {
	text-align: left;
	margin: 0 0 30px;
}
#faq dl.accordion dd img {
	margin: 0 0 30px;
}
#faq .question {
	width: 100%;
	background: #ff8a00;
	padding: 10px 0;
	font-size: 22px;
	line-height: 22px;
	color: #fff;
	font-weight: 700;
	margin: 0 0 20px;
	text-align: center;
	border-radius: 10px;
}
#faq .answer {
	width: 100%;
	background: #fff;
	border: solid 3px #ff8a00;
	padding: 10px 0;
	font-size: 22px;
	line-height: 22px;
	color: #ff8a00;
	font-weight: 700;
	margin: 0 0 20px;
	text-align: center;
	border-radius: 10px;
}
#faq .another {
	font-size: 22px;
	line-height: 22px;
	color: #1c68c1;
	margin-top: 68px;
}

.price {
	margin: 0 0 50px;
}

/* caution */
#caution {
	width: 100%;
	background-color: #e5e9ef;
	padding: 30px 0;
	margin: 0 0 20px;
}
#caution .inner {
	width: 940px;
	margin: 0 auto;
}
#caution ul {
	font-size: 14px;
	line-height: 24px;
	text-align: left;
}
#caution li {
	padding-left: 1em;
	text-indent: -1em;
}
#caution p {
	font-size: 14px;
	line-height: 14px;
	text-align: right;
}

/* footer */
footer {
	width: 100%;
	padding: 20px 0 30px;
	text-align: center;
}
footer ul {
	font-size: 16px;
	line-height: 16px;
	text-align: center;
	margin: 0 0 20px;
}
footer ul li {
	display: inline;
}
footer p {
	font-size: 12px;
	line-height: 12px;
}
#FloatFooter {
  width: 100%;
  background: #e5e9ee;
  position: fixed;
  bottom: 0;
  z-index: 1000;
  display: none;
}
#FloatFooter .inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 20px 0;
}
#FloatFooter .buttons {
	display: flex;
	justify-content: center;
	align-items: flex-end;
	gap: 20px;
}
#FloatFooter .buttons li {
	width:38%;
}
#FloatFooter .buttons li img {
	width: 100%;
}