﻿/*----------------------------------------
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: 19px !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;
}

.blue {
	color: #0000ff;
}

.yellow {
	color: #ffff00;
}

.green {
	color: #008800;
}

.orange {
	color: #ff8800;
}

.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.png) 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: #051e41;
	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: #228254;
}

.head-in-in-btn-list li.li-company .head-in-in-btn-list-btn-in {
	background: #0C93DF;
}

.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ページ
----------------------------------------*/

/*----------------------------------------
404ページ
----------------------------------------*/

/*----------------------------------------
sidebar
----------------------------------------*/

/*----------------------------------------
footer
----------------------------------------*/

footer {
	box-sizing: border-box;
}

.foot-in {
	background: #051e41;
	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: #fff !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: 22px 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: 28px;
	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;
}


/*----------------------------------------
2025年7月制作分 追加
----------------------------------------*/
.container {
	max-width: 1366px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 79px;
}
.main {
	color: #333;
}

h1,h2,h3,.bold {
	font-weight: 700;
}
.bold2 {
	font-weight: 500;
}
.dib {
	display: inline-block;
}

.bg_white66 {
	background: rgba(255,255,255,.66);
}
.bg_white {
	background: #fff;
}
.bg_blue {
	background: #219ce1;
}
.bg_blue2 {
	background: #0c93df;
}
.bg_blue3 {
	background: #0cc0df;
}
.bg_dblue {
	background: #004aad;
}
.bg_dblue2 {
	background: #2a649e;
}
.bg_lyellow {
	background: #fff7d9;
}
.bg_yellow {
	background: #ffde59;
}
.bg_lorange {
	background: #ffbd59;
}
.bg_orange {
	background: #ff914d;
}
.bg_lgreen {
	background: #e2f5f4;
}
.bg_green {
	background: #00bf63;
}
.bg_gray {
	background: #f1f1f1;
}
.green-2 {
	color: #05a281;
}
.lgreen {
	color: #00bf63;
}
.orange-3 {
	color: #ff914d;
}
.blue-2 {
	color: #0c93df;
}
.blue-3 {
	color: #0cc0df;
}
.dblue {
	color: #004aad;
}
.white {
	color: #fff;
}
.navy {
	color: #00204b;
}
.taC {
	text-align: center;
}

.content-inner {
	width: 90%;
	max-width: 1190px;
	margin-left: auto;
	margin-right: auto;
}
.content-inner-head {
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.content-inner-wide {
	width: 90%;
	max-width: 1250px;
	margin-left: auto;
	margin-right: auto;
}
.content-inner-wide2 {
	width: 90%;
	max-width: 1210px;
	margin-left: auto;
	margin-right: auto;
}
.content-inner-min {
	width: 90%;
	max-width: 1120px;
	margin-left: auto;
	margin-right: auto;
}
.container888 {
	width: 90%;
	max-width: 888px;
	margin-left: auto;
	margin-right: auto;
}

.fs54 {
	font-size: 70px;
	line-height: 1.4;
}
.fs46 {
	font-size: 60px;
	line-height: 1.4;
}
.fs42 {
	font-size: 55px;
	line-height: 1.4;
}
.fs40-2 {
	font-size: 52px;
	line-height: 1.4;
}
.fs39 {
	font-size: 51px;
	line-height: 1.4;
}
.fs36 {
	font-size: 47px;
	line-height: 1.4;
}
.fs35 {
	font-size: 45px;
	line-height: 1.4;
}
.fs33 {
	font-size: 43px;
	line-height: 1.4;
}
.fs30-2 {
	font-size: 42px;
	line-height: 1.4;
}
.fs29 {
	font-size: 38px;
	line-height: 1.4;
}
.fs27 {
	font-size: 35px;
	line-height: 1.4;
}
.fs26 {
	font-size: 34px;
	line-height: 1.4;
}
.fs25 {
	font-size: 33px;
	line-height: 1.4;
}
.fs23-2 {
	font-size: 29.5px;
	line-height: 1.4;
}
.fs22 {
	font-size: 28px;
	line-height: 1.4;
}
.fs21 {
	font-size: 27px;
	line-height: 1.4;
}
.fs19 {
	font-size: 25px;
	line-height: 1.4;
}
.fs18-2 {
	font-size: 23px;
	line-height: 1.8;
}
.fs18 {
	font-size: 23px;
	line-height: 1.4;
}
.fs17 {
	font-size: 22px;
	line-height: 1.5;
}
.fs16 {
	font-size: 21px;
	line-height: 1.5;
}
.fs15-2 {
	font-size: 20px;
	line-height: 1.5;
}
.fs14 {
	font-size: 18px;
	line-height: 1.5;
}
.fs12 {
	font-size: 15px;
	line-height: 1.5;
}

.bg_01 {
	background: url(images/bg.webp) center no-repeat;
	background-size: cover;
	padding: 3em 0;
}

.br17 {
	border-radius: 17px;
}
.br09 {
	border-radius: 9px;
}

.h1-wrap {
	padding: 1.4em;
}

.border-top {
	border-top: 3px solid #fff;
	padding: .3em .7em;
	margin-top: .35em;
}
.border-blue {
	border: 4px solid #0c93df;
}
.border-dblue {
	border: 4px solid #2a649e;
}

.flex-w45 {
	width: 44.51%;
}
.flex-w46 {
	width: 46%;
}
.flex-w48 {
	width: 48%;
}
.flex-w55 {
	width: 55.49%;
}
.flex-w45 img {
	max-width: 100%;
}

.box-1 {
	padding: 3.5% 4.5%;
}
.box-2 {
	padding: 1.5% 4.5%;
}
.box-3 {
	padding: 4% 5.5% 6%;
}
.pd-1 {
	padding: .22em .7em .28em;
}
.pd-2 {
	padding: .3em 0 1.3em;
}
.pd-3 {
	padding: 2.4em 0 1.2em;
}
.pd-4 {
	padding: .09em .7em .12em;
}
.pd-5 {
	padding: .6em .7em .66em;
}
.pd-6 {
	padding: .24em .7em .6em;
}
.pd-7 {
	padding: .22em 0 .28em;
}
.p-r {
	position: relative;
}
.p-a-1 {
	position: absolute;
	top: -.61em;
	right: -.73em;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 50%;
	font-size: 60px;
	line-height: 1.2;
	width: 4.1em;
	height: 4.1em;
}

.btn-1 {
	font-size: 25px;
	line-height: 1.4;
	border-radius: .5em;
	background: #ff914d;
	color: #fff;
	font-weight: 500;
	text-align: center;
	text-decoration: none;
	width: 13.44em;
	height: 3.6em;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}
.btn-1 span {
	padding-right: .7em;
}
.btn-1::after {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: .4em;
	font-family: 'icomoon' !important;
	speak: never;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	content: "\e002";
	font-size: 2em;
}
.btn-1 + .btn-1 {
	margin-left: 3.1em;
}
.btn-1:hover {
	color: #fff;
	background: #f35d00;
}
.btn-2 {
	font-size: 31px;
	line-height: 1.4;
	border-radius: .5em;
	background: #00bf63;
	color: #fff;
	font-weight: 500;
	text-align: center;
	text-decoration: none;
	width: 18.84em;
	height: 3.7em;
	display: flex;
	justify-content: center;
	align-items: center;
}
.btn-2:hover {
	color: #fff;
	background: #008a48;
}
.btn-3 {
	font-size: 41px;
	line-height: 1.4;
	border-radius: .3em;
	background: #00bf63;
	color: #fff;
	font-weight: 700;
	text-align: center;
	text-decoration: none;
	width: 14.2em;
	height: 2.8em;
	display: flex;
	justify-content: center;
	align-items: center;
}
.btn-3:hover {
	color: #fff;
	background: #008a48;
}
.btn-4 {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	text-align: center;
	border-radius: 16px;
	width: 20em;
	max-width: 88%;
	background: #fff;
	border: 2px solid #2a649e;
	color: #2a649e;
	font-weight: 700;
	border-radius: 8px;
}
.btn-4:hover {
	color: #2a649e;
	background: #d4e0ec;
}
.btn-4 span {
	padding: .7em 1em;
}
.arrow {
	position: relative;
}
.arrow::before,
.arrow::after {
	position: absolute;
	content: "";
	display: block;
	top: 50%;
	transform: translateY(-50%);
}
.arrow::before {
	border-radius: 50%;
	border: 1px solid #2a649e;
	width: 24px;
	height: 24px;
	right: 10px;
}
.arrow::after {
	clip-path: polygon(0 0, 0% 100%, 100% 50%);
	background: #2a649e;
	width: 8px;
	height: 9px;
	right: 18px;
}

.dl {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
.dl dt {
	width: 20%;
	font-weight: 700;
	color: #fff;
	background: #0c93df;
	text-align: center;
	font-size: 32px;
	line-height: 1.4;
	padding: .3em;
	box-sizing: border-box;
	margin: .43em 0;
}
.dl.dl-blue dt {
	background: #0c93df;
}
.dl.dl-green dt {
	background: #00bf63;
}
.dl dd {
	width: 80%;
	font-size: 39px;
	line-height: 1.4;
	box-sizing: border-box;
	padding: .25em 0 .3em .7em;
}
.bg-maru {
	width: 6.3em;
	height: 6.3em;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	line-height: 1.2;
	font-size: 39px;
	color: #fff;
}

.flex-aic {
	align-items: center;
}

@font-face {
	font-family: "Aoboshi One";
	font-style: normal;
	font-weight: 400;
	src: url('web-fonts/aoboshione-regular-webfont.woff');
}
.aoboshi {
	font-family: "Aoboshi One", sans-serif;
	font-weight: 400;
	font-style: normal;
}
.mb30 {
	margin-bottom: 30px !important;
}
.mt30 {
	margin-top: 30px !important;
}
.mt10 {
	margin-top: 10px !important;
}
.dl2 {
	display: flex;
	flex-wrap: wrap;
	font-size: 31px;
	line-height: 1.4;
	padding: .7em 1em;
}
.dl2 dt {
	width: 3em;
	padding: .25em 0;
	box-sizing: border-box;
}
.dl2 dd {
	padding: .25em 0;
	box-sizing: border-box;
}
.va {
	vertical-align: .3em;
}
.border-dot {
	background-image: linear-gradient(to right, #ff914d, #ff914d 4px, transparent 4px);
	background-size: 8px 4px;
	background-repeat: repeat-x;
	padding-top: .27em;
}
.border-dot-bottom {
	background-image: linear-gradient(to right, #ff914d, #ff914d 4px, transparent 4px);
	background-size: 8px 4px;
	background-position: left bottom;
	background-repeat: repeat-x;
	display: block;
	padding-bottom: .35em;
}

.page-top {
	position: fixed;
	bottom: 3.2em;
	z-index: 99;
	width: 5.3em;
	height: 2.8em;
	cursor: pointer;
	right: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #737373;
	font-size: 30px;
}
.page-top span {
	color: #fff;
	white-space: nowrap;
}