@charset "utf-8";

#page-bg {
	position: relative;
	overflow: hidden;
	display: block;
	background-color: #0779bf;
}
@media (max-width: 991px) {
	#page-bg {
		margin-top: 0;
		padding-top: 0;
	}
}
#outer {
    padding-top: 0;
}

.navbar-brand {
    opacity: 1;
}
#page-bg img {
	max-width: inherit;
	max-height: inherit;
	width: 100%;
	height: 100%;
	object-fit: cover;
	font-family: "object-fit: cover";
	object-position: 50% 50%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

section h4 {
	text-align: center;
	font-size: 36px;
	font-weight: normal;
	margin-bottom: 75px;
}
@media (max-width: 991px) {
	section h4 {
		font-size: 21px;
		margin-bottom: 35px;
	}
}

.space-devider + .space-devider {
	margin-top: 50px;
}
@media (max-width: 991px) {
	.space-devider + .space-devider {
		margin-top: 35px;
	}
}

.space-devider-xs + .space-devider-xs {
	margin-top: 35px;
}
@media (max-width: 991px) {
	.space-devider-xs + .space-devider-xs {
		margin-top: 15px;
	}
}

.h2-mask {
	z-index: 2;
	background-color: rgba(0, 0, 0, 0.25);
	padding: 160px 30px 80px;
	position: relative;
}
@media (max-width: 991px) {
	.h2-mask {
		padding: 80px 0 30px;
	}
}

.page-title {
	max-width: 1500px;
	margin: 0 auto;
	color: #fff;
	display: flex;
	flex-flow: column nowrap;
	justify-content: center;
	align-items: center;
}
@media (max-width: 991px) {
	.page-title {
		padding: 15px;
	}
}

#page-bg h2 {
	font-size: 36px;
	line-height: 1;
	text-align: center;
	color: #fff;
	font-weight: 700;
	border-bottom: 1px solid #fff;
	padding-bottom: 20px;
	margin-bottom: 20px;
}
@media (max-width: 991px) {
	#page-bg h2 {
		font-size: 24px;
		padding-bottom: 15px;
		margin-bottom: 15px;
	}
}

.h2-lead {
	font-size: 30px;
	text-align: center;
	font-weight: 700;
	line-height: 0.75;
}
@media (max-width: 991px) {
	.h2-lead {
		font-size: 18px;
	}
}

.h2-sublead {
	font-size: 18px;
	text-align: center;
}
@media (max-width: 991px) {
	.h2-sublead {
		font-size: 16px;
	}
}

.h2-sublead .en {
	letter-spacing: 0.1em;
	text-indent: 0.1em;
}

.breadcrumb {
	background: transparent;
	font-size: 12px;
	padding: 15px 0;
}
.ot-link {
	position: relative;
	padding-left: 30px;
	color: #0779bf;
	font-weight: 700;
	text-decoration: none;
	transition: 0.6s;
}
.ot-link:hover {
	transition: 0.6s;
	color: #d83f00 !important;
}
.ot-link:before {
	position: absolute;
	width: 20px;
	transition: 0.6s;
	content: "";
	background: url(../images/corp/icon_link.png) no-repeat center top/ cover;
	background-size: 100% auto;
	height: 20px;
	left: 5px;
	top: -2px;
}
.ot-link:hover:before {
	position: absolute;
	width: 20px;
	transition: 0.6s;
	content: "";
	background: url(../images/corp/icon_link_h.png) no-repeat center top/ cover;
	background-size: 100% auto;
	height: 20px;
	left: 5px;
	top: -2px;
}
.ot-link:after {
	position: absolute;
	width: 0;
	transition: 0.6s;
	content: "";
	background-color: #d83f00;
	height: 1px;
	bottom: 0;
	left: 30px;
}
.ot-link:hover:after {
	position: absolute;
	width: calc(100% - 30px);
	transition: 0.6s;
	content: "";
	background-color: #d83f00;
	height: 1px;
	bottom: 0;
	left: 30px;
}

/* title */
[class*="tit-level"] {
}
[class*="tit-level"]:first-child {
	margin-top: 0;
}
[class*="tit-level"]:last-child {
	margin-bottom: 0;
}
hr + [class*="tit-level"] {
	margin-top: 20px;
}

.tit-level1 {
	font-size: 28px;
	line-height: 1.25;
	font-weight: 700;
	position: relative;
	margin-bottom: 45px;
	padding-bottom: 16px;
	display: flex;
	flex-flow: column nowrap;
	justify-content: center;
}
@media (max-width: 991px) {
	.tit-level1 {
		font-size: 18px;
		padding-bottom: 15px;
	}
}

.tit-level1::before {
	background-image: linear-gradient(to right, #0779bf 0%, #0779bf 50%, #333 50%, #333 100%);
	width: 3em;
	height: 3px;
	position: absolute;
	left: 0%;
	bottom: 0;
	margin: 0;
	display: block;
	content: "";
}

.tit-level1.align-items-center {
	align-items: center;
}
.tit-level1.align-items-center::before {
	left: 50%;
	right: 50%;
	margin: 0 -1.5em;
}

.tit-level1:first-letter {
	color: #0779bf;
}

.tit-level2 {
	border-bottom: 1px dotted #666;
	font-size: 20px;
	line-height: 1.5;
	font-weight: 700;
	text-align: left;
	margin: 30px 0 20px;
	padding-bottom: 9px;
	position: relative;
}
@media (max-width: 991px) {
	.tit-level2 {
		font-size: 16px;
		margin: 10px 0 5px;
		padding-bottom: 5px;
	}
}

.tit-level2b {
	padding-left: 10px;
	border-left: 3px solid #0779bf;
	font-size: 18px;
	line-height: 1.5;
	font-weight: 700;
	text-align: left;
	margin: 10px 0 30px!important;
	padding-bottom: 9px;
	position: relative;
}
@media (max-width: 991px) {
	.tit-level2b {
		font-size: 16px;
		margin: 10px 0 25px!important;
		padding-bottom: 5px;
	}
}


.tit-level3 {
	line-height: 1.25;
	position: relative;
	border-left: 3px solid #0779bf;
	font-size: 18px;
	margin: 20px 0 15px;
	padding-left: 10px;
	font-weight: 700;
	text-align: left;
}
@media (max-width: 991px) {
	.tit-level3 {
		font-size: 15px;
		margin: 20px 0 10px;
		padding-left: 10px;
	}
}

.tit-level4 {
	text-align: left;
	font-size: 20px;
	font-weight: 700;
	margin-bottom: 30px;
	color: #000;
	line-height: 1.7;
}
.tit-level4 span {
	font-size: 42px;
	color: #000;
}
@media only screen and (max-width: 991px) {
	.tit-level4 {
		font-size: 28px;
		font-weight: 700;
		margin-bottom: 15px;
	}
	.tit-level4 span {
		display: block;
		font-size: 20px;
	}
}

.tit-level5 {
	text-align: left;
	font-size: 32px;
	font-weight: 700;
	color: #9f3434;
	margin-bottom: 30px;
}
@media only screen and (max-width: 991px) {
	.tit-level5 {
		font-size: 21px;
		font-weight: 700;
		margin-bottom: 15px;
	}
}

/* advantage */
.advantage-introduction {
	position: relative;
}
@media (max-width: 991px) {
	.advantage-introduction {
		padding-bottom: 90vw;
	}
}

.advantage-introduction::before {
	background: linear-gradient(to right, #fff 0%, transparent 50%), url(../images/advantage/advantage01.jpg) center center / cover no-repeat;
	position: absolute;
	top: 0;
	left: 50%;
	right: 0;
	bottom: 0;
	content: "";
}
@media (max-width: 991px) {
	.advantage-introduction::before {
		background: linear-gradient(to bottom, #fff 0%, transparent 50%), url(../images/advantage/advantage01.jpg) center center / cover no-repeat;
		top: calc(100% - 75vw);
		left: 0;
		right: 0;
		bottom: 0;
	}
}

.page-shortcut {
	display: block;
	position: relative;
}
.page-shortcut-image {
	overflow: hidden;
}
.page-shortcut-image img {
	width: 100%;
	height: auto;
}
a.page-shortcut .page-shortcut-image img {
	scale: 1;
	transition: scale 0.3s;
	opacity: 1;
}
a.page-shortcut:hover .page-shortcut-image img,
a.page-shortcut:active .page-shortcut-image img,
a.page-shortcut:focus .page-shortcut-image img {
	scale: 1.05;
	transition: scale 0.6s;
	opacity: 1;
}
.page-shortcut h4 {
	color: #fff;
	font-size: 24px;
	font-weight: 700;
	margin: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
a.page-shortcut h4 {
	background-color: rgba(0, 0, 0, 0.5);
	transition: background-color 0.6s;
}
a.page-shortcut:hover h4,
a.page-shortcut:active h4,
a.page-shortcut:focus h4 {
	background-color: rgba(0, 0, 0, 0.25);
	transition: background-color 0.6s;
}

/* item */
a.btn-category,
a.btn-category:hover,
a.btn-category:active,
a.btn-category:focus {
	background-color: #0779bf;
	color: #fff;
	border: 1px solid #0779bf;
	font-size: 20px;
	line-height: 2;
	margin: 0 auto;
	padding: 10px 15px;
	position: relative;
	display: block;
}

a.box-link,
a.box-link:hover,
a.box-link:hover,
a.box-link:hover {
	background-color: #fff;
	color: #333;
	width: 100%;
	height: 100%;
	display: block;
}
a.box-link {
	box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.1);
}
a.box-link:hover,
a.box-link:hover,
a.box-link:hover {
	box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.2);
}
.box-link-title {
	background-color: #efefef;
	display: flex;
}
.box-link-title-image {
	flex: 0 0 25%;
}
.box-link-title-image {
	flex: 0 0 25%;
}

.image-fit-cover {
	width: 100%;
	overflow: hidden;
	display: block;
	position: relative;
	padding-bottom: 66.6666666666%;
}
.image-fit-cover img {
	object-fit: cover;
	max-width: inherit;
	max-height: inherit;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

.image-fit-contain {
	background-color: #f5f5f5;
	width: 100%;
	overflow: hidden;
	display: block;
	position: relative;
	padding-bottom: 66.6666666666%;
}
.image-fit-contain img {
	object-fit: contain;
	max-width: inherit;
	max-height: inherit;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

.box-link-title-text {
	font-size: 20px;
	line-height: 1.5;
	margin: 0;
	padding: 20px;
	display: flex;
	align-items: center;
	flex: 0 0 75%;
}
.box-link-spec {
	padding: 3px;
}
.box-link-spec table {
	border-spacing: 2px;
}
.box-link-spec th,
.box-link-spec td {
	line-height: 1.5;
}
.box-link-spec th {
	background-color: #ddd;
	text-align: center;
	width: 5em;
}
.box-link-spec td {
	background-color: #f5f5f5;
}
.box-link-body {
	padding: 20px;
}

/* item-detail */
a.btn-download,
a.btn-download:hover,
a.btn-download:active,
a.btn-download:focus {
	background-color: #fff;
	color: #0779bf;
	border: 1px solid #0779bf;
	font-size: 16px;
	line-height: 2;
	margin: 0 auto;
	padding: 10px 15px;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
}
a.btn-download svg,
a.btn-download:hover svg,
a.btn-download:active svg,
a.btn-download:focus svg {
	margin-right: 0.25em;
}
a.btn-estimate,
a.btn-estimate:hover,
a.btn-estimate:active,
a.btn-estimate:focus {
	background-color: #0779bf;
	color: #fff;
	border: 1px solid #0779bf;
	font-size: 16px;
	line-height: 2;
	margin: 0 auto;
	padding: 10px 15px;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
}
a.btn-estimate svg,
a.btn-estimate:hover svg,
a.btn-estimate:active svg,
a.btn-estimate:focus svg {
	margin-right: 0.5em;
}
.table-fit-width {
	margin: -5px;
}
@media only screen and (max-width: 991px) {
	.table-fit-width {
		margin: 5px -5px;
	}
}
.item-price {
	border-spacing: 5px;
}
.item-price th,
.item-price td {
	text-align: center;
	line-height: 1.5;
}
.item-price th {
	background-color: #ddd;
	width: 10em;
}
@media only screen and (max-width: 991px) {
	.item-price th {
		width: 7em;
	}
}

.item-price td {
	background-color: #f5f5f5;
	font-weight: 700;
}

/* rental */
.row-reverse {
	flex-direction: row-reverse;
}

.rental-advantage::before {
	background-color: #0779bf;
	padding-bottom: 100%;
	width: 100%;
	display: block;
	content: "";
}
.rental-advantage p {
	color: #fff;
	font-size: 16px;
	font-weight: 700;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}

.list-check {
	list-style: none;

	padding-left: 1.5em;
}
.list-check li::before {
	font-family: "Font Awesome\ 5 Pro";
	font-weight: 900;
	margin-left: -1.5em;
	width: 1.5em;
	display: inline-block;
	content: "\f00c";
}

.spec-table {
	border-spacing: 5px;
}
.spec-table th,
.spec-table td {
	line-height: 1.5;
}
.spec-table th {
	background-color: #ddd;
	width: 10em;
}
@media only screen and (max-width: 991px) {
	.spec-table th {
		width: 7em;
	}
}

.spec-table td {
	background-color: #f5f5f5;
	font-weight: 700;
}

/* kasen */
.kasen-advantage::before {
	background-color: #0779bf;
	padding-bottom: 100%;
	width: 100%;
	display: block;
	content: "";
}
.kasen-advantage-icon {
	margin: 0 auto 15px;
	width: 48px;
}
@media only screen and (max-width: 991px) {
	.kasen-advantage-icon {
		width: 36px;
	}
}
.kasen-advantage-inner {
	color: #fff;
	font-size: 16px;
	font-weight: 700;
	text-align: center;
	display: flex;
	flex-flow: column nowrap;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}

/* company */
.outline-table {
	border-spacing: 5px;
	mix-blend-mode: multiply;
}
.outline-table th,
.outline-table td {
	line-height: 1.5;
}
.outline-table th {
	background-color: #ddd;
	width: 10em;
}
@media only screen and (max-width: 991px) {
	.outline-table th {
		width: 7em;
	}
}

.outline-table td {
	background-color: #f5f5f5;
	font-weight: 700;
}

.outline-grid-certification {
	display: grid;
	grid-template-columns: repeat(1, 15em 11em 1fr);
	mix-blend-mode: multiply;
	grid-gap: 5px;
}
.outline-grid-certification strong,
.outline-grid-certification span {
	display: block;
	line-height: 1.5;
	padding: 7px 1em;
}
.outline-grid-certification strong {
	background-color: #ddd;
	width: 15em;
}
@media only screen and (max-width: 991px) {
	.outline-grid-certification strong {
		width: 7em;
	}
}

.outline-grid-certification span {
	background-color: #f5f5f5;
	font-weight: 700;
}

.outline-grid-achievements {
	width: 100%;
	display: grid;
	grid-template-columns: repeat(1, 15em 1fr);
	mix-blend-mode: multiply;
	grid-gap: 5px;
}
.outline-grid-achievements strong,
.outline-grid-achievements span {
	display: block;
	line-height: 1.5;
	padding: 7px 1em;
}
.outline-grid-achievements strong {
	background-color: #ddd;
	width: 15em;
}
@media only screen and (max-width: 991px) {
	.outline-grid-achievements strong {
		width: 7em;
	}
}

.outline-grid-achievements span {
	background-color: #f5f5f5;
	font-weight: 700;
}

.list-slash {
	display: flex;
	flex-flow: row wrap;
	list-style: none;
}
.list-slash li {
	white-space: nowrap;
}
.list-slash li::after {
	margin: 0 0.33em;
	content: "/";
}
.list-slash li:last-child::after {
	display: none;
}

.outline-grid-blank {
	background-color: transparent !important;
}

/* works */
.works-item,
a.works-item:hover,
a.works-item:active,
a.works-item:focus {
	display: block;
	color: #333;
}
.works-item h4 {
	text-align: left;
	font-size: 20px;
	line-height: 1.5;
	font-weight: 700;
	margin-bottom: 35px;
	position: relative;
}
@media only screen and (max-width: 991px) {
	.works-item h4 {
		font-size: 16px;
		margin-bottom: 15px;
	}
}

.works-table {
	border-spacing: 5px;
	mix-blend-mode: multiply;
}
.works-table th,
.works-table td {
	line-height: 1.5;
}
.works-table th {
	background-color: #ddd;
	width: 10em;
}
@media only screen and (max-width: 991px) {
	.works-table th {
		width: 7em;
	}
}

.works-table td {
	background-color: #f5f5f5;
	font-weight: 700;
}

/* contact */
.contact-phone {
	font-size: 4em;
	text-align: center;
}
.fa-phone {
	rotate: 90deg;
}
.contact-phone [data-action="call"] {
	color: #333;
}

/* よくあるご質問 */
#faq1 {
}
#faq1 .container {
	max-width: 1500px;
	padding: 0;
}

#faq2 {
}
#faq2 .container {
	max-width: 1500px;
	padding: 0;
}

.qabox dd p {
	margin-top: -25px;
}

.qabox + .qabox {
	margin-top: 45px;
}
@media only screen and (max-width: 767px) {
	.qabox + .qabox {
		margin-top: 10px;
	}
}

.qabox {
	position: relative;
	word-wrap: break-word;
	background-color: #fff;
}
@media only screen and (max-width: 991px) {
	.qabox {
	}
}

.qabox dt {
	background-color: #f6f6f6;
	display: block;
	position: relative;
	overflow: hidden;
	font-size: 24px;
	line-height: 30px;
	padding: 45px 0 45px 60px;
	color: #00c1ff;
	font-weight: normal;
}
@media only screen and (max-width: 991px) {
	.qabox dt {
		font-size: 15px;
		line-height: 1.25;
		padding: 15px 0 15px 45px;
	}
}

.qabox dt .container:before {
	content: "Q.";
	display: inline-block;
	width: 60px;
	font-size: 30px;
	margin-left: -50px;
}
@media only screen and (max-width: 991px) {
	.qabox dt .container:before {
		width: 45px;
		margin-left: -45px;
	}
}

.qabox dd {
	background-color: #fff;
	display: block;
	position: relative;
	overflow: hidden;
	padding: 45px 0 45px 60px;
	font-weight: normal;
}
@media only screen and (max-width: 991px) {
	.qabox dd {
		line-height: 1.25;
		padding: 15px 0 15px 45px;
	}
}

.qabox dd .container:before {
	content: "A.";
	display: inline-block;
	width: 60px;
	font-size: 30px;
	margin-left: -50px;
	color: #903;
}
@media only screen and (max-width: 991px) {
	.qabox dd .container:before {
		width: 45px;
		margin-left: -45px;
	}
}

#organization a {
	text-decoration: underline;
	color: #1466e4;
}
#organization a:hover {
	text-decoration: none;
	color: #1466e4;
}

.ss-box h4 {
	background-color: #0779bf;
	padding: 10px;
	color: #fff;
	margin-bottom: 0;
	font-size: 17px;
}

.ss-box a {
	color: #333;
}
.ss-box a:hover {
	color: #333;
}
.ss-box p {
	margin-bottom: 25px;
}

#ssarea h3 {
	color: #000;
	font-size: 38px;
	margin-bottom: 75px;
	font-weight: 700;
	text-align: center;
}
@media only screen and (max-width: 991px) {
	#ssarea h3 {
		font-size: 28px;
		margin-bottom: 45px;
	}
}
#ssarea h3:first-letter {
	color: #0779bf;
}

#ssarea h3 span {
	font-size: 20px;
	color: #333;
	display: block;
	padding-top: 15px;
	font-weight: 700;
}

@media only screen and (max-width: 991px) {
	#ssarea h3 span {
		display: block;
	}
}

#ssarea h4 {
	text-align: left;
	font-size: 16px;
	margin-bottom: 25px;
	font-weight: 700;
	position: relative;
	line-height: 1.7;
}
@media only screen and (max-width: 991px) {
	#ssarea h4 {
		font-size: 16px;
		margin-bottom: 30px;
	}
}

#ssarea a {
	color: #333;
}

.link-txt a {
	text-decoration: underline;
	color: #1466e4;
}
.link-txt a:hover {
	text-decoration: none;
	color: #1466e4;
}

/* 料金プラン */

#plan1 {
}

#plan2 {
}

#plan2 h3 {
	color: #c03;
	font-size: 60px;
	font-weight: 700;
}
@media only screen and (max-width: 991px) {
	#plan2 h3 {
		color: #c03;
		font-size: 26px;
		font-weight: 700;
	}
}

#plan2 h4 {
	text-align: left;
	font-size: 28px;
	font-weight: 700;
	margin-bottom: 30px;
}
@media only screen and (max-width: 991px) {
	#plan2 h4 {
		font-size: 20px;
		font-weight: 700;
		margin-bottom: 15px;
	}
}

#plan2 h4:first-letter {
	color: #c03;
	text-align: left;
	font-size: 60px;
	font-weight: 700;
	margin-bottom: 30px;
	margin-right: 10px;
}
@media only screen and (max-width: 991px) {
	#plan2 h4:first-letter {
		font-size: 36px;
		font-weight: 700;
		margin-bottom: 15px;
	}
}

#plan2-copy img {
}
@media only screen and (max-width: 991px) {
	#plan2-copy img {
		width: 290px;
		height: auto;
	}
}

#plan2 .lead {
	font-size: 30px;
	line-height: 36px;
	margin: 30px 0;
}
@media only screen and (max-width: 991px) {
	#plan2 .lead {
		font-size: 21px;
		line-height: 27px;
		margin: 15px 0;
	}
}

#arrow1-1 {
	background: url(../images/plan/bg-flow1.jpg) center center / cover no-repeat #fff;
	height: 310px;
	padding-top: 30px;
	padding-bottom: 60px;
}
@media only screen and (max-width: 991px) {
	#arrow1-1 {
		background: url(../images/plan/bg-arrow1-sp.jpg) center center / cover no-repeat #fff;
		padding-bottom: 90%;
	}
}

#arrow1-2 {
	background: url(../images/plan/bg-arrow2.jpg) center center / cover no-repeat #fff;
	height: 310px;
	padding-top: 30px;
	padding-bottom: 60px;
}
@media only screen and (max-width: 991px) {
	#arrow1-2 {
		background: url(../images/plan/bg-arrow2-sp.jpg) center center / cover no-repeat #fff;
		padding-bottom: 90%;
	}
}

#arrow1-3 {
	background: url(../images/plan/bg-arrow3.jpg) center center / cover no-repeat #fff;
	height: 310px;
	padding-top: 30px;
	padding-bottom: 60px;
}
@media only screen and (max-width: 991px) {
	#arrow1-3 {
		background: url(../images/plan/bg-arrow3-sp.jpg) center center / cover no-repeat #fff;
		padding-bottom: 90%;
	}
}

#arrow1-4 {
	background: url(../images/plan/bg-arrow4.jpg) center center / cover no-repeat #fff;
	height: 310px;
	padding-top: 30px;
	padding-bottom: 60px;
}
@media only screen and (max-width: 991px) {
	#arrow1-4 {
		background: url(../images/plan/bg-arrow4-sp.jpg) center center / cover no-repeat #fff;
		padding-bottom: 90%;
	}
}

#arrow1-5 {
	background: url(../images/plan/bg-arrow5.jpg) center center / cover no-repeat #fff;
	height: 310px;
	padding-top: 30px;
	padding-bottom: 60px;
}
@media only screen and (max-width: 991px) {
	#arrow1-5 {
		background: url(../images/plan/bg-arrow5-sp.jpg) center center / cover no-repeat #fff;
		padding-bottom: 90%;
	}
}

#plan3 {
}
#plan3 h3 {
	border-bottom: 1px solid #ddd;
	padding-bottom: 19px;
	margin-bottom: 30px;
}
@media only screen and (max-width: 991px) {
	#plan3 h3 {
		font-size: 21px;
		margin-bottom: 15px;
		padding-bottom: 9px;
	}
}

#plan3 h4 {
	border-bottom: 1px solid #ddd;
	text-align: left;
	padding-bottom: 19px;
	font-size: 24px;
	margin-bottom: 30px;
}
@media only screen and (max-width: 991px) {
	#index3 h3 {
		font-size: 21px;
		margin-bottom: 15px;
		padding-bottom: 9px;
	}
}

#plan3 h4 small {
	display: block;
	font-size: 12px;
	margin-bottom: 10px;
}
@media only screen and (max-width: 991px) {
	#plan3 h3 small {
		font-size: 10px;
		margin-bottom: 5px;
	}
}

.tit-mini {
	color: #666;
}
.tit-light {
	color: #0093d3;
	position: relative;
}
.tit-standard {
	color: #f4e603;
}
.tit-advance {
	color: #cc006b;
}

#plan3 .balloon {
	width: 50px;
	height: 48px;
	text-align: center;
	font-size: 12px;
	line-height: 14px;
	padding: 7px 5px 10px;
	position: absolute;
	left: 180px;
	bottom: 10px;
	display: block;
}
@media only screen and (max-width: 991px) {
	#plan3 .balloon {
		left: 150px;
		bottom: 5px;
	}
}

.plan-tb {
	width: 100%;
}
.plan-tb th,
.plan-tb td {
	border-bottom: 1px solid #ddd;
	padding: 10px;
}
@media only screen and (max-width: 991px) {
	.plan-tb th,
	.plan-tb td {
		display: block;
	}
}

.plan-tb th {
	font-weight: normal;
	white-space: normal;
}
.plan-tb th span {
	font-weight: 700;
	font-size: 18px;
}
.plan-tb td {
	color: #333;
	font-weight: 700;
	font-size: 16px;
	text-align: right;
}

.plan-tb.total td {
	font-size: 30px;
}
.plan-tb.total td small {
	font-size: 14px;
}

#ban_web {
	background: url(../images/common/ban_web.jpg) center center / cover no-repeat #00c1ff;
	color: #fff;
}
@media only screen and (max-width: 991px) {
	#ban_web {
		background: url(../images/common/ban_web-sp.jpg) center center / cover no-repeat;
	}
}

#ban_web h2 {
	color: #fff;
	text-align: left;
	font-size: 60px;
	font-weight: 700;
	margin-bottom: 30px;
}
@media only screen and (max-width: 991px) {
	#ban_web h2 {
		font-size: 29px;
		font-weight: 700;
		margin-bottom: 15px;
	}
}

.ban_web-copy img {
}
@media only screen and (max-width: 991px) {
	.ban_web-copy img {
		width: 290px;
		height: auto;
	}
}

#ban_web .lead {
	font-size: 30px;
	line-height: 36px;
	margin: 30px 0;
}
@media only screen and (max-width: 991px) {
	#ban_web .lead {
		font-size: 21px;
		line-height: 27px;
		margin: 15px 0;
	}
}

.check {
	list-style: none;
}
.check li {
	font-size: 18px;
	line-height: 48px;
	padding-left: 45px;
	padding-left: 48px;
	position: relative;
}
@media (max-width: 991px) {
	.check li {
		font-size: 16px;
		line-height: 24px;
		padding-left: 24px;
	}
}

.check li:before {
	content: "";
	background: url(../images/common/checkmark.png) left center / 30px no-repeat;
	width: 30px;
	height: 48px;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
}
@media (max-width: 991px) {
	.check li:before {
		width: 30px;
		height: 24px;
		background-size: 20px;
	}
}

.comment {
	font-size: 18px;
	line-height: 48px;
	padding-left: 45px;
	padding-left: 48px;
	position: relative;
}
@media (max-width: 991px) {
	.check li {
		font-size: 14px;
		line-height: 24px;
		padding-left: 24px;
		padding-bottom: 10px;
	}
}

/* contact,inquiry,entry,estimate */
/* form control */
/* 以下必須マーク */
.common-tb.frm th.required,
.common-tb2.frm th.required {
	background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NiIgaGVpZ2h0PSIxNCIgdmlld0JveD0iMCAwIDQ2IDE0LjAxIj48dGl0bGU+cmVxdWlyZTwvdGl0bGU+PHJlY3Qgd2lkdGg9IjMyIiBoZWlnaHQ9IjE0IiBzdHlsZT0iZmlsbDojYzAwIi8+PHJlY3QgeD0iMzIiIHk9IjAuMDEiIHdpZHRoPSIxNCIgaGVpZ2h0PSIxNCIgc3R5bGU9ImZpbGw6bm9uZSIvPjxwYXRoIGQ9Ik0xMTcuODgsMTUxLjA5bC0xLjEzLS44NGExMi4yNSwxMi4yNSwwLDAsMCwuNzctMy41OGwxLjI5LjM4QTEzLjkxLDEzLjkxLDAsMCwxLDExNy44OCwxNTEuMDlabTIuOS4yOFYxNTJjMCwuMTgsMCwuMTkuMzIuMTloMS43N2MuNTIsMCwuNjEtLjE0LjY3LTEuOGwxLjM4LjcyYy0uMjksMi4zMy0uNjcsMi4zOS0yLDIuMzloLTIuMTJjLS44OCwwLTEuMzYsMC0xLjM2LS45NXYtLjI3YTkuOCw5LjgsMCwwLDEtMS44LDFsLS43OS0xLjIxYTEwLjcyLDEwLjcyLDAsMCwwLDIuNTktMS40OHYtNC4yNmgxLjMydjMuMzJhMTMuOTEsMTMuOTEsMCwwLDAsMy4xMi01bDEuMzIuODFTMTIzLjM2LDE0OS40MSwxMjAuNzgsMTUxLjM3Wm0xLjQ0LTQuNzZhMTMuMzYsMTMuMzYsMCwwLDAtMi43NS0xLjI5bC43Mi0xLjE1YTEyLjQ3LDEyLjQ3LDAsMCwxLDIuNzUsMS4yMlptMyw0Ljc2YTExLjg0LDExLjg0LDAsMCwwLTEuMTUtMy4yM2wxLjE5LS42N2ExOS41OCwxOS41OCwwLDAsMSwxLjE1LDNaIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMTEwLjU2IC0xNDEuOTEpIiBzdHlsZT0iZmlsbDojZmZmIi8+PHBhdGggZD0iTTEyNy41OSwxNTMuNjZsLS43MS0xLjIzYTcuMDYsNy4wNiwwLDAsMCwyLjg2LTIuNDFsLjg5LDFBNy40Niw3LjQ2LDAsMCwxLDEyNy41OSwxNTMuNjZabS4yNi02LjMyLS43My0xLjJhNi42NCw2LjY0LDAsMCwwLDIuMzgtMS45NWwuODcuOTNBNy42OCw3LjY4LDAsMCwxLDEyNy44NSwxNDcuMzRabTAsMy0uNzUtMS4yYTcuMiw3LjIsMCwwLDAsMi41My0ybC44NCwxQTcuNjEsNy42MSwwLDAsMSwxMjcuODcsMTUwLjMyWm03LjcxLDMuMzNhMTAuODgsMTAuODgsMCwwLDEtMi4yLTFsLjc0LS43M2gtMS43NmwuNzEuNzJhMTEsMTEsMCwwLDEtMi40MiwxLjA3bC0uOC0xLjE3YTkuNjUsOS42NSwwLDAsMCwxLjk0LS42MmgtMXYtNS41OUgxMzJhMi43NiwyLjc2LDAsMCwwLC4yOC0uNTRoLTEuODd2LTEuMTloNS43N3YxLjE5aC0yLjQxYTIuMjMsMi4yMywwLDAsMS0uMjYuNTRoMi4yNHY1LjU5aC0xLjE5YTExLjA3LDExLjA3LDAsMCwwLDEuNzYuNjRabS0xLTYuMjhIMTMydi40N2gyLjUzWm0wLDEuNDNIMTMydi40OGgyLjUzWm0wLDEuNDRIMTMydi41aDIuNTNaIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMTEwLjU2IC0xNDEuOTEpIiBzdHlsZT0iZmlsbDojZmZmIi8+PC9zdmc+), url(../images/cmn/bg-dot.jpg);

	background-position: right center, left top;
	background-size: 46px, inherit;
	background-repeat: no-repeat, repeat;
}

span.required-img {
	display: inline-block;
	background: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMiIgaGVpZ2h0PSIxNCIgdmlld0JveD0iMCAwIDMyIDE0Ij48dGl0bGU+cmVxdWlyZS10eHQ8L3RpdGxlPjxyZWN0IHdpZHRoPSIzMiIgaGVpZ2h0PSIxNCIgc3R5bGU9ImZpbGw6I2MwMCIvPjxwYXRoIGQ9Ik0xMTcuODgsMTUxLjA5bC0xLjEzLS44NGExMi4yNSwxMi4yNSwwLDAsMCwuNzctMy41OGwxLjI5LjM4QTEzLjkxLDEzLjkxLDAsMCwxLDExNy44OCwxNTEuMDlabTIuOS4yOFYxNTJjMCwuMTgsMCwuMTkuMzIuMTloMS43N2MuNTIsMCwuNjEtLjE0LjY3LTEuOGwxLjM4LjcyYy0uMjksMi4zMy0uNjcsMi4zOS0yLDIuMzloLTIuMTJjLS44OCwwLTEuMzYsMC0xLjM2LS45NXYtLjI3YTkuOCw5LjgsMCwwLDEtMS44LDFsLS43OS0xLjIxYTEwLjcyLDEwLjcyLDAsMCwwLDIuNTktMS40OHYtNC4yNmgxLjMydjMuMzJhMTMuOTEsMTMuOTEsMCwwLDAsMy4xMi01bDEuMzIuODFTMTIzLjM2LDE0OS40MSwxMjAuNzgsMTUxLjM3Wm0xLjQ0LTQuNzZhMTMuMzYsMTMuMzYsMCwwLDAtMi43NS0xLjI5bC43Mi0xLjE1YTEyLjQ3LDEyLjQ3LDAsMCwxLDIuNzUsMS4yMlptMyw0Ljc2YTExLjg0LDExLjg0LDAsMCwwLTEuMTUtMy4yM2wxLjE5LS42N2ExOS41OCwxOS41OCwwLDAsMSwxLjE1LDNaIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMTEwLjU2IC0xNDEuOTEpIiBzdHlsZT0iZmlsbDojZmZmIi8+PHBhdGggZD0iTTEyNy41OSwxNTMuNjZsLS43MS0xLjIzYTcuMDYsNy4wNiwwLDAsMCwyLjg2LTIuNDFsLjg5LDFBNy40Niw3LjQ2LDAsMCwxLDEyNy41OSwxNTMuNjZabS4yNi02LjMyLS43My0xLjJhNi42NCw2LjY0LDAsMCwwLDIuMzgtMS45NWwuODcuOTNBNy42OCw3LjY4LDAsMCwxLDEyNy44NSwxNDcuMzRabTAsMy0uNzUtMS4yYTcuMiw3LjIsMCwwLDAsMi41My0ybC44NCwxQTcuNjEsNy42MSwwLDAsMSwxMjcuODcsMTUwLjMyWm03LjcxLDMuMzNhMTAuODgsMTAuODgsMCwwLDEtMi4yLTFsLjc0LS43M2gtMS43NmwuNzEuNzJhMTEsMTEsMCwwLDEtMi40MiwxLjA3bC0uOC0xLjE3YTkuNjUsOS42NSwwLDAsMCwxLjk0LS42MmgtMXYtNS41OUgxMzJhMi43NiwyLjc2LDAsMCwwLC4yOC0uNTRoLTEuODd2LTEuMTloNS43N3YxLjE5aC0yLjQxYTIuMjMsMi4yMywwLDAsMS0uMjYuNTRoMi4yNHY1LjU5aC0xLjE5YTExLjA3LDExLjA3LDAsMCwwLDEuNzYuNjRabS0xLTYuMjhIMTMydi40N2gyLjUzWm0wLDEuNDNIMTMydi40OGgyLjUzWm0wLDEuNDRIMTMydi41aDIuNTNaIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMTEwLjU2IC0xNDEuOTEpIiBzdHlsZT0iZmlsbDojZmZmIi8+PC9zdmc+) center center / cover no-repeat;
	width: 28px;
	height: 14px;
	vertical-align: baseline;
	margin-right: 5px;
}

.point {
	color: #038fc4;
	text-align: center;
	font-size: 18px;
	margin-bottom: 10px;
}
@media (max-width: 991px) {
	.point {
		font-size: 18px;
	}
}

.point small {
	font-size: 12px;
	display: block;
	color: #333;
}

section#contact-introduction {
	padding: 75px 0 0;
}
.radio + .radio,
.checkbox + .checkbox {
	margin-top: 10px;
}
.form-inline .radio + .radio,
.form-inline .checkbox + .checkbox {
	margin-top: 0;
}

.required-img img {
	width: 32px;
	height: 14px;
	vertical-align: middle;
	margin-right: 0.25em;
}

.pp-scroll {
	height: 200px;
	overflow-y: scroll;
	padding: 28px;
	margin: -28px;
}
@media (max-width: 1199px) {
	.pp-scroll {
		padding: 23px;
		margin: -23px;
	}
}
@media (max-width: 991px) {
	.pp-scroll {
		padding: 13px;
		margin: -13px;
	}
}

.pp-scroll a,
.pp-scroll a:hover,
.pp-scroll a:active,
.pp-scroll a:focus {
	color: #333;
}
.pp-scroll a {
	text-decoration: underline;
}
.pp-scroll a:hover,
.pp-scroll a:active,
.pp-scroll a:focus {
	color: #333;
	text-decoration: none;
}

.pp-scroll > *:last-child {
}
@media (max-width: 991px) {
	.pp-scroll > *:last-child {
		padding-bottom: 13px;
	}
}

.tit-policy {
	padding-bottom: 9px;
	border-bottom: 1px dotted #666;
	font-weight: 700;
	margin: 30px 0 15px;
}
@media (max-width: 991px) {
	.tit-policy {
		font-size: 15px;
		margin: 20px 0 10px;
	}
}

input[type="checkbox"],
input[type="radio"] {
	vertical-align: baseline;
	margin-right: 5px !important;
}
.checkbox input[type="checkbox"],
.checkbox-inline input[type="checkbox"],
.radio input[type="radio"],
.radio-inline input[type="radio"] {
	margin-right: 0.5em;
	margin-top: 6px;
}
.form-inline .checkbox input[type="checkbox"],
.form-inline .radio input[type="radio"] {
	margin-right: 0.5em;
	margin-top: 1px;
}

input {
	font-size: 100%;
	vertical-align: middle;
}

input[type="text"],
input[type="text"]:focus,
input[type="password"],
input[type="password"]:focus,
input[type="tel"],
input[type="tel"]:focus,
input[type="email"],
input[type="email"]:focus,
select,
select:focus,
textarea,
textarea:focus {
	border: 1px solid #ddd;
	border-radius: 4px;
	line-height: normal;
}

input[type="text"],
input[type="password"],
input[type="tel"],
input[type="email"],
textarea {
	padding: 14px;
}
@media (max-width: 991px) {
	input[type="text"],
	input[type="password"],
	input[type="tel"],
	input[type="email"],
	textarea {
		padding: 9px;
	}
}

select {
	padding: 9px 14px;
}
@media (max-width: 991px) {
	select {
		padding: 6px 9px;
	}
}

textarea {
	font-size: 1;
	width: 100%;
	height: 200px;
}

input[type="text"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
	background-color: #f6f6f6;
}

.required input[type="text"],
.required input[type="password"],
.required select,
.required textarea {
	border: 1px solid #ffbaba;
	line-height: normal;
}

.required input[type="text"]:focus,
.required input[type="password"]:focus,
.required textarea:focus {
	background-color: #fff6f6;
	line-height: normal;
}

label {
	margin: 0 1em 0 0;
}

.form-ss {
	width: 80px;
}
.form-s {
	width: 100px;
}
.form-m {
	width: 33%;
	min-width: 240px;
}
.form-l {
	width: 100%;
}
.form-ll {
	width: 100%;
}

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

.list-toggle {
	list-style: none;
	margin-bottom: 15px;
}

.list-toggle-con {
	height: 0;
	overflow: hidden;
}

/* list-toggle */
.list-toggle li:first-child {
	border-top: 1px solid #ccc;
}

.list-toggle li {
	border-bottom: 1px solid #ccc;
	padding-left: 40px;
	position: relative;
}

.list-toggle li:before {
	content: "Q";
	font-weight: 700;
	font-size: 36px;
	line-height: 1;
	position: absolute;
	left: 5px;
	top: 18px;
	color: #0779bf;
}

.list-toggle-a {
	display: block;
	position: relative;
	padding: 14px 40px 14px 10px;
	line-height: 1.6;
	line-height: 1.4;
	font-size: 12px;
	font-size: 1.2rem;
}
.list-toggle-a::after {
	position: absolute;
	display: block;
	content: "";
	background-image: url(../images/recruit/f_arrow.png);
	background-repeat: no-repeat;
	width: 30px;
	height: 30px;
	background-size: 30px 30px;
	margin-left: auto;
	margin-right: auto;
	background-position: 0px 0px;
	top: 50%;
	margin-top: -10px;
	right: 5px;
	-webkit-transition: transform 0.3s ease;
	-moz-transition: transform 0.3s ease;
	-ms-transition: transform 0.3s ease;
	transition: transform 0.3s ease;
}
.list-toggle-a.state-active::after {
	-webkit-transition: transform 0.3s ease;
	-moz-transition: transform 0.3s ease;
	-ms-transition: transform 0.3s ease;
	transition: transform 0.3s ease;
	-webkit-transform: rotate(-180deg);
	-moz-transform: rotate(-180deg);
	-ms-transform: rotate(-180deg);
	transform: rotate(-180deg);
}
.list-toggle a:hover {
	color: #0779bf !important;
}
.list-toggle-con-jquery {
	display: none;
}
.list-toggle-con-jquery.state-active {
	border-bottom: 1px solid #ccc;
}

.list-toggle-con {
	height: 0;
	overflow: hidden;
}
.list-toggle-con.state-active {
}

.list-toggle-con-inner {
	position: relative;
	padding: 15px 10px 15px 10px;
	margin: 10px 0;
	background-color: #f7f7f7;
}

@media print, screen and (min-width: 991px) {
	.list-toggle-a {
		padding: 20px 40px 20px 10px;
		line-height: 1.6;
		font-size: 14px;
		font-size: 1.4rem;
		color: #333;
	}
	.list-toggle-a::after {
		position: absolute;
		display: block;
		content: "";
		background-image: url(../images/common/f_arrow.png);
		background-repeat: no-repeat;
		width: 30px;
		height: 30px;
		background-size: 30px 30px;
		margin-left: auto;
		margin-right: auto;
		background-position: 0px 0px;
		margin-top: -10px;
		right: 10px;
	}

	.list-toggle-con-inner {
		position: relative;
		padding: 20px 10px 20px 10px;
	}
}

dl#questionArea {
	line-height: 1.6;
	margin-bottom: 30px;
}
dl#questionArea dt {
	background: url("../../images/faq/i_question.gif") no-repeat 0 2px;
	padding: 0 0 0 25px;
	font-weight: 700;
	color: #011d73;
	margin-bottom: 20px;
}

dl#questionArea dt:before {
	content: "Q";
	font-size: 24px;
	background-color: #5b4a40;
	color: #fff;
	padding: 2px;
	margin-right: 20px;
	width: 40px;
	height: 40px;
	display: inline-block;
	text-align: center;
}

dl#questionArea dt a {
	color: #5b4a40;
	text-decoration: none;
}
dl#questionArea dt a:hover {
	text-decoration: none;
	color: #231f20;
}
dl#questionArea dd {
	background-color: #fbfbfb;
	border: 1px dotted #cdc8c8;
	padding: 10px;
	color: #5b4a40;
	margin-bottom: 20px;
}

.c-box {
	border: 2px solid #0779bf;
	padding: 30px 60px;
	background-color: #fff;
}
@media print, screen and (max-width: 991px) {
	.c-box {
		border: 2px solid #0779bf;
		padding: 30px 10px;
		background-color: #fff;
	}
}

.joblist table h4 {
	font-size: 16px;
	font-weight: 700;
	margin-bottom: 10px;
	text-align: left;
	border-left: 4px solid #0779bf;
	padding-left: 5px;
}
.joblist table ol,
.joblist table ul {
	padding-left: 20px;
	margin-bottom: 20px;
}

.pick-box{margin-bottom: 20px;}


.paging{text-align:center;margin:30px 0;display:flex;justify-content:center;}
.paging .paging-text,.paging .current	{margin:0 1px;color:#fff;text-decoration:none;text-align:center;padding:0;width:40px;line-height:38px;display:block;font-size:14px;border:1px solid #ddd;}
.paging .paging-text{background:#fff;color:#999;cursor:pointer;}
.paging .paging-text:hover{background:#0779bf;color:#fff;border:1px solid #0779bf;opacity:1;}
.paging .paging-text:first-child,
.paging .paging-text:last-child{width:40px;}

.paging .current{background:#0779bf;color:#fff;border:1px solid #0779bf;}


.pick-box{
	position: relative;
	width: 100%;
	padding: 75% 0 0;
}

.pick-box span{
	position: absolute;
	top: 0;
	left: 0;
	width:100%;
	height: 100%;
	display:block;
	background:#f6f6f6;
}

.pick-box img{
	width:auto;
	height:auto;
	text-align:center;
	max-width:100%;
	max-height: 100%;
	display: block;
	margin-left: auto;
	margin-right: auto;
}

