body {
	color: #16457a;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

.u-desktop {
	display: none;
}

/* リキッドレイアウト対応 */

/*  
  375px以下：ルートフォントを画面幅に応じて可変
  768px〜$innerで代入した値（インナー幅）：ルートフォントを画面幅に応じて可変
*/

html {
	font-size: 16px;
}

/* pcの電話番号発信対応 */

a[href^="tel:"] {
	pointer-events: all;
}

a {
	text-decoration: none;
}

*,
*::before,
*::after {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

/* Remove default padding */

ul,
ol {
	padding: 0;
}

/* Remove default margin */

body,
h1,
h2,
h3,
h4,
h5,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
	margin: 0;
}

/* Set core root defaults */

html {
	scroll-behavior: smooth;
}

/* Set core body defaults */

body {
	line-height: 1;
	min-height: 100vh;
	text-rendering: optimizeSpeed;
}

/* Remove list styles on ul, ol elements with a class attribute */

ul,
ol {
	list-style: none;
}

/* A elements that don't have a class get default styles */

a:not([class]) {
	-webkit-text-decoration-skip: ink;
	text-decoration-skip-ink: auto;
}

a {
	color: inherit;
}

/* Make images easier to work with */

img {
	display: block;
	height: auto;
	max-width: 100%;
	width: 100%;
}

/* Natural flow and rhythm in articles by default */

article > * + * {
	margin-top: 1em;
}

/* Inherit fonts for inputs and buttons */

input,
button,
textarea,
select {
	font: inherit;
}

/* フォームリセット */

input,
button,
select,
textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background: transparent;
	border: none;
	border-radius: 0;
	font: inherit;
	outline: none;
}

textarea {
	resize: vertical;
}

input[type=checkbox],
input[type=radio] {
	clip: rect(0 0 0 0);
	-webkit-clip-path: inset(50%);
	border: 0;
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	white-space: nowrap;
	width: 1px;
}

input[type=submit],
input[type=button],
label,
button,
select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: none;
	border-radius: 0;
	cursor: pointer;
}

select::-ms-expand {
	display: none;
}

.btn {
	border: 1px solid #16457a;
	border-radius: 40px;
	display: inline-block;
	font-size: 16px;
	font-weight: 500;
	line-height: 1;
	max-width: 150px;
	padding: 13px 0;
	text-align: center;
	-webkit-transition: background-color 0.3s, color 0.3s;
	transition: background-color 0.3s, color 0.3s;
	width: 100%;
}

.btn::after {
	content: "→";
	margin-left: 15px;
	margin-left: 0.9375rem;
}

.btn--blue {
	background-color: #16457a;
	color: #fff;
}

.common-contact {
	background: url(../images/common/common-contact-bg-sp.jpg) no-repeat center center/cover;
	color: #fff;
	padding: 60px 0 75px;
	text-transform: uppercase;
}

.common-contact__inner {
	margin: 0 auto;
	max-width: 240px;
	padding: 0 20px;
	padding: 0 1.25rem;
	width: 64%;
}

.common-contact__head {
	text-align: center;
}

.common-contact__title {
	font-size: 32px;
	font-size: 2rem;
	font-weight: 900;
	line-height: 1;
}

.common-contact__text {
	font-size: 10px;
	font-size: 0.625rem;
	font-weight: 400;
	line-height: 1;
	margin-top: 12px;
}

.common-contact__items {
	gap: 50px;
	gap: 3.125rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	margin-top: 40px;
}

.common-contact-item__title {
	display: block;
	font-size: 10px;
	font-size: 0.625rem;
	font-weight: 400;
	line-height: 1;
}

.common-contact-item__content {
	display: block;
	font-size: 16px;
	font-size: 1rem;
	font-weight: 700;
	margin-top: 10px;
}

.common-contact__tel {
	margin-top: 50px;
}

.common-contact__tel a {
	font-size: 19px;
	font-size: 1.1875rem;
	font-weight: 500;
	line-height: 1;
}

.common-contact__tel a::before {
	background: url(../images/common/tel-icon.png) no-repeat center center/contain;
	content: "";
	display: inline-block;
	height: 17px;
	margin-right: 16px;
	margin-right: 1rem;
	width: 14px;
}

.common-contact__tel a span {
	font-weight: 700;
}

.common-contact__link {
	margin-top: 50px;
	text-align: center;
	width: 100%;
}

.common-contact__btn {
	border: 1px solid #fff;
	border-radius: 60px;
	display: inline-block;
	font-size: 16px;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1;
	max-width: 175px;
	max-width: 10.9375rem;
	padding: 20px 0;
	text-align: center;
	-webkit-transition: background-color 0.3s;
	transition: background-color 0.3s;
	width: 100%;
}

.common-contact__btn span::before {
	background: url(../images/common/mail-icon.png) no-repeat center center/contain;
	content: "";
	display: inline-block;
	height: 16px;
	margin-right: 16px;
	margin-right: 1rem;
	width: 20px;
}

html.is-fixed {
	height: 100%;
	left: 0;
	position: fixed;
	right: 0;
	top: 0;
}

.br {
	display: inline-block;
}

.sub-page {
	background: url(../images/common/subpage-bg.png) no-repeat center -100px/cover;
	background: url(../images/common/subpage-bg.png) no-repeat center -6.25rem/cover;
	padding: 50px 0 60px;
}

.section-about__title {
	padding-bottom: 25px;
	padding-bottom: 1.5625rem;
	position: relative;
	text-align: right;
	width: 100%;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

.section-about__title::before {
	background: url(../images/common/estate-main-sp.png) no-repeat center center/contain;
	bottom: 0;
	content: "";
	display: block;
	height: 160px;
	height: 10rem;
	left: 0;
	position: absolute;
	width: 165px;
	width: 10.3125rem;
}

.section-about__title span { /* 背景色にグラデーションを指定 */
	-webkit-background-clip: text; /* テキストで切り抜く */
	-webkit-text-fill-color: transparent;
	background-image: linear-gradient(138deg, rgb(50, 104, 192) 0%, rgb(43, 161, 191) 49%, rgb(50, 104, 192) 100%);
	display: inline-block; /* 切り抜いた部分は背景を表示 */
	font-size: 24px;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.6041666667;
	text-align: left;
}

.energy .section-about__title {
	padding-bottom: 75px;
	padding-bottom: 4.6875rem;
}

.energy .section-about__title::before {
	background: url(../images/common/energy-main.png) no-repeat center center/contain;
	bottom: 0;
	content: "";
	display: block;
	height: 160px;
	height: 10rem;
	left: 0;
	position: absolute;
	width: 165px;
	width: 10.3125rem;
}

.section-about__block {
	height: 400px;
	height: 25rem;
	margin-top: 50px;
}

.section-about__text {
	font-size: 16px;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.59375;
}

.section-about__text:not(:first-child) {
	margin-top: 15px;
}

.sub-service {
	margin-top: 80px;
}

.sub-service__item {
	gap: 40px;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: reverse;
	-ms-flex-direction: column-reverse;
	flex-direction: column-reverse;
}

.sub-service__item:not(:first-child) {
	margin-top: 60px;
}

.sub-service__block {
	margin-top: 30px;
}

.sub-service__head {
	text-align: center;
}

.sub-service__title {
	display: inline-block;
	width: 18%;
}

.sub-service__subtitle {
	display: block;
	font-size: 24px;
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1;
	margin-top: 15px;
}

.sub-service__textBox {
	margin-top: 20px;
}

.sub-service__text {
	font-size: 16px;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.59375;
}

.sub-service__text:not(:first-child) {
	margin-top: 20px;
}

.sub-service__img {
	width: 81.967213%;
}

.footer__company {
	padding: 40px 0 35px;
}

.footer-company__title {
	display: block;
	margin: 0 auto;
	width: 74.6666667%;
}

.footer-company__subtitle {
	display: block;
	font-size: 16px;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1;
	margin-top: 15px;
	text-align: center;
}

.footer-company__block {
	gap: 16px;
	gap: 1rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	font-size: 10px;
	font-size: 0.625rem;
	font-weight: 300;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	line-height: 1.6;
	margin-top: 20px;
}

.footer__menu {
	background-color: #16457a;
	color: #fff;
	padding: 25px 0;
}

.footer-menu__lists {
	display: none;
}

.footer-menu__list a {
	display: inline-block;
	font-size: 16px;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1;
	padding: 10px 0;
	position: relative;
	-webkit-transition: -webkit-transform 0.3s;
	transition: -webkit-transform 0.3s;
	transition: transform 0.3s;
	transition: transform 0.3s, -webkit-transform 0.3s;
}

.footer-menu__list a::after {
	background-color: #fff;
	bottom: 0;
	content: "";
	display: block;
	height: 1px;
	left: 0;
	position: absolute;
	-webkit-transform: scale(0, 1);
	transform: scale(0, 1);
	-webkit-transform-origin: left;
	transform-origin: left;
	-webkit-transition: -webkit-transform 0.3s;
	transition: -webkit-transform 0.3s;
	transition: transform 0.3s;
	transition: transform 0.3s, -webkit-transform 0.3s;
	width: 100%;
}

.footer-menu__list:not(:first-child)::before {
	content: "/";
	display: inline-block;
	margin: 0 0.5em;
}

.copy {
	display: block;
	font-size: 10px;
	font-size: 0.625rem;
	font-weight: 400;
	text-align: center;
}

.header {
	height: 60px;
	left: 0;
	position: fixed;
	right: 0;
	top: 0;
	-webkit-transition: 0.3s;
	transition: 0.3s;
	z-index: 10;
}

.header__bg {
	background: -webkit-gradient(linear, left top, left bottom, from(rgba(43, 155, 191, .48)), to(rgba(43, 104, 191, .48)));
	background: linear-gradient(to bottom, rgba(43, 155, 191, .48), rgba(43, 104, 191, .48));
	height: inherit;
	width: 100%;
}

.header__inner {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	height: inherit;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin: 0 auto;
	padding: 0 20px;
	padding: 0 1.25rem;
}

.header__logo {
	max-width: 135px;
}

.hamburger {
	padding: 0;
	z-index: 9;
}

.header__drawer .hamburger .js-hamburger {
	padding: 0;
}

.hamburger span {
	background: #fff;
	border-radius: 10px;
	display: block;
	height: 3px;
	position: relative;
	-webkit-transition: ease 0.3s;
	transition: ease 0.3s;
	width: 30px;
}

.hamburger span:nth-child(1) {
	top: 0;
}

.hamburger span:nth-child(2) {
	margin: 4px 0;
}

.hamburger span:nth-child(3) {
	top: 0;
}

/*is-OPEN時の動き*/

.hamburger.is-open span:nth-child(1) {
	top: 6px;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.hamburger.is-open span:nth-child(2) {
	opacity: 0;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.hamburger.is-open span:nth-child(3) {
	top: -8px;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.inner {
	margin-left: auto;
	margin-right: auto;
	padding-left: 25px;
	padding-right: 25px;
	width: 100%;
}

.sub-inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 600px;
	max-width: 37.5rem;
	padding-left: 35px;
	padding-left: 2.1875rem;
	padding-right: 35px;
	padding-right: 2.1875rem;
	width: 100%;
}

.pc-nav {
	display: none;
	height: inherit;
}

.pc-nav__items {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	color: #FFFFFF;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	font-size: 20px;
	font-size: 1.25rem;
	font-weight: 700;
	height: inherit;
	line-height: 1;
}

.pc-nav__item {
	height: inherit;
}

.pc-nav__item a {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	height: inherit;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin: 0 15px;
	margin: 0 0.9375rem;
	position: relative;
}

.pc-nav__item a::after {
	background-color: #fff;
	bottom: 35%;
	content: "";
	height: 2px;
	left: 0;
	position: absolute;
	-webkit-transform: scale(0, 1);
	transform: scale(0, 1);
	-webkit-transform-origin: left;
	transform-origin: left;
	-webkit-transition: 0.3s;
	transition: 0.3s;
	-webkit-transition: -webkit-transform 0.3s;
	transition: -webkit-transform 0.3s;
	transition: transform 0.3s;
	transition: transform 0.3s, -webkit-transform 0.3s;
	width: 100%;
}

.pc-nav__item a:hover::after {
	-webkit-transform: scale(1, 1);
	transform: scale(1, 1);
}

.pc-nav__btn {
	background: -webkit-gradient(linear, left top, left bottom, from(#2b9bbf), to(#2b68bf));
	background: linear-gradient(to bottom, #2b9bbf, #2b68bf);
	border-radius: 60px;
	margin-left: 15px;
	margin-left: 0.9375rem;
	width: -moz-fit-content;
	width: -webkit-fit-content;
	width: fit-content;
}

.pc-nav__btn a {
	background-color: #fff;
	border: 1px solid #2b9bbf;
	border-radius: 59px;
	display: inline-block;
	font-size: 16px;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1;
	padding: 20px 40px;
	padding: 20px 2.5rem;
	position: relative;
	-webkit-transition: 0.5s;
	transition: 0.5s;
}

.pc-nav__btn a::before {
	background: -webkit-gradient(linear, left top, left bottom, from(#2b9bbf), to(#2b68bf));
	background: linear-gradient(to bottom, #2b9bbf, #2b68bf);
	border-radius: 59px;
	content: "";
	display: block;
	height: 100%;
	left: 0;
	opacity: 0;
	position: absolute;
	top: 0;
	-webkit-transition: opacity 0.5s;
	transition: opacity 0.5s;
	width: 100%;
	z-index: 0;
}

.pc-nav__btn a:hover::before {
	opacity: 1;
}

.pc-nav__btn a:hover span {
	-webkit-text-fill-color: #fff;
}

.pc-nav__btn span { /* 背景色にグラデーションを指定 */
	-webkit-background-clip: text; /* テキストで切り抜く */
	-webkit-text-fill-color: transparent;
	background-image: -webkit-gradient(linear, left top, left bottom, from(#2b9bbf), to(#2b68bf));
	background-image: linear-gradient(to bottom, #2b9bbf, #2b68bf);
	position: relative; /* 切り抜いた部分は背景を表示 */
	-webkit-transition: 0.5s;
	transition: 0.5s;
	z-index: 10;
}

.pc-nav__item a.current::after {
	background-color: #fff;
	bottom: 35%;
	content: "";
	height: 2px;
	left: 0;
	position: absolute;
	-webkit-transform: scale(1, 1);
	transform: scale(1, 1);
	width: 100%;
}

.sp-nav {
	background: -webkit-gradient(linear, left top, left bottom, from(#2b9bbf), to(#2b68bf));
	background: linear-gradient(to bottom, #2b9bbf, #2b68bf);
	height: 100vh;
	left: 0;
	overflow: scroll;
	padding-bottom: 57.3333333%;
	position: absolute;
	right: 0;
	top: 0;
	-webkit-transform: translateX(100%);
	transform: translateX(100%);
	-webkit-transition: opacity 0.5s, visibility 0.5s, -webkit-transform 0.5s;
	transition: opacity 0.5s, visibility 0.5s, -webkit-transform 0.5s;
	transition: transform 0.5s, opacity 0.5s, visibility 0.5s;
	transition: transform 0.5s, opacity 0.5s, visibility 0.5s, -webkit-transform 0.5s;
	width: 100%;
	z-index: -1;
}

.sp-nav.is-show {
	-webkit-transform: translateX(0);
	transform: translateX(0);
}

.sp-nav__items {
	margin-left: 13.333333333%;
	padding-top: 85px;
	padding-top: 5.3125rem;
}

.sp-nav__item a {
	color: #FFFFFF;
	display: block;
	font-size: 16px;
	font-size: 1rem;
	font-weight: 700;
	margin: 25px 0;
	padding: 25px 0;
}

.sp-nav__btn {
	background: -webkit-gradient(linear, left top, left bottom, from(#2b9bbf), to(#2b68bf));
	background: linear-gradient(to bottom, #2b9bbf, #2b68bf);
	border-radius: 60px;
	margin-top: 45px;
	width: -moz-fit-content;
	width: -webkit-fit-content;
	width: fit-content;
}

.sp-nav__btn a {
	background-color: #fff;
	border: 1px solid #2b9bbf;
	border-radius: 59px;
	display: inline-block;
	font-size: 16px;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1;
	padding: 20px 40px;
	padding: 20px 2.5rem;
}

.sp-nav__btn span { /* 背景色にグラデーションを指定 */
	-webkit-background-clip: text; /* テキストで切り抜く */
	-webkit-text-fill-color: transparent;
	background-image: -webkit-gradient(linear, left top, left bottom, from(#2b9bbf), to(#2b68bf));
	background-image: linear-gradient(to bottom, #2b9bbf, #2b68bf); /* 切り抜いた部分は背景を表示 */
}

.sub-fv {
	aspect-ratio: 750/900;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	color: #fff;
	width: 100%;
}

.sub-fv.estate {
	background-image: url(../images/common/estate-fv-sp.jpg);
}

.sub-fv.energy {
	background-image: url(../images/common/energy-fv-sp.jpg);
}

.sub-fv.company {
	background-image: url(../images/common/comapny-fv-sp.jpg);
}

.sub-fv.contact {
	background-image: url(../images/common/contact-fv-sp.jpg);
}

.sub-fv__inner {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	height: 100%;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	text-align: center;
}

.sub-fv__title {
	display: block;
	font-size: 45px;
	font-size: 2.8125rem;
	font-weight: 700;
	line-height: 1;
	margin-top: 15px;
	text-transform: uppercase;
}

.sub-fv__subtitle {
	display: block;
	font-size: 16px;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1;
	margin-top: 15px;
}

.overview__title {
	font-size: 24px;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1;
	text-align: center;
}

.overview__table {
	margin-top: 30px;
}

.overview__item {
	-webkit-box-align: baseline;
	-ms-flex-align: baseline;
	align-items: baseline;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	padding: 0.571428em 1.25em;
}

.overview__item:not(:first-child) {
	border-top: 1px solid #d6dbe0;
}

.overview__name {
	font-size: 14px;
	font-weight: 500;
	line-height: 1.6071428571;
	width: 20%;
}

.overview__content {
	font-size: 12px;
	font-weight: 400;
	line-height: 1.5833333333;
	width: 72%;
}

.access {
	margin-top: 70px;
}

.access__title {
	font-size: 24px;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1;
	text-align: center;
	text-transform: uppercase;
}

.access__map {
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	margin-top: 30px;
	width: 100vw;
}

.google-map {
	aspect-ratio: 750/900;
	width: 100%;
}

.access__addressBox {
	gap: 15px;
	gap: 0.9375rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	font-size: 14px;
	font-weight: 400;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	line-height: 1.5833333333;
	margin-top: 30px;
}

.access__postcode {
	-ms-flex-negative: 0;
	flex-shrink: 0;
}

.access__mapLink {
	margin-top: 50px;
	text-align: center;
}

.access__btn {
	border: 1px solid #16457a;
	border-radius: 40px;
	display: inline-block;
	font-size: 16px;
	font-weight: 500;
	line-height: 1;
	max-width: 175px;
	padding: 20px 0;
	text-align: center;
	-webkit-transition: background-color 0.3s, color 0.3s;
	transition: background-color 0.3s, color 0.3s;
	width: 100%;
}

.access__btn::after {
	content: "→";
	margin-left: 15px;
	margin-left: 0.9375rem;
}

.sub-page.contact {
	padding: 50px 0;
}

.contact__title {
	font-size: 24px;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1;
	text-align: center;
}

.contact__text {
	font-size: 16px;
	font-weight: 400;
	line-height: 1.59375;
	margin-top: 20px;
	text-align: center;
}

.contact__body {
	margin-top: 40px;
}

/*----------------------------------------
	お問合せ専用
----------------------------------------*/

/* -- form#mail_form, dl, dt, dd -------------------------------------------------------------------------------- */

form#mail_form dl:not(:first-child) {
	margin-top: 30px;
}

form#mail_form dt {
	font-size: 16px;
	font-weight: 500;
	line-height: 1;
}

form#mail_form dd {
	margin-top: 12px;
}

form#mail_form dl:after,
form#mail_form dl dt:after {
	content: ".";
	display: block;
	height: 0;
	visibility: hidden;
}

form#mail_form dl dt i {
	position: relative;
	top: -2px;
}

/* -- span.required, span.optional -------------------------------------------------------------------------------- */

form#mail_form dl dt span.required,
form#mail_form dl dt span.optional {
	border-radius: 3px;
	color: #ffffff;
	display: inline-block;
	padding: 4px 0;
}

form#mail_form dl dt span.required {
	color: #ff0000;
}

form#mail_form dl dt span.optional {
	background: #337ab7;
	border: 1px solid #2e6da4;
}

/* -- error message -------------------------------------------------------------------------------- */

form#mail_form dl dd span.error_blank,
form#mail_form dl dd span.error_format,
form#mail_form dl dd span.error_match {
	color: #ff0000;
	display: block;
	margin-top: 5px;
}

/* -- loading -------------------------------------------------------------------------------- */

div.loading-layer {
	background: rgba(0, 0, 0, .7);
	height: 100vh;
	left: 0px;
	position: fixed;
	top: 0px;
	width: 100vw;
	z-index: 10000;
}

span.loading {
	-webkit-animation: load-circle 1s linear infinite;
	animation: load-circle 1s linear infinite;
	border-bottom: 5px solid rgba(255, 255, 255, .2);
	border-left: 5px solid #ffffff;
	border-radius: 50%;
	border-right: 5px solid rgba(255, 255, 255, .2);
	border-top: 5px solid rgba(255, 255, 255, .2);
	height: 50px;
	left: 50%;
	margin-left: -30px;
	margin-top: -30px;
	position: absolute;
	top: 50%;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	width: 50px;
}

/* -- input, select, textarea -------------------------------------------------------------------------------- */

form#mail_form input[type=text],
form#mail_form input[type=email],
form#mail_form input[type=tel] {
	width: 100%;
}

form#mail_form input[type=text],
form#mail_form input[type=email],
form#mail_form input[type=tel] {
	-webkit-appearance: none;
	background: #fff;
	border: 1px solid #d6dbe0;
	border-radius: 5px;
	font-family: inherit;
	line-height: 2;
	padding: 0.5em 1em;
}

form#mail_form input[type=text]:focus,
form#mail_form input[type=email]:focus,
form#mail_form input[type=tel]:focus,
form#mail_form textarea:focus {
	background: #ffffff;
	border: 1px solid rgba(22, 69, 122, .5);
	-webkit-box-shadow: 0px 0px 5px rgba(22, 69, 122, .5);
	box-shadow: 0px 0px 5px rgba(22, 69, 122, .5);
}

form#mail_form ul li input[type=radio],
form#mail_form ul li input[type=checkbox] {
	margin: 0 10px 0 0;
}

form#mail_form textarea {
	-webkit-appearance: none;
	background: #fff;
	border: 1px solid #d6dbe0;
	border-radius: 5px;
	display: block;
	font-family: inherit;
	height: 225px;
	line-height: normal;
	padding: 0.5em 1em;
	resize: vertical;
	width: 100%;
}

/* -- ul, li -------------------------------------------------------------------------------- */

form#mail_form ul {
	list-style-type: none;
}

form#mail_form ul li label {
	background: #f0f0f0;
	border-radius: 3px;
	display: block;
	margin-top: 10px;
	padding: 7px 2%;
}

form#mail_form ul li:first-child label {
	margin-top: 0px;
}

form#mail_form ul li label:hover {
	background: #e0e0e0;
	cursor: pointer;
}

/* -- input design -------------------------------------------------------------------------------- */

/* -- button -------------------------------------------------------------------------------- */

.submit {
	margin-top: 50px;
	text-align: center;
}

input[type=button] {
	border: 1px solid #16457a;
	border-radius: 40px;
	color: #16457a;
	display: inline-block;
	font-size: 16px;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1;
	max-width: 200px;
	padding: 20px 0;
	text-align: center;
	-webkit-transition: background-color 0.3s, color 0.3s;
	transition: background-color 0.3s, color 0.3s;
	width: 100%;
}

/*規約に同意する
------------------------------------*/

.agreement {
	margin-top: 40px;
	padding: 0 10px;
	padding: 0 0.625rem;
	text-align: center;
}

.agreement__title {
	font-size: 16px;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.59375;
}

.agreement__text {
	font-size: 12px;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.5833333333;
	margin-top: 15px;
}

.agreement__check {
	margin-top: 30px;
}

.agreement__check label {
	display: block;
	margin: 0 auto;
	width: -moz-fit-content;
	width: -webkit-fit-content;
	width: fit-content;
}

.agreement__consent {
	font-size: 24px;
	font-weight: 500;
	line-height: 1;
}

form#mail_form div#agreement span.error_check {
	color: #ff0000;
	display: none;
	margin-top: 10px;
}

/*checkbox
------------------------------------*/

input[type=radio],
input[type=checkbox] {
	opacity: 0; /*透明にして見えなくする*/
	position: absolute; /*本来の配置から切り離す*/
}

/*クリック範囲*/

input[type=radio] + span,
input[type=checkbox] + span {
	cursor: pointer;
	display: inline-block;
	line-height: 1;
	padding: 0.3em 0.3em 0.3em 2.3em;
	position: relative;
	vertical-align: middle;
}

/*チェックボックススタイル*/

input[type=checkbox] + span:before {
	background: #fff;
	border: 1px solid #d6dbe0;
	border-radius: 5px;
	content: "";
	height: 1.6666666em;
	left: 0;
	line-height: 1;
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	width: 1.66666666em;
}

/*チェックボックス未チェック時*/

input[type=checkbox] + span:after {
	content: "";
	display: none;
}

/*チェックボックスチェック時*/

input[type=checkbox]:checked + span:after {
	border-bottom: 5px solid #16457a;
	border-right: 5px solid #16457a;
	content: "";
	display: block;
	height: 1.4em;
	left: 0.5em;
	position: absolute;
	top: 0;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	width: 0.6em;
}

.thanks {
	margin-top: 60px;
	padding: 100px 0;
}

.thanks__title {
	font-size: 20px;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.5;
	text-align: center;
}

.thanks__textBox {
	margin-top: 40px;
}

.thanks__text {
	font-size: 16px;
	font-size: 1rem;
	font-weight: 400;
	line-height: 2;
}

.thanks__text:not(:first-child) {
	margin-top: 20px;
}

.thanks__topBack {
	margin-top: 50px;
	text-align: center;
	text-transform: uppercase;
}

#slider {
	height: 100svh !important;
	height: 100vh !important;
	width: 100%; /*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
}

.fv__container {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	height: 100svh !important;
	height: 100vh !important;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	width: 100%;
}

.fv__title {
	width: 86.1333333333%;
}

.philosophy {
	overflow: hidden;
	padding: 50px 0 60px;
	position: relative;
}

.philosophy::before {
	background: url(../images/common/top-philosophy-ring-sp.png) no-repeat center/cover;
	content: "";
	display: block;
	height: 400px;
	height: 25rem;
	position: absolute;
	right: 0;
	top: -142px;
	top: -8.875rem;
	width: 200px;
	width: 12.5rem;
	z-index: -1;
}

.philosophy__inner {
	margin-left: auto;
	margin-right: auto;
	padding-left: 25px;
	padding-right: 25px;
	width: 100%;
}

.philosophy__title {
	margin: 0 auto;
	max-width: 82.461538%;
}

.philosophy__wrapper {
	margin-top: 20px;
}

.philosophy__block {
	margin-top: 30px;
}

.philosophy__subtitle {
	font-size: 24px;
	font-weight: 500;
	line-height: 1.6041666667;
	text-align: center;
}

.philosophy__text {
	font-size: 16px;
	font-weight: 400;
	line-height: 1.59375;
	margin-top: 30px;
}

.service {
	background: url(../images/common/top-service-bg-pc.png) no-repeat center center/cover;
	padding: 60px 0;
}

.service__title {
	font-size: 32px;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
	text-align: center;
	text-transform: uppercase;
}

.service__lists {
	margin-top: 50px;
}

.service__list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: reverse;
	-ms-flex-direction: column-reverse;
	flex-direction: column-reverse;
}

.service__list:not(:first-child) {
	margin-top: 50px;
}

.service-list__head {
	font-size: 24px;
	font-weight: 500;
	line-height: 1;
	margin-top: 40px;
	text-align: center;
}

.service-list__title {
	display: block;
	margin: 0 auto;
}

.service-list__title.estate {
	width: 61.538462%;
}

.service-list__title.energy {
	width: 38.461538%;
}

.service-list__subtitle {
	display: block;
	margin-top: 25px;
}

.service-list__text {
	font-size: 16px;
	font-weight: 400;
	line-height: 1.59375;
	margin-top: 15px;
}

.service-list__img {
	aspect-ratio: 650/430;
	margin-left: auto;
	margin-right: calc(50% - 50vw);
	position: relative;
	width: 100%;
}

.service-list__link {
	margin-top: 40px;
	text-align: center;
}

.service__list--reverse .service-list__img {
	margin-left: calc(50% - 50vw);
	margin-right: auto;
}

@media screen and (min-width: 768px) {

.u-desktop {
	display: block;
}

.u-mobile {
	display: none;
}

html {
	font-size: 1.3333333333vw; /* 
      16 / $inner * 100vw = 1.45454545vw （&inner = 1100pxの場合）
      global/fuction.scssで関数を組んでる
    */
}

a[href^="tel:"] {
	pointer-events: none;
}

.btn {
	border: 2px solid #16457a;
	border-radius: 30px;
	max-width: 200px;
	padding: 20px 0;
}

.btn::after {
	margin-left: 1.5625rem;
}

.btn--white:hover {
	background-color: #16457a;
	color: #fff;
}

.btn--blue:hover {
	background-color: transparent;
	color: #16457a;
}

.common-contact {
	background-image: url(../images/common/common-contact-bg-pc.jpg);
	padding: 125px 0;
}

.common-contact__inner {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	max-width: 1200px;
	padding: 0 2.1875rem;
	width: 100%;
}

.common-contact__title {
	font-size: 4rem;
}

.common-contact__text {
	font-size: 1rem;
	margin-top: 30px;
}

.common-contact__items {
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin-top: 60px;
}

.common-contact-item__title {
	font-size: 1rem;
	text-align: left;
}

.common-contact-item__content {
	font-size: 1.25rem;
	margin-top: 16px;
	text-align: left;
}

.common-contact__tel {
	margin-left: 9.0625rem;
	margin-top: 0;
}

.common-contact__tel a {
	font-size: 1.5rem;
}

.common-contact__link {
	margin-left: 6.875rem;
	margin-top: 0;
	max-width: 21.875rem;
}

.common-contact__btn {
	border: 2px solid #fff;
	font-size: 1.5rem;
	max-width: 21.875rem;
	padding: 50px 0;
}

.common-contact__btn:hover {
	background-color: #16457a;
}

.sub-page {
	background-image: url(../images/common/subpage-bg-pc.png);
	background-position: center -12.5rem;
	padding: 8.75rem 0 10rem;
}

.section-about {
	position: relative;
}

.section-about.estate::before {
	background: url(../images/common/estate-main.png) no-repeat center center/contain;
	bottom: 0;
	content: "";
	display: block;
	height: 18.5rem;
	left: 0;
	position: absolute;
	width: 19.125rem;
}

.section-about.energy::before {
	background: url(../images/common/energy-main.png) no-repeat center center/contain;
	bottom: 0;
	content: "";
	display: block;
	height: 18.5rem;
	left: 0;
	position: absolute;
	width: 19.125rem;
}

.section-about__wrapper {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}

.section-about__title {
	margin-left: 3.125rem;
	padding-bottom: 0;
	width: auto;
}

.section-about__title::before {
	display: none;
}

.section-about__title span {
	font-size: 4rem;
}

.energy .section-about__title::before {
	display: none;
}

.section-about__block {
	margin-top: 60px;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

.section-about__text:not(:first-child) {
	margin-top: 0;
}

.section-about__text:not(:last-child) {
	margin-left: 3.125rem;
}

.sub-service {
	margin-top: 15rem;
}

.sub-service__item {
	gap: 11.25rem;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.sub-service__item.sub-service__item--reverse {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}

.sub-service__item:not(:first-child) {
	margin-top: 8.75rem;
}

.sub-service__block {
	margin-top: 0;
	max-width: 31.25rem;
}

.sub-service__head {
	text-align: left;
}

.sub-service__title {
	width: 16%;
}

.sub-service__subtitle {
	font-size: 2.25rem;
	margin-top: 30px;
}

.sub-service__textBox {
	margin-top: 40px;
}

.sub-service__img {
	max-width: 31.25rem;
	width: 100%;
}

.footer__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.footer__company {
	padding: 60px 0;
	width: 32.291667%;
}

.footer-company__title {
	width: 57.741935%;
}

.footer-company__block {
	font-size: 0.75rem;
	margin-top: 40px;
}

.footer__menu {
	padding: 110px 0 60px;
	width: 67.708333%;
}

.footer-menu__lists {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.footer-menu__list a:hover::after {
	-webkit-transform: scale(1, 1);
	transform: scale(1, 1);
}

.copy {
	margin-top: 40px;
}

.header {
	height: 7.5rem;
}

.header__inner {
	max-width: 2000px;
	padding: 0 2.5rem;
}

.header__logo {
	-ms-flex-negative: 0;
	flex-shrink: 0;
	max-width: 450px;
	-webkit-transition: opacity 0.3s;
	transition: opacity 0.3s;
	width: 23.4375vw;
}

.header__logo:hover {
	opacity: 0.7;
}

.hamburger {
	display: none;
}

.inner {
	max-width: 1250px;
	padding-left: 25px;
	padding-right: 25px;
}

.sub-inner {
	max-width: 1280px;
	padding-left: 25px;
	padding-right: 25px;
}

.pc-nav {
	display: block;
}

.sub-fv.estate {
	background-image: url(../images/common/estate-fv-pc.jpg);
}

.sub-fv.energy {
	background-image: url(../images/common/energy-fv-pc.jpg);
}

.sub-fv.company {
	background-image: url(../images/common/comapny-fv-pc.jpg);
}

.sub-fv.contact {
	background-image: url(../images/common/contact-fv-pc.jpg);
}

.sub-fv {
	aspect-ratio: 1920/650;
}

.sub-fv__title {
	font-size: 5.625rem;
	margin-top: 30px;
}

.sub-fv__subtitle {
	font-size: 1.5rem;
	margin-top: 30px;
}

.overview {
	margin: 0 auto;
	max-width: 50rem;
}

.overview__title {
	font-size: 4rem;
}

.overview__table {
	margin-top: 90px;
}

.overview__item {
	padding: 1.8em 3em;
}

.overview__content {
	font-size: 16px;
	width: 57%;
}

.access {
	margin-top: 12.5rem;
}

.access__title {
	font-size: 4rem;
}

.access__map {
	margin-left: 0;
	margin-right: 0;
	margin-top: 90px;
	width: 100%;
}

.google-map {
	aspect-ratio: 1200/650;
}

.access__block {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.access__address {
	width: 90%;
}

.access__mapLink {
	max-width: 200px;
	width: 100%;
}

.access__btn {
	border: 2px solid #16457a;
	border-radius: 30px;
	max-width: 200px;
	padding: 20px 0;
	width: 100%;
}

.access__btn:hover {
	background-color: #16457a;
	color: #fff;
}

.access__btn::after {
	margin-left: 1.5625rem;
}

.sub-page.contact {
	padding: 160px 0;
}

.contact__title {
	font-size: 4rem;
}

.contact__text {
	margin-top: 70px;
}

.contact__body {
	margin-top: 80px;
}

.form__body {
	margin: 0 auto;
	max-width: 40rem;
	width: 100%;
}

form#mail_form dd {
	margin-top: 16px;
}

.submit {
	margin-top: 60px;
}

input[type=button] {
	border: 2px solid #16457a;
	border-radius: 30px;
	max-width: 250px;
	padding: 20px 0;
}

input[type=button]:hover {
	background-color: #16457a;
	color: #fff;
}

.agreement {
	margin-top: 80px;
}

.agreement__title {
	font-size: 1.5rem;
}

.agreement__text {
	font-size: 1rem;
}

.agreement__consent {
	font-size: 16px;
}

.thanks {
	margin-top: 120px;
	padding: 200px 0;
}

.thanks__title {
	font-size: 1.75rem;
}

.thanks__textBox {
	margin-top: 60px;
	text-align: center;
}

.fv__title {
	max-width: 1384px;
	width: 72.083333333%;
}

.philosophy {
	padding: 7.5rem 0 10rem;
}

.philosophy::before {
	background-image: url(../images/common/top-philosophy-ring-pc.png);
	height: 50rem;
	top: -12.5rem;
	width: 37.5rem;
}

.philosophy__inner {
	max-width: 1450px;
	padding-left: 25px;
	padding-right: 25px;
}

.philosophy__title {
	margin: 0 0 -9.0625rem auto;
	max-width: 50rem;
	position: relative;
	width: 66.6666667%;
	z-index: 10;
}

.philosophy__wrapper {
	gap: 3.75rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.philosophy__img {
	margin-left: calc(25% - 25vw);
	max-width: 46.875rem;
	width: 62.5%;
}

.philosophy__block {
	margin-top: 13.4375rem;
	width: 46.666667%;
}

.philosophy__text {
	margin-top: 50px;
}

.service {
	padding: 10rem 0;
}

.service__title {
	font-size: 4rem;
}

.service__lists {
	margin-top: 10rem;
}

.service__list {
	gap: 3.125rem;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-direction: row;
	flex-direction: row;
}

.service__list:not(:first-child) {
	margin-top: 12.5rem;
}

.service-list__block {
	width: 45.833333333%;
}

.service-list__head {
	font-size: 36px;
	margin-top: 0;
	text-align: left;
}

.service-list__title {
	margin: 0 auto 0 0;
}

.service-list__title.estate {
	max-width: 400px;
	width: 80%;
}

.service-list__title.energy {
	max-width: 250px;
	width: 50%;
}

.service-list__subtitle {
	margin-top: 50px;
}

.service-list__text {
	margin-top: 50px;
}

.service-list__img {
	aspect-ratio: 900/500;
	max-width: 56.25rem;
	width: 75%;
}

.service-list__link {
	margin-top: 50px;
	text-align: left;
}

.service__list--reverse {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}

}

@media (min-width: 1200px) {

html {
	font-size: 16px;
}

}

@media (max-width: 375px) {

html {
	font-size: 4.2666666667vw; /* 
      16 / 375 * 100vw = 4.26666667vw
      global/fuction.scssで関数を組んでる
    */
}

}

@-webkit-keyframes load-circle {

0% {
	-webkit-transform: rotate(0deg);
	transform: rotate(0deg);
}

100% {
	-webkit-transform: rotate(360deg);
	transform: rotate(360deg);
}

}

@keyframes load-circle {

0% {
	-webkit-transform: rotate(0deg);
	transform: rotate(0deg);
}

100% {
	-webkit-transform: rotate(360deg);
	transform: rotate(360deg);
}

}


/*# sourceMappingURL=styles.css.map */
