﻿/*----------------------------------------
reset
----------------------------------------*/

html, body, div, p, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6,
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-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

/*----------------------------------------
全体
----------------------------------------*/

body {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
	font-size: 18px;
	line-height: 28px;
	word-break: break-word;
	text-size-adjust: none;
}

.wrapper {
	box-sizing: border-box;
	height: 100%;
	margin: 0 auto;
	width: 1190px;
}

.sp-wrapper {
	overflow: hidden;
}

.center {
	display: block;
	margin: 0 auto;
}

.left {
	float: left;
}

.right {
	float: right;
}

.pc-left {
	float: left;
}

.pc-right {
	float: right;
}

.aligncenter {
	display: block;
	margin: 0 auto;
}

.alignleft {
	float: left;
}

.alignright {
	float: right;
}

.t-center {
	text-align: center !important;
}

.t-left {
	text-align: left !important;
}

.t-right {
	text-align: right !important;
}

.pc-t-center {
	text-align: center !important;
}

.clear {
	clear: both;
}

.inline {
	display: inline !important;
}

.inline-b {
	display: inline-block !important;
}

.block {
	display: block !important;
}

.of {
	overflow: hidden;
}

.pc-of {
	overflow: hidden;
}

.flex {
	display: flex;
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
}

.flex-center {
	display: flex;
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	justify-content: center;
}

.flex-middle {
	align-items: center;
	display: flex;
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	justify-content: space-between;
}

img,
iframe {
	display: block;
}

a:hover img {
	opacity: 0.6;
}

.img-banner {
	background-size: 100% !important;
	box-sizing: border-box;
	display: block;
	height: 0;
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
	width: 100%;
}

a:hover .img-banner {
	opacity: 0.6;
}

a {
	color: #0000ee;
}

a:hover {
	color: #681da8;
}

a.bo {
	text-decoration: underline;
}

a.bo:hover {
	text-decoration: none;
}

a.no-bo {
	text-decoration: none;
}

a.no-bo:hover {
	text-decoration: underline;
}

.full {
	height: auto;
	width: 100%;
}

.full-img {
	box-sizing: border-box;
	display: block;
	width: 100%;
}

.full-img img {
	height: auto;
	width: 100%;
}

.list {
	box-sizing: border-box;
	margin-bottom: 20px;
}

.list li {
	box-sizing: border-box;
	list-style: disc !important;
	margin-left: 1.5em !important;
}

_::-webkit-full-page-media, _:future, :root .list li {
	margin-left: 23px !important;
}

.num-list {
	box-sizing: border-box;
	margin-bottom: 20px;
}

.num-list li {
	box-sizing: border-box;
	list-style: decimal !important;
	margin-left: 20px !important;
}

.num-list li:nth-child(n+10) {
	margin-left: 28px !important;
}

.num-list-2 {
	box-sizing: border-box;
	margin-bottom: 20px;
}

.num-list-2 li {
	box-sizing: border-box;
	padding-left: 33px;
}

.num-in {
	left: 0;
	position: absolute;
}

.check-list {
	box-sizing: border-box;
	margin-bottom: 20px;
}

.check-list li {
	box-sizing: border-box;
	margin-bottom: 10px;
	min-height: 25px;
	padding-left: 37.5px;
	position: relative;
}

.check-list li:last-child {
	margin-bottom: 0;
}

.check-list li::before {
	background: #fff;
	box-sizing: border-box;
	border: 3px solid #000;
	content: "";
	left: 0;
	height: 25px;
	position: absolute;
	top: 3px;
	width: 25px;
}

.check-list li::after {
	box-sizing: border-box;
	border-right: 4px solid #ff0000;
	border-bottom: 4px solid #ff0000;
	content: "";
	left: 12px;
	height: 22px;
	position: absolute;
	top: -1px;
	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	width: 14px;
}

.douga {
	margin: 0 auto;
}

.douga iframe {
	margin: 0 auto;
}

.text-base {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 18px;
	position: relative;
}

.text-base-2 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 36px;
	position: relative;
}

.text-base-3 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 54px;
	position: relative;
}

.text-base-4 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 72px;
	position: relative;
}

.text-base-5 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 90px;
	position: relative;
}

.text-in {
	left: 0;
	position: absolute;
	top: 0;
}

.indent-1 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 1em;
	text-indent: -1em;
}

.indent-2 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 2em;
	text-indent: -2em;
}

.indent-3 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 3em;
	text-indent: -3em;
}

.indent-4 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 4em;
	text-indent: -4em;
}

.indent-5 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 5em;
	text-indent: -5em;
}

.indent-6 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 6em;
	text-indent: -6em;
}

.indent-7 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 7em;
	text-indent: -7em;
}

.indent-8 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 8em;
	text-indent: -8em;
}

.indent-9 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 9em;
	text-indent: -9em;
}

.indent-10 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 10em;
	text-indent: -10em;
}

.pc {
	display: block;
}

.pc.tab {
	display: block;
}

.pc.tab.mobi {
	display: block;
}

.tab {
	display: none;
}

.tab.mobi {
	display: none;
}

.pc.mobi {
	display: block;
}

.mobi {
	display: none;
}

.first {
	margin-top: 0 !important;
}

.last {
	margin-bottom: 0 !important;
}

.m20 {
	margin: 20px !important;
}

.mt20 {
	margin-top: 20px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.no-mt20 {
	margin-top: -20px !important;
}

.mt-20 {
	margin-top: 20px !important;
}

.mb-20 {
	margin-bottom: 20px !important;
}

.ml20 {
	margin-left: 20px !important;
}

.mr20 {
	margin-right: 20px !important;
}

.m40 {
	margin: 40px !important;
}

.mt40 {
	margin-top: 40px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.ml40 {
	margin-left: 40px !important;
}

.mr40 {
	margin-right: 40px !important;
}

.m60 {
	margin: 60px !important;
}

.mt60 {
	margin-top: 60px !important;
}

.mt-60 {
	margin-top: 60px !important;
}

.mb60 {
	margin-bottom: 60px !important;
}

.mb-60 {
	margin-bottom: 60px !important;
}

.ml60 {
	margin-left: 60px !important;
}

.mr60 {
	margin-right: 60px !important;
}

.m80 {
	margin: 80px !important;
}

.mt80 {
	margin-top: 80px !important;
}

.mb80 {
	margin-bottom: 80px !important;
}

.ml80 {
	margin-left: 80px !important;
}

.mr80 {
	margin-right: 80px !important;
}

.m100 {
	margin: 100px !important;
}

.mt100 {
	margin-top: 100px !important;
}

.mb100 {
	margin-bottom: 100px !important;
}

.ml100 {
	margin-left: 100px !important;
}

.mr100 {
	margin-right: 100px !important;
}

.p20 {
	padding: 20px !important;
}

.pt20 {
	padding-top: 20px !important;
}

.pb20 {
	padding-bottom: 20px !important;
}

.pl20 {
	padding-left: 20px !important;
}

.pr20 {
	padding-right: 20px !important;
}

.p40 {
	padding: 40px !important;
}

.pt40 {
	padding-top: 40px !important;
}

.pb40 {
	padding-bottom: 40px !important;
}

.pl40 {
	padding-left: 40px !important;
}

.pr40 {
	padding-right: 40px !important;
}

.p60 {
	padding: 60px !important;
}

.pt60 {
	padding-top: 60px !important;
}

.pb60 {
	padding-bottom: 60px !important;
}

.pl60 {
	padding-left: 60px !important;
}

.pr60 {
	padding-right: 60px !important;
}

.p80 {
	padding: 80px !important;
}

.pt80 {
	padding-top: 80px !important;
}

.pb80 {
	padding-bottom: 80px !important;
}

.pl80 {
	padding-left: 80px !important;
}

.pr80 {
	padding-right: 80px !important;
}

.p100 {
	padding: 100px !important;
}

.pt100 {
	padding-top: 100px !important;
}

.pb100 {
	padding-bottom: 100px !important;
}

.pl100 {
	padding-left: 100px !important;
}

.pr100 {
	padding-right: 100px !important;
}

/*----------------------------------------
文字スタイル
----------------------------------------*/

.gothic {
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}

.minchou {
	font-family: "游明朝", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.hirago {
	font-family: "ヒラギノ角ゴ ProN","Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
}

.hiramin {
	font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', '游明朝','Yu Mincho', '游明朝体', 'YuMincho','ＭＳ Ｐ明朝', 'MS PMincho', serif;
}

.sans {
	font-family: 'Noto Sans JP', sans-serif;
}

.serif {
	font-family: 'Noto Serif JP', serif;
}

.din-bold {
	font-family: "din-2014", sans-serif;
	font-weight: 700;
}

.din-ex-bold {
	font-family: "din-2014", sans-serif;
	font-weight: 800;
}

strong,b,.strong {
	font-weight: 700;
}

.red {
	color: #ff0000;
	color: #F63932;
}

.blue {
	color: #0000ff;
	color: #0EA9F3;
}

.yellow {
	color: #ffff00;
}

.green {
	color: #008800;
}

.orange {
	color: #ff8800;
	color: #F98F4B;
}

.purple {
	color: #9400d3;
}

.magenta {
	color: #F37C92;
}

.cyan {
	color: #5DBFF2;
}

.y-b {
	background: linear-gradient(transparent 50%, #ffff00 50%);
}

.orange-2 {
	color: #f47f38;
}

.gray {
	color: #7b7b7b;
}

.fs15 {
	font-size: 15px !important;
	line-height: 25px !important;
}

.fs23 {
	font-size: 23px !important;
	line-height: 33px !important;
}

.fs30 {
	font-size: 30px !important;
	line-height: 40px !important;
}

.fs40 {
	font-size: 40px !important;
	line-height: 50px !important;
}

.fs50 {
	font-size: 50px !important;
	line-height: 60px !important;
}

[class^="icon-"], [class*=" icon-"] {
	/* use !important to prevent issues with browser extensions that change fonts */
	font-family: 'icomoon' !important;
	speak: never;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;

	/* Better Font Rendering =========== */
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* > */
.icon-cheveron-up::before {
	content: "\e001";
}

/* 角が丸い> */
.icon-chevron-right::before {
	content: "\e024";
}

/* ▲ */
.icon-triangle-right::before {
	content: "\e002";
}

/* 正三角形な▲ */
.icon-triangle-1::before {
	content: "\e003";
}

/* 短めの▲ */
.icon-triangle-2::before {
	content: "\e004";
}

/* ○ */
.icon-maru-1::before {
	content: "\e005";
}

/* ● */
.icon-maru-2::before {
	content: "\e006";
}

/* ◎ */
.icon-maru-3::before {
	content: "\e007";
}

/* ◎の中の丸が黒 */
.icon-maru-4::before {
	content: "\e008";
}

/* □ */
.icon-shikaku-1::before {
	content: "\e009";
}

/* ■ */
.icon-shikaku-2::before {
	content: "\e010";
}

/* → */
.icon-yazirushi-1::before {
	content: "\e011";
}

/* 短めの→ */
.icon-yazirushi-2::before {
	content: "\e012";
}

/* かなり短めの→ */
.icon-yazirushi-3::before {
	content: "\e013";
}

/* 線だけの→ */
.icon-yazirushi-4::before {
	content: "\e014";
}

/* 本体ありの電話 */
.icon-old-phone::before {
	content: "\e015";
}

/* 受話器のみの電話 */
.icon-phone::before {
	content: "\e016";
}

/* 背景ありの手紙アイコン(簡易なデザイン) */
.icon-mail-envelope-closed2::before {
	content: "\e017";
}

/* 背景なしの手紙アイコン(簡易なデザイン) */
.icon-mail-envelope-closed3::before {
	content: "\e018";
}

/* 背景ありの手紙アイコン(複雑なデザイン) */
.icon-mail-envelope-closed::before {
	content: "\e019";
}

/* 背景なしの手紙アイコン(複雑なデザイン) */
.icon-mail-envelope-closed1::before {
	content: "\e020";
}

/* ＋ */
.icon-plus::before {
	content: "\e021";
}

/* － */
.icon-minus::before {
	content: "\e022";
}

/* × */
.icon-batsu::before {
	content: "\e023";
}

/*----------------------------------------
画像関連
----------------------------------------*/

/*----------------------------------------
header
----------------------------------------*/

header {
	box-sizing: border-box;
}

.head-in {
	background: #fff;
	box-sizing: border-box;
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 9999;
}

.head-in.fixed {
	box-shadow: 0 0 5px 0 rgba(0,0,0,0.6);
}

.head-in .wrapper {
	width: 100%;
}

.head-in-logo {
	box-sizing: border-box;
	float: left;
	line-height: 0;
	margin: 20px 0 0 63px;
	padding-left: 52px;
	position: relative;
	text-decoration: none;
}

.head-in-logo-icon {
	box-sizing: border-box;
	display: block;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	width: 48px;
}

.head-in-logo-icon::before {
	background: url(images/logo.png) no-repeat;
	background-size: 100% !important;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 0;
	padding-bottom: 100%;
	position: relative;
	width: 100%;
}

.head-in-logo .big {
	box-sizing: border-box;
	color: #000;
	display: inline-block;
	font-weight: 700;
	font-size: 20px;
	line-height: 1;
	letter-spacing: 0.05vw;
}

.head-in-logo .mini {
	box-sizing: border-box;
	color: #000;
	display: block;
	font-size: 14px;
	line-height: 1;
	letter-spacing: 0.04vw;
	margin-top: 7px;
}

.head-in-logo:hover {
	color: #000;
	opacity: 0.6;
}

.head-in-new-logo {
	box-sizing: border-box;
	display: block;
	float: left;
	line-height: 0;
	margin: 9px 0;
	margin-left: 63px;
	text-decoration: none;
}

.head-in-new-logo:hover {
	opacity: 0.6;
}

.head-in-new-logo-in {
	box-sizing: border-box;
	display: block;
	width: 130px;
}

.head-in-new-logo-in .img-banner {
	background: url(images/logo-new.jpg) no-repeat;
	padding-bottom: 32.840%;
}

.head-in-new-logo:hover .head-in-new-logo-in .img-banner {
	opacity: 1;
}

.head-in-new-logo .mini {
	box-sizing: border-box;
	color: #000;
	display: block;
	font-size: 12px;
	line-height: 1;
	letter-spacing: 0.04vw;
	margin-top: 5px;
}

.head-in-in {
	box-sizing: border-box;
	float: right;
	width: 833px;
}

.head-in-in-btn-list {
	box-sizing: border-box;
	float: left;
}

.head-in-in-btn-list li {
	box-sizing: border-box;
	float: left;
	margin-right: 1px;
	width: 176px;
}

.head-in-in-btn-list li:last-child {
	margin-right: 0;
}

.head-in-in-btn-list-btn {
	box-sizing: border-box;
	display: block;
	line-height: 0;
	text-align: center;
	text-decoration: none;
}

.head-in-in-btn-list-btn-in {
	background: #15090A;
	box-sizing: border-box;
	color: #fff;
	display: block;
	font-weight: 700;
	font-size: 16px;
	line-height: 1;
	height: 79px;
	position: relative;
}

.head-in-in-btn-list li.li-middle-aged .head-in-in-btn-list-btn-in {
	background: #F63932;
}

.head-in-in-btn-list li.li-company .head-in-in-btn-list-btn-in {
	background: #0EA9F3;
}

.head-in-in-btn-list-btn:hover .head-in-in-btn-list-btn-in {
	opacity: 0.6;
}

.head-in-in-btn-list-btn-in-text {
	box-sizing: border-box;
	display: block;
	left: 0;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
}

.head-in-in-btn-list-btn-in-text-in {
	box-sizing: border-box;
	display: inline-block;
	position: relative;
}

.head-in-in-tel {
	box-sizing: border-box;
	float: left;
	margin: 15px 0 0 26px;
}

.head-in-in-tel-title {
	box-sizing: border-box;
	line-height: 0;
	margin-left: 20px;
}

.head-in-in-tel-title-in {
	box-sizing: border-box;
}

.head-in-in-tel-title-in-in {
	box-sizing: border-box;
	font-size: 12px;
	line-height: 1;
	letter-spacing: 0.03vw;
}

.head-in-in-tel-num {
	box-sizing: border-box;
	line-height: 0;
	margin-top: 4px;
}

.head-in-in-tel-num-in {
	box-sizing: border-box;
	font-family: "din-2014", sans-serif;
	font-weight: 700;
	font-size: 32px;
	line-height: 1;
	letter-spacing: -0.01vw;
}

.head-in-in-tel-num-in-text {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 22px;
	position: relative;
}

.head-in-in-tel-num-in-text-icon {
	box-sizing: border-box;
	display: block;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	width: 15px;
}

.head-in-in-tel-num-in-text-icon::before {
	background: url(images/icon-tel.png) no-repeat;
	background-size: 100% !important;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 0;
	padding-bottom: 100%;
	position: relative;
	width: 100%;
}

@media (max-width: 1251px) {

	.head-in-logo {
		margin-left: 10px;
	}

	.head-in-in {
		width: 800px;
	}

}

/*----------------------------------------
TOPページ
----------------------------------------*/
.main {
	padding-top: 79px;
	line-height: 1.6;
	letter-spacing: 0.05em;
}
.main * {
	box-sizing: border-box;
}
.main img {
	max-width: 100%;
}
.main h2,
.main h3,
.main h4,
.main h5 {
	line-height: 1.4;
}
.container {
	width: 90%;
	max-width: 1140px;
	margin: 0 auto;
}
.container715 {
	max-width: 715px;
	margin: 0 auto;
}
.container752 {
	width: 90%;
	max-width: 752px;
	margin: 0 auto;
}
.container1440 {
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
}
.content-inner {
	width: 91.6%;
	margin: 0 auto;
}
.content-inner2 {
	width: 91%;
	margin: 0 auto;
}
.content-inner-min {
	width: 90%;
	max-width: 946px;
	margin: 0 auto;
}
.flex,
.flex_pc {
	display: flex;
	justify-content: center;
}
.flex_all {
	display: flex;
	justify-content: space-between;
}
.jcsb {
	justify-content: space-between;
}
.aic {
	align-items: center;
}
.flex-col-3,
.flex-col-3-2 {
	width: 32.6%;
	margin-right: 1.1%;
}
.flex-col-3:nth-child(3n) {
	margin-right: 0;
}
.flex-col-3-2:nth-child(2n) {
	margin-right: 0;
}
.flex-col-3-1 {
	width: 32.6%;
}
.flex-col-2 {
	width: 47.4%;
	margin-right: 5.2%;
}
.flex-col-2:nth-child(2n) {
	margin-right: 0;
}
.flex-col-2-2 {
	width: 48.3%;
	margin-right: 3.4%;
}
.flex-col-2-2:nth-child(2n) {
	margin-right: 0;
}
.flex-w66 {
	width: 65.9%;
}
.flex-w61 {
	width: 61%;
}
.flex-w59 {
	width: 59.4%;
}
.flex-w58 {
	width: 58%;
}
.flex-w56 {
	width: 55.9%;
}
.flex-w53 {
	width: 53%;
}
.flex-w44 {
	width: 44.1%;
}
.flex-w43 {
	width: 43%;
}
.flex-w42 {
	width: 42%;
}
.flex-w41 {
	width: 40.6%;
}
.flex-w39 {
	width: 39%;
}
.flex-w34 {
	width: 34.1%;
}
.content-inner .flex-col-3 {
	width: 32.56%;
	margin-right: 1.16%;
}
.content-inner .flex-col-3:nth-child(3n) {
	margin-right: 0;
}
.lh12 {
	line-height: 1.2;
}
.lh13 {
	line-height: 1.3 !important;
}
.lh14 {
	line-height: 1.4;
}
.lh15 {
	line-height: 1.5 !important;
}
.ls005 {
	letter-spacing: 0.05em;
}
.fw900 {
	font-weight: 900;
}
.fw700 {
	font-weight: 700;
}
.fw500 {
	font-weight: 500;
}
.fz80 { font-size: 80px; }
.fz72 { font-size: 72px; }
.fz56 { font-size: 56px; }
.fz48 { font-size: 48px; }
.fz44 { font-size: 44px; }
.fz40 { font-size: 40px; }
.fz36 { font-size: 36px; }
.fz32 { font-size: 32px; }
.fz30 { font-size: 30px; }
.fz28 { font-size: 28px; }
.fz26 { font-size: 26px; }
.fz24 { font-size: 24px; }
.fz20 { font-size: 20px; }
.fz18 { font-size: 18px; }
.fz16 { font-size: 16px; }
@media screen and (max-width: 1300px) {
.fz80 { font-size: 6.154vw; }
.fz72 { font-size: 5.538vw; }
.fz56 { font-size: 4.308vw; }
}
@media screen and (max-width: 1267px) {
.fz48 { font-size: 3.788vw; }
.fz44 { font-size: 3.473vw; }
.fz40 { font-size: 3.157vw; }
.fz36 { font-size: 2.841vw; }
.fz32 { font-size: 2.526vw; }
.fz30 { font-size: 2.368vw; }
.fz28 { font-size: 2.21vw; }
.fz26 { font-size: 2.052vw; }
.fz24 { font-size: 1.894vw; }
.fz20 { font-size: 1.579vw; }
.fz18 { font-size: 1.421vw; }
.fz16 { font-size: 1.263vw; }
}
.white {
	color: #fff;
}
.gray {
	color: #6F6F6F;
}
.dgray {
	color: #44413C;
}
.ddgray {
	color: #232723;
}
.bg_red {
	background: #F63932;
}
.bg_pink {
	background: #FAF0EF;
}
.bg_gray {
	background: #44413C;
}
.bg_lgray {
	background: #F6F6F6;
}
.bg_llgray {
	background: #FAFAFA;
}
.bg_blue {
	background: #0EA9F3;
}
.bg_lblue {
	background: #F0F6FA;
}
.bg_white {
	background: #fff;
}
.br06 { border-radius: 6px; }
.br08 { border-radius: 8px; }
.br16 { border-radius: 16px; }
.br24 { border-radius: 24px; }
.br50 { border-radius: 1em; }
.br16-top {
	border-top-left-radius: 16px;
	border-top-right-radius: 16px;
}
.br16-right {
	border-top-right-radius: 16px;
	border-bottom-right-radius: 16px;
}
.br16-left {
	border-top-left-radius: 16px;
	border-bottom-left-radius: 16px;
}
.br24-right {
	border-top-right-radius: 24px;
	border-bottom-right-radius: 24px;
}
.border-bottom-min {
	position: relative;
	padding-bottom: .6em;
}
.border-bottom-min::after {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	content: "";
	background: #F63932;
	display: block;
	width: 80px;
	height: 4px;
}
.border-red-2px {
	border: 2px solid #F63932;
}
.border-red-3px {
	border: 3px solid #F63932;
}
.border-red-4px {
	border: 4px solid #F63932;
}
.border-middle-red {
	position: relative;
}
.border-middle-red::before {
	position: absolute;
	width: 100%;
	height: 3px;
	left: 0;
	top: 50%;
	content: "";
	display: block;
	background: #F63932;
}
.border-middle-red span {
	background: #fff;
	padding: 0 .5em;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
	display: inline-block;
	white-space: nowrap;
}

.bg_01 {
	background: url(images/bg_head.webp) center no-repeat;
	background-size: cover;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	padding-left: 65px;
}
.text-dot {
	position: relative;
}
.text-dot::before {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	content: "●";
	font-size: 16px;
	top: -5px;
}
@media screen and (max-width: 1300px) {
.bg_01 {
	padding-left: 5vw;
}
.text-dot::before {
	font-size: 1.231vw;
}
}
.btn_01,
.btn_02,
.btn_03,
.btn_04,
.btn_05 {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #168C0E;
	color: #fff;
	text-decoration: none;
	text-align: center;
	font-weight: 500;
	max-width: 100%;
	border-radius: 16px;
}
.btn_02 {
	background: #184C9F;
	border-radius: 8px;
}
.btn_03 {
	width: 100%;
	max-width: 364px;
	background: #fff;
	border: 2px solid #F63932;
	color: #F63932;
	font-weight: 700;
	margin-top: 12px;
}
.btn_03-min {
	border-radius: 8px;
	margin-top: 0;
}
.btn_04 {
	width: 100%;
	max-width: 364px;
	background: #fff;
	border: 2px solid #0EA9F3;
	color: #0EA9F3;
	font-weight: 700;
	border-radius: 8px;
}
.btn_05 {
	width: 100%;
	max-width: 364px;
	background: #168C0E;
	color: #fff;
	font-weight: 700;
	border-radius: 8px;
}
.btn_01:hover,
.btn_02:hover,
.btn_05:hover {
	color: #fff;
	opacity: .7;
}
.btn_03:hover {
	color: #F63932;
	background: #FAF0EF;
}
.btn_04:hover {
	color: #0EA9F3;
	background: #F0F6FA;
}
.btn_01 span {
	padding: 1em 4.8em;
	max-width: 100%;
	min-height: 4.6em;
	min-width: 23em;
	max-width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}
.btn_02 span {
	padding: 1.12em 4em;
	max-width: 100%;
}
.btn_03 span {
	padding: 0 .5em 0 0;
	max-width: 100%;
	min-height: 4.2em;
	display: flex;
	align-items: center;
}
.btn_03-min span {
	min-height: 2.7em;
}
.btn_04 span {
	padding: 0 .5em 0 0;
	max-width: 100%;
	min-height: 2.7em;
	display: flex;
	align-items: center;
}
.btn_05 span {
	padding: 0 .5em 0 0;
	max-width: 100%;
	min-height: 2.7em;
	display: flex;
	align-items: center;
}
.arrow,
.arrow-step {
	position: relative;
}
.arrow::before,
.arrow::after {
	position: absolute;
	content: "";
	display: block;
	top: 50%;
	transform: translateY(-50%);
}
.arrow::before {
	border-radius: 50%;
	border: 1px solid #fff;
	width: 40px;
	height: 40px;
	right: 20px;
}
.arrow::after {
	background: #fff;
	clip-path: polygon(0 0, 0% 100%, 100% 50%);
	width: 12px;
	height: 14px;
	right: 34px;
}
.arrow.arrow-min::before {
	width: 24px;
	height: 24px;
	right: 16px;
}
.arrow.arrow-min::after {
	width: 8px;
	height: 9px;
	right: 24px;
}
.arrow.arrow-min-red::before {
	border-color: #F63932;
	width: 24px;
	height: 24px;
	right: 10px;
}
.arrow.arrow-min-red::after {
	background: #F63932;
	width: 8px;
	height: 9px;
	right: 18px;
}
.arrow.arrow-min-blue::before {
	border-color: #0EA9F3;
	width: 24px;
	height: 24px;
	right: 16px;
}
.arrow.arrow-min-blue::after {
	background: #0EA9F3;
	width: 8px;
	height: 9px;
	right: 24px;
}
.arrow-step::after {
	position: absolute;
	content: "";
	display: block;
	right: inherit;
	top: inherit;
	left: 50%;
	transform: translateX(-50%);
	background: #F63932;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
	width: 62px;
	height: 18px;
	bottom: -36px;
}
.arrow-step::before {
	content: none;
}

.h1 {
	font-size: 32px;
	border-radius: .25em;
	font-weight: 900;
	padding: .1em .6em;
	letter-spacing: 0.04em;
	background: #fff;
	margin-top: .6em;
}
@media screen and (max-width: 1300px) {
.h1 {
	font-size: 2.462vw;
}
}
.text-gra {
	background: linear-gradient(170deg, #FFBA33 0%, #DA4443 50%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
.pl30 { padding-left: 30px; }
.pb30 { padding-bottom: 30px; }
.pb15 { padding-bottom: 15px; }
.pt70 { padding-top: 70px; }
.pt30 { padding-top: 30px; }
.pt15 { padding-top: 15px; }
.mt70 { margin-top: 70px; }
.mt50 { margin-top: 50px; }
.mt30 { margin-top: 30px; }
.mt25 { margin-top: 25px; }
.mt15 { margin-top: 15px; }
.mt10 { margin-top: 10px; }
.mt05 { margin-top: 5px; }
.mb10 { margin-bottom: 10px; }
.pd-1 { padding: .3em 0; }
.pd-2 { padding: .5em 0; }
.pd-3 { padding: .6em 0; }
.pd-4 { padding: .72em 0; }
.icon-serif::before,
.icon-serif::after {
	content: "";
	background: #000;
	width: 0.77em;
	height: 1.3em;
	clip-path: polygon(0 0, 12% 0, 100% 100%, 88% 100%);
	display: inline-block;
	vertical-align: -0.3em;
	margin: 0 .2em;
}
.icon-serif::after {
	clip-path: polygon(88% 0, 100% 0, 12% 100%, 0 100%);
}
.box-1 {
	padding: .5% 1.5% 2.6%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.box-2 {
	min-height: 4.2em;
	display: flex;
	align-items: center;
	justify-content: center;
}
.box-3 {
	padding: 4.1% 2.5% 2% 2.5%;
}
.box-4 {
	padding: 2.5% 2% 3% 2.8%;
}
.box-5 {
	padding: 3.8% 3.5% 6% 4.5%;
}
.box-6 {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.box-7 {
	padding: 2.8% 2% 1% 2%;
}
.box-8 {
	padding: 2.2%;
}
.box-inner-1 {
	min-height: 4.3em;
	display: flex;
	align-items: center;
	justify-content: center;
}
.box-inner-2 {
	padding: .25em 1.7em;
	margin-right: .7em;
}
.box-inner-3 {
	text-align: center;
	display: inline-block;
	background: #44413C;
	color: #fff;
	font-weight: 500;
	padding: .25em 1.7em;
	border-radius: .3em;
}
.box-inner-4 {
	padding: 1em 1.5em;
}
.video {
	width: 100%;
	position: relative;
	padding-top: 56.25%;
}
.video iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.dl {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	margin-left: 25px;
	line-height: 1;
}
.dl dt {
	width: 29%;
	font-weight: 500;
	color: #fff;
	background: #44413C;
	text-align: center;
	font-size: 18px;
	padding: .5em;
	margin: .35em 0;
	border-radius: .3em;
}
.dl dd {
	width: 71%;
	font-size: 24px;
	padding: 0 .6em;
}
.dl2 {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	line-height: 1.5;
}
.dl2 dt {
	width: 13%;
	font-weight: 700;
	color: #fff;
	background: #0EA9F3;
	text-align: center;
	font-size: 20px;
	padding: .5em;
	border-radius: .2em;
	line-height: 1.2;
	margin: .7em 0;
}
.dl2.dl2-red dt {
	background: #F63932;
}
.dl2 dd {
	width: 87%;
	font-size: 18px;
	padding: 0 0 0 1.3em;
	margin: .7em 0;
}
.dl2 dd.dl2-mt {
	margin: 0 0 .7em;
}
.dl2 dd.dl2-mt2 {
	margin: .4em 0 .7em;
}
.dl3 {
	line-height: 1.5;
	padding: 1.5em 3em;
}
.dl3 dt {
	font-weight: 700;
	color: #fff;
	background: #0EA9F3;
	text-align: center;
	font-size: 20px;
	padding: .5em;
	border-radius: .2em;
	line-height: 1.2;
	margin: .45em 1em;
	white-space: nowrap;
	float: left;
}
.dl3 dd {
	font-size: 24px;
	padding: .5em 0 0 1.3em;
	margin: .2em 0;
	font-weight: 700;
}
.dl3 dd::after {
	content: '';
	display: block;
	height: 0;
	overflow: hidden;
	clear: both;
}
.dl3 {
	line-height: 1.5;
	padding: 1.5em 3em;
}
.dl4 {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
.dl4 dt {
	width: 28%;
	font-weight: 700;
	color: #fff;
	background: #0EA9F3;
	text-align: center;
	font-size: 20px;
	padding: .5em;
	border-radius: .4em;
	line-height: 1.2;
	margin: .45em 0;
}
.dl4 dd {
	width: 72%;
	font-size: 24px;
	font-weight: 900;
	padding: 0 0 0 1em;
	margin: .45em 0;
}
@media screen and (max-width: 1267px) {
	.dl {
		margin-left: 25px;
	}
	.dl dt {
		font-size: 18px;
	}
	.dl dd {
		font-size: 24px;
	}
	.dl2 dt {
		font-size: 20px;
	}
	.dl2 dd {
		font-size: 18px;
	}
	.dl3 dt {
		font-size: 20px;
	}
	.dl3 dd {
		font-size: 24px;
	}
	.dl4 dt {
		font-size: 20px;
	}
	.dl4 dd {
		font-size: 24px;
	}
	.dl {
		margin-left: 1.973vw;
	}
	.dl dt {
		font-size: 1.421vw;
	}
	.dl dd {
		font-size: 1.894vw;
	}
	.dl2 dt {
		font-size: 1.579vw;
	}
	.dl2 dd {
		font-size: 1.421vw;
	}
	.dl3 dt {
		font-size: 1.579vw;
	}
	.dl3 dd {
		font-size: 1.894vw;
	}
	.dl4 dt {
		font-size: 1.579vw;
	}
	.dl4 dd {
		font-size: 1.894vw;
	}
}
@font-face {
	font-family: "Akshar";
	font-optical-sizing: auto;
	font-style: normal;
	font-weight: 700;
	src: url('web-fonts/Akshar-VariableFont_wght.woff2');
}
.Akshar {
	font-family: "Akshar", sans-serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
	vertical-align: -0.05em;
}
.border-dashed-top {
	background-image: linear-gradient(to right, #0EA9F3, #0EA9F3 9px, transparent 5px);
	background-size: 14px 3px;
	background-repeat: repeat-x;
	display: block;
	padding-top: .55em;
}
.border-dashed-bottom {
	padding-bottom: .6em;
	background-image: linear-gradient(to right, #0EA9F3, #0EA9F3 9px, transparent 5px);
	background-size: 14px 3px;
	background-position: left bottom;
	background-repeat: repeat-x;
}
.border-dashed-bottom-red {
	padding-bottom: .45em;
	background-image: linear-gradient(to right, #F63932, #F63932 6px, transparent 6px);
	background-size: 12px 2px;
	background-position: left bottom;
	background-repeat: repeat-x;
}
.list-dot {
	padding-left: 1em;
}
.list-dot li {
	text-indent: -0.9em;
	padding: .2em 0;
}
.list-dot li::before {
	content: "●";
	color: #0EA9F3;
	font-size: 0.55em;
	margin-right: .6em;
	vertical-align: .2em;
}
.img_04 {
	margin: 0 auto;
}
.icon_01 {
	margin: 0 auto;
}
.step-1 {
	position: relative;
}
.step-1 img {
	position: absolute;
	left: -32px;
	top: -28px;
}

.comingsoon {
	background: #aaa;
	color: #fff;
	display: inline-block;
	padding: 1.5em 8em;
	max-width: 100%;
	border-radius: .5em;
}

.td-none {
	text-decoration: none;
}

/*----------------------------------------
404ページ
----------------------------------------*/

/*----------------------------------------
sidebar
----------------------------------------*/

/*----------------------------------------
footer
----------------------------------------*/

footer {
	box-sizing: border-box;
}

.foot-in {
	background: #15090A;
	box-sizing: border-box;
}

.foot-in .wrapper {
	padding: 69px 0 61px;
}

.foot-in-logo {
	box-sizing: border-box;
}

.foot-in-logo-main {
	box-sizing: border-box;
	line-height: 0;
	text-align: center;
}

.foot-in-logo-main-in {
	box-sizing: border-box;
}

.foot-in-logo-main-in-in {
	box-sizing: border-box;
	color: #fff;
	display: inline-block;
	font-weight: 700;
	font-size: 28px;
	line-height: 1;
	letter-spacing: 0.08vw;
}

.foot-in-logo-sub {
	box-sizing: border-box;
	line-height: 0;
	margin-top: 16px;
	text-align: center;
}

.foot-in-logo-sub-in {
	box-sizing: border-box;
}

.foot-in-logo-sub-in-in {
	box-sizing: border-box;
	color: #fff;
	display: inline-block;
	font-weight: 700;
	font-size: 18px;
	line-height: 1;
	letter-spacing: 0.05vw;
}

.foot-in-text {
	box-sizing: border-box;
	color: #fff;
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: 0.04vw;
	margin-top: 35px;
	text-align: center;
}

.foot-in-title {
	box-sizing: border-box;
	border-color: #7E7E7E !important;
	border-top: 1px solid;
	border-bottom: 1px solid;
	line-height: 0;
	margin: 48px 7px 0;
	padding: 23px 0;
	text-align: center;
}

.foot-in-title-in {
	box-sizing: border-box;
}

.foot-in-title-in-in {
	box-sizing: border-box;
	color: #fff;
	display: inline-block;
	font-weight: 700;
	font-size: 18px;
	line-height: 1.5;
	letter-spacing: 0.05vw;
}

.foot-in-title-in-in .text {
	box-sizing: border-box;
	display: inline-block;
	position: relative;
}

.foot-in-title-in-in .text::before {
	box-sizing: border-box;
	content: "：";
}

.foot-in-tel {
	box-sizing: border-box;
	float: left;
	margin-top: 28px;
}

.foot-in-tel-num {
	box-sizing: border-box;
	line-height: 0;
}

.foot-in-tel-num-in {
	box-sizing: border-box;
	color: #fff;
	font-family: "din-2014", sans-serif;
	font-weight: 700;
	font-size: 32px;
	line-height: 1;
	letter-spacing: -0.01vw;
}

.foot-in-tel-num-in-text {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 22px;
	position: relative;
}

.foot-in-tel-num-in-text-icon {
	box-sizing: border-box;
	display: block;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	width: 15px;
}

.foot-in-tel-num-in-text-icon::before {
	background: url(images/icon-tel-2.png) no-repeat;
	background-size: 100% !important;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 0;
	padding-bottom: 100%;
	position: relative;
	width: 100%;
}

.foot-in-tel-text {
	box-sizing: border-box;
	color: #fff;
	font-size: 15px;
	line-height: 1.4;
	letter-spacing: 0.01vw;
	margin-top: 4px;
	text-align: center;
}

.foot-in-mail-btn {
	box-sizing: border-box;
	display: block;
	line-height: 0;
	float: left;
	margin: 42px 0 0 73px;
}

.foot-in-mail-btn-in {
	box-sizing: border-box;
	color: #fff;
	display: block;
	font-family: "din-2014", sans-serif;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.5;
	letter-spacing: -0.01vw;
}

.foot-in-mail-btn-in-text {
	box-sizing: border-box;
	color: #fff;
	display: inline-block;
	padding-left: 28px;
	position: relative;
	text-decoration: none;
}

.foot-in-mail-btn-in-text:hover {
	color: #fff;
}

.foot-in-mail-btn-in-text-icon {
	box-sizing: border-box;
	display: block;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	width: 16px;
}

.foot-in-mail-btn-in-text-icon::before {
	background: url(images/icon-mail.png) no-repeat;
	background-size: 100% !important;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 0;
	padding-bottom: 75%;
	position: relative;
	width: 100%;
}

/*----------------------------------------
Edge CSSハック
----------------------------------------*/

@supports (-ms-ime-align: auto) {



}

/*----------------------------------------
IE11以下 CSSハック
----------------------------------------*/

@media screen\0 {



}

/*----------------------------------------
Firefox CSSハック
----------------------------------------*/

@-moz-document url-prefix() {



}

/*----------------------------------------
Safari CSSハック
----------------------------------------*/

_::-webkit-full-page-media, _:future, :root .num-list li {
	margin-left: 30px !important;
}

_::-webkit-full-page-media, _:future, :root .num-list li:nth-child(n+10) {
	margin-left: 40px !important;
}