@charset "utf-8";
/*==================================================
	【サブ】ページ固有のスタイル
==================================================*/
#service .red_box {
	border: 3px solid var(--color-red);
	border-radius: 50px;
	background: #fff;
	padding: 75px;
	position: relative;
	margin-bottom: 140px;
}
#service .red_box .in {
	position: relative;
}
#service .red_box .info {
	width: 460px;
	position: relative;
}
#service .red_box::before, #service .red_box::after, #service .red_box .in::before, #service .red_box .in::after {
	content: "";
	position: absolute;
	left: 45px;
	bottom: 45px;
	width: 10px;
	height: 10px;
	background: var(--color-red);
	border-radius: 50%;
	display: inline-block;
	z-index: 1;
}
#service .red_box::after {
	left: auto;
	right: 45px;
}
#service .red_box .in::before {
	left: -26px;
	bottom: auto;
	top: -26px;
}
#service .red_box .in::after {
	left: auto;
	right: -26px;
	bottom: auto;
	top: -26px;
}
#service .red_box .info .txt {
	font-size: 26px;
}
#service .red_box .info .txt.fm {
	margin-bottom: 0.5em;
	font-size: 30px;
	line-height: 1.6;
}
#service .red_box .info .txt.fs {
	font-size: 130%;
}
#service .red_box .info .label {
	background: var(--color-red);
	margin-bottom: 10px;
	color: #fff;
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-radius: 10px;
	padding: 10px 20px;
	font-size: 30px;
	line-height: 1;
}
#service .red_box .info .label:last-of-type {
	margin-bottom: 0;
}
#service .red_box .info .label dd {
	font-size: 35px;
}
#service .red_box .info .label dd span {
	font-size: 50px;
}
#service .red_box .info .label+p {
	margin-top: 1.5em;
}
#service .red_box .img img {
	border-radius: 10px;
}
#service .red_box .support span {
	display: inline-block;
	padding: 8px 15px;
	background: var(--color-primary);
	border-radius: 999px;
	color: #fff;
	font-size: 130%;
	line-height: 1.3;
}
#service .red_box ol {
	counter-reset: number;
	list-style-type: none;
}
#service .red_box ol li {
	position: relative;
	padding: 10px;
	padding-left: 55px;
	background: var(--color-red);
	border-radius: 10px;
	color: #fff;
	font-size: 140%;
	line-height: 1.5;
}
#service .red_box ol li:before{
	position: absolute;
	top: 10px;
	left: 10px;
	display: block;
	width: 30px;
	height: 30px;
	background: #fff;
	border-radius: 5px;
	color: var(--color-red);
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	counter-increment: number;
	content: counter(number);
	/* 縦方向中央揃え */
	display: flex;
	align-items: center;
	justify-content: center;
}
#service .red_box ol li+li {
	margin-top: 10px;
}
#service .red_box dl.note {
	margin-top: 1em;
	padding: 15px 20px;
	border: 2px solid #e7dd54;
	border-radius: 10px;
	font-size: 120%;
	line-height: 1.4;
	/* フレックス */
	display: flex;
	align-items: center;
	column-gap: 20px;
}
#service .red_box dl.note dt {
	color: var(--color-primary);
	font-size: 90%;
}
#service .red_box ul.note {
	margin-top: 1em;
	padding: 20px;
	border: 2px solid #e7dd54;
	border-radius: 10px;
}
#service .red_box ul.note li {
	position: relative;
	padding-left: 20px;
	line-height: 1.4em;
}
#service .red_box ul.note li::before {
	position: absolute;
	top: 0.3em;
	left: 0;
	display: block;
	width: 10px;
	height: 10px;
	background: #e7dd54;
	border-radius: 50%;
	content: "";
}
#service .red_box ul.note li+li {
	margin-top: 0.5em;
}
#service .red_box .consult {
	font-size: 120%;
}
/**/
#service .example {
	position: relative;
	margin-bottom: 60px;
}
#service .example::before {
	position: absolute;
	content: "";
	left: 50%;
	bottom: -80px;
	margin-left: -36px;
	border: 36px solid transparent;
	border-top: 20px solid #f2a65e;
}
#service .example .img {
	position: absolute;
	top: -90px;
	left: -95px;
}
#service .example .img img {
	border-radius : 0px 20px 100px 0px;
}
#service .example .bg_white {
	width: 950px;
	margin-left: auto;
	background: #fff;
	padding: 100px;
	border-radius: 20px;
}
#service .example .bg_white h3 {
	margin-left: 320px;
	font-size: 40px;
	border-bottom: 2px dashed var(--color-red);
	line-height: 1;
	padding-bottom: 20px;
	margin-bottom: 130px;
}
#service .example .bg_white ul li,
#service .example .bg_white p{
	background: url("../img/chk.png") no-repeat left top 1px;
	font-size: 19px;
	padding-left: 50px;
	margin-bottom: 10px;
}
#service .example .bg_white ul li:last-of-type {
	margin-bottom: 0;
}
/**/
#service .hash_tag .bg_white {
	border: 3px solid var(--color-red);
	border-left: none;
	background: #fff;
	padding: 90px 120px 80px 0;
	position: relative;
	border-radius : 0px 20px 20px 0px;
}
#service .hash_tag .bg_white::before {
	content: "";
	width: 50vw;
	position: absolute;
	background: #fff;
	border-top: 3px solid var(--color-red);
	border-bottom: 3px solid var(--color-red);
	top: -3px;
}
#service .hash_tag .bg_white .img {
	position: absolute;
	right: -100px;
	top: -30px;
}
#service .hash_tag .bg_white .img img {
	border-radius : 100px 0px 0px 20px;
}
#service .hash_tag .bg_white .ttl {
	font-size: 40px;
	margin-bottom: 50px;
}
#service .hash_tag .bg_white .ttl img {
	width: 260px;
	vertical-align: middle;
	position: relative;
	top: -3px;
	margin-right: 20px;
}
#service .hash_tag .bg_white ul {
	display: flex;
	flex-wrap: wrap;
	width: 820px;
}
#service .hash_tag .bg_white ul li a {
	display: inline-block;
	border: 1px solid #999;
	color: var(--color-red);
	border-radius: 5px;
	padding: 7px 17px;
	margin-right: 10px;
	margin-bottom: 10px;
	font-size: 19px;
}
#service .hash_tag .bg_white ul li a::before {
	content: "#";
	margin-right: 5px;
}
#service .cmn_faq .check {
	text-align: left;
	background: url("../img/chk.png") no-repeat left top 2px;
	background-size: 18px;
	padding-left: 24px;
	margin: 0.5em 0 ;
}
@media print, screen and (min-width: 769px){ /* PCのみ */
}
@media print, screen and (min-width: 641px){ /* PC・タブレット */
}
@media only screen and (max-width: 768px) and (min-width: 641px){ /* タブレットのみ */
}
@media only screen and (max-width: 768px) {  /* タブレット以下 */
	#service .red_box {
		padding: 35px 15px;
		border-radius: 20px;
	}
	#service .red_box::before {
		left: 15px;
		bottom: 15px;
	}
	#service .red_box::after {
		right: 15px;
		bottom: 15px;
	}
	#service .red_box .in::before {
		left: 0;
		top: -20px;
	}
	#service .red_box .in::after {
		right: 0;
		top: -20px;
	}
	#service .red_box .info, #service .red_box .img {
		width: 48%;
	}
	#service .red_box .info .txt {
		font-size: 20px;
	}
	#service .red_box .info .txt.fm {
		font-size: 25px;
	}
	#service .red_box .info .label {
		padding: 5px 10px;
		font-size: 20px;
	}
	#service .red_box .info .label dd {
		font-size: 25px;
	}
	#service .red_box .info .label dd span {
		font-size: 35px;
	}
	#service .red_box .support span {
		font-size: 120%;
	}
	#service .red_box ol {
		counter-reset: number;
		list-style-type: none;
	}
	#service .red_box ol li {
		padding-left: 45px;
		font-size: 130%;
	}
	#service .red_box ol li:before {
		width: 26px;
		height: 26px;
		font-size: 20px;
	}
	/**/
	#service .example .img {
		width: 50%;
		left: -20px;
	}
	#service .example .bg_white {
		width: 100%;
		padding: 30px;
	}
	#service .example .bg_white h3 {
		margin-bottom: 8vw;
		margin-left: 50%;
		font-size: 30px;
	}
	#service .example .bg_white ul li,
	#service .example .bg_white p{
		font-size: 16px;
		background-size: 25px auto;
		padding-left: 40px;
	}
	#service .hash_tag .bg_white {
		padding: 40px 0 20px;
	}
	#service .hash_tag .bg_white .ttl {
		padding-right: 40%;
		font-size: 30px;
		margin-bottom: 30px;
	}
	#service .hash_tag .bg_white .img {
		right: -20px;
		width: 210px;
		top: -45px;
	}
	#service .hash_tag .bg_white ul {
		width: 100%;
	}
	#service .hash_tag .bg_white ul li a {
		padding: 4px 10px;
		font-size: 16px;
	}
}
@media only screen and (max-width: 640px){ /* スマホ */
	#service .red_box {
		margin-bottom: 50px;
	}
	#service .red_box .info, #service .red_box .img {
		width: 100%;
	}
	#service .red_box .info {
		margin-bottom: 20px;
	}
	#service .red_box .info .txt {
		font-size: 17px;
	}
	#service .red_box .info .txt.fm {
		font-size: 135%;
	}
	#service .red_box .info .txt.fs {
		font-size: 110%;
	}
	#service .red_box .info .label {
		font-size: 18px;
	}
	#service .red_box .info .label dd {
		font-size: 20px;
	}
	#service .red_box .info .label dd span {
		font-size: 30px;
	}
	#service .red_box .support span {
		font-size: 115%;
	}
	#service .red_box ol li {
		font-size: 115%;
	}
	#service .red_box ol li:before {
		width: 24px;
		height: 24px;
	}
	#service .red_box .consult {
		font-size: 100%;
	}
	/**/
	#service .example .img {
		top: -10px;
	}
	#service .example .bg_white h3 {
		margin-left: 45%;
		font-size: 20px;
	}
	#service .example .bg_white {
		padding: 30px 15px 15px;
	}
	#service .example .bg_white ul li,
	#service .example .bg_white p{
		font-size: 15px;
		background-size: 20px auto;
		background-position: left top 4px;
		padding-left: 30px;
	}
	#service .hash_tag .bg_white {
		padding: 30px 0 20px;
	}
	#service .hash_tag .bg_white .img {
		width: 100px;
		right: -25px;
	}
	#service .hash_tag .bg_white .img img {
		border-radius: 50px 0px 0px 10px;
	}
	#service .hash_tag .bg_white .ttl {
		padding-right: 0;
		font-size: 20px;
	}
	#service .hash_tag .bg_white .ttl img {
		margin-right: 0;
		width: 250px;
	}
	#service .hash_tag .bg_white ul li a {
		padding: 2px 5px;
		font-size: 13px;
	}
	#service .hash_tag .bg_white ul li a::before {
		margin-right: 2px;
	}
	#service .cmn_faq .check {
		background: url("../img/chk.png") no-repeat left top 5px;
		background-size: 14px;
		padding-left: 15px;
	}
}
@media only screen and (max-width: 320px){
	#service .hash_tag .bg_white .ttl img {
		width: 200px;
	}
	#service .cmn_faq .check {
		background: url("../img/chk.png") no-repeat left top 5px;
		background-size: 10px;
		padding-left: 8px;
	}
	#service .cmn_faq .check span {
		font-size: 84%;
	}
}