@charset "utf-8";

* {
	margin: 0;
	padding: 0;
	vertical-align: top;
	font-family: "メイリオ", Meiryo, "ヒラギノ角ゴPro W3", "Hiragino Kaku Gothic Pro", sans-serif;
}

body {
	margin-left: auto;
	margin-right: auto;
	font-size: 3.73vw;
	line-height: 1;
	color: #000;
	-webkit-text-size-adjust: 100%;
}

p, h1, h2, h3, h4, th, td, li, dt, dd, figcaption,
.normal-font-style {
	font-size: 3.73vw;
	line-height: 2;
	font-weight: normal;
}

img {
	border: none;
}
img.fit {
	width: 100%;
}

a {
	color: #000;
}
a:hover {
	text-decoration: none;
}

ul, ol {
	list-style-type: none;
	padding-left: 0 !important;
}

.container {
    max-width: 1170px;
    margin: 0 auto;
}

/* -------------------------------------------------
	header
------------------------------------------------- */

#header {
	height: 12.26vw;
	text-align: center;
	border-bottom: solid 1.06vw #e9e8e3;
}
#header .logo {
	width: 18.4vw;
	margin-top: 2.8vw;
}

/* -------------------------------------------------
	contents
------------------------------------------------- */

#main-cont {
	display: block;
}

.cont-sp {
	margin-left: 6.66vw;
	margin-right: 6.66vw;
	position: relative;
}

/* -------------------------------------------------
	headline
------------------------------------------------- */

.h-style1 {
	text-align: center;
	position: relative;
}
.h-style1::after {
	width: 13.33vw;
	height: 1.06vw;
	background-color: #000;
	position: absolute;
	left: 50%;
	margin-left: -6.66vw;
	bottom: 0;
	content: "";
	display: block;
}
.h-style1 .small {
	display: block;
	font-size: 3.73vw;
	line-height: 1.3;
	margin: 0 6vw;
}
.h-style1 .large {
	padding: 2.5vw 0 3.5vw;
	display: block;
	font-size: 6.66vw;
	line-height: 1.4;
	font-weight: bold;
}

/* -------------------------------------------------
	main-visual
------------------------------------------------- */

#main-visual {

}
#main-visual .feature {
	margin-top: -44vw;
	text-align: center;
	padding-left: 0 !important;
}
#main-visual .feature li {
	width: 72%;
	padding: 10px 6px 6px;
	box-sizing: border-box;
	display: inline-block;
	background-color: #fff;
	box-shadow: rgba(14, 30, 37, 0.12) 0px 2px 4px 0px, rgba(14, 30, 37, 0.32) 0px 2px 16px 0px;
}
#main-visual .feature li + li {
	margin-top: 10px;
}
#main-visual .feature li .title {
	color: #e3131f;
	font-size: 4vw;
	line-height: 1.4;
	font-weight: bold;
	text-align: center;
}
#main-visual .feature li .title span {
	font-size: 5.3vw;
	vertical-align: baseline;
}

/* -------------------------------------------------
	entry-button
------------------------------------------------- */

.entry-button-top {
	margin-top: 3.67vw;
	margin-bottom: -13.33vw;
	display: block;
}
.entry-button {
	margin-top: -13.33vw;
	margin-bottom: -13.33vw;
	display: block;
}

.entry-button-top img,
.entry-button img {
	position: relative;
	z-index: 10;
}

/* -------------------------------------------------
	reason
------------------------------------------------- */

#reason {
	padding: 22vw 0 13vw;
	background-color: #f7f7f2;
	position: relative;
}
#reason::after {
	width: 40vw;
	height: 8vw;
	content: "";
	display: block;
	background: url(/wp-content/uploads/sf-images/default-source/efaxjp_lp/jp_60_pdf_sp/arrow.png) no-repeat 0 0 / contain;
	position: absolute;
	left: 50%;
	bottom: -4vw;
	margin-left: -20vw;
}
#reason .h-style1 {
	margin-bottom: 8vw;
}
#reason .points li {
	width: 93.34%;
	padding: 0 0 8vw;
	position: relative;
	background-color: #fff;
	box-sizing: border-box;
	clear: both;
	box-shadow: 0px 0px 4px 0 rgba(0,0,0,0.1);
	margin: 0 auto;
}
#reason .points li:nth-child(even) {

}
#reason .points li + li {
	margin-top: 8vw;
}
#reason .points li .ttl2 {
	width: 100%;
	margin-bottom: 5.33vw;
}
#reason .points li .pic2 {
    width: 92%;
    margin-bottom: 3.5vw;
    margin-left: 4%;
}
#reason .points p {
	width: 87.85%;
	line-height: 1.8;
}

#reason .points li:nth-child(odd) .ttl,
#reason .points li:nth-child(odd) .pic,

#reason .points li:nth-child(odd) p {
	margin-left: 6.66%;
}
#reason .points li:nth-child(even) .pic,
#reason .points li:nth-child(even) p {
	margin-left: 5%;
}
#reason .points h3 {
  padding-left: 15px
}
/* -------------------------------------------------
	function
------------------------------------------------- */

#function {
	padding: 10.5vw 0 21vw;
	background-color: #e9e8e3;
}
#function .funcs {
	margin-top: 8vw;
	text-align: center;
}
#function .funcs li {
	width: 42vw;
	height: 50vw;
	padding: 2.5vw 0 0;
	margin: 0 0 2.66vw;
	box-sizing: border-box;
	display: inline-block;
	background-color: #fff;
	text-align: center;
}
#function .funcs li:nth-child(even) {
	margin-left: 1.5vw;
}
#function .funcs li .title {
	font-size: 3.73vw;
	color: #e3131f;
	line-height: 1.7;
}
#function .funcs li .desc {
	margin: 0 7%;
	text-align: left;
	font-size: 3.2vw;
	line-height: 1.8;
}
#function .funcs li img {
	height: 14vw;
	margin: 1.5vw 0 1.5vw;
}

/* -------------------------------------------------
	voice
------------------------------------------------- */

#voice {
	padding: 22.5vw 0 13vw;
	background-color: #f7f7f2;
}

#voice .h-style1 .small {
	line-height: 1.7;
}

#voice .tab {
	margin-top: 8vw;
}
#voice .tab li {
	width: 49.23%;
	height: 13.33vw;
	margin-bottom: 1.33vw;
	float: left;
	box-sizing: border-box;
	border: solid 1px #f5dedb;
	background-color: #fff;
	line-height: 1.7;
	font-size: 3.2vw;
}
#voice .tab li:nth-child(even) {
	float: right;
}
#voice .tab li.current {
	background-color: #ffa2a2;
	border-color: #ffa2a2;
	background: -webkit-gradient(linear, left top, right top, color-stop(1.00, #ffa2a2), color-stop(0.00, #ff8686));
	background: -webkit-linear-gradient(left, #ff8686, #ffa2a2);
	background: -moz-linear-gradient(left, #ff8686, #ffa2a2);
	background: -o-linear-gradient(left, #ff8686, #ffa2a2);
	background: -ms-linear-gradient(left, #ff8686, #ffa2a2);
	background: linear-gradient(left, #ff8686, #ffa2a2);
}
#voice .tab li a {
	width: 100%;
	height: 100%;
	padding-top: 1.3vw;
	box-sizing: border-box;
	display: block;
	color: #000;
	text-decoration: none;
	text-align: center;
}
#voice .tab li:last-child a {
	padding-top: 4.0vw;
}
#voice .tab li.current a {
	color: #fff;
}
#voice .tab li:not(.current) a:hover {
	opacity: 0.7;
}

#voice .cont-box {

}

#voice .tab-cont {
	padding: 5vw 5vw 8vw;
	box-sizing: border-box;
	background-color: #fff;
	box-shadow: 0 0 10px 0 rgba(0,0,0,0.05);
	display: none;
}
#voice .tab-cont.current {
	display: block;
}
#voice .tab-cont .headline {
	padding-bottom: 1.5vw;
	margin-bottom: 5.3vw;
	color: #e3131f;
	border-bottom: solid 0.53vw #e3131f;
}
#voice .tab-cont .headline .small {
	margin-bottom: 2vw;
	display: block;
	line-height: 1.4;
	font-size: 3.2vw;
	color: #000;
}
#voice .tab-cont .headline .large {
	display: block;
	line-height: 1.6;
	font-size: 4.8vw;
	font-weight: bold;
}
#voice .tab-cont .pic {
	width: 100%;
	margin-bottom: 5vw;
}
#voice .tab-cont p {
	line-height: 1.7;
}
#voice .tab-cont p + p {
	margin-top: 3vw;
}

/* -------------------------------------------------
	faq
------------------------------------------------- */

#faq {
	padding: 8vw 0 22.5vw;
}
#faq dl {
	margin-top: 8vw;
}
#faq dt,
#faq dd {
	padding: 0 0 0 8.5vw;
	position: relative;
	line-height: 1.7;
}
#faq dt {
	color: #e3131f;
}
#faq dt::before,
#faq dd::before {
	width: 6.13vw;
	height: 6.13vw;
	content: "";
	display: inline-block;
	position: absolute;
	left: 0;
	top: 0;
}
#faq dt::before {
	background: url(/wp-content/uploads/sf-images/default-source/efaxjp_lp/jp_60_pdf_sp/ico_faq_q.png) no-repeat 0 0 / contain;
}
#faq dd {
	margin: 2vw 0 0;
}
#faq dd::before {
	background: url(/wp-content/uploads/sf-images/default-source/efaxjp_lp/jp_60_pdf_sp/ico_faq_a.png) no-repeat 0 0 / contain;
}

#faq dd + dt {
	margin-top: 6vw;
}

/* -------------------------------------------------
	price
------------------------------------------------- */

#price {
	padding: 23vw 0 10.5vw;
	background-color: #f7f7f2;
}
#price .lead {
	margin: 7vw 0 6vw;
	font-size: 3.73vw;
	padding: 8vw 0 6vw;
	line-height: 1.8;
}

/* 3months */
.price_block {
  padding: 20px 0 0;
  max-width: 600px;
  margin: 0 auto;
}
.price_block .text_01 {
  font-size: 16px;
  line-height: 1.8;
}
.price_block .price_fb_3box {
  padding: 0px 0 15px 0;
}
.price_block .fb_item {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  padding: 8px;
  background-color: #ffffff;
  text-align: center;
  -webkit-box-shadow: 2px 2px 10px rgba(80, 80, 80, 0.1);
          box-shadow: 2px 2px 10px rgba(80, 80, 80, 0.1);
  margin: 20px 0 0;
}
.price_block .fb_plan_name {
  color: #ffffff;
  background-color: #e4393f;
  text-align: center;
  font-size: 20px;
  font-weight: bold;
  padding: 10px 0;
}
.price_block .fb_pricebox {
  line-height: 1;
  gap: 5px;
  padding: 20px 0 10px;
}
.price_block .fb_pricebox .muryou {
  padding-top: 20px;
  font-size: 18px;
  font-weight: bold;
}
.price_block .fb_pricebox .muryou span {
  color: #e4393f;
}
.price_block .fb_pricebox .fb_price {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.price_block .fb_pricebox strong {
  font-size: 30px;
  font-weight: bold;
  padding-right: 5px;
}
.price_block .fb_pricebox span.en_zei {
  display: inline-block;
  font-size: 16px;
  font-weight: bold;
  padding-bottom: 3px;
}
.price_block .fb_pricebox .fb_otoku {
  padding: 8px 15px 0px;
}
.price_block .fb_pricebox .fb_otoku .price_otoku {
  position: relative;
  background: #FFFFFF;
  padding: 10px 16px 10px 24px;
  text-align: center;
  border: 2px solid #E4393F;
  color: #E4393F;
  font-size: 16px;
  font-weight: bold;
  border-radius: 50px;
  -webkit-transform: translateY(15px);
          transform: translateY(15px);
  display: inline-block;
}
.price_block .fb_pricebox .fb_otoku .price_otoku small {
  font-size: 14px;
  vertical-align: bottom;
}
.price_block .fb_pricebox .fb_otoku .price_otoku:after,
.price_block .fb_pricebox .fb_otoku .price_otoku:before {
  border: solid transparent;
  content: "";
  height: 0;
  width: 0;
  pointer-events: none;
  position: absolute;
  top: 100%;
  left: 50%;
}
.price_block .fb_pricebox .fb_otoku .price_otoku:after {
  border-color: rgba(255, 255, 255, 0);
  border-top-width: 9px;
  border-bottom-width: 9px;
  border-left-width: 8px;
  border-right-width: 8px;
  margin-left: -8px;
  border-top-color: #FFFFFF;
}
.price_block .fb_pricebox .fb_otoku .price_otoku:before {
  border-color: rgba(228, 57, 63, 0);
  border-top-width: 9px;
  border-bottom-width: 9px;
  border-left-width: 9px;
  border-right-width: 9px;
  margin-left: -9px;
  margin-top: 1px;
  border-top-color: #E4393F;
}
.price_block .fb_pricebox .fb_otoku .price_month {
  padding: 30px 20px 15px;
  background-image: linear-gradient(90deg, #ff8686 1%, #f57777b5 94%);
}
.price_block .fb_pricebox .fb_otoku .price_month span:nth-child(1) {
  font-size: 14px;
  font-weight: bold;
  color: #fff;
  vertical-align: middle;
  display: inline-block;
  padding-top: 7px;
}
.price_block .fb_pricebox .fb_otoku .price_month span:nth-child(2) {
  font-size: 26px;
  font-weight: bold;
  color: #fff;
  padding: 5px;
  vertical-align: middle;
  display: inline-block;
}
.price_block .fb_pricebox .fb_otoku .price_month span:nth-child(3) {
  font-size: 14px;
  line-height: 1;
  font-weight: bold;
  color: #fff;
  vertical-align: middle;
  padding-top: 7px;
  display: inline-block;
}
.price_block .fb_item .price_payment {
  display: block;
  margin: 10px 0 2px;
}
.price_block .fb_item .price_payment span {
  width: 100%;
  display: block;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 10px;
}
.price_block .fb_item .price_payment ul {
  width: 100%;
  border-top: 1px solid #CCCCCC;
  border-left: none;
  padding-top: 10px;
  margin: 0 auto;
}
.price_block .fb_item .price_payment ul li {
  padding: 3px 0;
  position: relative;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.7;
}
.price_block .price_note {
  text-align: center;
}
.price_block .price_note ul {
  display: inline-block;
  text-align: left;
}
.price_block .price_note li {
  font-size: 14px;
  line-height: 1.3;
  text-indent: -1em;
  padding-left: 1em;
  margin-bottom: 5px;
}
/* 3months */

/* 3600 */
#price p.plus {
    text-align: center;
    font-weight: bold;
    font-size: 9.8vw;
    margin: 0 auto;
    color: #e4393f;
    line-height: 1.0;
}
#price p.other_data {
	display: block;
	font-size: 4.8vw;
	font-weight: 600;
	text-align: center;
	color: rgb(228,57,63);
	background-color: #eeede9;
	padding: 14px 0;
	width: 100%;
	margin-top: 10px !important;
	box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
}
/* 3600 */

/* Geo */
  .geo_note {
     margin: 40px auto 10px;
	 line-height: 1.8;
  }
	
   .geo_documents {
    padding: 18px;
    display: block;
	background: #fff;
	box-shadow: 2px 2px 10px rgba(80, 80, 80, 0.1);
  }

  .geo_documents span {
    width: 100%;
    display: block;
    text-align: center;
    margin-bottom: 10px;
	font-weight: bold;
  }

  .geo_documents ul {
    width: 100%;
    border-top: 1px solid #CCCCCC;
    border-left: none;
    padding: 10px 0 0;
  }

  .geo_documents ul li {
    padding: 5px 0;
    position: relative;
    padding-left: 20px;
	line-height: 1.8;
  }

  .geo_documents ul li::after {
    content: "・";
    position: absolute;
    left: 0;
    top: 5px;
  }

  .geo_documents ul a {
    text-decoration: underline;
  }
/* Geo */

/* -------------------------------------------------
	comparison
------------------------------------------------- */

#comparison {
	padding: 10vw 0 22.5vw;
	background-color: #e9e8e3;
}
#comparison .lead {
	padding-top: 7vw;
	font-size: 3.73vw;
}
#comparison table {
	width: 100%;
	margin: 2vw 0 6vw;
	border-collapse: collapse;
}
#comparison table th,
#comparison table td {
	padding: 1.5vw 0 1.0vw;
	vertical-align: middle;
	white-space: nowrap;
}

#comparison table thead .logo {
	width: 17.33vw;
}
#comparison table thead th {
	font-size: 3.73vw;
	border-bottom: solid 1.33vw #e9e8e3;
}
#comparison table thead tr th + th {
	border-left: solid 1.33vw #e9e8e3;
}
#comparison table thead th:first-child {
	text-align: left;
}

#comparison table tbody th,
#comparison table tbody td {
	border-bottom: solid 1.33vw #e9e8e3;
}
#comparison table tbody th {
	background-color: #f7f7f2;
	font-size: 3.2vw;
	line-height: 1.5;
}
#comparison table tbody td {
	background-color: #fff;
	border-left: solid 1.33vw #e9e8e3;
	text-align: center;
}
#comparison table tbody tr td:first-of-type {
	font-size: 4vw;
	color: #e3131f;
}
#comparison table tbody tr td:last-of-type {
	font-size: 3.2vw;
}
#comparison table tbody td .note {
	font-size: 2vw;
}
#comparison table tbody tr:last-child td:last-child {
	font-size: 2.4vw;
	line-height: 1.7;
}

#comparison table tfoot th,
#comparison table tfoot td {
	padding-top: 2vw;
	position: relative;
}
#comparison table tfoot th::after,
#comparison table tfoot td::after {
	content: "";
	display: block;
	width: 100%;
	height: 0.4vw;
	padding-right: 10px;
	position: absolute;
	left: 0;
	top: 0;
	background-color: #e3131f;
}
#comparison table tfoot th {
	font-size: 3.2vw;
	font-weight: bold;
}
#comparison table tfoot td {
	text-align: center;
}
#comparison table tfoot td:first-of-type {
	font-size: 4vw;
	color: #e3131f;
}
#comparison table tfoot td:last-child::after {
	padding-right: 0;
}

#comparison p.note {
	font-size: 3.2vw;
	text-indent: -1.5em;
	margin-left: 1.5em;
}

/* -------------------------------------------------
	footer
------------------------------------------------- */

#footer {
	height: 68.86vw;
	padding-top: 23.73vw;
	box-sizing: border-box;
	text-align: center;
	background: -webkit-gradient(linear, left top, right top, color-stop(1.00, #606060), color-stop(0.00, #424242));
	background: -webkit-linear-gradient(left, #424242, #606060);
	background: -moz-linear-gradient(left, #424242, #606060);
	background: -o-linear-gradient(left, #424242, #606060);
	background: -ms-linear-gradient(left, #424242, #606060);
	background: linear-gradient(left, #424242, #606060);
}
#footer p,
#footer p a {
	color: #fff;
}
#footer p {
	font-size: 3.2vw;
	line-height: 1;
}

#footer p.copyright {
	padding: 6vw;
	line-height: 1.8;
}


/* -------------------------------------------------
	other
------------------------------------------------- */

/* float */

.l-side {
	float: left;
}
.r-side {
	float: right;
}

.clear {
	clear: both;
}
.clearfix {
	height: auto;
}
.clearfix::after {
	clear: both;
	content: "";
	height: 0;
	display: block;
}
