@charset "UTF-8";
/*--------------------
/ Foundation - reset
------------------- */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font: inherit;
	vertical-align: baseline;
}
body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video,
button, select, option, input, textarea {
	font-size: 100%;
}
ol, ul {
	list-style: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
caption, th, td {
	text-align: left;
	font-weight: normal;
	vertical-align: middle;
}
q, blockquote {
	quotes: none;
}
q:before, q:after,
blockquote:before, blockquote:after {
	content: "";
	content: none;
}
a img {
	border: none;
}
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
	display: block;
}
video {
	max-width: 100%;
}


/*  --------------------------------------
デバイス振り分け(PC)
--------------------------------------  */
@media screen and (min-width:837px) {
.sp {display:none!important;}
body{
	font-family : "游ゴシック体", yugothic, "游ゴシック", "yu gothic", "ヒラギノ角ゴシック", Hiragino Kaku Gothic ProN, Gothic MB101, Hiragino Sans,"ヒラギノ角ゴ ProN W3", Roboto, "Droid Sans", Meiryo, "メイリオ", Verdana, "ＭＳ Ｐゴシック", sans-serif;
	text-align : left;
	font-size:16px;
	color:#000;
	position:relative;
	overflow-x: hidden;
}
.layer {
	margin:0 auto;
	max-width:1200px;
	background: linear-gradient(to right, #7dccf3, #0091da);
}
/* --------------------  ヘッダー */
header {
	background: #a4d6c1;
	margin-top: 87px;
}
header .contact_area {
	padding-top: 80px;
}
.header_wrap_top {
	margin-top: 87px;
}
.header_wrap_top .inner {
	height: 100%;
}
.header_main{
	text-align: center;
}
.header_wrap_top .inner h2 {
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	font-size: 2.4rem;
}
.header_wrap_top .inner p {
	position: absolute;
	bottom: 10px;
	right: -200px;
	font-size: 1rem;
	text-shadow:1px 1px 1px #FFF, -1px -1px 1px #FFF,
	-1px 1px 1px #FFF, 1px -1px 1px #FFF,
	0px 1px 1px #FFF,  0-1px 1px #FFF,
	-1px 0 1px #FFF, 1px 0 1px #FFF;
}
.header_point_list_body {
	background: #f3f1df;
}
.header_point_list {
	display: flex;
	width: 770px;
	justify-content: space-between;
	margin: 0 auto;
	position: relative;
	top: -90px;
	padding-bottom: 30px;
}
header .menu.fix {
	width: 100%;
	opacity: 1;
	height: 87px;
	background: #fff;
}
header .menu.fix > ul {
	padding-top: 60px;
}
header .menu.fix .toggle {
	top: 9px;
	right: 8px;
}
header .menu.fix .toggle::before {
	display: none;
}
header .menu {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 102;
	width: 100%;
	min-width: 320px;
	height: 87px;
	background: #fff;
}
header .menu::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
}
header .menu .toggle {
	position: absolute;
	top: 9px;
	right: 8px;
	width: 64px;
	height: 65px;
	cursor: pointer;
	z-index: 1;
	border-radius: 10px;
}
header .menu .bar {
	position: relative;
	top: 6px;
	right: 0;
	display: block;
	height: 5px;
	width: 40px;
	background: #626262;
	margin: 9px auto;
	transition: all 0.7s ease;
	z-index: 3;
}
header .menu .middle {
	margin: 0 auto;
}
header .menu .toggle.on .top {
	transform: translateY(10px) rotateZ(45deg);
	width: 45px;
	top: 10px;
}
header .menu .toggle.on .bottom {
	transform: translateY(-6px) rotateZ(-45deg);
	width: 45px;
	top: -1px;
}
header .menu .toggle.on .middle {
	width: 0;
}
header .menu img {
	display: block;
}
header h1.logo {
	height: 100%;
}
header .menu h1.logo {
	display: inline-flex;
	align-items: center;
	width: 30%;
	height: 100%;
	transition: 0.5s;
	text-decoration: none;
	margin-left: 15px;
	font-size: 0.6rem;
}
header .menu h1.logo img {
	display: block;
	width: 200px;
	max-width: 300px;
	height: auto;
}
.menu {
	z-index: 9998;
}
header .menu_list {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	min-width: 320px;
	height: 120vh;
	z-index: 100;
	margin-top: 27px;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
	overflow-scrolling: touch;
	background: RGBA(255, 255, 255, 0.7);
	-webkit-backdrop-filter: blur(10px);
		backdrop-filter: blur(10px);
}
header .menu_list ul li {
	border-top: 1px solid #ddd;
}
header .menu_list ul li.g-navi07 {
	background: #624235;
}
header .menu_list ul li a {
	color: #626262;
	display: block;
	font-size: 15px;
	font-family: "游ゴシック体", Yu Gothic, YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	font-weight: bold;
	line-height: 1.4;
	padding: 13px 30px 13px 15px;
	text-decoration: none;
	position: relative;
	background: RGBA(255, 255, 255, 0.8);
}
header .menu_list ul li.cv a {
	color: #fff;
	background: #626262;
}
header .menu_list ul li a:hover {
	opacity: 1;
}
header .menu_list ul li a:after {
	position: absolute;
	right: 20px;
	top: 50%;
	margin-top: -5px;
	content: '';
	display: block;
	width: 10px;
	height: 10px;
	border-top: solid 2px #626262;
	border-right: solid 2px #626262;
	transform: rotate(45deg);
	z-index: 2;
}
header .menu_list ul li.cv a:after {
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
}
header .menu_list > ul {
	padding-top: 60px;
	border-bottom: 1px solid #ddd;
}
.header_notice_bnr{
	position: relative;
	text-align: center;
	top: -80px;
	padding-bottom: 50px;
}
.header_notice_bnr img{
  width: 670px;
}
.keyvisual {
	margin:0 auto;
	max-width:1200px;
	max-height:1429px;
	font-size:0;
	line-height:0;
	position:relative;
}
.innerlink_wrap div {
	width:58.75%;
	max-width:705px;
	max-height:71px;
}
.innerlink_wrap div:nth-child(1) {
	position:absolute;
	top:48.6%;
	left:29.3%;
}
.innerlink_wrap div:nth-child(2) {
	position:absolute;
	bottom:1.8%;
	left:50%;
	transform:translateX(-50%);
}
main {
	margin:0 auto;
	padding:0;
	width:100%;
	max-width:1200px;
}
.contact_wrap {
	margin:0 auto;
	width:100%;
	font-size:0;
	line-height:0;
}
.keyvisual h1 img,
.innerlink_wrap img,
.contact_wrap img {width:100%;}

[id="1"],
[id="2"],
[id="3"],
[id="4"],
[id="5"],
[id="6"],
[id="7"] {
/* 	margin-top:-87px!important;
	padding-top:87px!important; */
	margin-top:-7.25%!important;
	padding-top:7.25%!important;
}


/* =========================================
CONTENT
========================================= */
.add_link {
	width:100%;
	max-height:722px;
	position:relative;
}
.add_link div {
	width:49.67%;
	max-width:596px;
	max-height:71px;
	position:absolute;
	left:38.4%;
}
.add_link div:nth-child(2) {top:30.6%;}
.add_link div:nth-child(3) {top:44%;}
.add_link div:nth-child(4) {top:53.5%;}
.add_link div:nth-child(5) {top:63%;}
.s1_wrap {
	margin:0 auto;
	padding:5.55%;
	width:calc(100% - 11.1%);
	font-size:0;
	line-height:0;
	background:#f19ca6;
}
.opner {
	margin:0 auto;
	max-width:1200px;
	min-height:50px;
	font-size:0;
	line-height:0;
	position:relative;
}
.cap {
	margin:0 auto;
	width:57.83%;
	cursor:pointer;
	position:absolute;
	top:0;
	left:50%;
	transform:translateX(-50%);
	z-index:50;
}
.cap_inner {
	width:100%;
	max-height:844px;
	position:relative;
	z-index:49;
	display:none;
}
.ci_link {
	width:30%;
	position:absolute;
	bottom:28.7%;
	left:53.7%;
	z-index:50;
	display:none;
}
.s3_after,
.outline dl {
	position:relative;
}
.s3_after div:nth-child(2) {
	width:30%;
	max-width:360px;
	max-height:71px;
	position:absolute;
	top:32.2%;
	left:53.6%;
}
.s3_after div:nth-child(3) {
	width:30%;
	max-width:361px;
	max-height:56px;
	position:absolute;
	bottom:14%;
	left:14.9%;
}
.outline_wrap {
	padding:50px 0;
	background:#FFF;
}
.outline {
	margin:0 0 40px;
}
.s4_link {display:none;}
.s4_link div {
	width:30%;
	max-width:360px;
	position:absolute;
	left:40%;
}
.s4_link div:nth-child(1) {
	top:47.4%;
}
.s4_link div:nth-child(2) {
	bottom:2%;
}
.faq_wrap {
	padding:0 12.5% 60px;
	width:75%;
}
.faq_wrap dl:last-child {
	border-bottom:1.5px solid #FFF;
}
.block {
	display:block;
}
.leadwrap {
	margin:0 auto;
	width:100%;
}
.outline_wrap .dtl_opener {
	margin:0 auto;
	width:75%;
	font-size:0;
	line-height:0;
	cursor:pointer;
	position:relative;
}
.dtl_opener {
	margin:0 auto;
	width:100%;
	font-size:0;
	line-height:0;
	cursor:pointer;
	position:relative;
}
.cap:before,
.cap:after,
.dtl_opener:before,
.dtl_opener:after {
	content: '';
	width:2.8125%;
	height:5px;
	background:#FFF;
	transition:all .3s ease-in-out;
	position:absolute;
	top:43%;
	right:1.875%;
}
.cap:before,
.cap:after {
	background:#003f77;
	right:2.875%;
}
.outline .dtl_opener:before,
.outline .dtl_opener:after {
	width:2.3%;
	background:#0068b7;
	right:2.17%;
}
.cmp_outline .dtl_opener:before,
.cmp_outline .dtl_opener:after {
	width:2.3%;
	right:2.17%;
}
.faq_wrap .dtl_opener:before,
.faq_wrap .dtl_opener:after {
	width:2.3%;
	background:#0068b7;
	top:47%;
	right:1.6%;
}
.cap:before      {transform: rotate(90deg);}
.cap.open:before {transform: rotate(180deg);}
.cap.open:after  {opacity: 0;}
.dtl_opener:before      {transform: rotate(90deg);}
.dtl_opener.open:before {transform: rotate(180deg);}
.dtl_opener.open:after  {opacity: 0;}
.dtl_opener div {
	width:8.125%;
	font-size:0;
	line-height:0;
	position:absolute;
	top:50%;
	left:15%;
	transform: translateY(-50%);
}
.dtl_opener div img {width:100%;}
.dtl_txt {
	display: none;
	margin:0 auto;
	width:100%;
	position:relative;
}
.s3_layer {
	width:100%;
	background:url('../img/pc/s3_boxbk.png') repeat-y top left;
	background-size: contain;
}
.s1_link {
	width:30%;
	position:absolute;
	bottom:28.7%;
	left:53.7%;
	z-index:100;
}
.s1_link div {width:48.55%;}
a[href*="tel:"] {
	pointer-events: none;
	cursor: default;
	text-decoration: none;
}
.dtl_opener img,
.img100 img {width:100%;}
footer {
	background-color: #007c8a;
	display: flex;
	justify-content: space-between;
}
footer .left_wrap,
footer .right_wrap {
	width: 50%;
	padding: 2%;
}
footer .right_wrap {
	text-align: right;
}
footer p,
footer a {
	color: #fff;
	font-size: 12px;
	text-decoration:none;
}
footer a {
	display: inline-block;
	padding-bottom: 10px;
}
footer small {
	letter-spacing: .15rem;
}
.tracer {
	width:91px;
	font-size:0;
	line-height:0;
	position:fixed;
	top:194px;
	right:0;
	z-index:53;
}
.tracer img {width:100%;}

/* --------------------  aタグ処理 画像透過リンク */
a img {transition:opacity 0.5s;}
a:hover img {opacity:0.7;}
.innerlink_wrap div:nth-child(1) a img {opacity:1;}
.mb30 {margin-bottom:30px;}

}/* end */

/*  --------------------------------------
デバイス振り分け(SP)
--------------------------------------  */
@media screen and (max-width:836px) {
.pc {display:none!important;}
body{
	background : #FFF;
	font-family :  "ヒラギノ角ゴシック", Hiragino Kaku Gothic ProN, Gothic MB101, Hiragino Sans,"ヒラギノ角ゴ ProN W3", Roboto, "Droid Sans", YuGothic, "游ゴシック", Meiryo, "メイリオ", Verdana, "ＭＳ Ｐゴシック", sans-serif;
	width:100%;
	text-align : left;
	position:relative;
}
.layer {
	margin:0 auto;
	width:100%;
	background: linear-gradient(to right, #7dccf3, #0091da);
}

/*  --------------------------------------
Header
--------------------------------------  */
header {
	background: #a4d6c1;
	margin-top: 87px;
}
header .contact_area {
	padding-top: 80px;
}
.header_wrap_top {
	margin-top: 87px;
	height: 880px;
}
.header_wrap_top {
	height: auto;
	margin-top: 50px;
}
.header_wrap_top .inner {
	height: 100%;
}
.header_main{
	text-align: center;
}
.header_wrap_top .inner h2 {
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	font-size: 2.4rem;
}
.header_wrap_top .inner p {
	position: absolute;
	bottom: 10px;
	right: -200px;
	font-size: 1rem;
	text-shadow:1px 1px 1px #FFF, -1px -1px 1px #FFF,
	-1px 1px 1px #FFF, 1px -1px 1px #FFF,
	0px 1px 1px #FFF,  0-1px 1px #FFF,
	-1px 0 1px #FFF, 1px 0 1px #FFF;
}
.header_point_list_body {
	background: #f3f1df;
}
.header_point_list {
	display: flex;
	width: 770px;
	justify-content: space-between;
	margin: 0 auto;
	position: relative;
	top: -90px;
	padding-bottom: 30px;
}

header .menu.fix {
	width: 100%;
	opacity: 1;
	height: 87px;
	background: #fff;
}
header .menu.fix > ul {
	padding-top: 60px;
}
header .menu.fix .toggle {
	top: 9px;
	right: 8px;
}
header .menu.fix .toggle::before {
	display: none;
}
header .menu {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 102;
	width: 100%;
	min-width: 320px;
	height: 87px;
	background: #fff;
}
header .menu::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
}
header .menu .toggle {
	position: absolute;
	top: 9px;
	right: 8px;
	width: 64px;
	height: 65px;
	cursor: pointer;
	z-index: 1;
	border-radius: 10px;
}
header .menu .bar {
	position: relative;
	top: 6px;
	right: 0;
	display: block;
	height: 5px;
	width: 40px;
	background: #626262;
	margin: 9px auto;
	transition: all 0.7s ease;
	z-index: 3;
}
header .menu .middle {
	margin: 0 auto;
}
header .menu .toggle.on .top {
	transform: translateY(10px) rotateZ(45deg);
	width: 45px;
	top: 10px;
}
header .menu .toggle.on .bottom {
	transform: translateY(-6px) rotateZ(-45deg);
	width: 45px;
	top: -1px;
}
header .menu .toggle.on .middle {
	width: 0;
}
header .menu img {
	display: block;
}
header h1.logo {
	height: 100%;
}
header .menu h1.logo {
	display: inline-flex;
	align-items: center;
	width: 30%;
	height: 100%;
	transition: 0.5s;
	text-decoration: none;
	margin-left: 15px;
	font-size: 0.6rem;
}
header .menu h1.logo img {
	display: block;
	width: 200px;
	max-width: 300px;
	height: auto;
}
.menu {
	z-index: 9998;
}
header .menu_list {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	min-width: 320px;
	height: 120vh;
	z-index: 100;
	margin-top: 27px;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
	overflow-scrolling: touch;
	background: RGBA(255, 255, 255, 0.7);
	-webkit-backdrop-filter: blur(10px);
			backdrop-filter: blur(10px);
}
header .menu_list ul li {
	border-top: 1px solid #ddd;
}
header .menu_list ul li.g-navi07 {
	background: #624235;
}
header .menu_list ul li a {
	color: #626262;
	display: block;
	font-size: 3.6vw;
	font-family: "游ゴシック体", Yu Gothic, YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	font-weight: bold;
	line-height: 1.4;
	padding: 13px 30px 13px 15px;
	text-decoration: none;
	position: relative;
	background: RGBA(255, 255, 255, 0.8);
}
header .menu_list ul li.cv a {
	color: #fff;
	background: #626262;
}
header .menu_list ul li a:hover {
	opacity: 1;
}
header .menu_list ul li a:after {
	position: absolute;
	right: 20px;
	top: 50%;
	margin-top: -5px;
	content: '';
	display: block;
	width: 10px;
	height: 10px;
	border-top: solid 2px #626262;
	border-right: solid 2px #626262;
	transform: rotate(45deg);
	z-index: 2;
}
header .menu_list ul li.cv a:after {
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
}
header .menu_list > ul {
	padding-top: 60px;
	border-bottom: 1px solid #ddd;
}
.header_notice_bnr{
	position: relative;
	text-align: center;
	top: -80px;
	padding-bottom: 50px;
}
.header_notice_bnr img{
	width: 670px;
}
header .menu {
	min-width: auto;
	height: 50px;
/* background: red; */
}
header .menu.fix {
	height: 50px;
}
header .menu.fix .toggle {
	top: 5px;
}
header .menu .toggle {
	width: 30px;
	height: 30px;
	top: 5px;
	right: 8px;
}
header .menu .toggle.on {
	top: 3px;
}
header .menu .bar {
	top: 5px;
	right: 5px;
	width: 30px;
	height: 3px;
	margin: 5px auto;
}
header .menu .toggle.on .top {
	width: 30px;
	top: 4px;
}
header .menu .toggle.on .bottom {
	width: 30px;
	top: 4px;
}
header .menu_list > ul {
	padding-top: 23px;
}
.header_point_list {
	width: 100%;
	top: -30px;
}
.header_point_list li {
	width: calc(100% / 4);
}
.header_point_list li img {
	width: 100%;
}
header .contact_area {
	margin-top: 0px;
	padding-top: 25px;
}
.header_notice_bnr{
	top:-45px;
	padding-bottom: 25px;
}
.header_notice_bnr img{
	width: 310px;
}


.keyvisual {
	margin:0 auto;
	width:100%;
	font-size:0;
	line-height:0;
	position:relative;
}
.innerlink_wrap div {
	width:85.75%;
}
.innerlink_wrap div:nth-child(1) {
	position:absolute;
	top:37.5%;
	left:50%;
	transform:translateX(-50%);
}
.innerlink_wrap div:nth-child(2) {
	position:absolute;
	bottom:1.2%;
	left:50%;
	transform:translateX(-50%);
}
main {
	margin:0 auto;
	padding:0;
	width:100%;
	background: url(../img/sp/bk.png) repeat top left;
	background-size:7.54%;
}
.contact_wrap,
.innerlink_wrap img,
.keyvisual h1 img,
.contact_wrap img {width:100%;}

[id="1"],
[id="2"],
[id="3"],
[id="6"],
[id="7"] {
	margin-top:-10vw!important;
	padding-top:10vw!important;
}
[id="4"],
[id="5"] {
	margin-top:-15vw!important;
	padding-top:15vw!important;
}

/* =========================================
CONTENT
========================================= */
.add_link {
	width:100%;
	font-size:0;
	line-height:0;
	position:relative;
}
.add_link div {
	width:85.625%;
	position:absolute;
	left:50.2%;
	transform:translateX(-50%);
}
.add_link div:nth-child(2) {top:30.7%;}
.add_link div:nth-child(3) {top:54%;}
.add_link div:nth-child(4) {top:61%;}
.add_link div:nth-child(5) {top:68%;}
.s1_wrap {
	margin:0 auto;
	padding:4.125%;
	width:calc(100% - 8.25% - 4.25%);
	font-size:0;
	line-height:0;
	background:#f19ca6;
}
.s3_layer {
	width:100%;
	min-height:8vw;
	background:url('../img/sp/s3_boxbk.png') repeat-y top left;
	background-size: contain;
}
.opner {
	margin:0 auto;
	width:100%;
	font-size:0;
	line-height:0;
	position:relative;
}
.cap {
	margin:0 auto;
	width:73.5%;
	cursor:pointer;
	position:absolute;
	top:0;
	left:50%;
	transform:translateX(-50%);
	z-index:50;
}
.cap_inner {
	width:100%;
	position:relative;
	z-index:49;
	display:none;
}
.ci_link {
	width:62.25%;
	position:absolute;
	bottom:1.5%;
	left:50%;
	transform:translateX(-50%);
	z-index:50;
	display:none;
}
.s3_after,
.outline dl {
	position:relative;
}
.s3_after div {
	width:62.375%;
	position:absolute;
	left:50%;
	transform:translateX(-50%);
}
.s3_after div:nth-child(2) {
	top:60.2%;
}
.s3_after div:nth-child(3) {
	top:42%;
}
.s3_after div:nth-child(4) {
	width:84.125%;
	bottom:15%;
}
.outline_wrap {
	padding:6vw 0;
	background:#FFF;
}
.outline {
	margin:0 0 3vw;
}
.outline_wrap .dtl_opener {
	margin:0 auto;
	width:90.375%;
	font-size:0;
	line-height:0;
	cursor:pointer;
	position:relative;
}
.s4_link {display:none;}
.s4_link div {
	width:53.25%;
	position:absolute;
	left:29%;
}
.s4_link div:nth-child(1) {
	top:46.5%;
}
.s4_link div:nth-child(2) {
	bottom:-0.4%;
}
.faq_wrap {
	padding:0 5.125% 60px;
	width:89.75%;
}
.faq_wrap dl:last-child {
	border-bottom:1px solid #FFF;
}







.leadwrap {
	margin:0 auto;
	width:100%;
	background:#FFF;
}
.leadwrap {
	margin:0 auto;
	width:100%;
}
.dtl_opener {
	width:100%;
	font-size: 0;
	line-height:0;
	position: relative;
}
.cap:before,
.cap:after,
.dtl_opener:before,
.dtl_opener:after {
	content: '';
	width: 3vw;
	height: 0.7vw;
	border-radius:1px;
	background: #FFF;
	transition: all .3s ease-in-out;
	position: absolute;
	top: 42%;
	right: 3.2vw;
}
.cap:before,
.cap:after {
	background:#003f77;
	right: 3.2vw;
}
.outline .dtl_opener:before,
.outline .dtl_opener:after {
	width:2.4%;
	background:#0068b7;
	right:2.6vw;
}
.cmp_outline .dtl_opener:before,
.cmp_outline .dtl_opener:after {
	width:2.4%;
	right:2.6vw;
}
.faq_wrap .dtl_opener:before,
.faq_wrap .dtl_opener:after {
	width:2.4%;
	background:#0068b7;
	top:47%;
	right:1.8vw;
}
.cap:before      {transform: rotate(90deg);}
.cap.open:before {transform: rotate(180deg);}
.cap.open:after  {opacity: 0;}
.dtl_opener:before {transform: rotate(90deg);}
.dtl_opener.open:before {transform: rotate(180deg);}
.dtl_opener.open:after  {opacity: 0;}
.dtl_opener div {
	width:13.285%;
	font-size:0;
	line-height:0;
	position:absolute;
	top:50%;
	left:3%;
	transform: translateY(-50%);
}
.dtl_opener div img {width:100%;}
.dtl_txt {
	display: none;
	margin:0 auto;
	max-width:100%;
	position:relative;
}
.block {
	display:block;
}
.img100 {
	font-size:0;
	line-height:0;
}
.img100 img {width:100%;}
footer {
	margin:0 auto;
	padding:4vw 0 28vw;
	width:100%;
	background:#007c8a;
}
footer p,
footer a {
	font-size:2.8vw;
	line-height:4.4vw;
	text-align:center;
	font-weight:500;
	color: #fff;
	text-decoration:none;
}
footer a {
	padding: 3vw 0;
	display: inline-block;
}
footer small {
	font-size:2.4vw;
	letter-spacing: -0.0015rem;
}
.tracer {
	width:85.375%;
	display:flex;
	position:fixed;
	bottom:4vw;
	left:50%;
	transform:translateX(-50%);
	z-index:53;
}
.tracer div:nth-child(1) {width:82.1%}
.tracer div:nth-child(2) {width:17.9%}

.main01 img,
.tracer img,
footer img {width:100%;}

.mb10 {margin-bottom:4vw;}
.mb20 {margin-bottom:2.5vw;}
.mb30 {margin-bottom:2.5vw;}
.mb40 {margin-bottom:12vw;}
.mb100 {margin-bottom:10vw;}

.pt5 {padding-top:5.2vw;}
.pt6 {padding-top:6.7vw;}

}/* sp end */
