@charset "UTF-8";

@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,400,500,700,900|Montserrat:200,300,400,500,700|Open+Sans:300,400,600,700|Syncopate:400,700|Roboto:700&display=swap");
/* @import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,400,500,700,900|Montserrat:200,300,400,500,700|Open+Sans:300,400,600,700|Syncopate:400,700&display=swap"); */

/* =============================================
Focus Design
Style Sheet
First Update 2025-02-04
Last  Update 2025-02-04
============================================= */

/* =============================================
#  Foundation
============================================= */

/* ---------------------------------------------
	Reboot
	normalize | MIT License
--------------------------------------------- */
*,
*::before,
*::after {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

html {
	-webkit-tap-highlight-color: rgba(104, 101, 100, 0);
	-webkit-text-size-adjust: 100%;
	font-family: sans-serif;
	line-height: 1.15;
}

article,
aside,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section {
	display: block;
}

[tabindex="-1"]:focus:not(:focus-visible) {
	outline: 0 !important;
}

hr {
	-webkit-box-sizing: content-box;
	box-sizing: content-box;
	height: 0;
	overflow: visible;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin-bottom: 0;
	margin-top: 0;
}

p {
	margin-bottom: 0;
	margin-top: 0;
}

abbr[title],
abbr[data-original-title] {
	border-bottom: 0;
	cursor: help;
	text-decoration: underline;
	-webkit-text-decoration: underline dotted;
	text-decoration: underline dotted;
	-webkit-text-decoration-skip-ink: none;
	text-decoration-skip-ink: none;
}

address {
	font-style: normal;
	line-height: inherit;
	margin-bottom: 0;
}

ol,
ul,
dl {
	margin-bottom: 0;
	margin-top: 0;
}

ol ol,
ul ul,
ol ul,
ul ol {
	margin-bottom: 0;
}

/* dt {
	font-weight: 300;
} */

dd {
	margin-bottom: 0;
	margin-left: 0;
}

blockquote {
	margin: 0;
}

b,
strong {
	font-weight: 500;
}

em {
	font-style: normal;
}

small {
	font-size: 12px;
}

sub,
sup {
	font-size: 11px;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

a {
	background-color: transparent;
	color: #414141;
	text-decoration: none;
}

.mouse a:hover {
	color: #0094c6;
	text-decoration: underline;
}

.mouse a:focus {
	color: #0094c6;
	text-decoration: underline;
}

a:not([href]):not([tabindex]) {
	color: inherit;
	text-decoration: none;
}

.mouse a:not([href]):not([tabindex]):focus {
	color: inherit;
	text-decoration: none;
}

.touch a:not([href]):not([tabindex]):focus {
	color: inherit;
	text-decoration: none;
}

a:not([href]):not([tabindex]):focus {
	outline: 0;
}

pre,
code,
kbd,
samp {
	font-family: sans-serif;
	font-size: 15px;
	font-size: 1.5rem;
}

pre {
	margin-bottom: 0;
	margin-top: 0;
	overflow: auto;
}

img {
	border-style: none;
	vertical-align: middle;
}

svg {
	overflow: hidden;
	vertical-align: middle;
}

table {
	border-collapse: collapse;
}

caption {
	text-align: left;
}

th {
	text-align: inherit;
}

label {
	display: inline-block;
	margin-bottom: 0;
}

button {
	border-radius: 0;
}

button:focus {
	outline: 1px dotted;
	outline: 5px auto -webkit-focus-ring-color;
}

input,
button,
select,
optgroup,
textarea {
	font-family: inherit;
	font-size: 15px;
	line-height: inherit;
	margin: 0;
	outline: none;
}

button,
input {
	overflow: visible;
}

button,
select {
	text-transform: none;
}

select {
	word-wrap: normal;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
	-webkit-appearance: button;
}

button:not(:disabled),
[type="button"]:not(:disabled),
[type="reset"]:not(:disabled),
[type="submit"]:not(:disabled) {
	cursor: pointer;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

input[type="radio"],
input[type="checkbox"] {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	padding: 0;
}

input[type="date"],
input[type="time"],
input[type="datetime-local"],
input[type="month"] {
	-webkit-appearance: listbox;
}

textarea {
	overflow: auto;
	resize: vertical;
}

fieldset {
	border: 0;
	margin: 0;
	min-width: 0;
	padding: 0;
}

legend {
	color: inherit;
	display: block;
	font-size: 23px;
	line-height: inherit;
	margin-bottom: 0;
	max-width: 100%;
	padding: 0;
	white-space: normal;
	width: 100%;
}

progress {
	vertical-align: baseline;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

[type="search"] {
	-webkit-appearance: none;
	outline-offset: -2px;
}

[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

output {
	display: inline-block;
}

summary {
	display: list-item;
}

template {
	display: none;
}

[hidden] {
	display: none !important;
}

::-moz-selection {
	background-color: rgba(187, 187, 187, 0.4);
}

::selection {
	background-color: rgba(187, 187, 187, 0.4);
}

/* ---------------------------------------------
	Base
--------------------------------------------- */
* {
	margin: 0;
	padding: 0;
}

html,
body {
	height: 100%;
	width: 100%;
}

html {
	font-size: 62.5%;
	height: 100%;
	overflow-x: hidden;
	overflow-y: auto;
}

html.scroll-prevent {
	overflow: hidden;
}

body {
	background-color: #fff;
	color: #414141;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 16px;
	height: 100%;
	margin: 0;
	text-align: left;
	-moz-osx-font-smoothing: antialiased;
	-moz-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	-webkit-font-feature-settings: "palt";
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
	font-feature-settings: "palt";
	font-smooth: antialiased;
	font-style: normal;
	font-weight: normal;
	letter-spacing: 0.02em;
	line-height: 1.6;
	text-size-adjust: 100%;
}

body.fixed {
	overflow: hidden;
	position: fixed;
	width: 100%;
}

ul,
ol,
dl {
	padding-left: 0;
}

ul {
	list-style: none;
}

ol {
	list-style: none;
}

header,
footer,
main {
	position: relative;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-transition: -webkit-transform 0.3s;
	transition: -webkit-transform 0.3s;
	transition: transform 0.3s;
	transition: transform 0.3s, -webkit-transform 0.3s;
	will-change: transform;
}

a {
	cursor: pointer;
	display: block;
	font-weight: 300;
	outline: none;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}

a:hover,
a:focus {
	opacity: 0.6;
}

p a {
	color: #686564;
	display: inline-block;
}

p a:hover,
p a:focus {
	text-decoration: underline;
}

div > img {
	display: block;
}

* > img {
	height: auto;
	max-width: 100%;
	outline: none;
	vertical-align: middle;
	width: 100%;
}

img[src$=".svg"],
object[src$=".svg"] {
	/* IE対応 */
	height: auto;
	max-width: 100%;
	width: 100%;
}

a img {
	outline: none;
}

hr {
	border: 0;
	border-top: 1px solid #9e9e9e;
	margin-top: 4em;
}

strong {
	/* font-size: 130%; */
	font-weight: 500;
}

table {
	border-spacing: 0;
	width: 100%;
}

td,
th {
	padding: 0;
	text-align: left;
}

td:last-child,
th:last-child {
	padding-right: 0;
}

input[type="checkbox"],
input[type="radio"] {
	display: inline;
	/* margin: 3px 0.5em; */
}

label {
	cursor: pointer;
}

section {
	margin: 0;
	overflow-x: hidden;
	position: relative;
	width: 100%;
}

/* =============================================
#  Layout
============================================= */

/* ---------------------------------------------
	Main
--------------------------------------------- */
.l-wrapper {
	overflow: hidden;
	/* padding-bottom: 59px; */
	position: relative;
}

main p,
main a,
main ul,
main ol,
main dl {
	line-height: 1.75;
	font-weight: normal;
}

section,
aside {
	padding-bottom: 19.79167vw;
	padding-top: 19.79167vw;
	position: relative;
	z-index: 0;
}

section.margin {
	padding-bottom: 19.79167vw;
	padding-top: 55.20833vw;
}

section.margin::before {
	content: "";
	display: block;
	height: 138px;
	left: 0;
	margin: auto;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 0;
}

section.margin:last-of-type {
	padding-bottom: 30.20833vw;
}

section.margin.u-bg--blu::before {
	background: linear-gradient(180deg, #fff 0, #fff 100px, #e5f4f9 100px, #e5f4f9 100%);
}

section.margin.u-bg--blu + section.margin::before {
	background: linear-gradient(180deg, #e5f4f9 0, #e5f4f9 100px, #fff 100px, #fff 100%);
}

section.margin.u-bg--grn::before {
	background: linear-gradient(180deg, #fff 0, #fff 100px, #f0f7ed 100px, #f0f7ed 100%);
}

section.margin.u-bg--grn + section.margin::before {
	background: linear-gradient(180deg, #f0f7ed 0, #f0f7ed 100px, #fff 100px, #fff 100%);
}

section.margin.u-bg--cyan::before {
	background: linear-gradient(180deg, #fff 0, #fff 100px, #e5f7f5 100px, #e5f7f5 100%);
}

section.margin.u-bg--cyan + section.margin::before {
	background: linear-gradient(180deg, #e5f7f5 0, #e5f7f5 100px, #fff 100px, #fff 100%);
}

section.margin.u-bg--gry::before {
	background: linear-gradient(180deg, #fff 0, #fff 100px, #e5ebee 100px, #e5ebee 100%);
}

section.margin.u-bg--gry + section.margin::before {
	background: linear-gradient(180deg, #f0f0f0 0, #f0f0f0 100px, #fff 100px, #fff 100%);
}

.l-container {
	background-color: transparent;
	margin: auto;
	max-width: 1200px;
	position: relative;
	width: calc(100% - 12vw);
}

.l-content {
	margin: auto;
	max-width: 800px;
	position: relative;
	width: calc(100% - 20vw);
}

.l-container .l-content {
	padding-bottom: 15vw;
	padding-top: 15vw;
}

/* =============================================
#  Object -- Component
============================================= */

/* ---------------------------------------------
	Area -- bottom contact
--------------------------------------------- */
.c-area__contact {
	background-color: rgba(0, 148, 198, 0.95);
	bottom: 0;
	color: #fff;
	display: none;
	height: 60px;
	left: 0;
	padding: 0;
	position: fixed;
	width: 100%;
	z-index: 1;
}

.c-area__contact.on {
	display: block;
}

.c-area__contact .l-container {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.c-area__contact__tel p {
	font-size: 3.54167vw;
	font-weight: 400;
	line-height: 5.3125vw;
	margin-top: -3px;
}

.c-area__contact__tel p span {
	display: block;
	font-size: 80%;
	font-weight: 300;
}

.c-area__contact__tel a {
	color: #fff;
	display: block;
	font-family: "Open Sans", sans-serif;
	font-weight: 500;
	line-height: 1.2;
	margin-top: -0.5em;
	overflow: hidden;
	text-indent: -9999px;
	white-space: normal;
}

/* ---------------------------------------------
	Area -- page link
--------------------------------------------- */

.c-area__pagelink {
	background-color: #69b348;
	padding-bottom: 35px;
	padding-top: 35px;
}

.c-area__pagelink .l-container {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-flow: column wrap;
	flex-flow: column wrap;
}

.c-area__pagelink a {
	background: #fff;
	color: #69b348;
	font-weight: 700;
	height: 5em;
	line-height: 1;
	margin-bottom: 15px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 15px;
	max-width: 450px;
	padding-bottom: 2em;
	padding-top: 2em;
	position: relative;
	text-align: center;
	width: 100%;
}

.c-area__pagelink a::before {
	border-right: 1px solid #69b348;
	border-top: 1px solid #69b348;
	bottom: 0;
	content: "";
	height: 10px;
	margin: auto;
	position: absolute;
	right: 26px;
	top: 0;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	-webkit-transition: right 0.5s;
	transition: right 0.5s;
	width: 10px;
	z-index: 0;
}

.c-area__pagelink a:hover::before {
	right: 20px;
}

/* ---------------------------------------------
	Box -- round corner
--------------------------------------------- */

.c-box__rc {
	background: #fff;
	border: 1px solid #0094c6;
	border-radius: 6px;
}

/* ---------------------------------------------
	Key visual
--------------------------------------------- */
.c-keyvisual {
	-o-background-size: cover;
	-webkit-background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	position: relative;
	width: 100vw;
	z-index: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}
.c-keyvisual__text {
	color: #fff;
	display: block;
	font-weight: bold;
	text-align: center;
	letter-spacing: 0.1em;
	line-height: 1.2;
	width: 100%;
}

.c-keyvisual__text span {
	font-weight: 300;
	display: block;
	letter-spacing: normal;
	margin-top: 0.3em;
}

#features .c-keyvisual {
	background-image: url("../images/keyvisual/features.jpg");
}
#service_guide .c-keyvisual {
	background-image: url("../images/keyvisual/service_guide.jpg");
}
#personal_consultation .c-keyvisual {
	background-image: url("../images/keyvisual/personal_consultation.jpg");
}
#corporate_consultation .c-keyvisual {
	background-image: url("../images/keyvisual/corporate_consultation.jpg");
}
#company .c-keyvisual {
	background-image: url("../images/keyvisual/company.jpg");
}
#about_president .c-keyvisual {
	background-image: url("../images/keyvisual/about_president.jpg");
}
#form .c-keyvisual,
#contact2 .c-keyvisual {
	background-image: url("../images/keyvisual/form.jpg");
}
#contact .c-keyvisual {
	background-image: url("../images/keyvisual/contact.jpg");
}
#news .c-keyvisual {
	background-image: url("../images/keyvisual/news.jpg");
}
#privacy .c-keyvisual {
	background-image: url("../images/keyvisual/privacy.jpg");
}
#column .c-keyvisual {
	background-image: url("../images/keyvisual/column.jpg");
}

@media screen and (min-width: 768px) {
	.c-keyvisual {
		height: 280px;
	}
	.c-keyvisual__text {
		font-size: 32.766px;
		transform: translateY(0.5em);
	}
	.c-keyvisual__text span {
		font-size: 16px;
	}
}
@media screen and (max-width: 767.98px) {
	.c-keyvisual {
		height: 45vw;
	}
	.c-keyvisual__text {
		font-size: 5.734vw;
	}
	.c-keyvisual__text span {
		font-size: 2.8vw;
	}
	#features .c-keyvisual {
		background-image: url("../images/keyvisual/features_sp.jpg");
	}
	#service_guide .c-keyvisual {
		background-image: url("../images/keyvisual/service_guide_sp.jpg");
	}
	#personal_consultation .c-keyvisual {
		background-image: url("../images/keyvisual/personal_consultation_sp.jpg");
	}
	#company .c-keyvisual {
		background-position-x: 39%;
	}
	#about_president .c-keyvisual {
		background-image: url("../images/keyvisual/about_president_sp.jpg");
	}
	#form .c-keyvisual {
		background-image: url("../images/keyvisual/form_sp.jpg");
	}
}

/* ------------------------------
	Button
------------------------------ */
.c-btn {
	display: flex;
	background-color: #fff;
	text-align: center;
	justify-content: center;
	align-items: center;
	font-weight: bold;
	position: relative;
	max-width: 500.4px;
	margin: auto;
	min-height: 60px;
	font-size: 20px;
}
.c-btn::after {
	content: "";
	display: inline-block;
	border-right: 2.2677px solid;
	border-top: 2.2677px solid;
	position: absolute;
	transition: all 0.5s;
	width: 0.6em;
	height: 0.6em;
	right: 1em;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
}
.c-btn:hover::after {
	right: 0.5em;
}
.c-btn.__navy {
	color: #003352;
}
.c-btn.__navy::after {
	border-color: #003352;
}
.c-btn.__orange {
	color: #e97d0d;
}
.c-btn.__orange::after {
	border-color: #e97d0d;
}
.c-btn.__light-blue {
	color: #4997d8;
}
.c-btn.__light-blue::after {
	border-color: #4997d8;
}
.c-btn.__border {
	border: solid 2.8346px;
}
.c-btn.__border.__navy {
	border-color: #003352;
}
.c-btn.__large {
	font-size: 22px;
	min-height: 100px;
	max-width: 594.2021px;
}
.c-btn.__small {
	font-size: 18px;
	min-height: 49.6285px;
	font-weight: normal;
}
.c-btn.__small.__border {
	border-width: 1.1339px;
}
.c-btn[target="_blank"]::after {
	border: none;
}
.c-btn[target="_blank"] span {
	position: relative;
}
.c-btn[target="_blank"] span::after {
	content: "";
	display: "";
	width: 0.768077777777778em;
	height: 0.768077777777778em;
	background-image: url("../images/common/icon_link_blank.svg");
	background-repeat: no-repeat;
	background-size: 100%;
	transform: translateY(-50%) translateX(100%);
	position: absolute;
	top: 50%;
	right: -1em;
	transition: all 0.5s;
}
.c-btn[target="_blank"]:hover span::after {
	transform: translateY(-80%) translateX(130%);
}

/* Button -- 複数カラム
------------------------------ */
.c-btn__wrap {
	display: flex;
	justify-content: space-between;
	column-gap: 2.666666666666667%;
}
.c-btn__wrap .c-btn {
	width: 100%;
	margin: 0;
}
.c-btn__wrap:has(.__large) {
	column-gap: 0.916666666666667%;
}
.c-btn__wrap:has(.__small) {
	column-gap: 1%;
}
/* 子要素が1個だけの場合 */
.c-btn__wrap:not(:has(> .c-btn:nth-of-type(2))) {
	justify-content: center;
	column-gap: normal;
}

@media screen and (min-width: 768px) and (max-width: 1199.98px) {
	.c-btn {
		max-width: 41.7vw;
		min-height: 5vw;
		font-size: 1.667vw;
	}
	.c-btn::after {
		border-right: 0.189vw solid;
		border-top: 0.189vw solid;
	}
	.c-btn.__border {
		border: solid 0.236vw;
	}

	.c-btn.__large {
		font-size: 1.833vw;
		min-height: 8.333vw;
		max-width: 49.517vw;
	}

	.c-btn.__small {
		font-size: 1.5vw;
		min-height: 4.136vw;
	}
	.c-btn.__small.__border {
		border-width: 0.094vw;
	}
}

@media screen and (max-width: 767.98px) {
	.c-btn__wrap {
		display: block;
	}
	.c-btn {
		max-width: none;
		min-height: 10.5vw;
		font-size: 3.5vw;
		border-width: 0.5vw;
	}
	.c-btn::after {
		border-width: 0.5vw;
		width: 0.6em;
		height: 0.6em;
		right: 1em;
	}
	.c-btn + .c-btn {
		margin-top: 4.75vw;
	}
	.c-btn.__small {
		font-size: 3.15vw;
		min-height: 8.685vw;
		width: 48.965vw;
	}
	.c-btn.__border {
		border: solid 0.5vw;
	}
	.c-btn.__small.__border {
		border-width: 0.198vw;
	}
	.c-btn.__small + .c-btn.__small {
		margin-top: 2.75vw;
	}
	.c-btn.__large {
		font-size: 3.85vw;
		min-height: 17.5vw;
		max-width: none;
		width: 80vw;
		margin-left: auto;
		margin-right: auto;
	}
	.c-btn.__large + .c-btn.__large {
		margin-top: 6.75vw;
	}
}

/* ------------------------------
	Button -- more(news)
------------------------------ */

.c-btn__more {
	border: 1px solid rgba(104, 101, 100, 0.5);
	display: none;
	float: right;
	font-size: 13px;
	font-size: 1.3rem;
	height: 3em;
	margin-top: 30px;
	padding-top: 0.5em;
	text-align: center;
	width: 150px;
}

.c-btn__more.active {
	display: block;
}

/* ---------------------------------------------
	table
--------------------------------------------- */
.c-table .c-table__row {
	border-bottom: solid 0.5669px #9e9e9e;
}
@media screen and (max-width: 767.98px) {
	.c-table .c-table__h,
	.c-table .c-table__d {
		display: block;
	}
}

/* ---------------------------------------------
	List -- disc
--------------------------------------------- */

.c-list__disc {
	list-style: none;
	/* margin-bottom: 1.8em; */
	margin-left: 1em;
	/* margin-top: -1.8em; */
	text-indent: -1em;
}

.c-list__disc li::before {
	content: "・";
	margin-right: 0.3em;
	width: 0.5em;
}

/* ---------------------------------------------
	List -- table reader
--------------------------------------------- */

.c-list__tabreader li {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.c-list__tabreader li::after {
	background: radial-gradient(#686564 12%, transparent 0) center/8px 8px;
	content: "";
	-webkit-box-flex: 1;
	-ms-flex: 1 1 auto;
	flex: 1 1 auto;
	height: 8px;
	-webkit-box-ordinal-group: 2;
	-ms-flex-order: 1;
	order: 1;
}

.c-list__tabreader li span:first-of-type {
	padding-right: 8px;
}

.c-list__tabreader li span:last-of-type {
	-webkit-box-ordinal-group: 3;
	-ms-flex-order: 2;
	order: 2;
	padding-left: 8px;
}

/* ------------------------------
	Navigation -- page sub menu
------------------------------ */
.c-pnav {
	background: #003352;
	padding: 1.05em 0 0.9em;
}
.c-pnav .l-container {
	height: 100%;
}
.c-pnav ul {
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-around;
}
.c-pnav ul li {
	border-right: 2.8346px solid #fff;
	text-align: center;
	width: 100%;
}
.c-pnav ul li:first-child {
	border-left: 2.8346px solid #fff;
}
.c-pnav ul li a {
	color: #fff;
	font-weight: bold;
	font-size: 18px;
	line-height: 1.4;
	padding: 0.5em 0.5em 0.8em;
}
@media screen and (max-width: 999.98px) {
	.c-pnav {
		display: none;
	}
}

/* ------------------------------
	Access
------------------------------ */
.c-access {
	margin-top: 89px;
}
.c-access .c-access__address {
	margin-top: 54px;
}
.c-access .c-access__address .c-head__sc {
	letter-spacing: 0.02em;
}
.c-access .c-access__address address {
	font-size: 18px;
	line-height: 1.777777777777778;
	letter-spacing: 0.04em;
	margin-top: 1.27em;
}
.c-access .c-access__address .c-access__annotaion {
	font-size: 16px;
	margin-top: 0.8em;
	margin-bottom: 4.9em;
}
.c-access .c-access__address .c-access__annotaion li {
	font-size: inherit;
	font-weight: 300;
	line-height: 1.4;
}
.c-access .c-access__address .c-access__annotaion li + li {
	margin-top: 0.6em;
}
.c-access .c-access__box {
	padding: 31px 34px 42px;
}
.c-access .c-access__box .txt_wrap {
	font-size: 16px;
	width: 98%;
	margin: auto;
}
.c-access .c-access__box .txt_wrap .txt {
	font-size: 1em;
	line-height: 2;
	margin: 1.3em auto 0;
	letter-spacing: 0.055em;
}
.c-access .c-access__box .txt_wrap .c-access__box__link {
	font-size: 1em;
	margin-top: 0.45em;
	letter-spacing: 0.05em;
	position: relative;
	display: inline-block;
	line-height: 1.2;
}
.c-access .c-access__box .txt_wrap .c-access__box__link::after {
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	background-color: #000;
	position: absolute;
	bottom: 0;
}
.c-access .c-access__box + .c-access__box {
	margin-top: 42px;
}
@media screen and (min-width: 768px) and (max-width: 999.98px) {
	.c-access {
		margin-top: 8.9vw;
	}
	.c-access .c-access__address {
		margin-top: 5.4vw;
	}
	.c-access .c-access__address address {
		font-size: 1.8vw;
	}
	.c-access .c-access__address .c-access__annotaion {
		font-size: 1.6vw;
	}
	.c-access .c-access__box {
		padding: 3.1vw 3.4vw 4.2vw;
	}
	.c-access .c-access__box .txt_wrap {
		font-size: 1.6vw;
	}
	.c-access .c-access__box .txt_wrap .c-access__box__link::after {
		height: 0.1vw;
	}
	.c-access .c-access__box + .c-access__box {
		margin-top: 4.2vw;
	}
}
@media screen and (max-width: 767.98px) {
	.c-access {
		margin-top: 15.75vw;
	}
	.c-access .c-access__address {
		margin-top: 9.5vw;
	}
	.c-access .c-access__address address {
		font-size: 3.15vw;
	}
	.c-access .c-access__address .c-access__annotaion {
		font-size: 2.8vw;
		margin-top: 5vw;
		margin-bottom: 10vw;
	}
	.c-access .c-access__box {
		padding: 5.5vw 5vw;
	}
	.c-access .c-access__box .c-head__bar {
		font-size: 3.85vw;
	}
	.c-access .c-access__box .txt_wrap {
		font-size: 2.8vw;
		line-height: 2;
	}
	.c-access .c-access__box .txt_wrap .txt {
		margin-top: 5.25vw;
		letter-spacing: normal;
		text-align: justify;
	}
	.c-access .c-access__box .txt_wrap .c-access__box__link {
		margin-top: 1em;
	}
	.c-access .c-access__box + .c-access__box {
		margin-top: 5.5vw;
	}
}

/* ---------------------------------------------
	Color Box
--------------------------------------------- */
.c-colorbox .c-colorbox__header {
	text-align: center;
	padding: 36px 31px 31px;
}
.c-colorbox .c-colorbox__header .icon {
	display: inline-block;
	min-height: 71px;
	padding-bottom: 3%;
}
.c-colorbox .c-colorbox__header .icon.icon_personal {
	width: 43.6216px;
}
.c-colorbox .c-colorbox__header .icon.icon_corporate {
	width: 60.7344px;
	transform: translateY(-5px);
}
.c-colorbox .c-colorbox__header .head {
	font-size: 30px;
	letter-spacing: 0.08em;
}
.c-colorbox .c-colorbox__header .head .lang__en {
	display: block;
	font-size: 0.533333333333333em;
	letter-spacing: 0.04em;
	line-height: 1.4;
}
.c-colorbox .c-colorbox__body {
	padding: 38px 36px;
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}
.c-colorbox .c-colorbox__body .head__secondary {
	font-size: 27px;
	font-weight: 500;
	letter-spacing: 0.02em;
	margin-bottom: 0.32em;
	text-align: center;
}
.c-colorbox .c-colorbox__body .txt {
	font-size: 16px;
	line-height: 2.375;
	font-weight: normal;
	letter-spacing: 0.03em;
	flex-grow: 1;
	text-align: center;
}
.c-colorbox .c-colorbox__body .c-colorbox__btnArea {
	margin-top: 36px;
}
@media screen and (min-width: 768px) and (max-width: 1199.98px) {
	.c-colorbox .c-colorbox__header {
		padding: 3vw 2.583vw 2.583vw;
	}
	.c-colorbox .c-colorbox__header .icon {
		min-height: 5.917vw;
	}
	.c-colorbox .c-colorbox__header .icon.icon_personal {
		width: 3.635vw;
	}
	.c-colorbox .c-colorbox__header .icon.icon_corporate {
		width: 5.061vw;
		transform: translateY(-0.417vw);
	}
	.c-colorbox .c-colorbox__header .head {
		font-size: 2.5vw;
	}
	.c-colorbox .c-colorbox__body {
		padding: 3.167vw 3vw;
	}
	.c-colorbox .c-colorbox__body .head__secondary {
		font-size: 2.25vw;
	}
	.c-colorbox .c-colorbox__body .txt {
		font-size: 1.333vw;
	}
	.c-colorbox .c-colorbox__body .c-colorbox__btnArea {
		margin-top: 3vw;
	}
}
@media screen and (min-width: 768px) {
	.c-colorbox__wrap {
		display: flex;
		column-gap: 3.166666666666667%;
		justify-content: space-around;
	}
	.c-colorbox__wrap > .c-colorbox {
		width: 100%;
		display: flex;
		flex-direction: column;
	}
}
@media screen and (max-width: 767.98px) {
	.c-colorbox + .c-colorbox {
		margin-top: 10.25vw;
	}
	.c-colorbox .c-colorbox__header {
		padding: 6.5vw 5.5vw 5.5vw;
	}
	.c-colorbox .c-colorbox__header .icon {
		min-height: auto;
		padding-bottom: 3.7%;
	}
	.c-colorbox .c-colorbox__header .icon.icon_personal {
		width: 7.634vw;
	}
	.c-colorbox .c-colorbox__header .icon.icon_corporate {
		width: 10.629vw;
	}
	.c-colorbox .c-colorbox__header .head {
		font-size: 5.25vw;
	}
	.c-colorbox .c-colorbox__body {
		padding: 7.875vw 4.75vw 7vw;
	}
	.c-colorbox .c-colorbox__body .head__secondary {
		font-size: 4.725vw;
		margin-bottom: 0.42em;
	}
	.c-colorbox .c-colorbox__body .txt {
		font-size: 3.15vw;
		line-height: 1.833333333333333;
		letter-spacing: normal;
	}
	.c-colorbox .c-colorbox__body .c-colorbox__btnArea {
		margin-top: 9vw;
	}
}

/* ------------------------------
	Annotation
------------------------------ */
.c-annotaion {
	font-size: 16px;
	font-weight: 300;
}
@media screen and (min-width: 768px) and (max-width: 999.98px) {
	.c-annotaion {
		font-size: 1.6vw;
	}
}

/* ---------------------------------------------
	Slider
--------------------------------------------- */

.slick-arrow {
	background: transparent;
	border: none;
	border-bottom: none;
	border-bottom: none !important;
	border-left: none;
	border-left: none !important;
	border-right: 2px solid #0094c6;
	border-top: 2px solid #0094c6;
	height: 20px;
	outline: none !important;
	overflow: hidden;
	position: absolute;
	text-indent: 200%;
	top: 50%;
	white-space: nowrap;
	width: 20px;
	z-index: 1;
}

.slick-arrow.slick-prev {
	left: 1vw;
	-webkit-transform: rotate(-135deg);
	transform: rotate(-135deg);
}

.slick-arrow.slick-next {
	right: 1vw;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

/* ---------------------------------------------
	Heading -- section
--------------------------------------------- */

.c-head__sc {
	letter-spacing: 0.075em;
	text-align: center;
	font-size: 24px;
}
@media screen and (min-width: 768px) and (max-width: 999.98px) {
	.c-head__sc {
		font-size: 2.4vw;
	}
}
@media screen and (max-width: 767.98px) {
	.c-head__sc {
		font-size: 4.2vw;
	}
}

/* sc__box */
.c-head__sc__box {
	color: #fff;
	font-weight: bold;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1.4;
	letter-spacing: 0.1em;
	font-size: 24px;
	width: 400px;
	min-height: 61px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	top: -30.5px;
}
section:has(.c-head__sc__box) {
	padding-top: 0;
	overflow: visible;
}
@media screen and (min-width: 768px) and (max-width: 999.98px) {
	.c-head__sc__box {
		font-size: 2.4vw;
		width: 40vw;
		min-height: 6.1vw;
		top: -3.05vw;
	}
}
@media screen and (max-width: 767.98px) {
	.c-head__sc__box {
		font-size: 4.2vw;
		width: 70.031vw;
		min-height: 10.5vw;
		top: -5.25vw;
	}
}

/* .c-head__sc.box {
	color: #fff;
	height: 2.4em;
	left: 0;
	letter-spacing: 0.025em;
	line-height: 1;
	margin: auto;
	margin-bottom: 0;
	margin-top: calc(120px - 2.4em);
	overflow: visible;
	padding-top: 0.7em;
	position: absolute;
	right: 0;
	top: 0;
	width: 17em;
	z-index: 0;
	z-index: 1;
}

.c-head__sc.box.blue {
	background: #0094c6;
}

.c-head__sc.box.grn {
	background: #69b348;
}

.c-head__sc.box.cyan {
	background: #00b1a0;
}

.c-head__sc.box.gry {
	background: #686564;
} */

/* ---------------------------------------------
	Heading -- large
--------------------------------------------- */

.c-head__l {
	color: #003352;
	font-size: 6vw;
	font-weight: 400;
	text-align: center;
}

.c-head__l span {
	display: inline-block;
}

/* ---------------------------------------------
	Heading -- middle
--------------------------------------------- */

.c-head__m {
	color: #003352;
	font-size: 21px;
	line-height: 1.4;
}

.c-head__m span {
	display: inline-block;
}

/* ---------------------------------------------
	Heading -- small
--------------------------------------------- */

.c-head__s {
	color: #003352;
	font-size: 18px;
	line-height: 1.4;
	margin-bottom: 0.5em;
	margin-top: 4.5em;
}

.c-head__s span {
	display: inline-block;
}

/* ---------------------------------------------
	Heading -- bar
--------------------------------------------- */
.c-head__bar {
	font-size: 22px;
	border-bottom: 1px solid #003352;
	padding-bottom: 0.65em;
}
.c-head__bar:has(.icon) {
	display: flex;
	align-items: center;
	line-height: 1.2;
}
.c-head__bar:has(.icon) .icon {
	width: 3.5em;
}
.c-head__bar:has(.icon) .icon img.icon_car {
	width: 53%;
	margin-left: 0.25em;
}
/* 電車でお越しの方 */
.c-head__bar:has(.icon) .icon img.icon_train {
	width: 50%;
	margin-left: 0.55em;
}
@media screen and (min-width: 768px) and (max-width: 999.98px) {
	.c-head__bar {
		font-size: 2.2vw;
		/* border-bottom: 1px solid #003352; */
	}
}
@media screen and (max-width: 767.98px) {
	.c-head__bar {
		font-size: 4vw;
	}
}

/* ---------------------------------------------
	Heading -- box
--------------------------------------------- */

.c-head__box {
	border: 2px solid #0094c6;
	color: #0094c6;
	font-size: 17px;
	font-size: 1.7rem;
	padding-bottom: 5px;
	padding-top: 5px;
	text-align: center;
}

/* ---------------------------------------------
	Heading -- background color
--------------------------------------------- */

.c-head__bg {
	letter-spacing: 0;
}

.c-head__bg span {
	padding: 0.5em 1em;
}

.c-head__bg.blu span {
	background-color: #e5f4f9;
}

.c-head__bg.cyan span {
	background-color: #e5f7f5;
}

/* ---------------------------------------------
	Heading -- Underline
--------------------------------------------- */
.c-head__underline {
	font-size: 27.66px;
	letter-spacing: 0.075em;
	line-height: 1.65;
	text-decoration: underline;
	text-underline-offset: 0.3em;
	text-decoration-thickness: 2.8346px;
}
@media screen and (min-width: 768px) and (max-width: 999.98px) {
	.c-head__underline {
		font-size: 2.766vw;
	}
}
@media screen and (max-width: 767.98px) {
	.c-head__underline {
		font-size: 4.84vw;
	}
}

/* ---------------------------------------------
	Text -- large
--------------------------------------------- */

.c-text__l {
	color: #0094c6;
	font-size: 5.2vw;
	text-align: center;
}

.c-text__l span {
	display: inline-block;
}

.c-text__l.narrow {
	margin-bottom: 0;
}

/* ---------------------------------------------
	Tag -- border
--------------------------------------------- */

.c-tag span {
	background: #fff;
	border: 1px solid #0094c6;
	display: inline-block;
	font-size: 80%;
	font-weight: 500;
	letter-spacing: 0.01em;
	margin-right: 1em;
	padding-left: 0.5em;
	padding-right: 0.5em;
	text-align: center;
	width: 7em;
}

.c-tag span.grn {
	border-color: #69b348;
	color: #69b348;
}

.c-tag span.cyan {
	border-color: #00b1a0;
	color: #00b1a0;
}

/* ---------------------------------------------
	Tag -- background color
--------------------------------------------- */

.c-tag__bg span {
	background: #0094c6;
	color: #fff;
	display: inline-block;
	font-size: 60%;
	font-weight: 500;
	margin-right: 1em;
	padding-left: 0.5em;
	padding-right: 0.5em;
	text-align: center;
	width: auto;
}

.c-tag__bg span.grn {
	background: #69b348;
}

.c-tag__bg span.cyan {
	background: #00b1a0;
}

/* =============================================
#  Object -- Project
============================================= */

/* ---------------------------------------------
	Case details
--------------------------------------------- */

.p-case_details {
	padding-bottom: 120px;
}

.p-case_details .p-slider {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
}

.p-case_details .p-slider__item {
	background: #fff;
	/* max-width: calc($width-main - 12vw); */
	padding: 4vw 4vw 9vw;
	position: relative;
	width: calc(100% - 6vw);
}

.p-case_details .p-slider__item > p {
	color: #0094c6;
	font-weight: 500;
	margin-bottom: 0;
	text-align: right;
}

.p-case_details__inner {
	border: 1px solid #0094c6;
}

.p-case_details__inner > div {
	border-bottom: 1px solid #0094c6;
	position: relative;
}

.p-case_details__inner > div:last-of-type {
	border-bottom: none;
}

.p-case_details__inner > div:not(.head) {
	padding: 6vw 5vw 4vw;
}

.p-case_details__inner > div:not(.head) h4 {
	background: #0094c6;
	color: #fff;
	display: inline-block;
	font-size: 14px;
	font-size: 1.4rem;
	left: 0;
	line-height: 1;
	padding: 0.5em 1em;
	position: absolute;
	text-align: center;
	top: 0;
	z-index: 0;
}

.p-case_details__inner > div.head {
	border-bottom: 1px solid #0094c6;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	height: auto;
	width: 100%;
}

.p-case_details__inner > div.head h3 {
	background: #e5f4f9;
	color: #0094c6;
	font-family: "Syncopate", sans-serif;
	font-size: 26px;
	font-size: 2.6rem;
	font-weight: 700;
	height: 100%;
	letter-spacing: 0;
	line-height: 1.3;
	padding-top: 10px;
	text-align: center;
	width: 13%;
}

.p-case_details__inner > div.head h3::before {
	content: "CASE .";
	display: block;
	font-size: 30%;
	letter-spacing: -0.1em;
}

.p-case_details__inner > div.head ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	width: 87%;
}

.p-case_details__inner > div.head ul li {
	border-right: 1px solid #0094c6;
	height: 100%;
	padding-left: 2vw;
	padding-right: 2vw;
}

.p-case_details__inner > div.head ul li span {
	display: inline-block;
}

.p-case_details__inner > div.head ul li > span {
	font-size: 70%;
}

.p-case_details__inner > div.head ul li p {
	letter-spacing: 0;
	margin-bottom: 0;
	text-align: right;
}

.p-case_details__inner > div.head ul li:nth-child(1) {
	padding-left: 2vw;
	width: calc((100% - 5em) / 2);
}

.p-case_details__inner > div.head ul li:nth-child(2) {
	width: calc((100% - 5em) / 2);
}

.p-case_details__inner > div.head ul li:nth-child(3) {
	border-right: none;
	width: 5em;
}

.p-case_details__inner > div.data div {
	width: 70%;
}

.p-case_details__inner > div.data div ul {
	margin-bottom: 0;
}

.p-case_details__inner > div.data div ul li span:last-of-type {
	color: #0094c6;
	font-family: "Syncopate", sans-serif;
	font-weight: 700;
}

.p-case_details__inner > div.data p {
	background: #e5f4f9;
	color: #0094c6;
	font-size: 14px;
	font-size: 1.4rem;
	font-weight: 500;
	height: 85px;
	line-height: 1.3;
	padding-top: 10px;
	text-align: center;
	width: 22%;
}

.p-case_details__inner > div.data p span {
	display: block;
	font-family: "Syncopate", sans-serif;
	font-size: 32px;
	font-size: 3.2rem;
	font-weight: 700;
}

.p-case_details__inner > div.photo {
	padding-left: 4vw;
	padding-right: 4vw;
}

.p-case_details__inner > div.photo ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.p-case_details__inner > div.photo li {
	height: 232px;
	padding: 0 1.5% 20px;
	width: auto;
}

.p-case_details__inner > div.photo li img {
	height: 212px;
	width: auto;
}

.p-case_details .slick-arrow {
	top: calc(100% - 80px);
}

.p-case_details .slick-arrow.slick-prev {
	left: 5vw;
}

.p-case_details .slick-arrow.slick-next {
	right: 5vw;
}

.p-case_details__bottom {
	bottom: -20px;
	height: 100px;
	left: 0;
	margin: auto;
	position: absolute;
	right: 0;
	width: 100%;
	z-index: 0;
}

.p-case_details__bottom a {
	color: #0094c6;
	font-weight: 500;
	margin: auto;
	text-align: center;
	width: 16em;
}

/* ---------------------------------------------
	Case
--------------------------------------------- */

.p-case__filter li {
	color: #fff;
	font-weight: 500;
}

.p-case__filter li:nth-child(1) {
	-webkit-box-flex: 1;
	-ms-flex-positive: 1;
	flex-grow: 1;
}

.p-case__filter li:nth-child(2) {
	-webkit-box-flex: 1;
	-ms-flex-positive: 1;
	flex-grow: 1;
}

.p-case__filter li:nth-child(3) {
	-webkit-box-flex: 1;
	-ms-flex-positive: 1;
	flex-grow: 1;
}

.p-case__filter li:hover {
	cursor: pointer;
}

.p-case__list {
	margin: auto;
	min-height: 1000px;
	overflow: hidden;
	position: relative;
}

.p-case__list .item {
	height: 0;
	margin-top: 6vw;
	padding-bottom: 100%;
	position: relative;
	width: 100%;
}

.p-case__list .item a {
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.p-case__list .item p {
	background: #fff;
	border: 2px solid #0094c6;
	color: #0094c6;
	display: block;
	font-family: "Montserrat", sans-serif;
	font-size: 5vw;
	font-weight: 500;
	height: calc(2em - 2px);
	left: 3vw;
	position: absolute;
	text-align: center;
	top: 3vw;
	width: 2em;
	z-index: 0;
}

.p-case__list .item .c-tag__bg {
	margin-top: 0.5em;
}

.p-case__list .item h4 {
	margin-top: 0.5em;
}

/* ---------------------------------------------
	FAQ
--------------------------------------------- */

.p-faq .l-content > div {
	margin-top: 85px;
}

.p-faq .l-content > div:first-of-type {
	margin-top: 0;
}

.p-faq .c-pnav li:nth-child(1) {
	-webkit-box-flex: 3;
	-ms-flex-positive: 3;
	flex-grow: 3;
}

.p-faq .c-pnav li:nth-child(2) {
	-webkit-box-flex: 2;
	-ms-flex-positive: 2;
	flex-grow: 2;
}

.p-faq .c-pnav li:nth-child(3) {
	-webkit-box-flex: 3;
	-ms-flex-positive: 3;
	flex-grow: 3;
}

.p-faq .c-pnav li:nth-child(4) {
	-webkit-box-flex: 2;
	-ms-flex-positive: 2;
	flex-grow: 2;
}

.p-faq .c-pnav li:nth-child(5) {
	-webkit-box-flex: 2;
	-ms-flex-positive: 2;
	flex-grow: 2;
}

.p-faq dl {
	margin-top: 50px;
}

.p-faq dl dt {
	font-weight: 400;
	margin-top: 2em;
	padding-bottom: 0.5em;
	padding-left: 2.5em;
	padding-top: 0.5em;
	position: relative;
}

.p-faq dl dt::before {
	-o-background-size: contain;
	-webkit-background-size: contain;
	background-image: url(../images/faq/icon_q.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	height: 2em;
	left: 0;
	position: absolute;
	top: 5px;
	width: 2em;
	z-index: 0;
}

.p-faq dl dd {
	border-bottom: 1px solid rgba(104, 101, 100, 0.3);
	color: #0094c6;
	font-weight: 400;
	padding-bottom: 2em;
	padding-left: 2.5em;
	padding-top: 0.5em;
	position: relative;
}

.p-faq dl dd::before {
	-o-background-size: contain;
	-webkit-background-size: contain;
	background-image: url(../images/faq/icon_a.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	height: 2em;
	left: 0;
	position: absolute;
	top: 5px;
	width: 2em;
	z-index: 0;
}

/* ---------------------------------------------
	Our service
--------------------------------------------- */

.p-service .c-pnav li:nth-child(1) {
	-webkit-box-flex: 2;
	-ms-flex-positive: 2;
	flex-grow: 2;
}

.p-service .c-pnav li:nth-child(2) {
	-webkit-box-flex: 2;
	-ms-flex-positive: 2;
	flex-grow: 2;
}

.p-service .c-pnav li:nth-child(3) {
	-webkit-box-flex: 2;
	-ms-flex-positive: 2;
	flex-grow: 2;
}

.p-service .c-pnav li:nth-child(4) {
	-webkit-box-flex: 2;
	-ms-flex-positive: 2;
	flex-grow: 2;
}

.p-service .c-pnav li:nth-child(5) {
	-webkit-box-flex: 2;
	-ms-flex-positive: 2;
	flex-grow: 2;
}

.p-service .c-pnav li:nth-child(6) {
	-webkit-box-flex: 2;
	-ms-flex-positive: 2;
	flex-grow: 2;
}

.p-service-about {
	text-align: center;
}

.p-service-about .c-head__l {
	color: #686564;
}

.p-service-about .l-container .l-content {
	margin-top: -30px;
}

.p-service-about .l-container .l-content > .u-img {
	margin-bottom: 12vw;
	max-width: 300px;
	width: 65%;
}

.p-service-about .l-container > .u-img.zero {
	margin-bottom: 120px;
	margin-top: -30px;
	max-width: 1000px;
}

.p-service-merit .c-head__sc span {
	font-family: "Syncopate", sans-serif;
	font-weight: 700;
}

.p-service-merit__point {
	margin-bottom: 14vw;
}

.p-service-merit__point::after {
	background-image: repeating-linear-gradient(90deg, #231815 0px, #231815 1px, #fff 1px, #fff 4px);
	content: "";
	display: block;
	height: 1px;
	margin-bottom: 1.5em;
	margin-left: auto;
	margin-right: auto;
	width: 100%;
}

.p-service-merit__point .item {
	margin-bottom: 50px;
	position: relative;
}

.p-service-merit__point .item::before {
	background-image: repeating-linear-gradient(90deg, #231815 0px, #231815 1px, #fff 1px, #fff 4px);
	content: "";
	display: block;
	height: 1px;
	margin-bottom: 1.5em;
	margin-left: auto;
	margin-right: auto;
	width: 100%;
}

.p-service-merit__point .item h3 {
	-o-background-size: cover;
	-webkit-background-size: cover;
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
	display: block;
	height: 26vw;
	left: 0;
	max-height: 158px;
	max-width: 130px;
	overflow: hidden;
	position: absolute;
	text-indent: 200%;
	top: -4vw;
	white-space: nowrap;
	width: 23vw;
	z-index: 0;
}

.p-service-merit__point .item .box {
	-o-background-size: 22vw auto;
	-webkit-background-size: 22vw auto;
	background-position: right bottom;
	background-repeat: no-repeat;
	background-size: 22vw auto;
}

.p-service-merit__point .item .box .c-head__l {
	line-height: 1.4;
	padding-left: 26vw;
	text-align: left;
}

.p-service-merit__point .item .box p:not(.c-head__l) {
	font-size: 90%;
	margin-bottom: 0;
	padding-right: 22vw;
}

.p-service-merit__point .item:nth-of-type(1) h3 {
	background-image: url("../images/service/icon_medal1.svg");
}

.p-service-merit__point .item:nth-of-type(1) .box {
	background-image: url("../images/service/icon_merit1.svg");
}

.p-service-merit__point .item:nth-of-type(1) .box .c-head__l {
	padding-top: 1em;
}

.p-service-merit__point .item:nth-of-type(2) h3 {
	background-image: url("../images/service/icon_medal2.svg");
}

.p-service-merit__point .item:nth-of-type(2) .box {
	background-image: url("../images/service/icon_merit2.svg");
}

.p-service-merit__point .item:nth-of-type(3) h3 {
	background-image: url("../images/service/icon_medal3.svg");
}

.p-service-merit__point .item:nth-of-type(3) .box {
	background-image: url("../images/service/icon_merit3.svg");
}

.p-service-merit__point .item:nth-of-type(4) h3 {
	background-image: url("../images/service/icon_medal4.svg");
}

.p-service-merit__point .item:nth-of-type(4) .box {
	background-image: url("../images/service/icon_merit4.svg");
}

.p-service-merit__point .item:nth-of-type(5) h3 {
	background-image: url("../images/service/icon_medal5.svg");
}

.p-service-merit__point .item:nth-of-type(5) .box {
	background-image: url("../images/service/icon_merit5.svg");
}

.p-service-merit__point .item:nth-of-type(6) h3 {
	background-image: url("../images/service/icon_medal6.svg");
}

.p-service-merit__point .item:nth-of-type(6) .box {
	background-image: url("../images/service/icon_merit6.svg");
}

.p-service-method .u-img {
	margin-bottom: 12vw;
	max-width: 350px;
	width: 60%;
}

.p-service-cost .u-img {
	margin-bottom: 10vw;
}

.p-service-comparison .c-head__l {
	color: #686564;
}

.p-service-comparison .c-head__l span.u-blk {
	display: inline-block;
	font-weight: 700;
}

.p-service-comparison .c-head__l span.u-blk span {
	font-family: "Syncopate", sans-serif;
	font-weight: 700;
}

.p-service-comparison .u-img {
	margin-bottom: 12vw;
	margin-top: 12vw;
	max-width: 600px;
}

.p-service-howtouse .c-box__rc {
	padding: 50px 30px 0px;
}

.p-service-howtouse .c-box__rc:nth-of-type(1) {
	margin-bottom: 70px;
	margin-top: 70px;
}

.p-service-howtouse__flow {
	border-bottom: 1px solid rgba(104, 101, 100, 0.8);
	margin-bottom: 50px;
	margin-top: 40px;
}

.p-service-howtouse__flow div {
	background-color: #fff;
	border-top: 1px solid rgba(104, 101, 100, 0.8);
	padding-bottom: 20px;
	padding-top: 40px;
	position: relative;
}

.p-service-howtouse__flow div::before {
	background: #fff;
	border-bottom: 1px solid rgba(104, 101, 100, 0.8);
	border-left: 1px solid #fff;
	border-right: 1px solid rgba(104, 101, 100, 0.8);
	border-top: 1px solid #fff;
	content: "";
	display: block;
	height: 19px;
	left: 0;
	margin: auto;
	position: absolute;
	right: 0;
	top: -10px;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	width: 19px;
	z-index: 0;
	z-index: 1;
}

.p-service-howtouse__flow div::after {
	border-color: #f6e11c transparent transparent transparent;
	border-style: solid;
	border-width: 20px 20px 0 20px;
	content: "";
	display: block;
	height: 0;
	left: 0;
	margin: auto;
	position: absolute;
	right: 0;
	top: 0;
	width: 0;
	z-index: 0;
	z-index: 0;
}

.p-service-howtouse__flow div .c-head__m {
	position: relative;
}

.p-service-howtouse__flow div .c-head__m span {
	color: rgba(104, 101, 100, 0.8);
	display: block;
	font-family: "Montserrat", sans-serif;
	font-size: 75%;
	font-weight: 400;
}

.p-service-howtouse__flow div .c-head__m::before {
	bottom: 0;
	color: rgba(178, 223, 238, 0.8);
	content: "1";
	display: block;
	font-family: "Syncopate", sans-serif;
	font-size: 4em;
	height: 1em;
	position: absolute;
	right: 0;
	text-align: center;
	width: 1em;
	z-index: 0;
}

.p-service-howtouse__flow div p {
	margin-bottom: 0.5em;
}

.p-service-howtouse__flow div p:not(.u-note) {
	font-size: 105%;
	font-weight: 500;
	line-height: 1.4;
}

.p-service-howtouse__flow div p:not(.u-note) span {
	display: inline-block;
}

.p-service-howtouse__flow div:nth-of-type(1)::before,
.p-service-howtouse__flow div:nth-of-type(1)::after {
	display: none;
}

.p-service-howtouse__flow div:nth-of-type(1) .c-head__m::before {
	content: "1";
}

.p-service-howtouse__flow div:nth-of-type(2) .c-head__m::before {
	content: "2";
}

.p-service-howtouse__flow div:nth-of-type(3) .c-head__m::before {
	content: "3";
}

.p-service-howtouse__flow div:nth-of-type(4) .c-head__m::before {
	content: "4";
}

.p-service-howtouse__rental {
	border-bottom: 1px solid rgba(104, 101, 100, 0.5);
	padding-bottom: 40px;
	position: relative;
}

.p-service-howtouse__rental .c-head__s {
	color: #686564;
	margin-bottom: 1em;
	margin-top: 3em;
}

.p-service-howtouse__rental .c-text__l {
	line-height: 1.4;
	margin-bottom: 1.5em;
	margin-top: 1em;
	text-align: left;
}

.p-service-howtouse__rental .u-img {
	margin-left: 0;
	margin-top: 1.5em;
	max-width: 500px;
	width: 100%;
}

.p-service-howtouse__rental .u-note span {
	display: inline-block;
}

.p-service-howtouse__rental:nth-of-type(1) .c-head__s + p {
	border: 2px solid #f6e11c;
	font-weight: 500;
	margin-left: 0;
	margin-top: 1.5em;
	max-width: 500px;
	padding: 3px;
	text-align: center;
}

.p-service-howtouse__rental:nth-of-type(1) .c-head__s + p span {
	display: inline-block;
}

.p-service-howtouse__rental:nth-of-type(2) .c-flex__item:nth-of-type(1) .c-text__l {
	margin-bottom: 0.5em;
}

.p-service-howtouse__rental:nth-of-type(2) .c-flex__item:nth-of-type(2) .u-img {
	margin-top: 3em;
}

.p-service-howtouse__rental:nth-of-type(4) {
	border-bottom: none;
	margin-bottom: 30px;
}

.p-service-equipment__list .item {
	margin-left: auto;
	margin-right: auto;
	margin-top: 12vw;
	max-width: 500px;
}

.p-service-equipment__list .item h4 {
	color: #fff;
	font-size: 22px;
	font-size: 2.2rem;
	font-weight: 700;
	line-height: 1.4;
	margin-bottom: 55vw;
	padding-bottom: 4vw;
	padding-top: 4vw;
	position: relative;
	text-align: center;
}

.p-service-equipment__list .item h4 span {
	display: block;
	font-family: "Montserrat", sans-serif;
	font-size: 60%;
	font-weight: 400;
}

.p-service-equipment__list .item h4::after {
	-o-background-size: cover;
	-webkit-background-size: cover;
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
	bottom: -55vw;
	content: "";
	display: block;
	height: 55vw;
	left: 0;
	margin: auto;
	position: absolute;
	right: 0;
	width: 100%;
	z-index: 0;
}

.p-service-equipment__list .item .box {
	padding: 5vw;
}

.p-service-equipment__list .item .box .c-head__m {
	font-weight: 500;
}

.p-service-equipment__list .item .box a {
	background: #fff;
	font-weight: 500;
	padding: 0.5em;
	position: relative;
	text-align: center;
}

.p-service-equipment__list .item .box a::after {
	border-right: 2px solid;
	border-top: 2px solid;
	bottom: 0;
	content: "";
	display: block;
	height: 10px;
	margin: auto;
	position: absolute;
	right: 2em;
	top: 0;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	-webkit-transition: all 0.5s;
	transition: all 0.5s;
	width: 10px;
	z-index: 0;
}

.p-service-equipment__list .item .box a:hover::after {
	right: 1em;
}

.p-service-equipment__list .item:nth-of-type(1) h4 {
	background: #69b348;
}

.p-service-equipment__list .item:nth-of-type(1) h4::after {
	background-image: url("../images/service/led_img.jpg");
}

.p-service-equipment__list .item:nth-of-type(1) .box {
	background: #f0f7ed;
}

.p-service-equipment__list .item:nth-of-type(1) .box .c-head__m {
	color: #69b348;
}

.p-service-equipment__list .item:nth-of-type(1) .box a {
	color: #69b348;
}

.p-service-equipment__list .item:nth-of-type(1) .box a::after {
	border-color: #69b348;
}

.p-service-equipment__list .item:nth-of-type(2) h4 {
	background: #00b1a0;
}

.p-service-equipment__list .item:nth-of-type(2) h4::after {
	background-image: url("../images/service/ac_img.jpg");
}

.p-service-equipment__list .item:nth-of-type(2) .box {
	background: #e5f7f5;
}

.p-service-equipment__list .item:nth-of-type(2) .box .c-head__m {
	color: #00b1a0;
}

.p-service-equipment__list .item:nth-of-type(2) .box a {
	color: #00b1a0;
}

.p-service-equipment__list .item:nth-of-type(2) .box a::after {
	border-color: #00b1a0;
}

/* ---------------------------------------------
	Service01 -- LED
--------------------------------------------- */

.p-service01 .c-pnav {
	background: #69b348;
}

.p-service01 .c-pnav li:nth-child(1) {
	-webkit-box-flex: 2;
	-ms-flex-positive: 2;
	flex-grow: 2;
}

.p-service01 .c-pnav li:nth-child(2) {
	-webkit-box-flex: 3;
	-ms-flex-positive: 3;
	flex-grow: 3;
}

.p-service01 .c-pnav li:nth-child(3) {
	-webkit-box-flex: 2;
	-ms-flex-positive: 2;
	flex-grow: 2;
}

.p-service01 .c-pnav li:nth-child(4) {
	-webkit-box-flex: 2;
	-ms-flex-positive: 2;
	flex-grow: 2;
}

.p-service01 .c-head__l,
.p-service01 .c-text__l {
	color: #69b348;
}

.p-led-merit__point .item {
	margin: auto;
	margin-bottom: 10vw;
	position: relative;
}

.p-led-merit__point .item h3 {
	-o-background-size: contain;
	-webkit-background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	height: 23vw;
	left: -3.5vw;
	overflow: hidden;
	position: absolute;
	text-indent: 200%;
	top: -5vw;
	white-space: nowrap;
	width: 18vw;
	z-index: 0;
}

.p-led-merit__point .item .c-box__rc {
	border-color: #69b348;
	margin-left: 6vw;
	padding: 20px 20px 20px 10vw;
	width: calc(100% - 6vw);
}

.p-led-merit__point .item .c-box__rc .c-head__l {
	line-height: 1.4;
	margin-bottom: 20px;
	margin-top: -7vw;
	text-align: left;
}

.p-led-merit__point .item:nth-of-type(1) h3 {
	background-image: url("../images/led/icon_merit1.svg");
}

.p-led-merit__point .item:nth-of-type(2) h3 {
	background-image: url("../images/led/icon_merit2.svg");
}

.p-led-merit__point .item:nth-of-type(3) h3 {
	background-image: url("../images/led/icon_merit3.svg");
}

.p-led-merit__point .item:nth-of-type(4) h3 {
	background-image: url("../images/led/icon_merit4.svg");
}

.p-led-merit__point .item:nth-of-type(5) h3 {
	background-image: url("../images/led/icon_merit5.svg");
}

.p-led-merit__point + p:last-of-type {
	margin-top: 60px;
}

.p-led-costdown {
	padding-bottom: 0;
}

.p-led-costdown .u-img {
	margin-bottom: 8vw;
	max-width: 1072px;
	text-align: center;
}

.p-led-lineup {
	text-align: center;
}

.p-led-lineup .u-img:nth-of-type(1) {
	margin: -1em auto 2em;
	max-width: 600px;
}

.p-led-lineup .u-img:nth-of-type(1) + p {
	font-weight: 500;
}

.p-led-lineup .u-img:nth-of-type(2) {
	margin-bottom: 12vw;
	max-width: 1050px;
}

.p-led-proposal {
	margin-bottom: -100px;
	text-align: center;
}

.p-led-proposal__photo {
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin: auto;
	margin-bottom: 60px;
	max-width: 700px;
}

.p-led-proposal__photo .u-img {
	height: auto !important;
	margin: 4px;
	width: calc((100% - 24px) / 3);
}

/* ---------------------------------------------
	Service02 -- air conditioner
--------------------------------------------- */

.p-service02 .c-pnav {
	background: #00b1a0;
}

.p-service02 .c-pnav li:nth-child(1) {
	-webkit-box-flex: 1;
	-ms-flex-positive: 1;
	flex-grow: 1;
}

.p-service02 .c-pnav li:nth-child(2) {
	-webkit-box-flex: 1;
	-ms-flex-positive: 1;
	flex-grow: 1;
}

.p-service02 .c-pnav li:nth-child(3) {
	-webkit-box-flex: 1;
	-ms-flex-positive: 1;
	flex-grow: 1;
}

.p-service02 .c-head__l,
.p-service02 .c-text__l {
	color: #00b1a0;
}

.p-service02 .c-area__pagelink {
	background-color: #00b1a0;
}

.p-service02 .c-area__pagelink a {
	color: #00b1a0;
}

.p-service02 .c-area__pagelink a::before {
	border-right-color: #00b1a0;
	border-top-color: #00b1a0;
}

.p-ac-reason .c-head__sc {
	min-width: 17.5em;
}

.p-ac-reason__point .item {
	margin: auto;
	margin-bottom: 10vw;
	position: relative;
}

.p-ac-reason__point .item h3 {
	-o-background-size: contain;
	-webkit-background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	height: 23vw;
	left: -3.5vw;
	overflow: hidden;
	position: absolute;
	text-indent: 200%;
	top: -5vw;
	white-space: nowrap;
	width: 18vw;
	z-index: 0;
}

.p-ac-reason__point .item .c-box__rc {
	border-color: #00b1a0;
	margin-left: 6vw;
	padding: 30px;
	width: calc(100% - 6vw);
}

.p-ac-reason__point .item .c-box__rc > p:nth-of-type(1) {
	line-height: 1.2;
	margin-bottom: 6vw;
	margin-left: 4.5vw;
	width: calc(100% - 20px);
}

.p-ac-reason__point .item .c-box__rc > p:nth-of-type(1) span {
	display: inline-block;
}

.p-ac-reason__point .item .c-box__rc .c-head__l {
	font-size: 5vw;
	letter-spacing: 0;
	line-height: 1.2;
	margin-bottom: 20px;
	margin-left: 4.5vw;
	margin-top: -5vw;
	text-align: left;
	width: calc(100% - 20px);
}

.p-ac-reason__point .item:nth-of-type(1) h3 {
	background-image: url("../images/airconditioner/icon_reason1.svg");
}

.p-ac-reason__point .item:nth-of-type(2) h3 {
	background-image: url("../images/airconditioner/icon_reason2.svg");
}

.p-ac-reason__point .item:nth-of-type(3) h3 {
	background-image: url("../images/airconditioner/icon_reason3.svg");
}

.p-ac-reason__point .item:nth-of-type(3) .c-box__rc div > p:first-of-type {
	line-height: 1.2;
	margin-bottom: 6vw;
	margin-left: 4.5vw;
}

.p-ac-reason__point + p:last-of-type {
	margin-top: 40px;
}

.p-ac-costdown__item {
	border-top: 1px solid rgba(104, 101, 100, 0.3);
	padding-bottom: 50px;
	padding-top: 50px;
	text-align: left;
}

.p-ac-costdown__item div .c-head__l {
	font-size: 5.5vw;
	text-align: left;
}

.p-ac-costdown__item div .c-head__m {
	color: #686564;
	font-weight: 500;
	margin-top: -1em;
}

.p-ac-costdown__item .u-img {
	margin: 50px auto 30px;
	max-width: 500px;
}

.p-ac-costdown__item:nth-of-type(1) {
	border-top: 0;
	padding-top: 0;
}

.p-ac-lineup .l-container {
	margin-bottom: 60px;
}

.p-ac-lineup .c-head__sc {
	min-width: 17em;
}

.p-ac-lineup .c-box__rc {
	border-color: #00b1a0;
	margin-bottom: 40px;
	padding: 30px 30px 0px;
}

.p-ac-lineup .c-box__rc > p {
	letter-spacing: 0;
}

.p-ac-lineup__list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin-bottom: 15px;
}

.p-ac-lineup__list div {
	height: 0;
	padding-bottom: 32%;
	position: relative;
	width: calc(50% - 8px);
}

.p-ac-lineup__list div p {
	bottom: 0;
	font-size: 2.5vw;
	font-weight: 500;
	height: 2em;
	left: 0;
	letter-spacing: 0;
	line-height: 1;
	padding-bottom: 0.5em;
	padding-top: 0.5em;
	position: absolute;
	text-align: center;
	width: 100%;
	z-index: 0;
	z-index: 1;
}

.p-ac-lineup__list.place div {
	margin-bottom: calc(16px + 1em);
}

.p-ac-lineup__list.place p {
	background: #00b1a0;
	bottom: -3em;
	color: #fff;
}

.p-ac-lineup__list.ac {
	margin-top: 0;
}

.p-ac-lineup__list.ac div {
	position: relative;
}

.p-ac-lineup__list.ac div:nth-of-type(2) {
	margin-top: -22%;
	padding-bottom: 55%;
}

.p-ac-lineup__list.ac div:nth-of-type(2) img {
	margin: auto;
	width: 30%;
}

.p-ac-lineup__list.ac div p {
	bottom: -1.5em;
	color: #00b1a0;
	font-weight: 700;
}

.p-ac-lineup__maker {
	border: 2px solid #00b1a0;
	border-radius: 10px;
	margin-top: 40px;
	text-align: center;
	width: 100%;
}

.p-ac-lineup__maker .c-head__bg {
	font-size: 16px;
	font-size: 1.6rem;
	font-weight: 700;
	margin-top: -1em;
}

.p-ac-lineup__maker .c-head__bg span {
	padding-left: 3em;
	padding-right: 3em;
}

.p-ac-lineup__maker ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-flow: row wrap;
	flex-flow: row wrap;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin-top: -20px;
}

.p-ac-lineup__maker ul li {
	height: 0;
	margin: 0 auto 5px;
	max-width: 150px;
	padding-bottom: 10%;
	text-align: center;
	width: calc(100% / 3);
}

.p-ac-lineup__maker ul li img {
	height: auto;
	vertical-align: middle;
	width: 75%;
}

/* =============================================
#  Object -- Utility
============================================= */

/* ---------------------------------------------
	Color
--------------------------------------------- */

.u-bg--wht {
	background-color: #fff;
}
.u-bg--blu {
	background-color: #e6ebee;
}
.u-bg--grn {
	background-color: #f0f7ed;
}
.u-bg--cyan {
	background-color: #e5f7f5;
}
.u-bg--gry {
	background-color: #ececec;
}
.u-blk {
	color: #686564;
}

/* ---------------------------------------------
	Effect
--------------------------------------------- */
.u-hvr:hover,
.u-hvr:hover img {
	opacity: 0.6;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}

/* rectout */
.u-hvr--rectout {
	-webkit-transform: perspective(1px) translateZ(0);
	-webkit-transition-duration: 0.3s;
	-webkit-transition-property: color;
	background-color: transparent;
	-webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
	box-shadow: 0 0 1px rgba(0, 0, 0, 0);
	display: inline-block !important;
	position: relative;
	transform: perspective(1px) translateZ(0);
	transition-duration: 0.3s;
	transition-property: color;
	vertical-align: middle;
	z-index: 0;
}

.u-hvr--rectout::after {
	-webkit-transform: scale(0);
	-webkit-transition-duration: 0.3s;
	-webkit-transition-property: transform;
	-webkit-transition-timing-function: ease-out;
	background-color: #0094c6;
	/* background-color: rgba(0, 51, 82, 0.1); */
	bottom: 0;
	content: "";
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	transform: scale(0);
	transition-duration: 0.3s;
	-webkit-transition-property: -webkit-transform;
	transition-property: -webkit-transform;
	transition-property: transform;
	transition-property: transform, -webkit-transform;
	transition-timing-function: ease-out;
	z-index: -1;
}

.u-hvr--rectout:hover,
.u-hvr--rectout:focus,
.u-hvr--rectout:active {
	color: #fff;
}

.u-hvr--rectout:hover::after,
.u-hvr--rectout:focus::after,
.u-hvr--rectout:active::after {
	-webkit-transform: scale(1);
	transform: scale(1);
}

.u-hvr--rectout.w::after {
	background-color: #fff;
}

.u-hvr--rectout.w:hover,
.u-hvr--rectout.w:focus,
.u-hvr--rectout.w:active {
	color: #0094c6;
}

/* ---------------------------------------------
	Margin
--------------------------------------------- */

.u-mb1 {
	margin-bottom: 1rem;
}

.u-ml1 {
	margin-left: 1rem;
}

.u-mr1 {
	margin-right: 1rem;
}

.u-mt1 {
	margin-top: 1rem;
}

.u-mb2 {
	margin-bottom: 2rem;
}

.u-ml2 {
	margin-left: 2rem;
}

.u-mr2 {
	margin-right: 2rem;
}

.u-mt2 {
	margin-top: 2rem;
}

.u-mb3 {
	margin-bottom: 3rem;
}

.u-ml3 {
	margin-left: 3rem;
}

.u-mr3 {
	margin-right: 3rem;
}

.u-mt3 {
	margin-top: 3rem;
}

.u-mb4 {
	margin-bottom: 4rem;
}

.u-ml4 {
	margin-left: 4rem;
}

.u-mr4 {
	margin-right: 4rem;
}

.u-mt4 {
	margin-top: 4rem;
}

.u-mb5 {
	margin-bottom: 5rem;
}

.u-ml5 {
	margin-left: 5rem;
}

.u-mr5 {
	margin-right: 5rem;
}

.u-mt5 {
	margin-top: 5rem;
}

.u-mb6 {
	margin-bottom: 6rem;
}

.u-ml6 {
	margin-left: 6rem;
}

.u-mr6 {
	margin-right: 6rem;
}

.u-mt6 {
	margin-top: 6rem;
}

.u-mb7 {
	margin-bottom: 7rem;
}

.u-ml7 {
	margin-left: 7rem;
}

.u-mr7 {
	margin-right: 7rem;
}

.u-mt7 {
	margin-top: 7rem;
}

.u-mb8 {
	margin-bottom: 8rem;
}

.u-ml8 {
	margin-left: 8rem;
}

.u-mr8 {
	margin-right: 8rem;
}

.u-mt8 {
	margin-top: 8rem;
}

.u-mb9 {
	margin-bottom: 9rem;
}

.u-ml9 {
	margin-left: 9rem;
}

.u-mr9 {
	margin-right: 9rem;
}

.u-mt9 {
	margin-top: 9rem;
}

.u-mb10 {
	margin-bottom: 10rem;
}

.u-ml10 {
	margin-left: 10rem;
}

.u-mr10 {
	margin-right: 10rem;
}

.u-mt10 {
	margin-top: 10rem;
}

/* ---------------------------------------------
	Padding
--------------------------------------------- */

.u-pb1 {
	padding-bottom: 1rem;
}

.u-pl1 {
	padding-left: 1rem;
}

.u-pr1 {
	padding-right: 1rem;
}

.u-pt1 {
	padding-top: 1rem;
}

.u-pb2 {
	padding-bottom: 2rem;
}

.u-pl2 {
	padding-left: 2rem;
}

.u-pr2 {
	padding-right: 2rem;
}

.u-pt2 {
	padding-top: 2rem;
}

.u-pb3 {
	padding-bottom: 3rem;
}

.u-pl3 {
	padding-left: 3rem;
}

.u-pr3 {
	padding-right: 3rem;
}

.u-pt3 {
	padding-top: 3rem;
}

.u-pb4 {
	padding-bottom: 4rem;
}

.u-pl4 {
	padding-left: 4rem;
}

.u-pr4 {
	padding-right: 4rem;
}

.u-pt4 {
	padding-top: 4rem;
}

.u-pb5 {
	padding-bottom: 5rem;
}

.u-pl5 {
	padding-left: 5rem;
}

.u-pr5 {
	padding-right: 5rem;
}

.u-pt5 {
	padding-top: 5rem;
}

.u-pb6 {
	padding-bottom: 6rem;
}

.u-pl6 {
	padding-left: 6rem;
}

.u-pr6 {
	padding-right: 6rem;
}

.u-pt6 {
	padding-top: 6rem;
}

.u-pb7 {
	padding-bottom: 7rem;
}

.u-pl7 {
	padding-left: 7rem;
}

.u-pr7 {
	padding-right: 7rem;
}

.u-pt7 {
	padding-top: 7rem;
}

.u-pb8 {
	padding-bottom: 8rem;
}

.u-pl8 {
	padding-left: 8rem;
}

.u-pr8 {
	padding-right: 8rem;
}

.u-pt8 {
	padding-top: 8rem;
}

.u-pb9 {
	padding-bottom: 9rem;
}

.u-pl9 {
	padding-left: 9rem;
}

.u-pr9 {
	padding-right: 9rem;
}

.u-pt9 {
	padding-top: 9rem;
}

.u-pb10 {
	padding-bottom: 10rem;
}

.u-pl10 {
	padding-left: 10rem;
}

.u-pr10 {
	padding-right: 10rem;
}

.u-pt10 {
	padding-top: 10rem;
}

/* ---------------------------------------------
	Other
--------------------------------------------- */

span.unit {
	display: inline-block;
}

.u-over {
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.u-semibold {
	font-weight: 400;
}

.u-bold {
	font-weight: 500;
}

.u-bolder {
	font-weight: 700;
}

.u-note {
	font-size: 0.8em;
}

.u-must {
	color: #0094c6;
}

.u-img {
	margin: auto;
}

/* ---------------------------------------------
	Position
--------------------------------------------- */

.u-flt--l {
	float: left;
}

.u-flt--r {
	float: right;
}

/* =============================================
#  Media Queries
============================================= */

@media all and (-ms-high-contrast: none) {
	.u-img > img[src$=".svg"] {
		height: auto;
		max-width: 100%;
	}
}

@media screen and (min-width: 321px) {
	.p-case_details__inner > div.head {
		height: 14vw;
	}

	.p-case_details__inner > div.head ul li {
		height: 14vw;
	}

	.p-case_details__inner > div.data {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}
}

@media screen and (min-width: 480px) {
	section,
	aside {
		padding-bottom: 16vw;
		padding-top: 16vw;
	}

	section.margin {
		padding-bottom: 16vw;
		padding-top: 34vw;
	}

	section.margin:last-of-type {
		padding-bottom: 21vw;
	}

	.l-container .l-content {
		padding-bottom: 13.7vw;
		padding-top: 13.7vw;
	}

	.c-area__contact__tel p {
		font-size: 2.9vw;
		line-height: 4.3vw;
	}

	.p-case_details__inner > div.head {
		height: 60px;
	}

	.p-case_details__inner > div.head ul li {
		height: 60px;
	}

	.p-case_details__inner > div.data p span {
		font-size: 29px;
		font-size: 2.9rem;
	}

	.p-case_details__inner > div.chart1 {
		padding-left: 1em !important;
		padding-top: 2.5em !important;
	}

	.p-case__list .item {
		float: left;
		padding-bottom: 48%;
		width: 48%;
	}

	.p-case__list .item:nth-of-type(even) {
		margin-left: 4%;
	}

	.p-case__list .item p {
		font-size: 3.6vw;
		left: 1.5vw;
		top: 1.5vw;
	}
}

@media screen and (min-width: 600px) {
	/* .l-wrapper {
    padding-bottom: 120px;
  } */

	.c-area__contact {
		height: 120px;
	}

	.c-area__contact__tel {
		-o-background-size: auto 40px;
		-webkit-background-size: auto 40px;
		background-image: url(../images/common/icon_tel_white.svg);
		background-position: left center;
		background-repeat: no-repeat;
		background-size: auto 40px;
		padding-left: 50px;
	}

	.c-area__contact__tel p {
		font-size: 17px;
		font-size: 1.7rem;
		line-height: 1.4;
		margin-top: 10px;
	}

	.c-area__contact__tel a {
		font-size: 3.5vw;
		text-indent: 0;
		white-space: normal;
	}

	.c-head__l {
		font-size: 34px;
		font-size: 3.4rem;
	}

	.c-text__l {
		font-size: 33px;
		font-size: 3.3rem;
	}

	.p-case_details__inner > div.head ul li:nth-child(1) {
		width: 37.5%;
	}

	.p-case_details__inner > div.head ul li:nth-child(2) {
		width: 37.5%;
	}

	.p-case_details__inner > div.head ul li:nth-child(3) {
		width: 25%;
	}

	.p-case__list .item p {
		font-size: 20px;
		font-size: 2rem;
		left: 10px;
		top: 10px;
	}

	.p-case__list .item p {
		font-size: 24px;
		font-size: 2.4rem;
		left: 13px;
		top: 13px;
	}

	.p-service-about .l-container .l-content > .u-img {
		margin-bottom: 60px;
		max-width: 620px;
		width: 100%;
	}

	.p-service-merit__point .item .box {
		background-size: 110px auto;
	}

	.p-service-merit__point .item .box .c-head__l {
		padding-left: 170px;
	}

	.p-led-merit__point .item h3 {
		height: 130px;
		left: -20px;
		top: -27px;
		width: 100px;
	}

	.p-led-merit__point .item .c-box__rc {
		margin-left: 30px;
		padding-left: 70px;
	}

	.p-led-merit__point .item .c-box__rc .c-head__l {
		margin-top: -1em;
	}

	.p-led-costdown .u-img {
		margin-bottom: 60px;
	}

	.p-led-lineup .u-img:nth-of-type(1) + p {
		font-size: 18px;
		font-size: 1.8rem;
	}

	.p-led-lineup .u-img:nth-of-type(2) {
		margin-bottom: 50px;
		margin-top: 60px;
	}

	.p-ac-reason__point .item h3 {
		height: 130px;
		left: -20px;
		top: -27px;
		width: 100px;
	}

	.p-ac-reason__point .item .c-box__rc {
		margin-left: 30px;
		width: calc(100% - 30px);
	}

	.p-ac-reason__point .item .c-box__rc > p:nth-of-type(1) {
		margin-left: 34px;
	}

	.p-ac-reason__point .item .c-box__rc .c-head__l {
		font-size: 34px;
		font-size: 3.4rem;
		margin-left: 34px;
	}

	.p-ac-reason__point .item:nth-of-type(3) .c-box__rc div > p:first-of-type {
		margin-left: 34px;
	}

	.p-ac-costdown__item div .c-head__l {
		font-size: 32px;
		font-size: 3.2rem;
	}

	.p-ac-lineup__list div p {
		font-size: 13px;
		font-size: 1.3rem;
	}

	.p-ac-lineup__list.ac {
		margin-top: 8vw;
	}

	.p-ac-lineup__maker ul {
		margin-top: -10px;
	}

	.p-ac-lineup__maker ul li img {
		width: 90%;
	}
}

@media screen and (min-width: 768px) {
	section,
	aside {
		padding-bottom: 120px;
		padding-top: 120px;
	}

	section.margin {
		padding-bottom: 120px;
		padding-top: 290px;
	}

	section.margin:last-of-type {
		padding-bottom: 170px;
	}

	.l-container .l-content {
		padding-bottom: 103px;
		padding-top: 103px;
	}

	.c-area__pagelink .l-container {
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.c-area__pagelink a {
		margin-left: 0;
		margin-right: 0;
		max-width: 594px;
		width: calc((100% - 12px) / 2);
	}

	.p-case_details {
		padding-bottom: 120px;
	}

	.p-case_details__inner > div.head {
		height: 100px;
	}

	.p-case_details__inner > div.head h3 {
		font-size: 42px;
		font-size: 4.2rem;
		padding-top: 24px;
	}

	.p-case_details__inner > div.head h3::before {
		font-size: 35%;
	}

	.p-case_details__inner > div.head ul li {
		height: 100px;
		padding-bottom: 1em;
		padding-top: 1em;
		width: calc(100% / 3) !important;
	}

	.p-case_details__inner > div.head ul li p {
		margin-top: 1em;
	}

	.p-case_details__inner > div.data div {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.p-case_details__inner > div.data div ul {
		width: 47%;
	}

	.p-case_details__inner > div.data p span {
		font-size: 42px;
		font-size: 4.2rem;
	}

	.p-case__list .item {
		margin-right: 2.75%;
		padding-bottom: 31.5%;
		width: 31.5%;
	}

	.p-case__list .item:nth-of-type(even) {
		margin-left: 0;
	}

	.p-case__list .item:nth-of-type(3n) {
		margin-right: 0;
	}

	.p-service-merit__point {
		margin-bottom: 60px;
	}

	.p-service-method .u-img {
		margin-bottom: 12vw;
		margin-top: 4vw;
		max-width: 1170px;
		width: 100%;
	}

	.p-service-cost .u-img {
		margin-bottom: 80px;
	}

	.p-service-equipment__list .item h4 {
		margin-bottom: 320px;
	}

	.p-service-equipment__list .item h4::after {
		bottom: -320px;
		height: 320px;
	}

	.p-ac-reason__point .item .c-box__rc {
		padding-left: 35px;
		padding-right: 35px;
	}

	.p-ac-lineup .l-container {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.p-ac-lineup .c-box__rc {
		margin-top: 40px;
		padding-left: 2vw;
		padding-right: 2vw;
		width: 48%;
	}

	.p-ac-lineup__list div p {
		font-size: 12px;
		font-size: 1.2rem;
	}

	.p-ac-lineup__list.ac {
		margin-top: -0.5vw;
	}

	.p-ac-lineup__list.ac div {
		padding-bottom: 41%;
		width: 50%;
	}

	.p-ac-lineup__list.ac div img {
		bottom: 2em;
		left: 0;
		margin: auto;
		position: absolute;
		right: 0;
		z-index: 0;
	}

	.p-ac-lineup__list.ac div:nth-of-type(2) {
		padding-bottom: 63%;
	}

	.p-ac-lineup__maker ul li {
		height: 42px;
		margin-left: 10px;
		margin-right: 10px;
		padding-bottom: 0;
		width: calc(100% / 4);
	}
}

@media screen and (min-width: 1000px) {
	section.margin::before {
		height: 140px;
	}

	.c-area__contact {
		height: 90px;
		padding-top: 6px;
		text-align: left;
	}

	.c-area__contact__tel {
		background-position: left 60%;
		background-size: auto 45px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		padding-top: 1em;
		width: calc(100% - 280px);
	}

	.c-area__contact__tel p {
		margin-right: 1em;
		margin-top: 8px;
	}

	.c-area__contact__tel a {
		font-size: 39px;
		font-size: 3.9rem;
		margin-top: 5px;
		padding-left: 10px;
	}

	.c-head__box {
		font-size: 18px;
		font-size: 1.8rem;
	}

	.c-tag span {
		font-size: 12px;
		font-size: 1.2rem;
	}

	.p-case_details .p-slider__item {
		padding-bottom: 120px;
	}

	.p-case_details__bottom {
		bottom: 90px;
	}

	.p-service-merit__point .item::before {
		margin-bottom: 60px;
	}

	.p-service-merit__point .item h3 {
		top: 50px;
	}

	.p-service-merit__point .item .box {
		background-position: right center;
	}

	.p-service-merit__point .item .box .c-head__l {
		margin-bottom: 20px;
		margin-top: 0;
	}

	.p-service-merit__point .item .box p:not(.c-head__l) {
		min-height: 80px;
		padding-left: 170px;
		padding-right: 130px;
	}

	.p-service-merit__point .item:nth-of-type(1) .box .c-head__l {
		padding-top: 0;
	}

	.p-service-merit__point .item:nth-of-type(5) .box .c-head__l span {
		display: block;
	}

	.p-service-merit__point .item:nth-of-type(5) {
		margin-bottom: 20px;
	}

	.p-service-method .u-img {
		margin-bottom: 100px;
		margin-top: 50px;
	}

	.p-service-method p span {
		margin-left: 0.5em;
	}

	.p-service-comparison .u-img {
		margin-bottom: 60px;
		margin-top: 60px;
		max-width: 100%;
	}

	.p-service-howtouse__flow {
		border-bottom: none;
		border-left: 1px solid rgba(104, 101, 100, 0.8);
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.p-service-howtouse__flow div {
		border-right: 1px solid rgba(104, 101, 100, 0.8);
		border-top: none;
		padding-bottom: 0;
		padding-left: 15px;
		padding-right: 10px;
		padding-top: 0;
		width: calc((100% - 65px) / 4);
	}

	.p-service-howtouse__flow div::before {
		left: -25px;
		margin-left: 0;
		top: 50%;
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}

	.p-service-howtouse__flow div::after {
		border-color: transparent transparent transparent #f6e11c;
		border-width: 20px 0 20px 20px;
		left: -15px;
		margin-left: 0;
		top: calc(50% - 10px);
	}

	.p-service-howtouse__flow div .c-head__m::before {
		font-size: 3em;
	}

	.p-service-howtouse__flow div p:not(.u-note) {
		font-size: 1.4vw;
	}

	.p-service-howtouse__flow div:nth-of-type(1) {
		padding-left: 20px;
		width: calc(((100% - 65px) / 4) + 20px);
	}

	.p-service-howtouse__rental .c-flex {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.p-service-howtouse__rental .c-flex__item:nth-of-type(1) {
		width: 40%;
	}

	.p-service-howtouse__rental .c-flex__item:nth-of-type(2) {
		width: 55%;
	}

	.p-service-howtouse__rental .c-flex__item:nth-of-type(2) .u-img {
		margin-top: 4.5em;
	}

	.p-service-howtouse__rental .c-text__l {
		font-size: 2.5vw;
		margin-bottom: 0;
	}

	.p-service-howtouse__rental .u-img {
		margin-top: 3em;
		max-width: 100%;
	}

	.p-service-howtouse__rental:nth-of-type(1) .c-head__s + p {
		position: absolute;
		right: 0;
		top: -1.5em;
		width: 25em;
		z-index: 0;
	}

	.p-service-howtouse__rental:nth-of-type(2) .c-flex__item:nth-of-type(2) .u-img {
		margin-top: 6em;
	}

	.p-service-howtouse__rental:nth-of-type(3) .c-flex__item:nth-of-type(2) .u-img {
		margin-top: 7em;
	}

	.p-service-equipment__list {
		-webkit-box-align: stretch;
		-ms-flex-align: stretch;
		align-items: stretch;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.p-service-equipment__list .item {
		margin-left: 0;
		margin-right: 0;
		margin-top: 6vw;
		max-width: 48%;
		width: 48%;
	}

	.p-service-equipment__list .item .box {
		min-height: 22em;
		padding: 40px 30px 30px;
		position: relative;
	}

	.p-service-equipment__list .item .box a {
		bottom: 2em;
		left: 0;
		margin: auto;
		position: absolute;
		right: 0;
		width: calc(100% - 60px);
		z-index: 0;
	}

	.p-led-merit__point {
		-webkit-box-align: stretch;
		-ms-flex-align: stretch;
		align-items: stretch;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.p-led-merit__point .item {
		height: 340px;
		margin: 0;
		margin-bottom: 50px;
		width: 48%;
	}

	.p-led-merit__point .item .c-box__rc {
		height: 100%;
		width: calc(100% - 30px);
	}

	.p-led-merit__point .item .c-box__rc .c-head__l {
		font-size: 32px;
		font-size: 3.2rem;
	}

	.p-led-merit__point .item:nth-of-type(1) .c-box__rc .u-img {
		margin-top: 50px;
	}

	.p-led-merit__point .item:nth-of-type(3) .c-box__rc .u-img {
		margin-top: 50px;
	}

	.p-led-merit__point .item:nth-of-type(5) {
		height: auto;
		width: 100%;
	}

	.p-led-merit__point .item:nth-of-type(5) .c-box__rc {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		width: calc(100% - 30px);
	}

	.p-led-merit__point .item:nth-of-type(5) .c-box__rc div {
		width: 27%;
	}

	.p-led-merit__point .item:nth-of-type(5) .c-box__rc .u-img {
		margin-top: 10px;
		width: 70%;
	}

	.p-led-lineup .u-img:nth-of-type(1) + p {
		font-size: 22px;
		font-size: 2.2rem;
	}

	.p-led-proposal__photo {
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		max-width: 100%;
	}

	.p-led-proposal__photo .u-img {
		margin: 4px 0;
		width: 19%;
	}

	.p-ac-reason__point {
		-webkit-box-align: stretch;
		-ms-flex-align: stretch;
		align-items: stretch;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.p-ac-reason__point .item {
		height: auto;
		margin: 0;
		margin-bottom: 50px;
		width: 48%;
	}

	.p-ac-reason__point .item .c-box__rc {
		height: 100%;
		width: calc(100% - 30px);
	}

	.p-ac-reason__point .item .c-box__rc > p:nth-of-type(1) {
		margin-left: 25px;
	}

	.p-ac-reason__point .item .c-box__rc .c-head__l {
		font-size: 2.5vw;
		margin-left: 25px;
	}

	.p-ac-reason__point .item:nth-of-type(1) .c-box__rc .u-img {
		margin-top: 50px;
	}

	.p-ac-reason__point .item:nth-of-type(2) .c-head__l {
		letter-spacing: -0.05em;
	}

	.p-ac-reason__point .item:nth-of-type(3) {
		height: auto;
		width: 100%;
	}

	.p-ac-reason__point .item:nth-of-type(3) .c-box__rc {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		width: calc(100% - 30px);
	}

	.p-ac-reason__point .item:nth-of-type(3) .c-box__rc div > p:first-of-type {
		margin-left: 25px;
	}

	.p-ac-reason__point .item:nth-of-type(3) .c-box__rc div {
		width: 57%;
	}

	.p-ac-reason__point .item:nth-of-type(3) .c-box__rc .u-img {
		margin-right: 0;
		width: 43%;
	}

	.p-ac-costdown__item {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-flow: row wrap;
		flex-flow: row wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		text-align: left;
	}

	.p-ac-costdown__item div {
		width: 45%;
	}

	.p-ac-costdown__item div .c-head__l {
		font-size: 30px;
		font-size: 3rem;
		text-align: left;
	}

	.p-ac-costdown__item .u-img {
		margin-top: 15px;
		width: 52%;
	}

	.p-ac-costdown__item:nth-of-type(1) .u-img {
		position: relative;
	}

	.p-ac-costdown__item:nth-of-type(1) .u-img img {
		left: 50%;
		position: absolute;
		top: 50%;
		-webkit-transform: translate(-50%, -50%);
		transform: translate(-50%, -50%);
	}

	.p-ac-lineup__list.ac {
		margin-top: -30px;
	}

	.p-ac-lineup__maker ul li {
		max-width: calc((100% - 120px) / 6);
		width: calc((100% - 120px) / 6);
	}
}

@media screen and (min-width: 1000px) and (min-width: 1280px) {
	.p-service-howtouse__rental .c-flex__item:nth-of-type(1) {
		width: 34%;
	}

	.p-service-howtouse__rental .c-flex__item:nth-of-type(2) {
		width: 59%;
	}
}

@media screen and (min-width: 1230px) {
	.p-case_details .p-slider {
		max-width: 1200px;
		width: calc(100% - 12vw);
	}

	.p-case_details .p-slider__item {
		max-width: 100%;
	}
}

@media screen and (min-width: 1280px) {
	section,
	aside {
		padding-bottom: 160px;
		padding-top: 160px;
	}

	section.margin {
		padding-bottom: 140px;
		padding-top: 310px;
	}

	section.margin::before {
		height: 142px;
	}

	section.margin:last-of-type {
		padding-bottom: 190px;
	}

	.l-container .l-content {
		padding-bottom: 135px;
		padding-top: 112px;
	}

	.c-area__contact {
		height: 120px;
		padding-bottom: 14px;
		padding-top: 14px;
		text-align: left;
	}

	.c-area__contact__tel {
		background-size: 67px auto;
		padding-left: 90px;
	}

	.c-area__contact__tel p {
		font-size: 20px;
		font-size: 2rem;
		margin-top: 5px;
	}

	.c-area__contact__tel a {
		font-size: 53px;
		font-size: 5.3rem;
		margin-top: 0;
	}

	.c-head__l {
		font-size: 37px;
		font-size: 3.7rem;
	}

	.c-text__l {
		font-size: 35px;
		font-size: 3.5rem;
	}

	.p-case_details {
		padding-bottom: 140px;
	}

	.p-case_details .p-slider__item {
		padding-bottom: 140px;
	}

	.p-case_details__inner > div:not(.head) {
		padding-bottom: 40px;
		padding-top: 60px;
	}

	.p-case_details__bottom {
		bottom: 120px;
	}

	.p-service-howtouse__flow div {
		padding-right: 20px;
	}

	.p-service-howtouse__flow div p:not(.u-note) {
		font-size: 20px;
		font-size: 2rem;
	}

	.p-service-howtouse__rental .c-text__l {
		font-size: 30px;
		font-size: 3rem;
	}

	.p-service-howtouse__rental:nth-of-type(2) .c-flex__item:nth-of-type(2) .u-img {
		margin-top: 6%;
	}

	.p-service-howtouse__rental:nth-of-type(3) .c-flex__item:nth-of-type(2) .u-img {
		margin-top: 17%;
	}

	.p-service-howtouse__rental:nth-of-type(4) .c-flex__item:nth-of-type(2) .u-img {
		margin-top: 8%;
	}

	.p-led-merit__point .item .c-box__rc .c-head__l {
		font-size: 35px;
		font-size: 3.5rem;
	}

	.p-ac-reason__point .item .c-box__rc .c-head__l {
		font-size: 33px;
		font-size: 3.3rem;
	}

	.p-ac-lineup__list.ac {
		margin-top: 0;
	}

	.p-ac-lineup__list.ac div {
		height: 172px;
		margin-bottom: 30px;
		padding-bottom: 0;
	}

	.p-ac-lineup__list.ac div:nth-of-type(2) {
		height: 234px;
		margin-top: -62px;
		padding-bottom: 0;
	}

	.p-ac-lineup__maker ul {
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		padding-left: 20px;
		padding-right: 20px;
	}
}

@media screen and (min-width: 1450px) {
	.slick-arrow.slick-prev {
		left: -6vw;
	}

	.slick-arrow.slick-next {
		right: -6vw;
	}

	.c-head__l {
		font-size: 38px;
		font-size: 3.8rem;
	}

	.p-case_details__inner > div:not(.head) {
		padding-left: 60px;
		padding-right: 60px;
	}

	.p-case_details__inner > div.photo {
		padding-left: 50px;
		padding-right: 50px;
	}

	.p-led-merit__point .item .c-box__rc .c-head__l {
		font-size: 38px;
		font-size: 3.8rem;
	}

	.p-ac-reason__point .item .c-box__rc .c-head__l {
		font-size: 36px;
		font-size: 3.6rem;
	}

	.p-ac-costdown__item div .c-head__l {
		font-size: 32px;
		font-size: 3.2rem;
	}
}

@media screen and (max-width: 1279px) {
	.p-service-about .l-container > .u-img.zero {
		max-width: 80vw;
	}
}

@media screen and (max-width: 999px) {
	.c-area__contact .l-container {
		left: 50%;
		position: absolute;
		top: 50%;
		-webkit-transform: translate(-50%, -50%);
		transform: translate(-50%, -50%);
	}

	.p-case_details .slick-arrow {
		top: calc(100% + 50px);
	}

	.p-case .c-pnav {
		display: block;
	}

	.p-led-merit__point .item {
		max-width: 700px;
	}

	.p-ac-reason__point .item {
		max-width: 700px;
	}
}

@media screen and (max-width: 767.98px) {
	.p-case_details__inner > div.data div ul li {
		font-size: 14px;
		font-size: 1.4rem;
	}

	.p-case_details__inner > div.data p {
		font-size: 1.6vw;
		height: 60px;
		width: 90px;
	}

	.p-service-about .l-container > .u-img.zero {
		margin-bottom: 15vw;
		max-width: 400px;
	}

	.p-service-about .l-container > .u-img.recommend {
		max-width: 480px;
	}

	.p-service-merit__point .item:nth-of-type(5) .box .c-head__l span {
		display: inline;
	}
}

@media screen and (max-width: 599px) {
	.c-area__contact .l-container {
		height: 100%;
		padding-top: 10px;
		text-align: center;
	}

	.c-area__contact .l-container::before {
		-o-background-size: auto 100%;
		-webkit-background-size: auto 100%;
		background-image: url(../images/common/icon_tel_white.svg);
		background-position: left bottom;
		background-repeat: no-repeat;
		background-size: auto 100%;
		content: "";
		height: 40px;
		width: 40px;
	}

	.c-area__contact .l-container::after {
		-o-background-size: 62% auto;
		-webkit-background-size: 62% auto;
		background-color: #f6e11c;
		background-image: url(../images/common/icon_mail_gray.svg);
		background-position: center;
		background-repeat: no-repeat;
		background-size: 62% auto;
		content: "";
		height: 40px;
		width: 40px;
	}

	.c-area__contact__tel a {
		bottom: 0;
		height: 100%;
		left: -6vw;
		margin: auto;
		position: fixed;
		top: 0;
		width: 20%;
		z-index: 1;
	}

	.p-case_details__inner > div.head ul li > span {
		-webkit-transform: scale(0.8);
		transform: scale(0.8);
		-webkit-transform-origin: left center;
		transform-origin: left center;
	}

	.p-service-about .l-container .l-content {
		width: 100%;
	}
}

@media screen and (max-width: 479px) {
	/* main p,
  main a,
  main ul,
  main ol,
  main dl {
    font-size: 14px;
    font-size: 1.4rem;
  } */

	.c-head__m {
		font-size: 5vw;
	}

	.c-head__s {
		font-size: 4.58333vw;
	}

	.c-text__l {
		line-height: 1.3;
	}

	.c-thanks__message p {
		font-size: 2.91667vw;
	}

	.p-case_details .p-slider__item > p {
		font-size: 2.91667vw;
	}

	.p-case_details__inner > div:not(.head) {
		padding: 30px 10px 20px;
	}

	.p-case_details__inner > div:not(.head) h4 {
		font-size: 2.91667vw;
	}

	.p-case_details__inner > div.head h3 {
		font-size: 5.20833vw;
		width: 55px;
	}

	.p-case_details__inner > div.head ul {
		width: calc(100% - 55px);
	}

	.p-case_details__inner > div.head ul li > span {
		-webkit-transform: scale(0.7);
		transform: scale(0.7);
	}

	.p-case_details__inner > div.head ul li p {
		font-size: 2.91667vw;
		letter-spacing: -0.1em;
	}

	.p-case_details__inner > div.data div {
		width: 55%;
	}

	.p-case_details__inner > div.data div ul li {
		font-size: 2.91667vw;
	}

	.p-service-howtouse .c-box__rc {
		padding: 12.5vw 6.25vw 0;
	}

	.p-service-equipment__list .item h4 {
		font-size: 5.20833vw;
	}

	.p-service-equipment__list .item .box .c-head__m {
		font-size: 4.58333vw;
	}

	.p-service-equipment__list .item .box a {
		font-size: 3.75vw;
	}

	.p-led-lineup .u-img:nth-of-type(1) {
		max-width: 200px;
	}

	.p-led-proposal {
		margin-bottom: 0;
	}

	.p-ac-reason__point .item .c-box__rc {
		padding: 20px;
	}

	.p-ac-lineup .c-box__rc {
		padding: 9.58333vw 6.25vw 0;
	}

	.p-ac-lineup .c-box__rc > p {
		font-size: 78%;
	}
}

@media screen and (max-width: 320px) {
	main p,
	main a,
	main ul,
	main ol,
	main dl {
		font-size: 3.75vw;
	}

	section.margin::before {
		height: 29.16667vw;
	}

	.c-area__contact .l-container::before {
		bottom: 5px;
		height: 25px;
		left: -10px;
		position: absolute;
		width: 25px;
	}

	.c-area__contact .l-container::after {
		bottom: 5px;
		height: 25px;
		position: absolute;
		right: -10px;
		width: 25px;
	}

	.c-area__contact__tel {
		margin: auto;
	}

	.c-head__sc.box {
		margin-top: 25vw;
	}

	.c-head__box {
		font-size: 3.33333vw;
	}

	.c-head__bg span {
		padding-left: 5px;
		padding-right: 5px;
	}

	.c-tag span {
		font-size: 8px;
		font-size: 0.8rem;
	}

	.p-case_details__inner > div.head h3 {
		margin-bottom: 0;
		width: 100%;
	}

	.p-case_details__inner > div.head ul {
		margin-bottom: 0;
		width: 100%;
	}

	.p-case_details__inner > div.head ul li p {
		font-size: 8px;
	}

	.p-case_details__inner > div.data div {
		width: 100%;
	}

	.p-case_details__inner > div.data p {
		font-size: 2.91667vw;
		margin: 10px 0 0 auto;
		padding-top: 2vw;
	}

	.p-case__list .item p {
		font-size: 110%;
	}

	.p-led-proposal__photo .u-img {
		width: calc((100% - 8px) / 2);
	}

	.p-ac-reason__point .item .c-box__rc > p:nth-of-type(1) {
		margin-left: 2vw;
	}

	.p-ac-reason__point .item .c-box__rc .c-head__l {
		margin-left: 2vw;
	}

	.p-ac-reason__point .item:nth-of-type(3) .c-box__rc div > p:first-of-type {
		margin-left: 2vw;
	}

	.p-ac-lineup__list {
		display: block;
	}

	.p-ac-lineup__list div {
		padding-bottom: 66%;
		width: 100% !important;
	}

	.p-ac-lineup__list div p {
		height: 4em;
		padding-bottom: 1.5em;
		padding-top: 1.5em;
	}

	.p-ac-lineup__list.place div {
		margin-bottom: 30px;
	}

	.p-ac-lineup__list.place p {
		bottom: -4em;
	}

	.p-ac-lineup__list.ac div:nth-of-type(2) {
		margin-top: 10px;
		padding-bottom: 140%;
	}

	.p-ac-lineup__list.ac div:nth-of-type(2) img {
		width: 40%;
	}

	.p-ac-lineup__maker .c-head__bg {
		font-size: 6.25vw;
	}

	.p-ac-lineup__maker .c-head__bg span {
		padding-left: 1em;
		padding-right: 1em;
	}

	span.unit {
		display: inline;
	}
}

/* ---------------------------------------------
	Utilities
--------------------------------------------- */
.u-algn--c {
	text-align: center !important;
}
.u-algn--r {
	text-align: right !important;
}
.u-algn--l {
	text-align: left !important;
}

.u-fc--navy {
	color: #003352 !important;
}
.u-fc--orange {
	color: #e97d0d !important;
}
.u-fc--light-blue {
	color: #4997d8 !important;
}
.u-fc--white {
	color: #fff !important;
}
.u-fc--000 {
	color: #000 !important;
}

.u-bg--navy {
	background-color: #003352 !important;
}
.u-bg--light-navy {
	background-color: #e5ebee !important;
}
.u-bg--orange {
	background-color: #e97d0d !important;
}
.u-bg--light-orange {
	background-color: #fdf2e7 !important;
}
.u-bg--light-blue {
	background-color: #4997d8 !important;
}
.u-bg--powder-blue {
	background-color: #e4eff9 !important;
}
.u-bg--white {
	background-color: #fff !important;
}

.u-font--noto_sans_jp {
	font-family: "Noto Sans JP", sans-serif !important;
}
.u-font--montserrat {
	font-family: "Montserrat", sans-serif !important;
}
.u-font--syncopate {
	font-family: "Syncopate", sans-serif !important;
}

.u-fw--normal {
	font-weight: normal !important;
}
.u-fw--bold {
	font-weight: bold !important;
}
.u-fw--300 {
	font-weight: 300 !important;
}
.u-fw--400 {
	font-weight: 400 !important;
}
.u-fw--500 {
	font-weight: 500 !important;
}
.u-fw--600 {
	font-weight: 600 !important;
}
.u-fw--700 {
	font-weight: 700 !important;
}
.u-fw--800 {
	font-weight: 800 !important;
}
.u-fw--900 {
	font-weight: 900 !important;
}

.u-w--100p {
	width: 100% !important;
}
.u-mw--100p {
	max-width: 100% !important;
}

.u-border-top-style {
	border-top-style: dashed !important;
}
.u-border-bottom-style {
	border-bottom-style: dashed !important;
}

.u-dsp--b {
	display: block !important;
}
.u-dsp--lb {
	display: inline-block !important;
}

@media screen and (min-width: 1000px) {
	.u-pc-dsp-n {
		display: none;
	}
}
@media screen and (max-width: 999px) {
	.u-tablet-dsp-b {
		display: block;
	}
	.u-tablet-dsp-lb {
		display: inline-block;
	}
	.u-tablet-dsp-n {
		display: none;
	}
}
@media screen and (min-width: 768px) {
	.u-dsp--b__is_sp {
		display: none;
	}
}
@media screen and (max-width: 767.08px) {
	.u-dsp--b__is_sp {
		display: block;
	}
	.u-sp-dsp--n {
		display: none;
	}
	.u-sp-algn--l {
		text-align: left !important;
	}
}
/*# sourceMappingURL=maps/style.css.map */
