@charset "utf-8";

/* =======================================

	lp.css
	Last Up Date 2014/03/18

 -----------------------------------------
	INDEX
 -----------------------------------------
	0. common style [base]

	1. .header_wrapper

	2. .nav_wrapper

	3. .easy1Step_container

	4. .contents_wrapper

	5. .contents_main

	6. .contents_side

	7. .footer_wrapper

	x. common style [strong]

========================================== */
.fsc_lead {
	display: flex;
	justify-content: space-around;
	margin: 20px 50px;
	align-items: center;
	flex-wrap: wrap;
}

.fsc_lead p {
	text-align: center;
	font-size: 1.3em;
}

.fsc_point {
	display: flex;
	justify-content: space-around;
	margin: 40px 30px;
}

.fsc_point>div {
	width: 32%;
}

.fsc_point>div>h2 {
	text-align: center;
	color: #285fd5;
	font-weight: bold;
	font-size: 20px;
	margin-bottom: 5px;
}

.fsc_point>div>h2 span {
	color: #ff6e00;
}

.fsc_point>div>div img {
	width: 100%;
}

.fsc_point>div>p {
	margin-top: 10px;
	font-size: 16px;
	line-height: 1.5;
}

.fsc_mokuji {
	text-align: center;
	margin: 30px 0;
	font-size: 1.3em;
}

.fsc_mokuji>div {
	display: inline-block;
	border: solid 2px #285fd5;
	padding: 20px 30px;
	margin: auto;
	line-height: 2em;
}

.fsc_mokuji>div>div {
	text-align: left;
}

.fsc_mokuji>div>div a {
	color: #285fd5;
}

.fsclp h2 {
	color: #fff;
	background: #285FD5;
	padding: 6px 15px;
	font-size: 28px;
	margin: 0 0 30px;
}

.fsclp h3 {
	padding-bottom: 2px;
	font-size: 1.6em;
	color: #285fd5;
	font-weight: bold;
	margin: 10px 0 5px;
	line-height: 1.2;
}

.fsclp p {
	line-height: 1.5em;
	margin: 5px 0;
	font-size: 16px;
	color: #555;
}

.fsclp p strong {
	background: linear-gradient(transparent 50%, #fff7a4 50%);
	font-weight: bold;
}

.fsc_product {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.fsc_product>div {
	width:100%;
	margin-bottom: 50px;
}

.fsc_product>div div {
	display: inline-block
}

.nouki>span {
	color: #ff6e00;
	border: 1px solid #ff6e00;
	padding: 3px;
	font-weight: bold;
}

.siyou {
	line-height: 1.2;
}

.product {
	margin: 15px 0 0 !important;
	width: 100%;
	height: 250px;
	border: solid #f5f5f5 30px;
	object-fit: none;
}

.fsc_product img {
	width: 100%;
	box-shadow: 4px 4px 4px #eee;
}

.price span {
	color: #ff6e00;
	font-size: 1.5em;
	font-weight: bold;
}

.detail {
	margin-top: 10px !important;
	background: #ff6e00;
	border-radius: 5px;
	padding: 8px;
	font-size: 1.4em !important;
	text-align: center;
	color: #fff !important;
}

.fsc_sample {
	display: flex;
	justify-content: space-between;
}

.fsc_sample>div {
	width: 100%;
	margin-bottom: 1em;
}

.fsc_sample>div:nth-child(1) {
	width: 60%;
}

.fsc_sample>div:nth-child(1)>div {
	display: flex;
	align-items: center;
	font-size: 2em;
	font-weight: bold;
}

.fsc_sample>div:nth-child(2) {
	width: 35%;
}

.fsc_sample>div:nth-child(2) img {
	max-width: 100%;
}

.yousi {
	background: #e9f4eb;
	padding: 1.5em;
}

.yousi span {
	font-size: 1.2em;
	font-weight: bold;
	color: #285fd5;
}

span.yousi_cate {
	background: #285fd5;
	color: #fff;
	font-weight: normal;
	font-size: 1em;
	display: inline-block;
	width: 5em;
	text-align: center;
	margin-right: 5px;
}

.fsc_button {
	padding: 0 0;
	text-align: center;
	margin-top: 40px;
	background: #fff;
}

.fsc_button a {
	display: inline-block;
	font-weight: bold;
	font-size: 2em;
	margin: 10px auto;
	padding: 20px 40px;
	border-radius: 40px;
	color: #fff;
	background: #ff8f16;
	text-decoration: none;
	box-shadow: #555;
}

.fsc_button a:hover {
	opacity: 0.7;
	transition: 0.5s;
}

.topback {
	text-align: center;
	margin-top: 60px;
}

.topback a {
	font-size: 1.8em;
	padding: 10px 80px;
	border-radius: 5px;
	color: #fff;
	background: #285fd5;
	text-decoration: none;
}

.topback a:hover {
	opacity: 0.7;
	transition: 0.5s;
}

.checklist {
	display: flex;
	font-size: 2em;
	color: #285fd5;
	font-weight: 100;
	margin-bottom: 0.5em;
}

.point {
	background-color: #f1f6f5;
	padding-bottom: 130px;
	padding-top: 100px;
	position: relative;
}

.point::before {
	border-color: #f1f6f5 transparent transparent transparent;
	border-style: solid;
	border-width: 42px 42px 0 42px;
	bottom: 0;
	content: "";
	height: 0;
	left: 50%;
	position: absolute;
	transform: translateX(-50%) translateY(100%);
	width: 0;
	z-index: 1;
}

.point__inner {
	margin: 0 auto;
	max-width: 100%;
	padding: 0 220px;
	width: 1440px;
}

.point__title::after {
	-webkit-text-stroke: 2px #fff;
	color: #f1f6f5;
	content: "point";
	font-size: 195px;
	font-weight: 900;
	position: absolute;
	right: -140px;
	top: -90px;
	z-index: -1;
}

.point__subtitle {
	color: #285c4d;
	font-size: 42px;
	font-weight: bold;
	margin-top: 60px;
	position: relative;
	text-align: center;
	z-index: 2;
}

.point__lead {
	color: #000000;
	font-size: 16px;
	letter-spacing: 0.02em;
	line-height: 1.6;
	margin-top: 5px;
	position: relative;
	text-align: center;
	z-index: 2;
}

.point__lead span {
	color: #285FD5;
}

.point__list {
	margin-top: 75px;
}

.point__item {
	background-color: #fff;
	margin-top: 25px;
	position: relative;
}

.point__top {
	align-items: center;
	display: flex;
	padding: 30px 40px;
	background: #e8f7ea;
}

.point__img {
	width: 160px;
}

.point__img img {
	height: auto;
	width: 108px;
}

.point__contents {
	border-left: 1px solid #000;
	padding-left: 50px;
	width: calc(100% - 160px);
}

.point__text {
	color: #285fd5;
	font-size: 2em !important;
	font-weight: bold !important;
}

.point__text._red {
	color: #285FD5;
}

.point__subtext {
	font-size: 18px;
}

.point__bottom {
	padding: 0px 40px 25px;
	background: #e8f7ea;

}

.point__bottomWrap {
	align-items: center;
	background-color: #fff;
	display: flex;
	padding: 20px 20px 20px;
}

.point__card-img {
	flex-shrink: 0;
	position: relative;
	width: 252px;
	border: #285FD5 1px solid;
}

.point__card-img::before {
	content: "";
	display: block;
	padding-top: 60%;
}

.point__card-img img {
	-o-object-fit: cover;
	height: 100%;
	left: 0;
	max-width: none;
	object-fit: cover;
	position: absolute;
	top: 0;
	width: 100%;
}

.point__card-contents {
	height: 140px;
	margin-left: 35px;
	width: calc(100% - 252px);
}

.point__card-text {
	-webkit-text-stroke: 1px #195f41;
	color: #f1f6f5;
	font-size: 24px;
	font-weight: bold;
	line-height: 1.45;
	padding-bottom: 10px;
}

.point__card-text._red {
	-webkit-text-stroke: 1px #285FD5;
	margin: 0 !important;
}

.point__card-subtext {
	border-top: 1px solid #000;
	font-size: 18px;
	line-height: 1.45;
	padding-top: 10px;
	margin: 0 !important;
}

.point__number {
	-webkit-text-stroke: 1px #1fc76a !important;
	color: #ffffff !important;
	font-size: 5em !important;
	font-weight: 900 !important;
	height: 107px !important;
	left: 10px !important;
	position: absolute !important;
	top: -45px !important;
	width: 91px !important;
}

.point__number._red {
	-webkit-text-stroke: 1px #285FD5 !important;
}

.point__tag {
	align-items: center;
	background-color: #285c4d;
	color: #fff !important;
	display: flex;
	display: inline-block;
	font-size: 16px;
	padding: 10px 25px;
	position: absolute;
	right: 0;
	top: 0;
	margin: 0 !important;
}

.point__tag._red {
	background-color: #285FD5;
}

.faq__q {
	color: #285fd5 !important;
	margin-bottom: 0.5em !important;
}

.faq__q span {
	font-size: 1.4em;
	font-weight: bold;
	margin-right: 0.5em;
}

.faq__a {
	margin-top: 0.5em !important;
	margin-bottom: 1.5em !important;
}

.faq__a span {
	font-size: 1.4em;
	font-weight: bold;
	margin-right: 0.5em;
}

h3.title {
	font-size: 28px;
	padding-bottom: 5px;
	border-bottom: #285fd5 1px solid;
	margin: 3em 0 1em;
}

.fsc_environment {
	display: flex;
	justify-content: space-around;
	margin: 40px 0px;
	flex-wrap: wrap;
}

.fsc_environment>div {
	width: 32%;
}

.fsc_environment>div>h3 {
	text-align: center;
	color: #285fd5;
	font-weight: bold;
	font-size: 20px;
	margin-bottom: 5px;
}

.fsc_environment>div>h2 span {
	color: #ff6e00;
}

.fsc_environment>div>div {
	text-align: center;
}

.fsc_environment>div>div img {
	width: 50%;
}

.fsc_environment>div>p {
	margin-top: 10px;
	font-size: 16px;
	line-height: 1.5;
}

.electionNotice {
	border: 2px solid #dee9ff;
	background: #f7faff;
	padding: 20px 25px;
	margin: 30px auto;
	max-width: 1100px;
}

.electionNotice__title {
	font-size: 20px;
	font-weight: bold;
	color: #285FD5;
	margin-bottom: 10px;
}

.electionNotice p {
	font-size: 15px;
	line-height: 1.6;
	color: #555;
	margin-bottom: 8px;
}

.electionNotice__note {
	font-size: 14px;
	color: #666;
}

.electionTags {
	margin-bottom: 6px;
}

.tag {
	display: inline-block;
	font-size: 12px;
	font-weight: bold;
	padding: 2px 8px;
	border-radius: 12px;
	margin-top: 10px;
	margin-right: 4px;
}

.tag-pre {
	background: #285FD5;
	color: #fff;
	border: none;
	border-radius: 0;
}

.tag-post {
	background: #cb0000;
	color: #fff;
	border: none;
	border-radius: 0;
}

.tag-all {
	background: #777;
	color: #fff;
	border: none;
	border-radius: 0;
}

.fsc_product {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px 20px;
}

/* SP時は自動で2列などに */
@media screen and (max-width: 768px) {
  .fsc_product {
    grid-template-columns: repeat(2, 1fr);
  }
}