/*----------------------------------------
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: 1200px;
}

.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;
}

strong,b,.strong {
	font-weight: 700;
}

:root {
	--red-2: #c70025;
	--blue-2: #0d3092;
	--green-2: #008868;
}

.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%);
}

.red-2 {
	color: var(--red-2);
}

.blue-2 {
	color: var(--blue-2);
}

.green-2 {
	color: var(--green-2);
}

.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;
	box-shadow: 0 0 15px 0 rgba(0,0,0,0.6);
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 100;
}

body#office-cleaning .head-in {
	box-shadow: none;
}

body#office-cleaning .head-in.fixed {
	box-shadow: 0 0 15px 0 rgba(0,0,0,0.6);
}

.customize-support .head-in {
	margin-top: 32px;
}

.head-in .wrapper {
	padding: 10px 0;
}

.head-in-logo {
	box-sizing: border-box;
	display: block;
	float: left;
	line-height: 0;
	overflow: hidden;
	text-decoration: none;
}

.head-in-logo:hover {
	opacity: 0.6;
}

.head-in-logo-text {
	box-sizing: border-box;
	color: #0d3092;
	display: inline-block;
	float: left;
	font-weight: 900;
	font-size: 36px;
	line-height: 1.5;
}

.head-in-logo-icon {
	box-sizing: border-box;
	display: block;
	float: left;
	margin: 15px 0 0 15px;
	position: relative;
	width: 250px;
}

.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: 11.173%;
	position: relative;
	width: 100%;
}

.head-in-logo-new {
	box-sizing: border-box;
	display: block;
	float: left;
	text-decoration: none;
	width: 580px;
}

.head-in-logo-new .img-banner {
	background: url(images/logo-new.png) no-repeat;
	padding-bottom: 10.077%;
}

.head-in-in {
	box-sizing: border-box;
	float: right;
}

.head-in-in-tel {
	box-sizing: border-box;
	float: left;
	line-height: 0;
}

.head-in-in-tel-in {
	box-sizing: border-box;
	color: var(--red-2);
	display: block;
	font-weight: 700;
	font-size: 30px;
	line-height: 1.5;
}

.head-in-in-tel-in-text {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 30px;
	position: relative;
}

.head-in-in-tel-in-text-icon {
	box-sizing: border-box;
	display: block;
	left: 0;
	position: absolute;
	top: 9px;
	width: 25px;
}

.head-in-in-tel-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: 104%;
	position: relative;
	width: 100%;
}

.head-in-in-tel-in-sub-text {
	box-sizing: border-box;
	color: #000;
	font-weight: 400;
	font-size: 13px;
	line-height: 1.5;
	margin-top: -5px;
	text-align: center;
}

.head-in-in-mail-btn {
	box-sizing: border-box;
	display: block;
	float: left;
	line-height: 0;
	margin-left: 20px;
	text-align: center;
	text-decoration: none;
	width: 210px;
}

.head-in-in-mail-btn:hover .head-in-in-mail-btn-in {
	opacity: 0.6;
}

.head-in-in-mail-btn-in {
	background: var(--red-2);
	box-sizing: border-box;
	border-radius: 10px;
	color: #fff;
	display: block;
	font-weight: 700;
	font-size: 16px;
	line-height: 1.5;
	padding: 15px;
}

.head-in-in-mail-btn-in-text {
	box-sizing: border-box;
	display: inline-block;
	position: relative;
}

/*----------------------------------------
TOPページ
----------------------------------------*/

.top-content {
	box-sizing: border-box;
}

.top-content .wrapper {
	padding: 100px 0;
}

.top-content.top-onestop .wrapper,
.top-content.top-clean-service .wrapper,
.top-content.top-point .wrapper,
.top-content.top-price .wrapper,
.top-content.top-company .wrapper {
	padding-bottom: 0;
}

.top-main-title {
	box-sizing: border-box;
	line-height: 0;
	margin-bottom: 40px;
	padding-bottom: 50px;
	position: relative;
	text-align: center;
}

.top-main-title::after {
	background: var(--green-2);
	box-sizing: border-box;
	bottom: 0;
	content: "";
	left: 0;
	height: 50px;
	margin: 0 auto;
	position: absolute;
	right: 0;
	width: 5px;
}

.top-main-title-in {
	box-sizing: border-box;
	border-color: var(--green-2) !important;
	border-bottom: 5px solid;
	display: inline-block;
	padding-bottom: 15px;
	position: relative;
}

.top-main-title-in-text {
	box-sizing: border-box;
	display: inline-block;
	font-weight: 700;
	font-size: 36px;
	line-height: 1.5;
}

.top-main-text {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.8;
	margin: 0 140px;
}

.top-main-text p {
	margin-bottom: 30px;
}

.top-main-text p:last-child {
	margin-bottom: 0;
}

.top-main-text .big {
	font-weight: 700;
	font-size: 24px;
}

.top-main-info-tb {
	box-sizing: border-box;
}

.top-main-text + .top-main-info-tb {
	margin-top: 60px;
}

.top-main-info-tb table {
	box-sizing: border-box;
	width: 100%;
}

.top-main-info-tb table th {
	background: #73beac;
	box-sizing: border-box;
	border-color: #000 !important;
	border: 1px solid;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.5;
	padding: 20px 10px;
	vertical-align: middle;
	text-align: center;
	width: 33.3%;
}

.top-main-info-tb table th:nth-child(2) {
	width: 33.4%;
}

.top-main-info-tb table th.th-1 {
	background: #c5e3dc;
}

.top-main-info-tb table td {
	background: #fff;
	box-sizing: border-box;
	border-color: #000 !important;
	border: 1px solid;
	font-size: 20px;
	line-height: 1.5;
	padding: 20px 10px;
	vertical-align: middle;
	text-align: center;
}

.top-main-info-tb-caution-text {
	box-sizing: border-box;
	font-size: 18px;
	line-height: 1.5;
	margin-top: 10px;
	text-align: right;
}

/*------------------------------
TOP KV
------------------------------*/

.top-kv {
	background: url(images/top-kv-img.jpg) no-repeat;
	background-size: 100% !important;
	box-sizing: border-box;
	display: block;
	margin-top: 79.5px;
	padding-bottom: 37.5%;
	width: 100%;
}

/*------------------------------
こんなお悩み
------------------------------*/

.top-worry-content {
	box-sizing: border-box;
}

.top-worry-content .wrapper {
	padding: 60px 0;
}

.top-worry-content-title {
	box-sizing: border-box;
	line-height: 0;
	text-align: center;
}

.top-worry-content-title-in {
	box-sizing: border-box;
	display: inline-block;
	padding: 0 112px 20px;
	position: relative;
}

.top-worry-content-title-in::before,
.top-worry-content-title-in::after {
	background: var(--blue-2);
	box-sizing: border-box;
	content: "";
	height: 100%;
	position: absolute;
	top: 0;
	width: 5px;
}

.top-worry-content-title-in::before {
	left: 44px;
	transform: rotate(-30deg);
	-webkit-transform: rotate(-30deg);
}

.top-worry-content-title-in::after {
	right: 44px;
	transform: rotate(30deg);
	-webkit-transform: rotate(30deg);
}

.top-worry-content-title-in-text {
	box-sizing: border-box;
	display: inline-block;
	font-weight: 700;
	font-size: 42px;
	line-height: 1.5;
}

.top-worry-content-title-in-text .big {
	font-size: 60px;
	line-height: 1.25;
}

.top-worry-content-con {
	box-sizing: border-box;
	margin: 40px 40px 0;
}

.top-worry-content-con section {
	box-sizing: border-box;
	float: left;
	margin-right: 50px;
	width: 340px;
}

.top-worry-content-con section:last-child {
	margin-right: 0;
}

.top-worry-content-con-title {
	box-sizing: border-box;
	line-height: 0;
	padding-top: 30px;
	position: relative;
	text-align: center;
}

.top-worry-content-con-title-icon {
	background: #fff;
	box-sizing: border-box;
	display: block;
	left: 0;
	padding: 0 10px 10px 0;
	position: absolute;
	top: 0;
	width: 70px;
}

.top-worry-content-con section.sec-question .top-worry-content-con-title-icon {
	width: 48px;
}

.top-worry-content-con section.sec-request .top-worry-content-con-title-icon {
	width: 55px;
}

.top-worry-content-con-title-icon-in {
	box-sizing: border-box;
	display: block;
	position: relative;
	width: 100%;
}

.top-worry-content-con-title-icon-in::before {
	background-size: 100% !important;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 0;
	position: relative;
	width: 100%;
}

.top-worry-content-con section.sec-dissatisfaction .top-worry-content-con-title-icon-in::before {
	background: url(images/top-worry-icon-1.png) no-repeat;
	padding-bottom: 67.5%;
}

.top-worry-content-con section.sec-question .top-worry-content-con-title-icon-in::before {
	background: url(images/top-worry-icon-2.png) no-repeat;
	padding-bottom: 123.25%;
}

.top-worry-content-con section.sec-request .top-worry-content-con-title-icon-in::before {
	background: url(images/top-worry-icon-3.png) no-repeat;
	padding-bottom: 102%;
}

.top-worry-content-con-title-in {
	box-sizing: border-box;
	border-color: var(--blue-2) !important;
	border: 2px solid;
	border-radius: 10px;
	padding: 10px 15px;
}

.top-worry-content-con-title-in-text {
	box-sizing: border-box;
	color: var(--blue-2);
	display: inline-block;
	font-size: 24px;
	line-height: 1.5;
}

.top-worry-content-con-title-in-text .big {
	font-weight: 700;
	font-size: 36px;
	line-height: 1;
}

.top-worry-content-con-img {
	box-sizing: border-box;
	display: block;
	margin-top: 20px;
	width: 100%;
}

.top-worry-content-con-img img {
	height: auto;
	width: 100%;
}

.top-worry-content-con-text {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.8;
	margin-top: 20px;
}

.top-worry-content-con-text p {
	margin-bottom: 20px;
}

.top-worry-content-con-text p:last-child {
	margin-bottom: 0;
}

/*------------------------------
名鉄グループの信頼
------------------------------*/

.top-about-content {
	box-sizing: border-box;
	position: relative;
}

.top-about-content::before {
	background: url(images/top-about-bg.jpg);
	background-size: cover;
	background-position: top center;
	box-sizing: border-box;
	bottom: 0;
	content: "";
	left: 0;
	height: calc(100% - 70px);
	position: absolute;
	width: 100%;
}

.top-about-content .wrapper {
	padding-bottom: 60px;
	position: relative;
	z-index: 2;
}

.top-about-content-title {
	box-sizing: border-box;
	line-height: 0;
	text-align: center;
}

.top-about-content-title-in {
	box-sizing: border-box;
}

.top-about-content-title-in-text {
	box-sizing: border-box;
	display: inline-block;
	font-weight: 700;
	font-size: 30px;
	line-height: 1.5;
}

.top-about-content-title-in-text .box {
	background: var(--red-2);
	box-sizing: border-box;
	color: #fff;
	display: inline-block;
	margin-top: 5px;
	padding: 0 10px;
}

.top-about-content-main-title {
	box-sizing: border-box;
	line-height: 0;
	margin-top: 80px;
	text-align: center;
}

.top-about-content-main-title-in {
	box-sizing: border-box;
	border-color: var(--green-2) !important;
	border-bottom: 5px solid;
	display: inline-block;
	padding-bottom: 5px;
}

.top-about-content-main-title-in-text {
	box-sizing: border-box;
	display: inline-block;
	font-weight: 700;
	font-size: 42px;
	line-height: 1.5;
}

.top-about-content-main-title-in-text .text {
	box-sizing: border-box;
	display: inline-block;
	margin: 0 21px;
}

.top-about-content-text {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.5;
	margin-top: 40px;
	text-align: center;
}

.top-about-content-text p {
	margin-bottom: 30px;
}

.top-about-content-text p:last-child {
	margin-bottom: 0;
}

.top-about-content-con {
	box-sizing: border-box;
	margin-top: 60px;
}

.top-about-content-con section {
	box-sizing: border-box;
	margin-right: 40px;
	position: relative;
	width: 215px;
}

.top-about-content-con section::before {
	background: url(images/top-about-icon-bg.png) no-repeat;
	background-size: 100% !important;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 0;
	padding-bottom: 99.534%;
	position: relative;
	width: 100%;
}

.top-about-content-con section:last-child {
	margin-right: 0;
}

.top-about-content-con-title {
	box-sizing: border-box;
	line-height: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	text-align: center;
}

.top-about-content-con-title-in {
	box-sizing: border-box;
}

.top-about-content-con-title-in-text {
	box-sizing: border-box;
	color: var(--green-2);
	display: inline-block;
	font-weight: 700;
	font-size: 24px;
	line-height: 1.5;
}

/*------------------------------
選ばれる理由
------------------------------*/

.top-reason-conetnt {
	box-sizing: border-box;
	overflow: hidden;
	position: relative;
}

.top-reason-conetnt-bg {
	box-sizing: border-box;
	display: block;
	left: 0;
	position: absolute;
	top: 0;
	width: 889px;
}

.top-reason-conetnt-bg::before {
	background: url(images/top-reason-bg.png) no-repeat;
	background-size: 100% !important;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 0;
	padding-bottom: 110.12%;
	position: relative;
	width: 100%;
}

.top-reason-conetnt .wrapper {
	padding: 100px 0;
	position: relative;
	z-index: 2;
}

.top-reason-conetnt-con {
	box-sizing: border-box;
	margin: 0 100px;
}

.top-reason-conetnt-con section {
	background: #fff;
	box-sizing: border-box;
	border-color: #ccc !important;
	border: 2px solid;
	border-bottom: 5px solid;
	margin-bottom: 40px;
	padding-left: 100px;
	position: relative;
}

.top-reason-conetnt-con section:last-child {
	margin-bottom: 0;
}

.top-reason-conetnt-con-bg {
	background: var(--blue-2);
	box-sizing: border-box;
	left: 0;
	height: 100%;
	position: absolute;
	top: 0;
	width: 100px;
}

.top-reason-conetnt-con-bg-icon {
	box-sizing: border-box;
	display: block;
	left: 0;
	margin: 0 auto;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	width: 55px;
}

.top-reason-conetnt-con section.sec-license .top-reason-conetnt-con-bg-icon {
	width: 34px;
}

.top-reason-conetnt-con section.sec-report .top-reason-conetnt-con-bg-icon {
	width: 38px;
}

.top-reason-conetnt-con-bg-icon::before {
	background-size: 100% !important;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 0;
	position: relative;
	width: 100%;
}

.top-reason-conetnt-con section.sec-history .top-reason-conetnt-con-bg-icon::before {
	background: url(images/top-reason-icon-1.png) no-repeat;
	padding-bottom: 76.363%;
}

.top-reason-conetnt-con section.sec-license .top-reason-conetnt-con-bg-icon::before {
	background: url(images/top-reason-icon-2.png) no-repeat;
	padding-bottom: 141.17%;
}

.top-reason-conetnt-con section.sec-report .top-reason-conetnt-con-bg-icon::before {
	background: url(images/top-reason-icon-3.png) no-repeat;
	padding-bottom: 113.15%;
}

.top-reason-conetnt-con-in {
	box-sizing: border-box;
	padding: 30px;
}

.top-reason-conetnt-con-in-title {
	box-sizing: border-box;
	border-color: var(--blue-2) !important;
	border-right: 3px solid;
	float: left;
	line-height: 0;
	padding-right: 30px;
	width: 270px;
}

.top-reason-conetnt-con-in-title-in {
	box-sizing: border-box;
}

.top-reason-conetnt-con-in-title-in-text {
	box-sizing: border-box;
	color: var(--blue-2);
	display: inline-block;
	font-weight: 700;
	font-size: 24px;
	line-height: 1.5;
}

.top-reason-conetnt-con-in-in {
	box-sizing: border-box;
	float: right;
	width: calc(100% - 300px);
}

.top-reason-conetnt-con-in-in-text {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.8;
}

.top-reason-conetnt-con-in-in-text p {
	margin-bottom: 20px;
}

.top-reason-conetnt-con-in-in-text p:last-child {
	margin-bottom: 0;
}

.top-reason-conetnt-con + .top-main-title {
	margin-top: 100px;
}

.top-reason-conetnt-support-con {
	box-sizing: border-box;
}

.top-reason-conetnt-support-con section {
	box-sizing: border-box;
	margin-bottom: 60px;
}

.top-reason-conetnt-support-con section:last-child {
	margin-bottom: 0;
}

.top-reason-conetnt-support-con-title {
	box-sizing: border-box;
	border-color: var(--blue-2) !important;
	border-top: 2px solid;
	border-bottom: 2px solid;
	padding: 20px;
}

.top-reason-conetnt-support-con-title-in {
	box-sizing: border-box;
}

.top-reason-conetnt-support-con-title-in-text {
	box-sizing: border-box;
	color: var(--blue-2);
	display: inline-block;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.5;
	padding-left: 38px;
	position: relative;
}

.top-reason-conetnt-support-con section.sec-group .top-reason-conetnt-support-con-title-in-text {
	padding-left: 52px;
}

.top-reason-conetnt-support-con-title-in-text-icon {
	box-sizing: border-box;
	display: block;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	width: 28px;
}

.top-reason-conetnt-support-con section.sec-group .top-reason-conetnt-support-con-title-in-text-icon {
	width: 42px;
}

.top-reason-conetnt-support-con-title-in-text-icon::before {
	background-size: 100% !important;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 0;
	position: relative;
	width: 100%;
}

.top-reason-conetnt-support-con section.sec-license .top-reason-conetnt-support-con-title-in-text-icon::before {
	background: url(images/top-reason-icon-license.png) no-repeat;
	padding-bottom: 139.28%;
}

.top-reason-conetnt-support-con section.sec-group .top-reason-conetnt-support-con-title-in-text-icon::before {
	background: url(images/top-reason-icon-group.png) no-repeat;
	padding-bottom: 66.666%;
}

.top-reason-conetnt-support-con-text {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.5;
	margin: 20px 70px 0;
}

.top-reason-conetnt-support-con-in + .top-reason-conetnt-support-con-text {
	margin-top: 20px;
}

.top-reason-conetnt-support-con-text p {
	margin-bottom: 20px;
}

.top-reason-conetnt-support-con-text p:last-child {
	margin-bottom: 0;
}

.top-reason-conetnt-support-con-in {
	background: #f4f6fa;
	box-sizing: border-box;
	padding: 20px 70px;
}

.top-reason-conetnt-support-con-text + .top-reason-conetnt-support-con-in {
	margin-top: 20px;
}

.top-reason-conetnt-support-con-in-con {
	box-sizing: border-box;
}

.top-reason-conetnt-support-con .top-reason-conetnt-support-con-in-con section {
	box-sizing: border-box;
	float: left;
	margin: 0 70px 0 0;
	width: 495px;
}

.top-reason-conetnt-support-con .top-reason-conetnt-support-con-in-con section:last-child {
	margin-right: 0;
}

.top-reason-conetnt-support-con-in-con-text {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.5;
}

.top-reason-conetnt-support-con-in-con-text p {
	margin-bottom: 20px;
}

.top-reason-conetnt-support-con-in-con-text p:last-child {
	margin-bottom: 0;
}

/*------------------------------
導入例
------------------------------*/

.top-example-content {
	box-sizing: border-box;
}

.top-example-content .wrapper {
	padding: 100px 0;
}

.top-example-content-con {
	box-sizing: border-box;
}

.top-example-content-con section {
	box-sizing: border-box;
	margin-bottom: 100px;
}

.top-example-content-con section:last-child {
	margin-bottom: 0;
}

.top-example-content-con-main-title {
	box-sizing: border-box;
}

.top-example-content-con-sub-title + .top-example-content-con-main-title {
	margin-top: 20px;
}

.top-example-content-con-main-title-main {
	background: var(--green-2);
	box-sizing: border-box;
	line-height: 0;
	padding: 10px 15px;
	text-align: center;
}

.top-example-content-con-main-title-main-in {
	box-sizing: border-box;
}

.top-example-content-con-main-title-main-in-text {
	box-sizing: border-box;
	color: #fff;
	display: inline-block;
	font-weight: 700;
	font-size: 24px;
	line-height: 1.5;
}

.top-example-content-con-main-title-sub {
	box-sizing: border-box;
	line-height: 0;
	padding: 20px 0;
	position: relative;
	text-align: center;
}

.top-example-content-con-main-title-sub::before {
	background: #eaeaea;
	box-sizing: border-box;
	clip-path: polygon(50% 100%, 0 0, 100% 0);
	content: "";
	left: 0;
	height: 100%;
	position: absolute;
	top: 0;
	width: 100%;
}

.top-example-content-con-main-title-sub-in {
	box-sizing: border-box;
	position: relative;
	z-index: 2;
}

.top-example-content-con-main-title-sub-in-text {
	box-sizing: border-box;
	display: inline-block;
	font-size: 18px;
	line-height: 2;
}

.top-example-content-con-main-title-sub-in-text .big {
	font-weight: 700;
	font-size: 24px;
}

.top-example-content-con-main-title-sub-in-text .big-2 {
	font-weight: 700;
	font-size: 30px;
}

.top-example-content-con-sub-title {
	box-sizing: border-box;
	line-height: 0;
	text-align: center;
}

.top-example-content-con-sub-title-in {
	box-sizing: border-box;
	display: inline-block;
	padding: 0 90px 14px;
	position: relative;
}

.top-example-content-con-sub-title-in::before,
.top-example-content-con-sub-title-in::after {
	background: var(--blue-2);
	box-sizing: border-box;
	content: "";
	height: 100%;
	position: absolute;
	top: 0;
	width: 5px;
}

.top-example-content-con-sub-title-in::before {
	left: 33px;
	transform: rotate(-30deg);
	-webkit-transform: rotate(-30deg);
}

.top-example-content-con-sub-title-in::after {
	right: 33px;
	transform: rotate(30deg);
	-webkit-transform: rotate(30deg);
}

.top-example-content-con-sub-title-in-text {
	box-sizing: border-box;
	display: inline-block;
	font-size: 18px;
	line-height: 2.667;
}

.top-example-content-con-sub-title-in-text .big {
	font-weight: 700;
	font-size: 24px;
}

.top-example-content-con-title {
	box-sizing: border-box;
	position: relative;
}

.top-example-content-con-title::before {
	background-image: radial-gradient(circle, var(--red-2) 5px, transparent 5px);
	background-position: left top;
	background-repeat: repeat-x;
	background-size: 25px 10px;
	box-sizing: border-box;
	content: "";
	left: 0;
	height: 10px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	width: 100%;
}

.top-example-content-con-title-in {
	background: var(--red-2);
	box-sizing: border-box;
	border-radius: 50%;
	height: 160px;
	position: relative;
	width: 160px;
	z-index: 2;
}

.top-example-content-con-title-in-text {
	box-sizing: border-box;
	color: #fff;
	display: inline-block;
	font-size: 18px;
	line-height: 1.5;
	left: 0;
	position: absolute;
	text-align: center;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	width: 160px;
}

.top-example-content-con-title-in-text .big {
	font-weight: 700;
	font-size: 24px;
}

.top-example-content-con-in {
	box-sizing: border-box;
	margin-left: 100px;
}

.top-example-content-con-in-img {
	box-sizing: border-box;
	display: block;
	float: left;
	width: 130px;
}

.top-example-content-con-in-img img {
	height: auto;
	width: 100%;
}

.top-example-content-con-in-in {
	box-sizing: border-box;
	float: right;
	width: calc(100% - 170px);
}

.top-example-content-con-in-in-text {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.8;
}

.top-example-content-con-in-in-text p {
	margin-bottom: 30px;
}

.top-example-content-con-in-in-text p:last-child {
	margin-bottom: 0;
}

.top-example-content-con-in-in-img {
	box-sizing: border-box;
	display: block;
	margin-top: 30px;
	width: 545px;
}

.top-example-content-con-in-in-img img {
	height: auto;
	width: 100%;
}

.top-example-content-con-in-in-img-list {
	box-sizing: border-box;
	margin: 30px 0 -30px;
}

.top-example-content-con-in-in-img-list li {
	box-sizing: border-box;
	float: left;
	margin: 0 30px 30px 0;
	width: 450px;
}

.top-example-content-con-in-in-img-list li:nth-child(2n),
.top-example-content-con-in-in-img-list li:last-child {
	margin-right: 0;
}

.top-example-content-con-in-in-img-list-img {
	box-sizing: border-box;
	display: block;
	width: 100%;
}

.top-example-content-con-in-in-img-list-img img {
	height: auto;
	width: 100%;
}

/*------------------------------
メリット
------------------------------*/

.top-merit-content {
	background: #f9fcfb;
	box-sizing: border-box;
}

.top-merit-content .wrapper {
	padding: 100px 0;
}

.top-merit-content-con {
	box-sizing: border-box;
	margin-top: 60px;
}

.top-merit-content-con section {
	box-sizing: border-box;
	margin-bottom: 60px;
}

.top-merit-content-con section:last-child {
	margin-bottom: 0;
}

.top-merit-content-con section:nth-child(2n) > .of.flex-middle {
	flex-direction: row-reverse;
}

.top-merit-content-con-img {
	box-sizing: border-box;
	display: block;
	float: left;
	width: 380px;
}

.top-merit-content-con section:nth-child(2n) .top-merit-content-con-img {
	float: right;
}

.top-merit-content-con-img img {
	height: auto;
	width: 100%;
}

.top-merit-content-con-in {
	box-sizing: border-box;
	float: right;
	width: calc(100% - 420px);
}

.top-merit-content-con section:nth-child(2n) .top-merit-content-con-in {
	float: left;
}

.top-merit-content-con-in-title {
	box-sizing: border-box;
	border-color: var(--green-2) !important;
	border-bottom: 5px dotted;
	line-height: 0;
	padding-bottom: 5px;
}

.top-merit-content-con-in-title-in {
	box-sizing: border-box;
}

.top-merit-content-con-in-title-in-text {
	box-sizing: border-box;
	color: var(--green-2);
	display: inline-block;
	font-weight: 700;
	font-size: 30px;
	line-height: 1.5;
}

.top-merit-content-con-in-text {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.8;
	margin-top: 20px;
}

.top-merit-content-con-in-text p {
	margin-bottom: 20px;
}

.top-merit-content-con-in-text p:last-child {
	margin-bottom: 0;
}

/*------------------------------
強み
------------------------------*/

.top-point-con {
	box-sizing: border-box;
	counter-reset: number 0;
	margin-top: 40px;
}

.top-point-con section {
	box-sizing: border-box;
	float: left;
	width: 400px;
}

.top-point-con-img {
	box-sizing: border-box;
	display: block;
	width: 100%;
}

.top-point-con-img img {
	height: auto;
	width: 100%;
}

.top-point-con-in {
	box-sizing: border-box;
	border-color: var(--green-2) !important;
	border-right: 2px solid;
	height: 100%;
	margin-top: 20px;
	padding: 0 20px;
}

.top-point-con section:first-child .top-point-con-in {
	padding-left: 0;
}

.top-point-con section:last-child .top-point-con-in {
	border-right: 0;
	padding-right: 0;
}

.top-point-con-in-main-title {
	box-sizing: border-box;
	line-height: 0;
	margin: 0 auto;
	position: relative;
	text-align: center;
	width: 148px;
}

.top-point-con-in-main-title::before {
	background: url(images/top-point-title-icon.png) no-repeat;
	background-size: 100% !important;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 0;
	padding-bottom: 70.945%;
	position: relative;
	width: 100%;
}

.top-point-con-in-main-title-in {
	box-sizing: border-box;
	bottom: 7px;
	left: 0;
	position: absolute;
	right: 0;
	z-index: 2;
}

.top-point-con-in-main-title-in-text {
	box-sizing: border-box;
	color: #fff;
	display: inline-block;
	font-weight: 700;
	font-size: 18px;
	line-height: 1.5;
	padding-bottom: 33px;
	position: relative;
}

.top-point-con-in-main-title-in-text::after {
	box-sizing: border-box;
	bottom: 0;
	counter-increment: number 1;
	content: counter(number);
	font-size: 28px;
	line-height: 1.5;
	left: 0;
	position: absolute;
	right: 0;
}

.top-point-con-in-title {
	box-sizing: border-box;
	border-color: var(--green-2) !important;
	border-bottom: 5px dotted;
	line-height: 0;
	height: 93px;
	margin-top: 10px;
	position: relative;
}

.top-point-con-in-title-in {
	box-sizing: border-box;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
}

.top-point-con-in-title-in-text {
	box-sizing: border-box;
	display: inline-block;
	font-weight: 700;
	font-size: 24px;
	line-height: 1.5;
}

.top-point-con-in-text {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.8;
	margin-top: 20px;
}

.top-point-con-in-text p {
	margin-bottom: 20px;
}

.top-point-con-in-text p:last-child {
	margin-bottom: 0;
}

/*------------------------------
流れ
------------------------------*/

.top-flow-con {
	box-sizing: border-box;
	counter-reset: number 0;
	margin: 0 100px;
}

.top-flow-con section {
	box-sizing: border-box;
	border-color: #000 !important;
	border: 2px solid;
	border-radius: 10px;
	margin-bottom: 60px;
	padding-left: 100px;
	position: relative;
}

.top-flow-con section::after {
	box-sizing: border-box;
	border-style: solid;
	border-width: 40px 65px 0;
	border-color: var(--green-2) transparent transparent;
	bottom: -42px;
	content:
	"";
	left: 0;
	height: 0;
	margin: 0 auto;
	position: absolute;
	right: 0;
	width: 0;
}

.top-flow-con section:last-child {
	margin-bottom: 0;
}

.top-flow-con section:last-child::after {
	content: none;
}

.top-flow-con-num {
	box-sizing: border-box;
	border-color: #000 !important;
	border-right: 2px solid;
	left: 0;
	height: 100%;
	position: absolute;
	width: 100px;
}

.top-flow-con-num::before {
	box-sizing: border-box;
	color: var(--green-2);
	counter-increment: number 1;
	content: counter(number);
	font-weight: 700;
	font-size: 48px;
	line-height: 1.5;
	left: 0;
	position: absolute;
	right: 0;
	text-align: center;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	width: 100px;
}

.top-flow-con-in {
	box-sizing: border-box;
	padding: 20px;
}

.top-flow-con-in-icon {
	box-sizing: border-box;
	display: block;
	float: left;
	width: 28px;
}

.top-flow-con-in-icon::before {
	background-size: 100% !important;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 0;
	position: relative;
	width: 100%;
}

.top-flow-con section.sec-contact .top-flow-con-in-icon::before {
	background: url(images/top-flow-icon-1.png) no-repeat;
	padding-bottom: 157.14%;
}

.top-flow-con section.sec-investigation .top-flow-con-in-icon::before {
	background: url(images/top-flow-icon-2.png) no-repeat;
	padding-bottom: 143.33%;
}

.top-flow-con section.sec-estimate .top-flow-con-in-icon::before {
	background: url(images/top-flow-icon-3.png) no-repeat;
	padding-bottom: 143.33%;
}

.top-flow-con section.sec-implementation .top-flow-con-in-icon::before {
	background: url(images/top-flow-icon-4.png) no-repeat;
	padding-bottom: 92.452%;
}

.top-flow-con section.sec-follow .top-flow-con-in-icon::before {
	background: url(images/top-flow-icon-5.png) no-repeat;
	padding-bottom: 133.33%;
}

.top-flow-con-in-in {
	box-sizing: border-box;
	float: right;
	width: calc(100% - 48px);
}

.top-flow-con-in-in-title {
	box-sizing: border-box;
	line-height: 0;
}

.top-flow-con-in-in-title-in {
	box-sizing: border-box;
}

.top-flow-con-in-in-title-in-text {
	box-sizing: border-box;
	display: inline-block;
	font-weight: 700;
	font-size: 24px;
	line-height: 1.5;
}

.top-flow-con-in-in-text {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.5;
}

/*------------------------------
会社概要
------------------------------*/

.top-company-info-tb {
	box-sizing: border-box;
	margin: 0 50px;
}

.top-company-info-tb table {
	box-sizing: border-box;
	width: 100%;
}

.top-company-info-tb table th {
	background: #c5e3dc;
	box-sizing: border-box;
	border-color: #000 !important;
	border-right: 3px solid;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.8;
	padding: 10px 15px;
	padding-right: 50px;
	vertical-align: top;
	text-align: right;
	width: 19%;
}

.top-company-info-tb table td {
	background: #fff;
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.8;
	padding: 10px 15px;
	vertical-align: top;
}

.top-company-info-tb table td p {
	margin-bottom: 20px;
}

.top-company-info-tb table td p:last-child {
	margin-bottom: 0;
}

/*------------------------------
よくある質問
------------------------------*/

.top-faq-con {
	box-sizing: border-box;
	margin: 0 100px;
}

.top-faq-con-dl {
	box-sizing: border-box;
	margin-bottom: 60px;
}

.top-faq-con-dl:last-child {
	margin-bottom: 0;
}

.top-faq-con-dl dt {
	box-sizing: border-box;
	line-height: 0;
}

.top-faq-con-dl-dt-in {
	box-sizing: border-box;
}

.top-faq-con-dl-dt-in-text {
	box-sizing: border-box;
	color: var(--green-2);
	display: inline-block;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.8;
	padding-left: 40px;
	position: relative;
}

.top-faq-con-dl-dt-in-text::before {
	box-sizing: border-box;
	content: "Q.";
	left: 0;
	position: absolute;
	top: 0;
}

.top-faq-con-dl dd {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.8;
	padding-left: 40px;
	position: relative;
}

.top-faq-con-dl dd::before {
	box-sizing: border-box;
	content: "A.";
	left: 0;
	position: absolute;
	top: 0;
}

/*----------------------------------------
個別ページ
----------------------------------------*/

.main {
	box-sizing: border-box;
	margin-top: 79.5px;
}

body#office-cleaning .main {
	margin-top: 0;
}

.page-content {
	box-sizing: border-box;
}

.page-content .wrapper {
	padding: 50px 0 100px;
}

.page-main-title {
	background: var(--red-2);
	box-sizing: border-box;
	line-height: 0;
	margin-bottom: 20px;
	padding: 10px 15px;
	text-align: center;
}

.page-main-title-in {
	box-sizing: border-box;
}

.page-main-title-in-text {
	box-sizing: border-box;
	color: #fff;
	display: inline-block;
	font-weight: 700;
	font-size: 30px;
	line-height: 1.5;
}

.page-main-text {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.8;
	margin: 0 140px;
}

.page-main-text p {
	margin-bottom: 30px;
}

.page-main-text p:last-child {
	margin-bottom: 0;
}

.page-check-list {
	box-sizing: border-box;
	margin-top: 20px;
	text-align: center;
}

.page-check-list ul {
	box-sizing: border-box;
	display: inline-block;
	text-align: left;
}

.page-check-list ul li {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.8;
	margin-bottom: 20px;
	padding-left: 40px;
	position: relative;
}

.page-check-list ul li::before {
	background: var(--red-2);
	box-sizing: border-box;
	border-radius: 5px;
	color: #fff;
	content: "\f00c";
	font-family: "Font Awesome 6 Pro";
	font-weight: 900;
	font-size: 18px;
	line-height: 30px;
	left: 0;
	height: 30px;
	position: absolute;
	text-align: center;
	top: 4px;
	width: 30px;
}

.page-check-list ul li:last-child {
	margin-bottom: 0;
}

/*------------------------------
お問い合わせバナー
------------------------------*/

.contact-banner-content {
	background: url(images/contact-bg.jpg) no-repeat;
	background-size: cover;
	background-position: top center;
	box-sizing: border-box;
}

.contact-banner-content .wrapper {
	padding: 40px 0;
}

.contact-banner-content-btn {
	box-sizing: border-box;
	display: block;
	line-height: 0;
	margin: 0 auto;
	padding: 41px 0 5px;
	position: relative;
	text-align: center;
	text-decoration: none;
	width: 650px;
}

.contact-banner-content-btn-title {
	box-sizing: border-box;
	display: block;
	line-height: 0;
	left: 0;
	margin: 0 auto;
	position: absolute;
	right: 0;
	top: 0;
	text-align: center;
	z-index: 2;
}

.contact-banner-content-btn:hover .contact-banner-content-btn-title {
	top: 5px;
}

.contact-banner-content-btn-title-in {
	background: #fff;
	box-sizing: border-box;
	border-color: var(--red-2) !important;
	border: 3px solid;
	border-radius: 100px;
	display: inline-block;
	padding: 10px 50px;
}

.contact-banner-content-btn-title-in-text {
	box-sizing: border-box;
	color: #000;
	display: inline-block;
	font-weight: 700;
	font-size: 27px;
	line-height: 1.5;
	padding: 0 25px;
	position: relative;
}

.contact-banner-content-btn-title-in-text::before,
.contact-banner-content-btn-title-in-text::after {
	background: var(--red-2);
	box-sizing: border-box;
	content: "";
	height: 100%;
	position: absolute;
	top: 0;
	width: 3px;
}

.contact-banner-content-btn-title-in-text::before {
	left: 6px;
	transform: rotate(-15deg);
	-webkit-transform: rotate(-15deg);
}

.contact-banner-content-btn-title-in-text::after {
	right: 6px;
	transform: rotate(15deg);
	-webkit-transform: rotate(15deg);
}

.contact-banner-content-btn-title-in-text .big {
	font-size: 43px;
	line-height: 1;
}

.contact-banner-content-btn-in {
	background: var(--red-2);
	box-sizing: border-box;
	box-shadow: 0 5px #ccc;
	border-radius: 100px;
	color: #fff;
	display: block;
	font-weight: 700;
	font-size: 42px;
	line-height: 1.5;
	padding: 30px 10px 10px;
	position: relative;
}

.contact-banner-content-btn-in::after {
	background: #fff;
	box-sizing: border-box;
	border-radius: 50%;
	color: var(--red-2);
	content: "\e014";
	font-family: 'icomoon';
	font-weight: 400;
	font-size: 30px;
	line-height: 50px;
	height: 50px;
	position: absolute;
	right: 30px;
	text-align: center;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	width: 50px;
}

.contact-banner-content-btn:hover .contact-banner-content-btn-in {
	box-shadow: none !important;
	transform: translate3d(0,5px,0);
	-webkit-transform: translate3d(0,5px,0);
}

.contact-banner-content-btn-in-text {
	box-sizing: border-box;
	display: inline-block;
}

.contact-banner-content-tel {
	box-sizing: border-box;
	line-height: 0;
	text-align: center;
}

.contact-banner-content-tel-in {
	box-sizing: border-box;
	color: var(--red-2);
	display: inline-block;
	font-weight: 700;
	font-size: 48px;
	line-height: 1.5;
}

.contact-banner-content-tel-in-text {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 50px;
	position: relative;
}

.contact-banner-content-tel-in-text-icon {
	box-sizing: border-box;
	display: block;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	width: 40px;
}

.contact-banner-content-tel-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: 102.5%;
	position: relative;
	width: 100%;
}

.contact-banner-content-tel-in-sub-text {
	box-sizing: border-box;
	color: #000;
	font-weight: 400;
	font-size: 20px;
	line-height: 1.5;
	margin-top: -5px;
}

/*------------------------------
お問い合わせはお気軽に！
------------------------------*/

.contact-info-content {
	background: url(images/contact-info-bg.jpg) no-repeat;
	background-size: cover;
	background-position: top center;
	box-sizing: border-box;
}

.contact-info-content .wrapper {
	padding: 100px 0;
}

.contact-info-content-main-title {
	box-sizing: border-box;
	line-height: 0;
	text-align: center;
}

.contact-info-content-main-title-in {
	box-sizing: border-box;
}

.contact-info-content-main-title-in-text {
	box-sizing: border-box;
	color: var(--red-2);
	display: inline-block;
	font-weight: 700;
	font-size: 30px;
	line-height: 1.5;
}

.contact-info-content-text {
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.5;
	margin-top: 60px;
	text-align: center;
}

.contact-info-content-text p {
	margin-bottom: 30px;
}

.contact-info-content-text p:last-child {
	margin-bottom: 0;
}

.contact-info-content-title {
	box-sizing: border-box;
	line-height: 0;
	margin-top: 60px;
	text-align: center;
}

.contact-info-content-title-in {
	background: #fff;
	box-sizing: border-box;
	display: inline-block;
	padding: 5px 30px;
}

.contact-info-content-title-in-text {
	box-sizing: border-box;
	display: inline-block;
	font-weight: 700;
	font-size: 24px;
	line-height: 1.5;
}

/*------------------------------
お問い合わせ
------------------------------*/

.contact-form-tb {
	box-sizing: border-box;
	margin: 60px 200px 0;
}

.contact-form-tb table {
	box-sizing: border-box;
	width: 100%;
}

.contact-form-tb table th {
	box-sizing: border-box;
	display: block;
	font-weight: 400;
	font-size: 20px;
	line-height: 1.5;
	vertical-align: top;
	text-align: left;
	width: 100%;
}

.contact-form-tb table th .required {
	box-sizing: border-box;
	color: #ff0000;
	display: inline-block;
	margin-left: 10px;
}

.contact-form-tb table td {
	box-sizing: border-box;
	display: block;
	font-size: 20px;
	line-height: 1.5;
	padding: 10px 0 40px;
	vertical-align: top;
	width: 100%;
}

.contact-form-tb table tr:last-child td {
	padding-bottom: 0;
}

.contact-form-tb table td input[type="text"],
.contact-form-tb table td input[type="email"] {
	background: #fff;
	box-sizing: border-box;
	border-color: #ccc !important;
	border: 1px solid;
	border-radius: 5px;
	display: block;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 20px;
	line-height: 1.5;
	padding: 5px 10px;
	width: 100%;
	-webkit-appearance: none;
}

.contact-form-tb table td .wpcf7-checkbox {
	box-sizing: border-box;
}

.contact-form-tb table td .wpcf7-checkbox .wpcf7-list-item {
	box-sizing: border-box;
	display: block;
	margin: 0 0 10px;
}

.contact-form-tb table td .wpcf7-checkbox .wpcf7-list-item:last-child {
	margin-bottom: 0;
}

.contact-form-tb table td .wpcf7-checkbox .wpcf7-list-item label {
	box-sizing: border-box;
	cursor: pointer;
	display: inline-block;
	position: relative;
}

.contact-form-tb table td .wpcf7-checkbox .wpcf7-list-item label::before {
	box-sizing: border-box;
	border-color: #ccc !important;
	border: 2px solid;
	border-radius: 50%;
	content: "";
	left: 0;
	height: 30px;
	position: absolute;
	top: 0;
	width: 30px;
}

.contact-form-tb table td .wpcf7-checkbox .wpcf7-list-item label input[type="checkbox"] {
	display: none;
}

.contact-form-tb table td .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label {
	box-sizing: border-box;
	display: block;
	min-height: 30px;
	padding-left: 40px;
	position: relative;
}

.contact-form-tb table td .wpcf7-checkbox .wpcf7-list-item label input[type="checkbox"]:checked + .wpcf7-list-item-label::before {
	background: var(--red-2);
	box-sizing: border-box;
	border-radius: 50%;
	content: "";
	left: 7px;
	height: calc(30px - 14px);
	position: absolute;
	top: 7px;
	width: calc(30px - 14px);
}

.contact-form-tb table td textarea {
	background: #fff;
	box-sizing: border-box;
	border-color: #ccc !important;
	border: 1px solid;
	border-radius: 5px;
	display: block;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 20px;
	line-height: 1.5;
	height: 200px;
	padding: 5px 10px;
	width: 100%;
	-webkit-appearance: none;
}

.contact-form-send-btn {
	box-sizing: border-box;
	display: block;
	margin: 40px auto 0;
	padding-bottom: 5px;
	width: 300px;
}

.contact-form-send-btn input[type="submit"] {
	background: var(--red-2);
	box-sizing: border-box;
	border: 0;
	box-shadow: 0 5px #93001d;
	border-radius: 10px;
	cursor: pointer;
	color: #fff;
	display: block;
	font-family: 'Noto Sans JP', sans-serif;
	'Noto Sans JP', font-family: sans-serif;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.5;
	padding: 20px;
	text-align: center;
	width: 100%;
	-webkit-appearance: none;
}

.contact-form-send-btn input[type="submit"]:hover {
	box-shadow: none !important;
	transform: translate3d(0,5px,0);
	-webkit-transform: translate3d(0,5px,0);
}

.wpcf7-spinner,
.wpcf7 form .wpcf7-response-output {
	display: none !important;
}

.grecaptcha-badge {
	bottom: 20px !important;
	z-index: 102;
}

/*----------------------------------------
404ページ
----------------------------------------*/

/*----------------------------------------
sidebar
----------------------------------------*/

/*----------------------------------------
footer
----------------------------------------*/

footer {
	box-sizing: border-box;
	border-color: #e60000 !important;
	border-top: 5px solid;
}

.foot-in {
	box-sizing: border-box;
}

.foot-in .wrapper {
	padding: 40px 0;
	position: relative;
}

.foot-in-main-logo {
	box-sizing: border-box;
	display: block;
	left: -203px;
	position: absolute;
	top: 40px;
	width: 103px;
}

.foot-in-main-logo img {
	height: auto;
	width: 100%;
}

.foot-in-logo {
	box-sizing: border-box;
	float: left;
	width: 270px;
}

.foot-in-logo-main {
	box-sizing: border-box;
	display: block;
	width: 100%;
}

.foot-in-logo-main img {
	height: auto;
	width: 100%;
}

.foot-in-logo-sub {
	box-sizing: border-box;
	display: block;
	margin-top: 10px;
	width: 172px;
}

.foot-in-logo-sub img {
	height: auto;
	width: 100%;
}

.foot-in-menu {
	box-sizing: border-box;
	float: right;
	width: 790px;
}

.foot-in-menu ul {
	box-sizing: border-box;
	float: left;
	margin-right: 73px;
}

.foot-in-menu ul:last-child {
	margin-right: 0;
}

.foot-in-menu ul li {
	box-sizing: border-box;
	font-size: 15px;
	line-height: 25px;
	margin-bottom: 10px;
}

.foot-in-menu ul li.li-title {
	color: #e61a1a;
	font-weight: 700;
}

.foot-in-menu ul li.li-sub {
	padding-left: 28px;
	position: relative;
}

.foot-in-menu ul li.li-sub::before {
	box-sizing: border-box;
	border-color: #e60000 !important;
	border-top: 2px solid;
	content: "";
	left: 0;
	position: absolute;
	top: 11px;
	width: 15px;
}

.foot-in-menu ul li:last-child {
	margin-bottom: 0;
}

.foot-in-menu ul li a {
	color: #000;
	text-decoration: none;
}

.foot-in-menu ul li.li-title a {
	color: #e61a1a;
}

.foot-in-menu ul li a:hover {
	text-decoration: underline;
}

/*----------------------------------------
ページトップ
----------------------------------------*/

.pagetop {
	width: 50px;
	height: 50px;
	cursor: pointer;
	position: fixed;
	right: 10px;
	bottom: 120px;
	background: #e60000;
	display: none;
	border-radius: 50%;
	z-index: 100;
}

body#office-cleaning-contact .pagetop {
	bottom: 125px;
}

.pagetop span {
	position: relative;
	display: block;
	width: 50px;
	height: 50px;
	text-decoration: none;
}

.pagetop span::before {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	content: "";
	vertical-align: middle;
	width: 7px;
	height: 7px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.pagetop span::after {
	content: 'PAGE TOP';
	font-size: 10px;
	color: #fff;
	position: absolute;
	top: 55px;
	bottom: 0;
	right: 0;
	left: 0;
	margin: auto;
	text-align: center;
	color: #e60000;
	white-space:nowrap;
}

/*----------------------------------------
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;
}