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

body {
	font-family: "Noto Sans JP", sans-serif;
}

.u-desktop {
	display: none;
}

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

html {
	font-size: 16px;
}

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

/* Remove default padding */

ul,
ol {
	padding: 0;
}

/* Remove default margin */

body,
h1,
h2,
h3,
h4,
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.5;
	min-height: 100vh;
	text-rendering: optimizeLegibility;
}

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

/* Make images easier to work with */

img {
	display: block;
	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;
}

/* Blur images when they have no alt attribute */

img:not([alt]) {
	filter: blur(10px);
}

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

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] {
	display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
	cursor: pointer;
}

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

/* ホバー */

a {
	-webkit-text-decoration: none;
	-webkit-text-decoration: none;
	color: inherit;
	text-decoration: none;
	transition: opacity 0.3s;
}

.top-archive-works-development {
	margin-top: 2.5rem;
}

.top-archive-works-product {
	margin-top: 2.5rem;
}

.top-breadcrumb {
	margin-top: 0.5rem;
}

.top-contact {
	margin-top: 5rem;
	position: relative;
}

/* 非表示ユーティリティ */
.is-contact-hidden {
	display: none !important;
}


.top-footer {
	margin-top: 6.25rem;
}

.top-section {
	margin-top: 2.5rem;
	overflow: hidden;
	padding-bottom: 0.625rem;
	width: 100%;
}

.top-sub-contents {
	margin-top: 3.25rem;
}

.about__images {
	display: flex;
	padding-bottom: 1.625rem;
	position: relative;
	width: 100%;
}

.about__contents {
	margin-top: 2.5rem;
}

.about__title {
	color: #d63638;
	font-family: "Gotu", sans-serif;
	font-size: 2.5rem;
	font-weight: 400;
	line-height: 1;
}

.about-content {
	margin-top: 1rem;
}

.about__text {
	color: #300c0c;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
}

.access-info {
	background-color: #f5f0e7;
	border-radius: 0.5rem;
	padding: 1.875rem;
	width: 100%;
}

.access-info__name {
	border-bottom: 1px solid #d01c1f;
	font-size: 1.125rem;
	font-weight: bold;
	padding: 0.625rem;
}

.access-info__address,
.access-info__contact,
.access-info__note {
	font-size: 1rem;
	padding: 0.625rem;
	padding-bottom: 10px;
}

.access-info__address+.access-info__contact,
.access-info__contact+.access-info__note {
	border-top: 1px solid #d01c1f;
}

.access-info__button {
	display: flex;
	justify-content: center;
}

.access-info__button a {
	background-color: #d63638;
	border: none;
	border-radius: 30px;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
	color: #fff;
	cursor: pointer;
	display: inline-block;
	font-size: 14px;
	font-weight: bold;
	margin: auto;
	margin-top: 1.875rem;
	max-width: 18.75rem;
	padding: 0.625rem;
	text-align: center;
	transition: background-color 0.3s ease;
	width: 100%;
}

.access-info__button:hover a {
	background-color: #b01a1a;
}

.anotherLink-card__content {
	box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.25);
	color: #300c0c;
	display: block;
	width: 100%;
}

.anotherLink-card:hover {
	cursor: pointer;
	opacity: 0.8;
}

.anotherLink-card__image {
	position: relative;
	width: 100%;
}

.anotherLink-card__image img {
	-o-object-fit: cover;
	aspect-ratio: 1;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.anotherLink-card__title {
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.5;
	text-align: center;
}

.anotherLink-card__text {
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 1rem;
	padding: 0 0.0625rem;
}

.anotherLink-card__button {
	margin-top: 1.875rem;
	text-align: right;
}

.archive-people__member {
	margin-bottom: 16rem;
	margin-top: 2.5rem;
}

.archive-sample__list {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	/* アイテム間のスペース */
	grid-template-columns: 1fr;
	/* 1列に設定 */
}

.page-works-product {
	position: relative;
}

.archive-works-development__list {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
}

.archive-works-product__list {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	/* アイテム間のスペース */
	grid-template-columns: 1fr;
	/* 1列に設定 */
}

.archive-works-product__item {
	overflow: hidden;
	position: relative;
}

.archive-works-product__link {
	display: block;
	height: 100%;
	position: relative;
	width: 100%;
}

.archive-works-product__link img {
	-o-object-fit: cover;
	aspect-ratio: 345/219;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease-in-out;
	width: 100%;
}

.archive-works-product__link:hover img {
	transform: scale(1.1);
}

/* オーバーレイ背景＋中央タイトル */

.archive-works-product__overlay {
	align-items: center;
	background-color: rgba(0, 0, 0, 0.5);
	bottom: 0;
	display: flex;
	justify-content: center;
	left: 0;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	transition: opacity 0.3s ease-in-out;
	z-index: 1;
}

.archive-works-product__link:hover .archive-works-product__overlay {
	opacity: 1;
}

.archive-works-product__title {
	color: #fff;
	font-size: 0.9rem;
	font-weight: 600;
	line-height: 1.4;
	text-align: center;
	white-space: pre-line;
	z-index: 2;
}

.blog-card {
	background-color: #fff;
	box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.25);
	color: #300c0c;
	display: block;
	padding: 1rem 1rem 1.5rem;
	width: 100%;
}

.blog-card:hover {
	cursor: pointer;
	opacity: 0.8;
}

.blog-card__image {
	position: relative;
	width: 100%;
}

.blog-card__image img {
	-o-object-fit: cover;
	aspect-ratio: 301/201;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.blog-card__content {
	margin-top: 1.0625rem;
}

.blog-card__header {
	border-bottom: 1px solid #d63638;
	padding-bottom: 0.25rem;
}

.blog-card__date {
	font-family: "Gotu", sans-serif;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.5;
}

.blog-card__title {
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.5;
}

.blog-card__text {
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 1rem;
	padding: 0 0.0625rem;
}

.blog-card--home__image {
	overflow: hidden;
	width: 100%;
}

.blog-card--home__image img {
	height: auto;
	transition: transform 0.6s ease;
}

.blog-card--home__image:hover img {
	transform: scale(1.1);
}

.blog-bg {
	padding-top: 5rem;
}

.blog__items {
	margin: auto;
	margin-top: 1.5rem;
}

.blog__button {
	margin-top: 2.5rem;
	text-align: center;
}

body {
	background-color: #DDD6CD;
}

.breadcrumb__inner,
.breadcrumb__inner--white {
	color: #300c0c;
	font-size: 0.875rem;
	font-weight: 400;
	letter-spacing: 0.05em;
}

.breadcrumb__inner--white {
	color: #fff;
}

.card-list__item+.card-list__item {
	margin-top: 2.5rem;
}

/* 通常時は非表示 */

.child__item {
	background-color: #ebebeb;
	display: none;
	left: 0;
	position: absolute;
	top: 100%;
	transition: all 1s;
	width: 100%;
}

.child__item li a {
	color: #444;
	display: block;
	font-size: 0.875rem;
	font-weight: bold;
	padding: 1.25rem 0;
	text-align: center;
}

.child__item li:not(:first-child) a {
	border-top: 1px solid #acacac;
	/* 2番目以降のリンクにのみ上線を付ける */
}

.child__item li a:hover {
	background-color: #acacac;
}

.column-grid {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.column-grid__swiper {
	margin-bottom: 24px;
	order: -1;
	width: 100%;
}

.column-grid__item {
	width: 100%;
}

.column-flex {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	justify-content: flex-start;
	margin-top: 3.75rem;
}

.column-flex__item {
	width: 100%;
}

.column__swiper {
	height: 100%;
	position: relative;
	width: 100%;
}

.column__swiper img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.column__pickup {
	position: relative;
}

.column__pickup a {
	display: block;
	height: 100%;
}

.column__pickup img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.column-pickup__content {
	bottom: 16px;
	color: #fff;
	display: flex;
	flex-direction: column;
	font-size: 0.875rem;
	gap: 1rem;
	left: 16px;
	max-width: 90%;
	position: absolute;
	z-index: 2;
}

.column-pickup__header {
	display: flex;
	flex-direction: column;
	font-size: 0.875rem;
	gap: 0.25rem;
}

.column-pickup__categry {
	align-self: flex-start;
	background-color: #d63638;
	color: #fff;
	display: inline-block;
	padding: 0.125rem 0.5rem;
}

.column-pickup__text {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.column-pickup__title {
	font-size: 1.125rem;
	font-weight: bold;
}

.column-pickup__info {
	align-items: center;
	color: #fff;
	display: flex;
	font-size: 0.875rem;
	margin-top: auto;
}

.column-pickup__read {
	align-items: center;
	display: flex;
	gap: 0.25rem;
}

.column-pickup__icon {
	color: #fff;
	font-size: 0.875rem;
}

.column-pickup__divider {
	color: #fff;
	margin: 0 0.5rem;
}

.column-pickup__date {
	margin-left: 0.25rem;
}

.swiper-pagination {
	background: rgba(0, 0, 0, 0.2);
	bottom: 0;
	height: 4px;
	left: 0;
	pointer-events: none;
	position: absolute;
	width: 100%;
	z-index: 2;
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
	background-color: #d63638;
}

.swiper-horizontal>.swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal,
.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite,
.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
	bottom: 0;
	top: auto;
	top: initial;
}

.column-card__box {
	background-color: rgba(255, 255, 255, 0.5098039216);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	display: flex;
	flex-direction: row;
	height: 100%;
	transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.column-card__box:hover {
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
	transform: translateY(-4px);
}

.column-card__image {
	aspect-ratio: 430/300;
	flex-shrink: 0;
	height: auto;
	overflow: hidden;
	position: relative;
	width: 40%;
}

.column-card__image img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.column-card__ribbon {
	box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
	color: #fff;
	font-size: 0.625rem;
	font-weight: bold;
	letter-spacing: 0.1em;
	padding: 0.25rem 1.875rem;
	position: absolute;
	right: -20px;
	text-align: center;
	top: 5px;
	transform: rotate(45deg);
	z-index: 2;
}

.column-card__ribbon--hot {
	background-color: #ff0004;
}

.column-card__ribbon--new {
	background-color: #fe8c00;
}

.column-card__content {
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: 1rem;
	padding: 1rem 1rem;
}

.column-card__header {
	display: flex;
	flex-direction: column;
	font-size: 0.875rem;
	gap: 0.25rem;
}

.column-card__title {
	font-weight: bold;
}

.column-card__categry {
	align-self: flex-start;
	background-color: #d63638;
	color: #fff;
	display: inline-block;
	font-size: 0.625rem;
	letter-spacing: 0.1em;
	padding: 0.125rem 0.25rem;
}

.column-card__text {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.column-card__copy {
	font-size: 0.875rem;
}

.column-card__title {
	font-size: 1rem;
	font-weight: bold;
}

.column-card__title-sub {
	font-size: 0.9rem;
}

.column-card__info {
	color: #666;
	display: flex;
	flex-direction: column-reverse;
	font-size: 0.75rem;
	margin-top: auto;
}

.column-card__read {
	align-items: center;
	display: flex;
	gap: 0.25rem;
}

.column-card__icon {
	color: #999;
	font-size: 0.875rem;
}

.column-card__divider {
	color: #ccc;
	margin: 0 0.5rem;
}

.column-card__date {
	margin-left: 0.25rem;
}

.colorbox {
	position: relative;
	width: 100%;
}

.colorbox .color {
	background-color: #d63638;
	height: 100%;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 2;
}

.colorbox img {
	display: block;
	width: 100%;
}

.common-button {
	background-color: #d63638;
	border: 1px solid #d63638;
	color: #fff;
	display: inline-block;
	font-family: "Gotu", sans-serif;
	font-size: 0.75rem;
	line-height: 1.571;
	padding: 0.6rem 1.9rem 0.5rem 0;
	position: relative;
	text-align: center;
	width: 9.625rem;
	z-index: 1;
}

.common-button span {
	border-bottom: 1px solid #fff;
	border-right: 1px solid #fff;
	display: inline-block;
	height: 0.375rem;
	margin-left: 0.3125rem;
	margin-top: 0.3125rem;
	position: absolute;
	transform: skew(45deg);
	width: 1.5rem;
	z-index: inherit;
}

.common-button::before {
	border: 1px solid #d63638;
	bottom: -0.25rem;
	content: "";
	display: inline-block;
	left: 0.25rem;
	position: absolute;
	right: -0.25rem;
	top: 0.25rem;
	z-index: -1;
}

.common-button::after {
	background-color: #fff;
	content: "";
	display: inline-block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
	width: 100%;
	z-index: -1;
}

.common-button:hover {
	color: #d63638;
}

.common-button:hover span {
	border-bottom: 1px solid #d63638;
	border-right: 1px solid #d63638;
}

.common-button:hover::after {
	transform: scale(1, 1);
}

.common-button--white {
	background-color: #fff;
	border: 1px solid #fff;
	color: #d63638;
	display: inline-block;
	font-family: "Gotu", sans-serif;
	font-size: 0.75rem;
	line-height: 1.571;
	padding: 0.6rem 1.9rem 0.5rem 0;
	position: relative;
	text-align: center;
	width: 9.625rem;
	z-index: 1;
}

.common-button--white span {
	border-bottom: 1px solid #d63638;
	border-right: 1px solid #d63638;
	display: inline-block;
	height: 0.375rem;
	margin-left: 0.3125rem;
	margin-top: 0.3125rem;
	position: absolute;
	transform: skew(45deg);
	width: 1.5rem;
	z-index: inherit;
}

.common-button--white::before {
	border: 1px solid #fff;
	bottom: -0.25rem;
	content: "";
	display: inline-block;
	left: 0.25rem;
	position: absolute;
	right: -0.25rem;
	top: 0.25rem;
	z-index: -1;
}

.common-button--white::after {
	background-color: #d63638;
	content: "";
	display: inline-block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
	width: 100%;
	z-index: -1;
}

.common-button--white:hover {
	color: #fff;
}

.common-button--white:hover span {
	border-bottom: 1px solid #fff;
	border-right: 1px solid #fff;
}

.common-button--white:hover::after {
	transform: scale(1, 1);
}

.contact-button {
	background-color: #d63638;
	border: 1px solid #d63638;
	color: #fff;
	display: inline-block;
	font-family: "Gotu", sans-serif;
	font-size: 0.875rem;
	line-height: 1.571;
	padding: 1.125rem;
	text-align: center;
	transition: 0.5s;
	width: 12.625rem;
	/* マウスカーソルを外すとき */
}

.contact-button:hover {
	background-color: #FFF;
	border: 1px solid #d63638;
	color: #d63638;
	transition: 0.5s;
	/* マウスカーソルを載せるとき */
}

.company-profile__contents {
	background-color: rgba(255, 255, 255, 0.5098039216);
	border: 1px solid #ddd;
	border-radius: 0.5rem;
	line-height: 1.6;
	margin: 0 auto;
	max-width: 50rem;
	padding: 0.625rem;
}

.company-profile__title {
	font-size: 1.25rem;
	font-weight: 700;
}

.company-profile__list {
	margin-top: 1.875rem;
}

.company-profile__item {
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
}

.company-profile__item+.company-profile__item {
	margin-top: 2rem;
}

.company-profile__heading {
	font-size: 1rem;
	font-weight: 700;
	text-align: left;
	width: 100%;
}

.company-profile__heading span {
	border-bottom: 1px solid #070202;
}

.company-profile__text {
	font-size: 1.125rem;
	margin-top: 0.5rem;
	text-align: left;
	width: 100%;
}

.company__button {
	margin-right: 0.625rem;
	margin-top: 1.25rem;
	text-align: right;
}

/* コメントボックスのスタイル */

.comment-box__content {
	border: 1px solid #ddd;
	border-radius: 8px;
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	margin-top: 3.75rem;
	padding: 1.25rem;
	width: 100%;
}

.comment-box__content+.comment-box__content {
	margin-top: 2.5rem;
}

/* 画像部分 */

.comment-box__image {
	display: flex;
	flex-direction: row;
	height: 100%;
	width: 40%;
}

.comment-box__image img {
	-o-object-fit: cover;
	border: 1px solid #ddd;
	border-radius: 8px;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.comment-box__description {
	padding-top: 1.25rem;
	width: 100%;
}

.comment-box__place {
	color: #070202;
	font-size: 1.2rem;
	font-weight: bold;
	margin: 0;
}

.comment-box__name span {
	font-size: 1rem;
	font-weight: normal;
	margin-right: 5px;
}

.comment-box__name {
	color: #070202;
	font-size: 1.2rem;
	font-weight: bold;
	margin-top: 5px;
}

/* コメント本文 */

.comment-box__comment {
	margin-top: 1.25rem;
}

.comment-box__text {
	color: #333;
	font-size: 0.95rem;
	line-height: 1.8;
}

/* 詳細情報リスト */

.works-info__details {
	margin-top: 2.5rem;
}

.works-info__list {
	font-size: 0.9rem;
	line-height: 1.8;
	padding: 1.25rem;
}

.works-info__item {
	color: #333;
	display: flex;
	flex-direction: column;
}

.works-info__item+.works-info__item {
	margin-top: 0.5rem;
}

.works-info__title {
	width: 100%;
}

.works-info__content {
	width: 100%;
}

.contact__header {
	border-top: 1px solid #300c0c;
	padding-top: 3.5rem;
	text-align: center;
}

.contact__title {
	font-size: 1.5rem;
	font-weight: 700;
}

.contact__comment {
	font-size: 1rem;
	margin-top: 0.5rem;
}

.contact__inner {
	margin: auto;
}

.contact__box {
	background-color: #fff;
}

.contact__box::after {
	background-image: url(../images/common/contact-fish.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	height: 3.5625rem;
	position: absolute;
	right: -0.0625rem;
	top: -1.75rem;
	width: 6.875rem;
}

.contact__info {
	margin: auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}

.contact__logo {
	border-bottom: 1px solid #d63638;
	text-align: center;
}

.contact__logo img {
	display: inline-block;
	width: 10.875rem;
}

.contact__access {
	margin-top: 1rem;
}

.contact__access-text {
	text-align: center;
}

.contact__access-text p {
	color: #300c0c;
	font-size: 1rem;
	font-weight: 400;
	letter-spacing: 0.019em;
	line-height: 1.5;
}

.contact__access-text p:not(:first-child) {
	margin-top: 0.25rem;
}

.contact__access-text p:not(:first-child) {
	margin-top: 0.25rem;
}

.contact__access-map {
	margin-top: 1rem;
	position: relative;
	width: 100%;
}

.contact__access-map::before {
	content: "";
	display: block;
	padding-top: 54.237%;
}

.contact__access-map iframe {
	-o-object-fit: cover;
	height: 100%;
	left: 50%;
	object-fit: cover;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}

.contact__content {
	margin-top: 2.5rem;
	padding-left: 1.875rem;
	padding-right: 1.875rem;
	text-align: center;
}

.contact__entitle {
	color: #300c0c;
	font-family: "Gotu", sans-serif;
	font-size: 5rem;
	font-weight: 400;
	line-height: 1;
	margin-left: calc(50% - 50vw);
	text-align: center;
	width: 100vw;
}

.contact__entitle::first-letter {
	color: #d63638;
}

.contact__text {
	color: #d63638;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.286;
	margin-top: 0.875rem;
}

.contact__button {
	margin-top: 2.5rem;
	text-align: center;
}

.contact__illust {
	display: inline-block;
	position: absolute;
	right: 0.9375rem;
	top: -1.5625rem;
	width: 6.8125rem;
	width: 100%;
}

.development-card__content {
	background-color: #fff;
	box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.25);
	color: #300c0c;
	display: flex;
	flex-direction: column;
	height: 100%;
	/* コンテンツを縦方向に配置 */
	padding: 0.5rem;
	/* 高さを均等に揃えるための設定 */
}

.development-card:hover {
	cursor: pointer;
	opacity: 0.8;
}

.development-card__image {
	position: relative;
	width: 100%;
}

.development-card__image img {
	-o-object-fit: cover;
	aspect-ratio: 301/201;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.development-card__title {
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.5;
	text-align: center;
}

.development-card__price,
.development-card__size {
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	text-align: center;
}

.faq-box__question {
	-webkit-user-select: none;
	-moz-user-select: none;
	background-color: #d63638;
	color: #fff;
	cursor: pointer;
	font-size: 1rem;
	font-weight: 400;
	margin-top: 2.5rem;
	padding: 0.875rem 1rem;
	position: relative;
	user-select: none;
}

.faq-box__question:first-child {
	margin-top: 0;
}

.faq-box__question::before,
.faq-box__question::after {
	background-color: #fff;
	content: "";
	display: block;
	height: 0.0625rem;
	position: absolute;
	right: 1rem;
	top: 50%;
	width: 1.75rem;
}

.faq-box__question::after {
	transform: rotate(0deg);
	transition-duration: 0.3s;
}

.faq-box__question.is-active::after {
	transform: rotate(-90deg);
}

.faq-box__answer {
	backface-visibility: hidden;
	background-color: #fff;
	border: 1px solid #d63638;
	color: #300c0c;
	font-size: 1rem;
	height: auto;
	letter-spacing: 0.006em;
	line-height: 1.45;
	opacity: 1;
	padding: 1.5rem 1rem 1.375rem;
}

.faq-boxes {
	grid-gap: 2.5rem;
	display: grid;
	gap: 2.5rem;
}

.form__comment {
	font-size: 1rem;
	line-height: 1.45;
	text-align: center;
}

.form__contents {
	margin-top: 2.5rem;
}

.footer {
	padding-bottom: 3.5rem;
}

.footer__info {
	border-top: 1px solid #070202;
	padding-top: 3.5rem;
}

.footer__logo {
	margin: auto;
	width: 9.5rem;
}

.footer__logoLink {
	display: block;
}

.footer__snsIcon {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-top: 2rem;
}

.footer__instagram {
	align-items: center;
	background-image: linear-gradient(90deg, #d63638, #f7a65d);
	display: flex;
	gap: 0.5rem;
	justify-content: center;
	padding: 0.625rem;
}

.footer__instagram--icon img {
	width: 1.5rem;
}

.footer__instagram--name {
	color: #FFF;
	font-size: 1rem;
	font-weight: bold;
}

.footter__nav {
	margin-top: 2.5rem;
}

.footer__copyright {
	display: block;
	margin-top: 5rem;
	text-align: center;
}

.footer__copyright {
	color: #070202;
	font-family: "Gotu", sans-serif;
	font-size: 0.75rem;
	line-height: 1.5;
}

.form__item {
	border-bottom: 1px dotted #d63638;
	padding-top: 1.5rem;
	padding-bottom: 1.5rem;
}

.form__item dt {
	color: #300c0c;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1;
}

.form__required-tag {
	background-color: #C94800;
	color: #fff;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1;
	margin-left: 0.5rem;
	padding: 0.125rem 1.125rem;
}

input::-moz-placeholder {
	color: #feeee5;
	font-size: 1rem;
	font-weight: 400;
}

input::placeholder {
	color: #feeee5;
	font-size: 1rem;
	font-weight: 400;
}

.form__checkbox {
	margin-top: 1rem;
}

.form__checkbox label {
	display: block;
}

.form__privacyCheck {
	margin-top: 2.5rem;
	text-align: center;
}

.form__button {
	margin-top: 1.5rem;
	text-align: center;
}

.form__error {
	display: none;
	justify-content: center;
}

.form__error p {
	color: #C94800;
	font-size: 0.875rem;
	padding-left: 1em;
	text-align: left;
	text-indent: -1em;
}

.form__input.error input,
.form__textarea.error textarea,
.form__checkbox.error input {
	background-color: rgba(201, 72, 0, 0.2);
	border: 1px solid #C94800;
}

.form__input.error input::-moz-placeholder {
	color: #fff;
}

.form__input.error input::placeholder {
	color: #fff;
}

.form__labelSub {
	font-size: 0.8rem;
	margin-top: 0.5rem;
	line-height: 1.2;
}

.cfswitch.is-hidden {
	display: none;
}

/*デフォルト色の指定*/

/*サイズ等の指定*/

/*ボタン系の指定*/

/*チェックボックスの指定*/

/*テキストエリアの指定*/

[type=text],
[type=search],
[type=tel],
[type=url],
[type=email],
[type=password],
[type=date],
textarea {
	background: #fff;
	background-image: none;
	/*↓リセットCSS */
	border: none;
	border: 1px solid #d63638;
	font-family: inherit;
	font-size: 1rem;
	/*↓カスタム */
	margin-top: 1rem;
	padding: 0.5rem 1rem;
	width: 100%;
	/*↓↓↓↓不要ならコメントアウト or 削除 */
	/*↓↓選択されているときの色*/
}

[type=text]:focus,
[type=search]:focus,
[type=tel]:focus,
[type=url]:focus,
[type=email]:focus,
[type=password]:focus,
[type=date]:focus,
textarea:focus {
	border: 1px solid #300c0c;
}

[type=tel] {
	width: 100%;
}

.wpcf7-list-item {
	display: block;
	line-height: 1;
}

.wpcf7-list-item+.wpcf7-list-item {
	margin-top: 0.5rem;
}

input[type=checkbox] {
	display: none;
}

.wpcf7-list-item-label {
	display: inline-block;
	height: 20px;
	line-height: 20px;
	padding-left: 25px;
	position: relative;
}

.wpcf7-list-item-label::before {
	background: #fff;
	border: 1px solid #d63638;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 20px;
	left: 0;
	position: absolute;
	top: 0;
	width: 20px;
}

input[type=checkbox]:checked+.wpcf7-list-item-label::after {
	border-right: 3px solid #d63638;
	border-top: 3px solid #d63638;
	content: "";
	display: block;
	height: 6px;
	left: 5px;
	position: absolute;
	top: 4px;
	transform: rotate(135deg);
	width: 9px;
}

.wpcf7-spinner {
	display: none;
}

select {
	/*↓デフォルトのアイコンを消す場合はコメントアウト（noneにする）*/
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-color: #fff;
	/*↓デフォルトではないアイコンを使う場合は入力する*/
	background-image: url(../images/common/Polygon.png);
	background-position: right 0.3125rem top 0.75rem;
	background-repeat: no-repeat;
	background-size: 0.75rem;
	border: none;
	border: 1px solid #d63638;
	/*↓リセットCSS */
	border-radius: 0;
	color: inherit;
	cursor: pointer;
	font-family: inherit;
	font-size: 0.75rem;
	/*↓カスタム */
	margin-top: 0.625rem;
	padding: 0.625rem 0.625rem;
	width: 100%;
}

select:focus {
	border: 1px solid #300c0c;
}

option {
	width: 100%;
}

textarea {
	height: 12.5rem;
	width: 100%;
}

.front-contact {
	margin-top: 3.25rem;
	position: relative;
}

.front-content {
	display: flex;
	flex-direction: column-reverse;
	position: relative;
}

.front-content__header {
	align-items: stretch;
	background-color: transparent;
	background-color: initial;
	display: flex;
	flex-direction: column;
	margin-right: 0.625rem;
	margin-top: 1.25rem;
	position: relative;
}

.front-content__title {
	align-items: center;
	border-left: 3px solid #d63638;
	color: #070202;
	display: flex;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.5;
	padding: 0.25rem 0.5rem;
	position: relative;
}

.front-content__comment {
	align-items: center;
	display: flex;
	flex: 1;
	/* 内容部分を残りスペースで伸縮可能に */
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 0.625rem;
	word-break: break-word;
	/* テキストの折り返しを有効にする */
}

.front-content__images {
	margin-top: 1.25rem;
	position: relative;
}

.front-content__button {
	bottom: 0.625rem;
	position: absolute;
	right: 0.625rem;
}

/* ========== RECORD セクション ========== */

.record-image__contents {
	grid-gap: 0.5rem;
	display: grid;
	gap: 0.5rem;
	grid-template-columns: repeat(2, 1fr);
	margin-top: 1.25rem;
}

.record-image__item {
	aspect-ratio: 1/1;
	overflow: hidden;
}

.record-image__link {
	display: block;
	height: 100%;
	position: relative;
	width: 100%;
}

.record-image__link img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
	width: 100%;
}

.record-image__link:hover img {
	transform: scale(1.1);
}

.record-image__overlay {
	align-items: center;
	background-color: rgba(0, 0, 0, 0.5);
	bottom: 0;
	color: #fff;
	display: flex;
	justify-content: center;
	left: 0;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	transition: opacity 0.3s ease;
	z-index: 1;
	/* ← これがあるからリンク押せる！ */
}

.record-image__link:hover .record-image__overlay {
	opacity: 1;
}

.record-image__title {
	font-size: 0.8rem;
	line-height: 1.4;
	text-align: center;
	white-space: pre-line;
}

/* ========== COMPANY セクション ========== */

.company-card__contents {
	display: flex;
	gap: 0.5rem;
	justify-content: space-between;
	margin-top: 1.25rem;
}

.company-card__left {
	flex: 1;
}

.company-card__right {
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: 0.5rem;
}

/* ホバー演出用スタイル */

.company-card__item {
	overflow: hidden;
	position: relative;
}

.company-card__link {
	display: block;
	height: 100%;
	position: relative;
	width: 100%;
}

.company-card__link img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
	width: 100%;
}

.company-card__link:hover img {
	transform: scale(1.1);
}

.company-card__overlay {
	align-items: center;
	background-color: rgba(0, 0, 0, 0.5);
	bottom: 0;
	display: flex;
	justify-content: center;
	left: 0;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	transition: opacity 0.3s ease;
	z-index: 1;
}

.company-card__link:hover .company-card__overlay {
	opacity: 1;
}

.company-card__title {
	color: #fff;
	font-size: 0.8rem;
	line-height: 1.4;
	text-align: center;
	white-space: pre-line;
	z-index: 2;
}

.guest-card {
	box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.25);
	padding: 0.9375rem 1rem 1.5rem;
}

.guest-card__contents {
	display: flex;
	justify-content: space-between;
}

.guest-card__content {
	margin-top: auto;
	width: 47.604%;
}

.guest-card__tag {
	border: 1px solid #d63638;
	color: #d63638;
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.833;
	padding: 0.1875rem 0.6875rem;
}

.guest-card__info {
	color: #300c0c;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.5;
}

.guest-card__title {
	border-bottom: 1px solid #d63638;
	color: #300c0c;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.4;
	margin-top: 0.25rem;
	padding-bottom: 0.3125rem;
}

.guest-card__image {
	max-width: 48.243%;
	position: relative;
	width: 100%;
}

.guest-card__image::before {
	content: "";
	display: block;
	padding-top: 77.483%;
}

.guest-card__image img {
	-o-object-fit: cover;
	height: 100%;
	left: 50%;
	object-fit: cover;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}

.guest-card__text {
	color: #070202;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 1rem;
}

.hamburger {
	height: 2.25rem;
	position: relative;
	width: 2rem;
	z-index: 9999;
}

.hamburger span {
	background-color: #fff;
	height: 0.0625rem;
	position: absolute;
	transition: 0.5s;
	width: inherit;
}

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

.hamburger span:nth-child(2) {
	opacity: 1;
	top: 50%;
}

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

.hamburger.is-active span:nth-child(1) {
	top: 48%;
	transform: rotate(37deg);
}

.hamburger.is-active span:nth-child(2) {
	opacity: 0;
	top: 50%;
}

.hamburger.is-active span:nth-child(3) {
	top: 48%;
	transform: rotate(-37deg);
}

.header {
	height: 5rem;
	left: 0;
	position: fixed;
	right: 0;
	top: 0;
	transition: 0.3s;
	width: 100%;
	z-index: 8888;
}

.header__inner {
	align-items: center;
	background-color: rgba(7, 2, 2, 0.4);
	display: flex;
	height: inherit;
	justify-content: space-between;
	padding: 0 0.9375rem;
	position: relative;
	transition: 0.3s;
	z-index: 9999;
}

.header__logoLink {
	display: block;
	padding-top: 0.4375rem;
	width: 6.9375rem;
	z-index: 100;
}

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

.home-column__header {
	font-size: 2rem;
	font-weight: bold;
	letter-spacing: 0.05em;
	line-height: 1.75;
	text-align: center;
}

.home-column__header--categry {
	text-align: left;
}

.home-column__category-head {
	border-bottom: 1px solid #d63638;
	display: inline-block;
	font-size: 1.25rem;
	font-weight: bold;
	margin-bottom: 1rem;
}

.home-column__category-description {
	font-size: 1rem;
	letter-spacing: 0.05em;
	line-height: 1.75;
	margin-top: 1.25rem;
	text-align: left;
}

.home-column__categry {
	margin-top: 2.5rem;
}

.home-column__contents {
	margin-top: 3.75rem;
}

.home-column__popularity {
	margin-top: 5rem;
}

.home-column__keyword {
	margin-top: 5rem;
}

.home-column__category-explanation {
	font-size: 1rem;
	font-weight: 400;
	letter-spacing: 0.03em;
	line-height: 1.75;
	margin-top: 2.5rem;
	text-align: center;
}

.category-explanation__first {
	display: block;
	font-family: "Noto Serif JP", serif;
	font-size: 2.5rem;
	font-weight: bold;
	margin-bottom: 0.5rem;
}

.category-explanation__second {
	display: block;
	font-size: 1.25rem;
	font-weight: bold;
	margin-bottom: 0.5rem;
}

.single-column__contents {
	display: flex;
	flex-direction: column;
	gap: 80px;
}

.single-column__sidebar {
	align-self: flex-start;
	height: -moz-fit-content;
	height: fit-content;
	margin: 0 auto;
	position: sticky;
	top: 100px;
	width: 100%;
}

.card-list--2col {
	display: flex;
	flex-direction: column;
	margin: auto;
	max-width: 31.25rem;
}

.information__contents {
	margin-left: auto;
	margin-right: auto;
	margin-top: 1.5rem;
}

.information__image {
	position: relative;
	width: 100%;
}

.information__image::before {
	content: "";
	display: block;
	padding-top: 65.797%;
}

.information__image img {
	-o-object-fit: cover;
	display: inline-block;
	height: 100%;
	left: 50%;
	object-fit: cover;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}

.information__content {
	margin-top: 1.5rem;
}

.information__title {
	border-bottom: 1px solid #d63638;
	color: #300c0c;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.2;
	padding-bottom: 0.25rem;
}

.information__text {
	color: #300c0c;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 0.5rem;
}

.information__button {
	margin-top: 2.5rem;
	text-align: center;
}

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

.loader {
	align-items: center;
	background-color: #fff;
	display: flex;
	height: 100vh;
	justify-content: center;
	left: 0;
	position: fixed;
	top: 0;
	width: 100vw;
	z-index: 99998;
}

.loader__header {
	color: #d63638;
	left: 50%;
	position: absolute;
	text-align: center;
	top: 50%;
	transform: translate(-50%, -50%);
	z-index: 99999;
}

.loader-title {
	color: #d63638;
	font-family: "Gotu", sans-serif;
	font-size: 2.5rem;
	font-weight: 400;
	letter-spacing: 0.54em;
	line-height: 1;
	text-transform: uppercase;
}

.loader__subtitle {
	color: #d63638;
	font-family: "Gotu", sans-serif;
	font-size: 1.25rem;
	font-weight: 400;
	line-height: 1;
	text-transform: uppercase;
}

.mv {
	height: 100vh;
}

.mv__inner {
	position: relative;
}

.mv__images {
	height: 100vh;
	position: relative;
}

.mv__img--sp {
	display: block;
}

.mv__img--pc {
	display: none;
}

.mv__img::before {
	content: "";
	display: block;
	padding-top: 177.867%;
}

.mv__img img {
	-o-object-fit: cover;
	height: 100%;
	left: 50%;
	object-fit: cover;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}

.nav-contents__box {
	-ms-overflow-style: none;
	display: flex;
	flex-wrap: wrap;
	scrollbar-width: none;
}

.nav-contents__box::-webkit-scrollbar {
	display: none;
}

.nav-contents__left,
.nav-contents__right {
	width: 50%;
}

.nav-contents__right {
	padding-left: 0.6875rem;
}

.nav-contents__left .nav-contents__items:nth-child(2) {
	margin-top: 2.5rem;
}

.nav-contents__right .nav-contents__items:nth-child(2) {
	margin-top: 2.5rem;
}

.nav-contents__items:nth-child(4) {
	margin-top: 2.5rem;
}

.nav-contents__item:not(:first-child) {
	margin-top: 2.5rem;
}

.nav-contents__title a {
	display: flex;
}

.nav-contents__title a:hover {
	opacity: 0.7;
}

.nav-contents__title p {
	color: #070202;
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.125;
	margin-left: 0.25rem;
}

.nav-contents__title img {
	aspect-ratio: 256/182;
	display: inline-block;
	height: 100%;
	margin-top: 0.3125rem;
	width: 1rem;
}

.nav-contents__text {
	color: #070202;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1;
	margin-left: 1.5rem;
	margin-top: 1.5rem;
}

.nav-contents__text:hover {
	opacity: 0.7;
}

.news-card {
	box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.25);
	display: flex;
	flex-direction: column;
	height: 100%;
	max-width: 17.5rem;
	width: 100%;
}

.news-card__image {
	position: relative;
	width: 100%;
}

.news-card__image::before {
	content: "";
	display: block;
	padding-top: 67.143%;
}

.news-card__image img {
	-o-object-fit: cover;
	height: 100%;
	left: 50%;
	object-fit: cover;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}

.news-card__content {
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 1.0625rem 1rem 1.3125rem;
	width: 100%;
}

.news-card__header {
	border-bottom: 1px solid #d63638;
	padding-bottom: 0.5rem;
}

.news-card__tag p {
	border: 1px solid #d63638;
	color: #d63638;
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.833;
	padding: 0.1875rem 0.6875rem;
}

.news-card__title p {
	color: #300c0c;
	display: inline-block;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.5;
}

.news-card__title {
	margin-top: 0.25rem;
}

.news-card__price-pop {
	margin-top: auto;
	text-align: center;
}

.news-card__price-text {
	color: #300c0c;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.714;
}

.news-card__price-box {
	display: flex;
	justify-content: space-between;
	margin-top: 0.5rem;
	padding-left: 1.25rem;
	padding-right: 2.5rem;
}

.news-card__price-before {
	-webkit-text-decoration: line-through;
	-webkit-text-decoration: line-through;
	color: #300c0c;
	font-family: "Lato", sans-serif;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1;
	padding-top: 0.625rem;
	text-decoration: line-through;
	text-decoration-color: #c94800;
	text-decoration-thickness: 0.25rem;
}

.news-card__price-after {
	color: #d63638;
	font-family: "Lato", sans-serif;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
	padding-left: 1.1875rem;
}

.news-card--sidebar-title {
	text-align: center;
}

.news-card--sidebar__price-pop {
	margin-top: 0.5rem;
}

.news-card--sidebar__price-box {
	align-items: center;
	justify-content: center;
	padding-left: 2.5rem;
}

.news-card--sidebar__price-before {
	font-size: 1.25rem;
	line-height: 1;
}

.news-card__price-after.news-card--sidebar__price-after {
	font-size: 2rem;
	line-height: 1;
	padding-left: 1rem;
}

.news__boxes {
	display: flex;
	flex-direction: column;
	gap: 1.875rem;
}

.news__latest {
	width: 100%;
}

.news__media {
	width: 100%;
}

.newsBox__header {
	background-color: #d63638;
	color: #fff;
	font-size: 1rem;
	font-weight: 700;
	padding: 0.5rem;
}

/* 全体のリストスタイル */

.newsBox__content {
	background-color: rgba(255, 255, 255, 0.8156862745);
	display: flex;
	flex-direction: column;
	height: 18.75rem;
	overflow-y: scroll;
	padding: 0 1rem;
}

.newsBox__list {
	display: flex;
	flex-direction: column;
}

/* 各アイテムのスタイル */

.newsBox__item {
	padding: 1.25rem 0;
}

.newsBox__item+.newsBox__item {
	border-top: 1px solid #888;
}

.newsBox__meta {
	align-items: center;
	display: flex;
	flex-shrink: 0;
}

/* 日付部分 */

.newsBox__date {
	color: #070202;
	font-size: 0.9375rem;
	letter-spacing: 0.1em;
}

/* タグ部分 */

.newsBox__category {
	background-color: #E8E8E8;
	border-radius: 50px;
	flex-shrink: 0;
	font-size: 0.6875rem;
	letter-spacing: 0.05em;
	line-height: 1;
	margin-left: 0.9375rem;
	padding: 0.25rem 1.125rem;
}

/* 内容部分 */

.newsBox__title {
	border-bottom: 1px solid #070202;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.5;
}

.newsBox__text {
	font-size: 0.875rem;
	padding-top: 0.625rem;
}

.page-404 {
	background-color: #d63638;
	padding-top: 5rem;
	position: relative;
}

.page-404__inner {
	position: relative;
}

.page-404__breadcrumb {
	position: absolute;
	top: 0.5rem;
}

.page-404__image {
	max-width: 43.625rem;
	position: relative;
	top: 0;
	width: 100%;
}

.page-404__content {
	color: #fff;
	font-family: sub-english-font-family;
	font-weight: 400;
	text-align: center;
}

.page-404__box {
	left: 50%;
	position: absolute;
	top: 60%;
	transform: translate(-50%, -50%);
}

.page-404__title {
	font-size: 5rem;
	letter-spacing: 0.5em;
	line-height: 1;
	text-indent: 2.5rem;
}

.page-404__text {
	font-size: 1rem;
	line-height: 1.5;
}

.page-404__button {
	margin-top: 2.5rem;
}

.page-404__footer.footer {
	margin-top: -0.0625rem;
}

.page-aboutus {
	position: relative;
}

.page-aboutus__item::after {
	display: none;
}

.page-aboutus__images {
	padding-bottom: 0;
}

.page-aboutus__right {
	top: 0;
	width: 100%;
}

.page-aboutus__title {
	color: #fff;
	left: 1.5rem;
	position: absolute;
	top: 1.5rem;
	z-index: 3;
}

.page-news-card {
	box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.25);
	display: flex;
	flex-direction: column;
	height: 100%;
	max-width: 17.5rem;
	width: 100%;
}

.page-news-card__image {
	position: relative;
	width: 100%;
}

.page-news-card__image::before {
	content: "";
	display: block;
	padding-top: 67.143%;
}

.page-news-card__image img {
	-o-object-fit: cover;
	height: 100%;
	left: 50%;
	object-fit: cover;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}

.page-news-card__content {
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 1.125rem 0.8125rem 1.375rem 1.125rem;
	width: 100%;
}

.page-news-card__content-header {
	border-bottom: 1px solid #d63638;
	padding-bottom: 0.5rem;
}

.page-news-card__tag p {
	border: 1px solid #d63638;
	color: #d63638;
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.833;
	padding: 0.1875rem 0.6875rem;
}

.page-news-card__content-title p {
	color: #300c0c;
	display: inline-block;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.5;
}

.page-news-card__price-pop {
	margin-top: 0.5rem;
	text-align: center;
}

.page-news-card__price-text {
	color: #300c0c;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.714;
}

.page-news-card__price-box {
	display: flex;
	justify-content: center;
	margin-top: 0.5rem;
}

.page-news-card__price-before {
	-webkit-text-decoration: line-through;
	-webkit-text-decoration: line-through;
	color: #300c0c;
	font-family: "Lato", sans-serif;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1;
	padding-top: 0.625rem;
	text-decoration: line-through;
	text-decoration-color: #c94800;
	text-decoration-thickness: 0.25rem;
}

.page-news-card__price-after {
	color: #d63638;
	font-family: "Lato", sans-serif;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
	padding-left: 1.1875rem;
}

.page-news-card__button {
	margin-top: 1rem;
	text-align: center;
}

.page-news {
	position: relative;
}

.page-news__contents {
	margin-top: 2.5rem;
}

.page-news__card-list {
	align-items: center;
	align-items: center;
	display: grid;
	justify-items: center;
	justify-items: center;
	place-items: center;
}

.page-news__content-item+.page-news__content-item {
	margin-top: 2.5rem;
}

.page-company-profile__list {
	margin-top: 2.5rem;
}

.page-faq {
	position: relative;
}

.page-information {
	position: relative;
}

.page-navi {
	margin-top: 5rem;
}

.page-price {
	position: relative;
}

.page-privacy-policy {
	position: relative;
}

.page-service__message p {
	font-size: 1rem;
	line-height: 1.5;
	text-align: center;
}

.page-service__image {
	margin-top: 1.5rem;
}

.page-service__image img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.page-service__youtube {
	aspect-ratio: 16/9;
	margin-top: 1.5rem;
	width: 100%;
}

.page-service__youtube iframe {
	height: 100%;
	width: 100%;
}

.page-service__title {
	margin-top: 2.5rem;
	text-align: left;
}

.page-service__image--2col {
	display: flex;
	gap: 1rem;
	justify-content: flex-start;
	margin-top: 1.5rem;
}

.page-service__image--2col img {
	-o-object-fit: contain;
	display: block;
	object-fit: contain;
	width: 50%;
}

.page-service__contents {
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	margin-top: 1.5rem;
	text-align: left;
}

.page-service__contents .page-service__circle {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.5;
}

.page-service__contents .page-service__circle::before {
	color: #d63638;
	content: "● ";
}

.page-service__contents--2col {
	align-items: flex-start;
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	justify-content: center;
	margin-top: 1.5rem;
	text-align: left;
}

.page-service__contents--2col iframe {
	width: 100%;
}

.page-service__item--2col {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	width: 100%;
}

.page-service__item--2col p {
	font-size: 1rem;
	line-height: 1.5;
}

.page-service__item--2col span {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.5;
}

.page-service__item--2col span::before {
	color: #d63638;
	content: "● ";
}

.page-service__contents p {
	font-size: 1rem;
	line-height: 1.5;
}

.page-service__contents li {
	color: #300c0c;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	padding-left: 1.6875rem;
	text-align: left;
	text-indent: -1.6875rem;
}

.page-service__contents li::before {
	background: url(../images/common/hitode_blue.png) no-repeat;
	background-size: contain;
	content: "";
	display: inline-block;
	height: 1.125rem;
	margin-right: 0.5625rem;
	vertical-align: middle;
	width: 1.125rem;
}

.page-service__contents img {
	-o-object-fit: contain;
	height: 100%;
	max-height: 29.25rem;
	object-fit: contain;
	width: 100%;
}

.page-service__button {
	margin-top: 2.5rem;
	text-align: right;
}

.page-service__box {
	border: 1px solid #070202;
	margin-top: 1.875rem;
}

.page-service__box table {
	border-collapse: collapse;
	display: block;
	font-size: 1rem;
	width: 100%;
}

.page-service__box tr {
	display: block;
}

.page-service__box th,
.page-service__box td {
	border: 1px solid #070202;
	display: block;
	padding: 0.625rem;
	text-align: left;
	width: 100%;
}

.page-service__box th {
	font-weight: bold;
	width: 100%;
}

.page-service__box td {
	width: 100%;
}

.page-service__list {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	/* アイテム間のスペース */
	grid-template-columns: repeat(2, 1fr);
	/* 2列に設定 */
	margin-top: 2.5rem;
}

.page-siteMAP__inner {
	width: 100%;
}

.page-siteMAP__content {
	position: relative;
}

.page-siteMAP__content .nav-contents__title p,
.page-siteMAP__content .nav-contents__text {
	color: #300c0c;
}

.page-siteMAP__content-right {
	padding-left: 1.375rem;
}

.page-siteMAP__content-right .nav-contents__items:nth-child(2) {
	margin-top: 1.25rem;
}

.page-thanks {
	position: relative;
}

.page-thanks__content {
	color: #300c0c;
	font-size: 1rem;
	font-weight: 400;
	text-align: center;
}

.page-thanks__title {
	font-size: 1.5rem;
	line-height: 1.125;
}

.page-thanks__messege {
	line-height: 1.4;
	margin-top: 2.5rem;
}

.page-thanks__footer {
	margin-top: 9.25rem;
}

.page-transfer__list {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	justify-content: space-between;
}

.page-transfer__item {
	position: relative;
}

.page-transfer__image {
	position: relative;
}

.page-transfer__button {
	bottom: 0.625rem;
	position: absolute;
	right: 0.625rem;
}

.pagination {
	display: flex;
	gap: 0.75rem;
	justify-content: center;
	margin-top: 80px;
}

.pagination .page-numbers {
	-webkit-text-decoration: none;
	align-items: center;
	background-color: #FFF;
	border: 1px solid #d63638;
	color: #d63638;
	cursor: pointer;
	display: inline-flex;
	font-family: "Lato", sans-serif;
	font-size: 1rem;
	font-weight: bold;
	height: 2.375rem;
	justify-content: center;
	position: relative;
	text-decoration: none;
	transition: 0.3s ease;
	width: 2.375rem;
}

.pagination .page-numbers.current {
	background-color: #d63638;
	color: #FFF;
}

.pagination .page-numbers:hover {
	background-color: #d63638;
	color: #fff;
}

.pagination .prev,
.pagination .next {
	-webkit-text-decoration: none;
	background-color: #FFF;
	color: #d63638;
	font-size: 1rem;
	font-weight: bold;
	margin: 0 1rem;
	padding: 0.5rem 1rem;
	text-decoration: none;
}

.pagination .prev:hover,
.pagination .next:hover {
	background-color: #d63638;
	color: #fff;
}

.pc-nav__items {
	align-items: center;
	display: flex;
	gap: 2.5rem;
	height: inherit;
}

.pc-nav__list {
	display: flex;
	height: inherit;
}

.pc-nav__item {
	align-items: center;
	display: flex;
	flex: 1;
	/* アイテムの幅を等分 */
	min-width: 9.375rem;
	/* 最小幅を指定（狭すぎを防ぐ） */
	position: relative;
}

.pc-nav__item a {
	color: #fff;
	cursor: pointer;
	font-size: 1rem;
	font-weight: 700;
	height: 100%;
	justify-content: center;
	width: 100%;
}

.pc-nav__item a span {
	font-size: 0.875rem;
	font-weight: 400;
}

.pc-nav__item-title {
	display: flex;
	flex-direction: column;
	position: relative;
	text-align: center;
}

/* dropdownクラスhoverしたら隣接要素のdropdown_menuクラスを表示 */

.pc-nav__item-title:hover+.pc-nav__dropdown,
.pc-nav__dropdown:hover {
	display: block;
}

.popularity-blog {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.popularity-blog__card {
	background-color: #FFF;
	box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.25);
	display: flex;
	gap: 1rem;
	padding: 0.5625rem 0.5rem 0.75rem 1rem;
}

.popularity-blog__image {
	padding-bottom: 0.3125rem;
	padding-top: 0.3125rem;
	width: 7.5625rem;
}

.popularity-blog__image img {
	aspect-ratio: 121/90;
	height: 100%;
	width: 100%;
}

.popularity-blog__title time {
	color: #300c0c;
	font-size: 0.75rem;
	font-weight: 400;
	line-height: 1.5;
}

.popularity-blog__title p {
	color: #300c0c;
	font-size: 1rem;
	font-weight: 500;
	margin-top: 0.25rem;
}

.price-box__header {
	background-color: #d63638;
	display: flex;
	flex-direction: row-reverse;
	gap: 0.5rem;
	justify-content: center;
	padding: 0.4375rem 0;
}

.price-box__header p {
	color: #fff;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.5;
}

.price-box__header img {
	height: 1.5rem;
	width: 1.5rem;
}

.price-box table {
	border-collapse: collapse;
	width: 100%;
}

.price-box td {
	border: solid 1px #d63638;
	color: #300c0c;
	font-size: 1rem;
	font-weight: 400;
	height: 3.75rem;
	line-height: 1.5;
}

.price-box td.title {
	text-align: center;
	width: 69.5%;
}

.price-box td.money {
	padding-right: 1rem;
	text-align: right;
	width: 31.725%;
}

.price-boxes {
	grid-gap: 2.5rem;
	display: grid;
	gap: 2.5rem;
}

.price__contents {
	margin: auto;
	margin-top: 1.75rem;
}

.price__contents::after {
	background-image: url(../images/common/price-fish.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	bottom: 3.125rem;
	content: "";
	height: max(8.8125rem, min(13.96vw, 12.5625rem));
	left: calc(50% - max(21.6875rem, min(27.85vw, 25.0625rem)));
	position: absolute;
	transform: translateX(-50%);
	width: max(19.125rem, min(30.35vw, 27.3125rem));
}

.price__image {
	position: relative;
}

.price__image::before {
	content: "";
	display: block;
	padding-top: 65.797%;
}

.price__image img {
	-o-object-fit: cover;
	height: 100%;
	left: 50%;
	object-fit: cover;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}

.price__content {
	margin-top: 2.5rem;
}

.price__list+.price__list {
	margin-top: 2.4375rem;
}

.price__list-title {
	border-bottom: 1px solid #d63638;
	color: #300c0c;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.5;
	padding-bottom: 0.25rem;
}

.price__list-item {
	display: flex;
	justify-content: space-between;
	margin-top: 0.5rem;
}

.price__list-item li {
	color: #300c0c;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.714;
}

.price__money {
	letter-spacing: 0.02em;
	padding-left: 2.5rem;
}

.price__button {
	margin-top: 2.5rem;
	text-align: center;
}

.record__button {
	margin-right: 0.625rem;
	margin-top: 1.25rem;
	text-align: right;
}

.review-card__image {
	width: 100%;
}

.review-card__image img {
	aspect-ratio: 294/218;
	height: 100%;
	width: 100%;
}

.review-card__tag {
	color: #300c0c;
	font-size: 0.75rem;
	font-weight: 400;
	letter-spacing: -0.1em;
	line-height: 1.5;
	margin-top: 0.9375rem;
}

.review-card__title {
	color: #300c0c;
	font-size: 1.5rem;
	font-weight: 500;
	margin-top: 0.5rem;
}

.review-card__button {
	margin-top: 2.5rem;
	text-align: center;
}

.section-header {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.section-header__title {
	align-items: stretch;
	background-color: #d63638;
	border-bottom-right-radius: 1rem;
	border-top-left-radius: 1rem;
	color: #fff;
	display: flex;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.5;
	padding: 0.5rem;
	position: relative;
}

.section-header__comment {
	align-items: center;
	display: flex;
	flex: 1;
	/* 内容部分を残りスペースで伸縮可能に */
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.5;
	word-break: break-word;
	/* テキストの折り返しを有効にする */
}

.service-title {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.service-title__title {
	align-items: stretch;
	border-left: 0.3125rem solid #d63638;
	color: #070202;
	display: flex;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.5;
	padding: 0.5rem;
	position: relative;
}

.sheet-list__item+.sheet-list__item {
	margin-top: 2.5rem;
}

.sub-blog {
	position: relative;
}

.sub-blog__content {
	display: flex;
	flex-direction: column;
}

.single-blog__header {
	border-bottom: 1px solid #408F95;
}

.single-blog__header time {
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.286;
}

.single-blog__title {
	color: #0d2936;
	font-size: 1.5rem;
	font-weight: 500;
	margin-top: 0.625rem;
}

.single-blog__image {
	margin-top: 1.5rem;
}

.single-blog__image img {
	-o-object-fit: cover;
	aspect-ratio: 700/468;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.single-blog__entry {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	margin-top: 1.5rem;
}

.single-blog__entry h2 {
	font-size: 1rem;
	line-height: 1.5;
}

.single-blog__entry h3 {
	font-size: 1rem;
	line-height: 1.5;
}

.single-blog__entry p {
	font-size: 1rem;
	line-height: 1.5;
}

.single-blog__entry li {
	color: #0d2936;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	padding-left: 1.6875rem;
	text-indent: -1.6875rem;
}

.single-blog__entry li::before {
	background: url(../images/common/hitode_blue.png) no-repeat;
	background-size: contain;
	content: "";
	display: inline-block;
	height: 1.125rem;
	margin-right: 0.5625rem;
	vertical-align: middle;
	width: 1.125rem;
}

.single-blog__entry img {
	-o-object-fit: contain;
	height: 100%;
	max-height: 29.25rem;
	object-fit: contain;
	width: 100%;
}

.single-works__header {
	border-bottom: 1px solid #d63638;
}

.single-works__title {
	color: #070202;
	font-size: 2rem;
	font-weight: 500;
	padding: 0.625rem;
	text-align: center;
}

.single-works__entry {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	margin-top: 3.75rem;
}

.single-works__entry h2 {
	align-items: stretch;
	border-left: 0.3125rem solid #d63638;
	color: #070202;
	display: flex;
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.5;
	padding: 0.5rem;
	position: relative;
}

.single-works__entry h3 {
	font-size: 1rem;
	line-height: 1.5;
}

.single-works__entry h3::before {
	color: #d63638;
	content: "● ";
}

.single-works__entry .wp-block-column p {
	font-size: 1rem;
	line-height: 1.5;
}

.single-works__entry p {
	font-size: 1rem;
	line-height: 1.5;
}

.single-works__entry li {
	color: #070202;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	padding-left: 1.6875rem;
	text-indent: -1.6875rem;
}

.single-works__entry li::before {
	background: url(../images/common/list-icon.png) no-repeat;
	background-size: contain;
	content: "";
	display: inline-block;
	height: 1rem;
	margin-right: 0.5625rem;
	transform: rotate(-90deg);
	vertical-align: baseline;
	width: 1rem;
	/* 90度回転 */
}

.single-works__entry img {
	-o-object-fit: contain;
	height: 100%;
	object-fit: contain;
	width: 100%;
}

.single-works__entry iframe {
	-o-object-fit: cover;
	aspect-ratio: 500/281;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.sidebar {
	display: flex;
	flex-direction: column;
	gap: 5rem;
	margin: auto;
	margin-top: 5rem;
	width: 100%;
}

.sidebar__box {
	display: flex;
	flex-direction: column;
}

.sidebar__header span img {
	width: 3.125rem;
}

.sidebar__header {
	align-items: center;
	border-left: 7px solid #d63638;
	color: #300c0c;
	display: flex;
	font-size: 1.5rem;
	font-weight: 400;
	gap: 0.625rem;
	padding-left: 1rem;
}

.sidebar__content {
	margin-top: 24px;
	width: 100%;
}

.sidebar__new {
	display: flex;
	flex-direction: column;
	gap: 24px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.sidebar__item {
	display: flex;
	gap: 8px;
}

.sidebar-card__thumbnail {
	aspect-ratio: 430/300;
	height: 100%;
	width: 100%;
}

.sidebar-card__thumbnail img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.sidebar-card__box {
	display: flex;
	flex-direction: row;
	gap: 8px;
}

.sidebar-card__date {
	font-size: 14px;
}

.sidebar-card__categry {
	border: 1px solid #d63638;
	color: #d63638;
	display: inline-block;
	font-size: 12px;
	font-weight: bold;
	padding: 0 6px;
}

.sidebar-card__title {
	font-size: 16px;
	font-weight: bold;
}

.sidebar__popular {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.sidebar__tag {
	display: flex;
	flex-direction: row;
	gap: 0.5rem;
}

.sidebar__tag a {
	background-color: #f0f0f0;
	border-radius: 9999px;
	display: inline-block;
	font-size: 1rem;
	font-weight: bold;
	padding: 0.5rem 1rem;
	transition: background-color 0.3s ease, color 0.3s ease;
}

.sidebar__tag a:hover {
	background-color: #d63638;
	color: #fff;
}

.single-content__header {
	border-bottom: 1px solid #d63638;
}

.single-content__header time {
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.286;
}

.single-content__title {
	color: #300c0c;
	font-size: 1.5rem;
	font-weight: 500;
	margin-top: 0.625rem;
}

.single-content__image {
	margin-top: 1.5rem;
}

.single-content__image img {
	-o-object-fit: cover;
	aspect-ratio: 700/468;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.single-content__image--2col {
	display: flex;
	gap: 1rem;
	margin-top: 1.5rem;
}

.single-content__image--2col img {
	width: 50%;
}

.single-content__entry {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	margin-top: 1.5rem;
}

.single-content__entry p {
	font-size: 1rem;
	line-height: 1.5;
}

.single-content__entry li {
	color: #300c0c;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	padding-left: 1.6875rem;
	text-indent: -1.6875rem;
}

.single-content__entry li::before {
	background: url(../images/common/list-icon.png) no-repeat;
	background-size: contain;
	content: "";
	display: inline-block;
	height: 1.125rem;
	margin-right: 0.5625rem;
	margin-top: 0.3125rem;
	vertical-align: middle;
	width: 1.125rem;
}

.single-content__entry img {
	-o-object-fit: contain;
	height: 100%;
	max-height: 29.25rem;
	object-fit: contain;
	width: 100%;
}

.skills-list__list {
	border: 1px solid #070202;
	border-radius: 0.5rem;
	padding: 1.25rem;
	width: 100%;
}

.skills-list__item {
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	font-size: 1.125rem;
}

.skills-list__item+.skills-list__item {
	margin-top: 1.25rem;
}

.skills-list__title {
	font-weight: 700;
	width: 100%;
}

.skills-list__triangle {
	line-height: 1.5;
	width: 100%;
}

.skills-list__triangle::before {
	color: #d63638;
	content: "▶ ";
}

.sp-nav {
	background-color: #FFFFFF;
	display: none;
	height: 100vh;
	left: 0;
	overflow-y: scroll;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 8888;
}

.sp-nav.is-active {
	display: block;
}

.sp-nav__item {
	min-height: 100vh;
	padding-bottom: 1.9375rem;
	padding-top: 6.5rem;
}

.sub-info {
	margin: auto;
	max-width: 50rem;
}

.sub-info__title p {
	color: #300c0c;
	font-size: 1.5rem;
	font-weight: 500;
}

.sub-info__text-box.first {
	margin-top: 2.25rem;
}

.sub-info__text-box {
	margin-top: 2rem;
}

.sub-info__text-box p,
.sub-info__text-box li {
	color: #300c0c;
	font-size: 1rem;
	font-weight: 400;
	line-height: 2;
}

.sub-info__text-box ol {
	list-style-type: decimal;
	padding-left: 1.5rem;
}

.sub-mv__inner {
	position: relative;
}

.sub-mv__img img {
	-o-object-fit: cover;
	aspect-ratio: 375/460;
	height: 28.75rem;
	object-fit: cover;
}

.sub-mv__header {
	color: #fff;
	left: 50%;
	position: absolute;
	text-align: center;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
	z-index: 10;
}

.sub-mv__title {
	color: #fff;
	display: inline-block;
	font-family: "Lato", sans-serif;
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1;
}

.sub-mv__title::first-letter {
	text-transform: uppercase;
}

.sub-mv__header p {
	margin-top: 1rem;
}

.sub-mv__comment {
	margin-top: 1rem;
}

.tab-info__items {
	display: flex;
	gap: 1.1875rem;
	justify-content: space-between;
}

.tab-info__list {
	box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.25);
	cursor: pointer;
	height: 100%;
	text-align: center;
	width: 100%;
}

.tab-info__header {
	background-color: #DDF0F1;
	color: #d63638;
	display: block;
	font-size: 0.875rem;
	line-height: 1.4;
	padding: 0.625rem;
	transition: 0.3s;
}

.tab-info__header:hover {
	background-color: #d63638;
	color: #fff;
}

.tab-info__header.is-active {
	background-color: #d63638;
	color: #fff;
}

.tab-info__header.is-active .whale {
	background-color: #fff;
}

.tab-info__header.is-active .shark {
	background-color: #fff;
}

.tab-info__header.is-active .small-fish {
	background-color: #fff;
}

/* タブコンテンツ */

.tab-info__content {
	display: none;
}

.tab-info__content.is-active {
	display: inline;
	margin-top: 1rem;
	padding: 1.5rem;
}

.tab-info__title {
	border-bottom: 1px solid #d63638;
	color: #300c0c;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1;
	padding-bottom: 0.5rem;
}

.tab-info__message {
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 0.5rem;
}

.tab-info__image {
	margin-top: 0.5rem;
}

.tab-info__image img {
	-o-object-fit: cover;
	aspect-ratio: 297/189;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

/* タブメニュー */

.tab-menu__list {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem 1.3125rem;
}

.tab-menu__item {
	background-color: #fff;
	border: 1px solid #d63638;
	box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.25);
	color: #d63638;
	cursor: pointer;
	display: block;
	font-size: 0.875rem;
	line-height: 1.714;
	max-width: 10.125rem;
	padding: 0.1875rem;
	text-align: center;
	transition: 0.3s;
	width: calc((100% - 1.3125rem) / 2);
}

.tab-menu__item a {
	display: block;
}

.tab-menu__item.current {
	background-color: #d63638;
	color: #fff;
}

.tab-menu__item:hover {
	background-color: #d63638;
	color: #fff;
}

.team-section {
	width: 100%;
}

.team-section__header,
.team-section__header--management,
.team-section__header--planning,
.team-section__header--salesDevelopment,
.team-section__header--manufacturing {
	align-items: center;
	border-radius: 50%;
	color: #fff;
	display: flex;
	font-size: 1.5rem;
	font-weight: bold;
	height: 120px;
	justify-content: center;
	margin: 0 auto;
	position: relative;
	text-align: center;
	width: 120px;
	z-index: 100;
}

.team-section__header--manufacturing {
	background-color: #d63638;
}

.team-section__header--salesDevelopment {
	background-color: #43BDD9;
}

.team-section__header--planning {
	background-color: #F2C34B;
}

.team-section__header--management {
	background-color: #34747B;
}

.team-section__content {
	align-items: center;
	display: flex;
	gap: 1.875rem;
	justify-content: center;
	margin-top: 2.5rem;
	position: relative;
}

.team-section__photos,
.team-section__photos--right,
.team-section__photos--left {
	display: flex;
	flex-wrap: wrap;
	gap: 1.875rem;
	max-width: 45rem;
	padding: 0 3.75rem;
	z-index: 20;
}

.team-section__photos--left {
	justify-content: left;
}

.team-section__photos--right {
	justify-content: right;
}

.team-section__photo,
.team-section__photo--management,
.team-section__photo--planning,
.team-section__photo--salesDevelopment,
.team-section__photo--manufacturing {
	align-items: center;
	border-radius: 50%;
	display: flex;
	height: 150px;
	justify-content: center;
	overflow: hidden;
	transition: box-shadow 0.3s ease-in-out, transform 0.3s ease-in-out;
	width: 150px;
}

.team-section__photo--manufacturing {
	box-shadow: 5px 5px 10px rgb(229, 1, 18);
	/* 右下に影を追加 */
}

.team-section__photo--salesDevelopment {
	box-shadow: 5px 5px 10px rgb(67, 189, 217);
	/* 右下に影を追加 */
}

.team-section__photo--planning {
	box-shadow: 5px 5px 10px rgb(242, 195, 75);
	/* 右下に影を追加 */
}

.team-section__photo--management {
	box-shadow: 5px 5px 10px rgb(52, 116, 123);
	/* 右下に影を追加 */
}

.team-section__photo--manufacturing:hover {
	box-shadow: 0 0 30px rgba(229, 1, 18, 0.8);
	transform: scale(1.01);
}

.team-section__photo--salesDevelopment:hover {
	box-shadow: 0 0 30px rgba(67, 189, 217, 0.8);
	transform: scale(1.01);
}

.team-section__photo--planning:hover {
	box-shadow: 0 0 30px rgba(242, 195, 75, 0.8);
	transform: scale(1.01);
}

.team-section__photo--management:hover {
	box-shadow: 0 0 3dvi rgba(52, 116, 123, 0.8);
	transform: scale(1.01);
}

.team-section__photo a,
.team-section__photo--manufacturing a,
.team-section__photo--salesDevelopment a,
.team-section__photo--planning a,
.team-section__photo--management a {
	height: 100%;
	width: 100%;
}

.team-section__photo img,
.team-section__photo--manufacturing img,
.team-section__photo--salesDevelopment img,
.team-section__photo--planning img,
.team-section__photo--management img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.team-section__descriptionRight,
.team-section__descriptionRight--planning,
.team-section__descriptionRight--manufacturing {
	border-bottom-left-radius: 200px;
	border-bottom-right-radius: 0;
	border-top-left-radius: 200px;
	border-top-right-radius: 0;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
	color: white;
	font-size: 1.875rem;
	height: 400px;
	padding: 1.875rem 0;
	padding-right: 1.25rem;
	position: absolute;
	right: 0;
	text-align: center;
	top: 11.25rem;
	width: 200px;
	writing-mode: vertical-rl;
	z-index: 10;
}

.team-section__descriptionRight--manufacturing {
	background: linear-gradient(to bottom, #d63638, #f97306);
	transform: translateY(-50%);
}

.team-section__descriptionRight--planning {
	background: linear-gradient(to bottom, #F1C04A, #d63638);
	transform: translateY(-50%);
}

.team-section__descriptionLeft,
.team-section__descriptionLeft--management,
.team-section__descriptionLeft--salesDevelopment {
	border-bottom-left-radius: 0;
	border-bottom-right-radius: 200px;
	border-top-left-radius: 0;
	border-top-right-radius: 200px;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
	color: white;
	font-size: 1.875rem;
	height: 400px;
	left: 0;
	padding: 1.875rem 0;
	padding-left: 1.25rem;
	position: absolute;
	text-align: center;
	top: 12.5rem;
	width: 200px;
	writing-mode: vertical-lr;
	z-index: 10;
}

.team-section__descriptionLeft--salesDevelopment {
	background: linear-gradient(to bottom, #DADB55, #89CED7);
	transform: translateY(-50%);
}

.team-section__descriptionLeft--management {
	background: linear-gradient(to bottom, #46AD4B, #3570A1);
	transform: translateY(-50%);
}

.page-terms-of-service {
	position: relative;
}

.toggle-list__content {
	display: none;
}

.toggle-list__title,
.toggle-list__title--child {
	color: #d63638;
	cursor: pointer;
	display: block;
	font-size: 1.5rem;
	font-weight: 400;
	margin-top: 0.0625rem;
	padding-left: 2rem;
	position: relative;
}

.toggle-list__title::after,
.toggle-list__title--child::after {
	background-image: url(../images/common/toggle-button.png);
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	display: inline-block;
	height: 1.25rem;
	left: -0.625rem;
	position: absolute;
	top: 30%;
	transform: translate(50%);
	transition: 0.3s;
	vertical-align: middle;
	width: 1.25rem;
}

.toggle-list__title.is-active::after,
.is-active.toggle-list__title--child::after {
	top: 30%;
	transform: translate(50%) rotate(90deg);
	transition: 0.3s;
}

.toggle-list__title.is-active::before,
.is-active.toggle-list__title--child::before {
	opacity: 0;
}

.toggle-list__title+.toggle-list__title,
.toggle-list__title--child+.toggle-list__title,
.toggle-list__title+.toggle-list__title--child,
.toggle-list__title--child+.toggle-list__title--child {
	margin-top: 0.25rem;
}

.toggle-list__content {
	margin-top: 0.25rem;
	padding-left: 2rem;
}

.top-up {
	bottom: 0.9375rem;
	position: fixed;
	right: 0.9375rem;
	z-index: 1000;
}

.top-up a:hover {
	opacity: 0.8;
}

.top-up__circle {
	background-color: #fff;
	border: 1px solid #d63638;
	border-radius: 50%;
	box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
	display: inline-block;
	height: 3rem;
	position: relative;
	width: 3rem;
}

.top-up__yazirusi {
	left: 0.625rem;
	position: absolute;
	top: 50%;
	transform: rotate(270deg);
	width: 1.75rem;
}

.top-up__line01 {
	background-color: #d63638;
	height: 0.0625rem;
}

.top-up__line02 {
	background-color: #d63638;
	height: 0.0625rem;
	position: absolute;
	right: 0;
	top: 0;
	transform: rotate(45deg);
	transform-origin: right bottom;
	width: 0.625rem;
}

.topic__contents {
	align-items: flex-start;
	background-color: rgba(255, 255, 255, 0.6431372549);
	border-radius: 0.5rem;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	padding: 1.25rem;
	text-align: left;
}

.topic__contents span {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.5;
}

.topic__contents span::before {
	color: #d63638;
	content: "● ";
}

.topic__title {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.5;
}

.topic__text {
	font-size: 1rem;
	line-height: 1.5;
}

.voice__items {
	margin: auto;
	margin-top: 1.5rem;
}

.voice__button {
	margin-top: 2.5rem;
	text-align: center;
}

.contact-badge {
	-webkit-text-decoration: none;
	background-color: #d63638;
	border-radius: 50%;
	bottom: 5rem;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
	color: #fff;
	height: 3rem;
	overflow: hidden;
	position: fixed;
	right: 0.9375rem;
	text-decoration: none;
	transition: all 0.3s ease;
	width: 3rem;
	z-index: 999;
}

.contact-badge__content {
	height: 100%;
	position: relative;
	width: 100%;
}

.contact-badge__icon {
	font-size: 1.2rem;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	transition: top 0.3s ease;
}

.contact-badge__text {
	opacity: 0;
}

.development-3d__viewer {
	aspect-ratio: 400/200;
	display: block;
	height: 100%;
	width: 100%;
	background: #FFF;
}

.development-3d__controlWrapper {
	margin-top: 1.25rem;
}

.development-3d__viewerWrapper {
	margin-bottom: 1.5em;
}

.development-3d__note {
	padding-right: 1rem;
	text-align: right;
}

.development-3d__tabButtons {
	display: flex;
	justify-content: space-between;
}

.development-3d__tabButton {
	background: rgba(249, 249, 249, 0.8);
	border: 1px solid #ccc;
	border-radius: 0 0.5rem 0 0;
	cursor: pointer;
	flex: 0 0 49%;
	padding: 0.2rem 1rem;
}

.development-3d__tabButton.is-active {
	background: #333;
	border-color: #333;
	color: #fff;
}

.development-3d__tabContent {
	background: rgba(249, 249, 249, 0.8);
	padding: 0.5rem;
}

.development-3d__textureGroup {
	display: flex;
	padding-bottom: 0.5rem;
	padding-top: 0.5rem;
}

.development-3d__textureGroup+.development-3d__textureGroup {
	border-top: 0.0625rem solid #ccc;
}

.development-3d__textureLabel {
	font-size: 0.875rem;
	font-weight: 700;
	width: 40%;
}

.development-3d__sizeButtons {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 60%;
}

.development-3d__sizeButton {
	background: #eee;
	border: 0.0625rem solid #ccc;
	box-sizing: border-box;
	cursor: pointer;
	flex: 0 0 32%;
	padding: 0.2rem 0;
	text-align: center;
	font-size: 0.875rem;
}

.development-3d__sizeButton:hover,
.development-3d__sizeButton.is-active {
	background: #333;
	border-color: #333;
	color: #fff;
}

.js-3d-tab-content {
	display: none;
}

.js-3d-tab-content.is-active {
	display: block;
}

/* カスタムローディングスタイル */
.development-3d__viewer-wrapper {
	position: relative;
	display: block;
	height: 100%;
	width: 100%;
}

.development-3d__loading {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(255, 255, 255, 0.95);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	z-index: 10;
	transition: opacity 0.3s ease;
}

.development-3d__loading.is-hidden {
	opacity: 0;
	pointer-events: none;
}

.development-3d__loading-spinner {
	position: relative;
	width: 60px;
	height: 60px;
	margin-bottom: 20px;
}

.spinner-ring {
	position: absolute;
	width: 100%;
	height: 100%;
	border: 3px solid transparent;
	border-top: 3px solid #333;
	border-radius: 50%;
	animation: spin 1.2s linear infinite;
}

.spinner-ring:nth-child(2) {
	width: 80%;
	height: 80%;
	top: 10%;
	left: 10%;
	border-top-color: #666;
	animation-delay: -0.4s;
}

.spinner-ring:nth-child(3) {
	width: 60%;
	height: 60%;
	top: 20%;
	left: 20%;
	border-top-color: #999;
	animation-delay: -0.8s;
}

@keyframes spin {
	0% {
		transform: rotate(0deg);
	}

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

.development-3d__loading-text {
	font-size: 14px;
	color: #333;
	margin-bottom: 15px;
	font-weight: 500;
}

.development-3d__loading-progress {
	width: 200px;
	text-align: center;
}

.progress-bar {
	width: 100%;
	height: 4px;
	background-color: #e0e0e0;
	border-radius: 2px;
	overflow: hidden;
	margin-bottom: 8px;
}

.progress-fill {
	height: 100%;
	background: linear-gradient(90deg, #333, #666);
	border-radius: 2px;
	width: 0%;
	transition: width 0.3s ease;
}

.progress-percentage {
	font-size: 12px;
	color: #666;
	font-weight: 500;
}

.js-other-input {
	display: none;
}

.js-other-input.wpcf7-text {
	margin-top: 0.5rem;
}

.development-details__table {
	background-color: #fff;
	border: 1px solid #ddd;
	border-collapse: separate;
	border-radius: 0.5rem;
	border-spacing: 0;
	font-size: 1rem;
	overflow: hidden;
	width: 100%;
}

.development-details__table th,
.development-details__table td {
	box-sizing: border-box;
	display: block;
	padding: 0.5rem;
	text-align: left;
	width: 100%;
}

.development-details__table th {
	background-color: #f5f5f5;
	font-weight: bold;
	padding: 0.5rem;
	text-align: left;
}

.development-details__table td {
	border-bottom: 1px solid #eee;
}

.development-details__table tr:last-child th,
.development-details__table tr:last-child td {
	border-bottom: none;
}

.development-details__table ul {
	list-style: none;
	margin: 0;
	padding: 0.5rem;
}

.development-details__table li {
	margin-bottom: 1rem;
}

.development-details__table a {
	-webkit-text-decoration: underline;
	color: #d63638;
	font-weight: 500;
	text-decoration: underline;
}

.development-details__table a:hover {
	-webkit-text-decoration: none;
	text-decoration: none;
}

.development-details__label {
	display: block;
	font-weight: bold;
	margin-bottom: 0.25rem;
	min-width: auto;
}

.development-details__coloned {
	display: block;
	padding-left: 0;
}

.development-details__indent {
	display: block;
	margin-top: 0;
	padding-left: 1em;
}

.archive-works-development__list {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
	justify-content: flex-start;
}

.archive-works-development__item,
.development-card {
	box-sizing: border-box;
	flex: 1 1 calc(33.333% - 2rem);
	margin-bottom: 2rem;
	max-width: calc(33.333% - 2rem);
	min-width: 260px;
}

.development-image__item {
	/* 4列（gap考慮） */
	aspect-ratio: 1/1;
	cursor: pointer;
	overflow: hidden;
	width: calc(25% - 0.75rem);
}

.development-image__item img {
	-o-object-fit: cover;
	border-radius: 4px;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

/* モーダル */

.development-image__modal {
	align-items: center;
	background: rgba(0, 0, 0, 0.85);
	display: none;
	height: 100%;
	justify-content: center;
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 9999;
}

.development-image__modal.active {
	display: flex;
}

.development-image__modalContent {
	align-items: center;
	display: flex;
	height: 90%;
	justify-content: center;
	overflow: hidden;
	position: relative;
	width: 90%;
}

.development-image__modalImg {
	-o-object-fit: contain;
	border-radius: 8px;
	display: block;
	height: auto;
	max-height: 100%;
	max-width: 100%;
	object-fit: contain;
	width: auto;
}

.development-image__modalClose {
	color: #fff;
	cursor: pointer;
	font-size: 2rem;
	position: absolute;
	right: 1rem;
	top: 1rem;
}

.development-info {
	letter-spacing: 0.03em;
	line-height: 1.5;
}

.development-info__title {
	border-bottom: 1px solid #d63638;
	font-size: 1.125rem;
	font-weight: bold;
	margin-top: 1.25rem;
	padding-bottom: 0.25rem;
}

.development-info__explanation {
	font-size: 1rem;
	margin-top: 0.25rem;
}

.development-info__reference-price {
	font-size: 1.125rem;
	margin-top: 0.25rem;
}

.development-info__header {
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	line-height: 1.5;
}

.development-info__table {
	border-collapse: collapse;
	display: block;
	margin-top: 1rem;
	width: 100%;
}

.development-info__table tbody {
	display: block;
}

.development-info__table tr {
	display: block;
}

.development-info__table th,
.development-info__table td {
	background-color: #fff;
	display: block;
	font-size: 1rem;
	letter-spacing: 0.03em;
	line-height: 1.5;
	padding: 0.5rem 1rem;
	text-align: left;
	vertical-align: top;
	width: 100%;
}

.development-info__table th {
	background-color: #f5f5f5;
}

.development-info__table td a {
	color: #d63639;
	text-decoration: underline;
	font-style: italic;
}

.development-section-title {
	border-bottom: 1px solid #d63638;
	font-size: 1.125rem;
	font-weight: bold;
	margin-bottom: 1.5rem;
	padding-bottom: 0.25rem;
}

.home-categry__list {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 1.5rem 0rem;
}

.home-categry__list li {
	font-size: 1.25rem;
	letter-spacing: 0.03em;
	line-height: 1.5;
	text-align: center;
	width: 100%;
}

.home-categry__list li a strong {
	font-weight: bold;
}

.home-categry__item.is-current a {
	border-bottom: 2px solid #d63638;
	color: #d63638;
	font-weight: bold;
}

.keyword-column__header {
	font-size: 1.5rem;
	font-weight: bold;
	letter-spacing: 0.05em;
	line-height: 1.75;
	text-align: center;
}

.keyword-column__dots {
	font-size: 0.75rem;
	font-weight: bold;
	text-align: center;
}

.keyword-column__list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
	justify-content: center;
	margin-top: 1.25rem;
}

.keyword-column__link {
	background-color: #f0f0f0;
	border-radius: 9999px;
	display: inline-block;
	font-size: 1rem;
	font-weight: bold;
	padding: 0.5rem 1rem;
	transition: background-color 0.3s ease, color 0.3s ease;
}

.keyword-column__link:hover {
	background-color: #d63638;
	color: #fff;
}

.keyword-column__item.is-current .keyword-column__link {
	background-color: #d63638;
	color: #fff;
}

.people-impressions__list {
	display: flex;
	flex-direction: column;
	gap: 2.5rem;
}

.people-impressions__item {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.people-impressions__comment {
	background: #fff;
	border: 2px solid #eee;
	border-radius: 1.25rem;
	display: inline-block;
	font-size: 1rem;
	padding: 0.625rem 1rem;
	position: relative;
}

.people-impressions__comment::before {
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-top: 10px solid #ffffff;
	bottom: -10px;
	content: "";
	height: 0;
	left: 30%;
	position: absolute;
	width: 0;
}

.people-impressions__image {
	align-items: center;
	aspect-ratio: 1/1;
	border-radius: 50%;
	display: flex;
	height: auto;
	justify-content: center;
	overflow: hidden;
	transition: box-shadow 0.3s ease-in-out, transform 0.3s ease-in-out;
	width: 55%;
}

.people-impressions__image.planning_relations {
	box-shadow: 5px 5px 10px rgb(242, 195, 75);
}

.people-impressions__image.sales_development {
	box-shadow: 5px 5px 10px rgb(67, 189, 217);
}

.people-impressions__image.management {
	box-shadow: 5px 5px 10px rgb(52, 116, 123);
}

.people-impressions__image.manufacturing {
	box-shadow: 5px 5px 10px rgb(229, 1, 18);
}

.people-impressions__image a {
	height: 100%;
	width: 100%;
}

.people-impressions__image img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.people-impressions__image:hover {
	transform: translateY(-2px);
}

.popularity-column__header {
	font-size: 1.5rem;
	font-weight: bold;
	letter-spacing: 0.05em;
	line-height: 1.75;
	text-align: center;
}

.popularity-column__dots {
	font-size: 0.75rem;
	font-weight: bold;
	text-align: center;
}

.popularity-column__list {
	grid-gap: 1.5rem;
	display: grid;
	gap: 1.5rem;
	margin-top: 1.25rem;
}

.popularity-column__item {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	overflow: hidden;
	transition: box-shadow 0.3s ease, transform 0.3s ease;
	width: 100%;
}

.popularity-column__link {
	color: inherit;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.popularity-column__thumb {
	aspect-ratio: 430/300;
	overflow: hidden;
	width: 100%;
}

.popularity-column__thumb img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.popularity-column__item:hover {
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
	transform: translateY(-4px);
}

.single-column__text {
	margin-top: 2.5rem;
	text-align: center;
}

.single-column__copy {
	font-size: 0.875rem;
}

.single-column__title {
	font-size: 1.5rem;
	padding: 0.5rem 0;
}

.single-column__author-list {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	margin-top: 2.5rem;
	text-align: center;
}

.single-column__author-item {
	font-family: "Noto Serif JP", serif;
	font-size: 0.875rem;
}

.single-column__header {
	align-items: baseline;
	display: flex;
	flex-direction: column;
	font-size: 0.875rem;
	font-weight: bold;
	gap: 0.5rem;
	justify-content: space-between;
	margin-top: 1rem;
}

.single-column__categry {
	background-color: #d63638;
	color: #fff;
	padding: 0.125rem 0.375rem;
}

.single-column__info {
	align-items: center;
	color: #666;
	display: flex;
	font-size: 14px;
}

.single-column__read {
	align-items: center;
	display: flex;
	gap: 4px;
}

.single-column__icon {
	color: #999;
	font-size: 14px;
}

.single-column__divider {
	color: #ccc;
	margin: 0 8px;
}

.single-column__date {
	margin-left: 4px;
}

.single-column__image {
	margin-top: 2.5rem;
}

.single-column__thumbnail {
	aspect-ratio: 430/300;
}

.single-column__image img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.single-column__entry {
	word-wrap: anywhere;
	margin-top: 3.75rem;
}

.single-column__entry h3 {
	border-left: 4px solid #d63638;
	font-size: 1.5rem;
	font-weight: bold;
	letter-spacing: 0.05em;
	line-height: 1.75;
	margin: 2.5rem 0;
	padding-left: 0.5rem;
}

.single-column__entry h4 {
	border-bottom: 1px solid #d63638;
	font-size: 1.25rem;
	font-weight: bold;
	letter-spacing: 0.05em;
	line-height: 1.75;
	margin: 1.875rem 0;
	padding-bottom: 0.25rem;
}

.single-column__entry p {
	font-size: 1rem;
	letter-spacing: 0.05em;
	line-height: 1.75;
	margin: 1.25rem 0;
}

.single-column__entry p a {
	-webkit-text-decoration: underline;
	font-size: 1rem;
	font-style: italic;
	letter-spacing: 0.05em;
	line-height: 1.75;
	text-decoration: underline;
}

.single-column__entry li {
	font-size: 1rem;
	line-height: 1.75;
	list-style: circle inside;
	margin: 0.5rem 0;
}

.single-column__entry figure {
	margin: 2.5rem 0;
}

.single-column__entry img {
	-o-object-fit: cover;
	height: auto;
	object-fit: cover;
	width: auto;
}

/* 商品INFO */

.single-development__series {
	border-bottom: 1px solid #333;
	display: inline-block;
	font-family: "Montserrat", sans-serif;
	font-size: 0.875rem;
	letter-spacing: 0.03em;
	line-height: 1.5;
	padding: 0.125rem 0.75rem;
}

.single-development__title {
	font-size: 1.75rem;
	letter-spacing: 0.03em;
	line-height: 1.5;
}

.single-development__3d {
	margin-top: 2.5rem;
	width: 100%;
}

.single-development__image {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 2rem;
}

.single-development__explanation {
	font-size: 1rem;
	margin-top: 2.5rem;
}

.single-development__explanation p+p {
	margin-top: 0.5rem;
}

.single-development__info {
	margin-top: 2.5rem;
}

.single-development__cta {
	background-color: #CEC8BF;
	margin-top: 2.5rem;
	padding: 2rem 1rem;
	text-align: center;
}

.single-development__ctaTitle {
	color: #d63638;
}

.single-development__ctaText {
	margin-top: 0.5rem;
}

.single-development__ctaButton {
	-webkit-text-decoration: none;
	background-color: #d63638;
	border-radius: 0.25rem;
	color: #fff;
	display: inline-block;
	margin-top: 1rem;
	padding: 1rem 2rem;
	text-decoration: none;
	transition: background-color 0.3s ease;
}

.single-development__ctaButton:hover {
	background-color: #a62d2f;
}

.single-faq {
	margin-top: 3.75rem;
	width: 100%;
}

.single-faq__item {
	border-bottom: 1px solid #ccc;
	cursor: pointer;
	padding: 1rem 0;
}

.single-faq__question {
	font-weight: bold;
	position: relative;
}

.single-faq__question::after {
	content: "+";
	font-size: 1.2rem;
	position: absolute;
	right: 0;
	transition: transform 0.3s;
}

.single-faq__item.open .single-faq__question::after {
	content: "−";
}

.single-faq__answer {
	color: #333;
	display: none;
	margin-top: 0.5rem;
}

.single-nav {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	margin: 5rem auto 0;
	max-width: 37.5rem;
}

.single-nav__prev {
	display: flex;
	flex-shrink: 0;
}

.single-nav__center {
	align-items: center;
	display: flex;
	flex-direction: column;
	flex-shrink: 0;
}

.single-nav__next {
	display: flex;
	flex-shrink: 0;
}

.single-nav__center span {
	color: #d63638;
}

.single-nav__prev a,
.single-nav__next a {
	align-items: center;
	cursor: pointer;
	display: inline-flex;
	font-size: 1rem;
	font-weight: bold;
	justify-content: center;
	transition: 0.3s ease;
}

.single-nav__button {
	align-items: center;
	color: #d63638;
	cursor: pointer;
	display: inline-flex;
	font-size: 0.875rem;
	font-weight: bold;
	justify-content: center;
	transition: 0.3s ease;
}

.single-nav__prev a:hover,
.single-nav__next a:hover,
.single-nav__button:hover {
	opacity: 0.7;
}

.single-people__content {
	display: flex;
	flex-direction: column;
	gap: 5rem;
}

.single-people__box {
	width: 100%;
}

.single-people__image {
	align-items: center;
	aspect-ratio: 1/1;
	border-radius: 50%;
	display: flex;
	height: auto;
	justify-content: center;
	margin: 0 auto;
	overflow: hidden;
	transition: box-shadow 0.3sease-in-out, transform 0.3sease-in-out;
	width: 80%;
}

.single-people__image.planning_relations {
	box-shadow: 5px 5px 10px rgb(242, 195, 75);
}

.single-people__image.sales_development {
	box-shadow: 5px 5px 10px rgb(67, 189, 217);
}

.single-people__image.management {
	box-shadow: 5px 5px 10px rgb(52, 116, 123);
}

.single-people__image.manufacturing {
	box-shadow: 5px 5px 10px rgb(229, 1, 18);
}

.single-people__image img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.single-people__info {
	border-left: 2px solid #333;
	margin-left: 1.875rem;
	margin-top: 2.5rem;
	padding: 0.625rem 1.25rem 0.625rem;
}

.single-people__name {
	font-size: 1.5rem;
	font-weight: bold;
	letter-spacing: 0.05em;
	line-height: 1.75;
}

.single-people__description {
	font-size: 1rem;
	letter-spacing: 0.03em;
	line-height: 1.75;
	margin-top: 1.125rem;
}

.single-people__heading {
	font-size: 1.375rem;
	font-weight: bold;
	margin-bottom: 1.25rem;
	padding-bottom: 0.5rem;
	position: relative;
	text-align: center;
}

.single-people__heading::after {
	background: #ff5733;
	bottom: 0;
	content: "";
	display: block;
	height: 3px;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	width: 15%;
}

.single-people__q span,
.single-people__a span {
	color: #d63638;
	font-size: 1.125rem;
	font-weight: bold;
}

.single-people__question-list {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.single-people__question-item {
	box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.1);
	padding: 1rem;
}

.single-people__q,
.single-people__a {
	display: flex;
	flex-direction: row;
	font-size: 1rem;
	gap: 0.5rem;
	letter-spacing: 0.03em;
	line-height: 1.75;
}

.single-people__q {
	font-weight: bold;
	padding-bottom: 0.5rem;
}

.single-people__a {
	border-top: 1px solid rgba(51, 51, 51, 0.1764705882);
	padding-top: 0.5rem;
}

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

	.archive-works-development__list {
		grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	}

	.column-grid {
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		grid-template-rows: repeat(3, 1fr);
	}

	.column-grid__swiper {
		grid-area: 1/1/3/3;
		margin-bottom: 0;
		order: 0;
	}

	.column-grid__item {
		width: auto;
	}

	.column-grid__item:nth-of-type(2) {
		grid-area: 1/3/2/4;
	}

	.column-grid__item:nth-of-type(3) {
		grid-area: 1/4/2/5;
	}

	.column-grid__item:nth-of-type(4) {
		grid-area: 2/3/3/4;
	}

	.column-grid__item:nth-of-type(5) {
		grid-area: 2/4/3/5;
	}

	.column-grid__item:nth-of-type(6) {
		grid-area: 3/3/4/4;
	}

	.column-grid__item:nth-of-type(7) {
		grid-area: 3/4/4/5;
	}

	.column-flex__item {
		width: calc((100% - 120px) / 4);
	}

	.column-card__box {
		flex-direction: column;
	}

	.column-card__image {
		width: 100%;
	}

	.column-card__ribbon {
		color: #fff;
		font-size: 0.75rem;
		padding: 0.5rem 3.75rem;
		right: -40px;
		top: 16px;
	}

	.column-card__categry {
		font-size: 0.75rem;
		padding: 0.125rem 0.5rem;
	}

	.column-card__copy {
		font-size: 1rem;
	}

	.column-card__title {
		font-size: 1.125rem;
	}

	.column-card__info {
		align-items: center;
		flex-direction: row;
		font-size: 0.875rem;
	}

	.record-image__contents {
		grid-template-columns: repeat(3, 1fr);
	}

	.home-column__header--categry {
		text-align: center;
	}

	.home-column__category-description {
		text-align: center;
	}

	.home-column__popularity {
		margin-top: 6.25rem;
	}

	.home-column__keyword {
		margin-top: 8.75rem;
	}

	.category-explanation__first {
		font-size: 3.125rem;
		font-weight: bold;
		margin-bottom: 1rem;
	}

	.category-explanation__second {
		font-size: 1.5rem;
		font-weight: bold;
		margin-bottom: 1rem;
	}

	.single-works__entry {
		margin-top: 5rem;
	}

	.sidebar-card__box {
		flex-direction: column;
	}

	.sidebar__popular {
		gap: 0.5rem;
	}

	.sidebar__tag {
		flex-direction: column;
	}

	.u-desktop {
		display: block;
	}

	.u-mobile {
		display: none;
	}

	html {
		font-size: 1.4814814815vw;
	}

	.top-contact {
		margin: auto;
		margin-top: 8.75rem;
	}

	.top-footer {
		margin-top: 10rem;
	}

	.top-section {
		margin-top: 7.5rem;
		position: relative;
	}

	.top-sub-contents {
		margin-top: 5rem;
	}

	.about__images {
		padding-bottom: 5rem;
	}

	.about__contents {
		display: flex;
		gap: 2.5rem;
		margin-top: 0;
		position: absolute;
		right: 2.5rem;
		top: 12.5rem;
		z-index: 10;
	}

	.about__title {
		color: #fff;
		font-size: 5rem;
		line-height: 1.25;
	}

	.about-content {
		margin-top: 0;
		width: 25rem;
	}

	.about__text {
		color: #fff;
	}

	.archive-people__member {
		margin-top: 5rem;
	}

	.archive-works-product__list {
		grid-template-columns: repeat(2, 1fr);
	}

	.archive-works-product__item img {
		aspect-ratio: 580/369;
	}

	.archive-sample__list {
		grid-template-columns: repeat(2, 1fr);
		/* 2列に設定 */
	}

	.blog {
		position: relative;
	}

	.blog-bg {
		height: 40%;
		padding-top: 6.25rem;
		width: 100%;
	}

	.blog-bg::before {
		background-image: url("../images/common/blog-bg.jpg");
		background-size: cover;
		content: "";
		height: 60%;
		left: 0px;
		position: absolute;
		top: 0px;
		width: 100%;
		z-index: -1;
	}

	.blog__items {
		position: relative;
		z-index: 10;
	}

	.blog__items::before {
		background-image: url(../images/common/blog-fish.png);
		background-position: center;
		background-repeat: no-repeat;
		background-size: contain;
		content: "";
		height: 12.5625rem;
		left: calc(50% - min(27.85vw, 25.0625rem));
		position: absolute;
		top: -10.625rem;
		transform: translateX(-50%);
		width: min(30.35vw, 27.3125rem);
		z-index: 30;
	}

	.blog__button {
		margin-top: 5rem;
	}

	.breadcrumb__inner,
	.breadcrumb__inner--white {
		letter-spacing: 0.05em;
	}

	.card-list {
		grid-gap: 2.5rem;
		display: grid;
		gap: 2.5rem;
		grid-template-columns: repeat(3, 1fr);
	}

	.card-list__item+.card-list__item {
		margin-top: 0;
	}

	.company-profile__contents {
		padding: 1.875rem;
	}

	.company-profile__item {
		flex-direction: row;
	}

	.company-profile__heading {
		width: 25%;
	}

	.company-profile__heading span {
		border-bottom: none;
	}

	.company-profile__text {
		margin-top: 0;
		width: 75%;
	}

	.company__button {
		margin-right: 1.875rem;
		margin-top: 2.5rem;
	}

	.contact__inner {
		padding-left: 1.5625rem;
		padding-right: 1.5625rem;
	}

	.contact__box {
		align-items: center;
		box-shadow: 4px 4px 10px 0px rgba(0, 0, 0, 0.25);
		display: flex;
		margin: auto;
		padding: 4.1875rem 7rem 5rem 3.125rem;
	}

	.contact__box::after {
		height: max(6.0625rem, min(10.21vw, 9.1875rem));
		right: calc(50% - max(32.1875rem, min(46.81vw, 42.125rem)));
		top: -2.5rem;
		width: max(13.1875rem, min(21.39vw, 19.25rem));
	}

	.contact__info {
		margin: 0;
		padding-left: 0;
		padding-right: 0;
		padding-top: 1rem;
		width: 48%;
	}

	.contact__logo {
		border-bottom: 0;
	}

	.contact__logo img {
		min-width: 12.5rem;
	}

	.contact__access {
		display: flex;
		margin-top: 1.5625rem;
	}

	.contact__access-text {
		text-align: left;
		width: 38%;
	}

	.contact__access-map {
		margin-top: 0;
		width: 62%;
	}

	.contact__access-map::before {
		padding-top: 54.212%;
	}

	.contact__content {
		border-left: 1px solid #d63638;
		margin-left: 5rem;
		margin-top: 0.3125rem;
		padding-bottom: 1rem;
		padding-left: 8.75rem;
		padding-right: 0;
		padding-top: 0.5625rem;
		width: 35%;
	}

	.contact__entitle {
		margin-left: -3.625rem;
		position: relative;
		width: auto;
		width: initial;
		z-index: 50;
	}

	.contact__text {
		width: 110%;
	}

	.contact__button {
		margin-top: 2.25rem;
	}

	.contact__illust {
		right: 3.125rem;
		top: -1.25rem;
		width: 18.8125rem;
	}

	/* コメントボックスのスタイル */

	.comment-box__content {
		flex-direction: row;
	}

	/* 画像部分 */

	.comment-box__image {
		flex-direction: column;
		width: 20%;
	}

	.comment-box__description {
		width: 80%;
	}

	.common-button {
		background-color: #d63638;
		border: 1px solid #d63638;
		color: #fff;
		display: inline-block;
		font-family: "Gotu", sans-serif;
		font-size: 0.875rem;
		line-height: 1.571;
		padding: 1.125rem 3.375rem 1rem 0;
		position: relative;
		text-align: center;
		width: 12.625rem;
		z-index: 1;
	}

	.common-button span {
		border-bottom: 1px solid #fff;
		border-right: 1px solid #fff;
		display: inline-block;
		height: 0.375rem;
		margin-left: 0.3125rem;
		margin-top: 0.3125rem;
		position: absolute;
		transform: skew(45deg);
		width: 2.5rem;
		z-index: inherit;
	}

	.common-button::before {
		border: 1px solid #d63638;
		bottom: -0.25rem;
		content: "";
		display: inline-block;
		left: 0.25rem;
		position: absolute;
		right: -0.25rem;
		top: 0.25rem;
		z-index: -1;
	}

	.common-button::after {
		background-color: #fff;
		content: "";
		display: inline-block;
		height: 100%;
		left: 0;
		position: absolute;
		top: 0;
		transform: scale(0, 1);
		transform-origin: left top;
		transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
		width: 100%;
		z-index: -1;
	}

	.common-button:hover {
		color: #d63638;
	}

	.common-button:hover span {
		border-bottom: 1px solid #d63638;
		border-right: 1px solid #d63638;
	}

	.common-button:hover::after {
		transform: scale(1, 1);
	}

	.common-button--white {
		background-color: #fff;
		border: 1px solid #fff;
		color: #d63638;
		display: inline-block;
		font-family: "Gotu", sans-serif;
		font-size: 0.875rem;
		line-height: 1.571;
		padding: 1.125rem 3.375rem 1rem 0;
		position: relative;
		text-align: center;
		width: 12.625rem;
		z-index: 1;
	}

	.common-button--white span {
		border-bottom: 1px solid #d63638;
		border-right: 1px solid #d63638;
		display: inline-block;
		height: 0.375rem;
		margin-left: 0.3125rem;
		margin-top: 0.3125rem;
		position: absolute;
		transform: skew(45deg);
		width: 2.5rem;
		z-index: inherit;
	}

	.common-button--white::before {
		border: 1px solid #fff;
		bottom: -0.25rem;
		content: "";
		display: inline-block;
		left: 0.25rem;
		position: absolute;
		right: -0.25rem;
		top: 0.25rem;
		z-index: -1;
	}

	.common-button--white::after {
		background-color: #d63638;
		content: "";
		display: inline-block;
		height: 100%;
		left: 0;
		position: absolute;
		top: 0;
		transform: scale(0, 1);
		transform-origin: left top;
		transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
		width: 100%;
		z-index: -1;
	}

	.common-button--white:hover {
		color: #fff;
	}

	.common-button--white:hover span {
		border-bottom: 1px solid #fff;
		border-right: 1px solid #fff;
	}

	.common-button--white:hover::after {
		transform: scale(1, 1);
	}

	.development-card__content {
		padding: 1rem;
	}

	.faq-box__question {
		font-size: 1.25rem;
		padding: 1.5625rem 2.5rem;
	}

	.faq-box__question::before,
	.faq-box__question::after {
		height: 0.0625rem;
		right: 2.5rem;
		width: 2rem;
	}

	.faq-box__answer {
		margin-top: 1rem;
		padding: 2.4375rem;
	}

	/* テキストのデザイン */

	.front-image__title {
		/* 内側の余白 */
		border-radius: 5px;
		/* 完全に中央に揃える */
		color: #fff;
		/* テキストの色を白に設定 */
		font-size: 1rem;
		/* 親要素の中央に配置 */
		left: 50%;
		/* 背景色より前面に表示 */
		opacity: 0;
		/* フォントサイズを調整 */
		padding: 0.5rem 1rem;
		position: absolute;
		text-align: center;
		/* 親要素内で自由に配置 */
		top: 50%;
		/* 親要素の中央に配置 */
		transform: translate(-50%, -50%);
		/* 初期状態は非表示 */
		transition: opacity 0.3s ease-in-out;
		/* 表示切り替えを滑らかに */
		width: 100%;
		/* 角を丸くする */
		z-index: 2;
	}

	.footer {
		padding: 5rem 0;
	}

	.footer__info {
		display: flex;
	}

	.footer__logo {
		margin: 0;
		width: 12.8125rem;
	}

	.footer__snsIcon {
		display: flex;
		flex-direction: row;
		gap: 1rem;
		margin-left: 2.1875rem;
		margin-top: 0;
	}

	.footter__nav {
		margin-top: 4.875rem;
	}

	.footer__copyright {
		margin-top: 4.6875rem;
	}

	.footer__copyright {
		font-size: 0.875rem;
		margin-top: 7.5rem;
	}

	.form__contents {
		margin-top: 3.75rem;
	}

	.form__item {
		align-items: flex-start;
		display: flex;
		padding-bottom: 2.5rem;
	}

	.form__item dt {
		width: 30%;
	}

	.form__item dd {
		margin-left: 0.625rem;
		width: 68%;
	}

	.form__checkbox {
		margin-top: 0;
	}

	.form__privacyCheck {
		margin-top: 5rem;
	}

	.form__button {
		margin-top: 2.5rem;
	}

	[type=text],
	[type=search],
	[type=tel],
	[type=url],
	[type=email],
	[type=password],
	[type=date],
	textarea {
		margin-top: 0;
	}

	select {
		margin-top: 0;
	}

	.front-contact {
		margin-top: 2.5rem;
	}

	.front-contact__inner {
		margin: auto;
		max-width: 46.875rem;
	}

	.front-content {
		flex-direction: column;
	}

	.front-content__header {
		background-color: #fff;
		flex-direction: row;
		left: 1.875rem;
		margin-right: 1.875rem;
		position: absolute;
		top: 3.75rem;
	}

	.front-content__title {
		align-items: center;
		background-color: #d63638;
		color: #fff;
		display: flex;
		font-size: 1.75rem;
		font-weight: 700;
		padding: 0.5rem 1rem;
		position: relative;
	}

	.front-content__comment {
		display: flex;
		font-size: 1.25rem;
		margin-top: 0;
		padding: 0.625rem;
	}

	.front-content__images {
		margin-top: 2.5rem;
	}

	.front-content__button {
		bottom: 1.875rem;
		right: 1.875rem;
	}

	.front-company__contents {
		margin-top: 2rem;
	}

	.front-company__title {
		font-size: 1.2rem;
	}

	.front-image__contents {
		/* 3列構成 */
		grid-gap: 0.5rem;
		display: grid;
		gap: 0.5rem;
		/* グリッドレイアウトを使用 */
		grid-template-columns: repeat(3, 1fr);
		/* アイテム間の間隔 */
		margin-top: 1.25rem;
		/* 上部の余白 */
	}

	.guest-card {
		padding: 1.5rem 1.5rem 1.5rem;
	}

	.guest-card__content {
		width: 58.475%;
	}

	.guest-card__header {
		align-items: flex-end;
		display: flex;
		justify-content: space-between;
	}

	.guest-card__tag {
		padding: 0.375rem 1rem;
	}

	.guest-card__title {
		font-size: 1.5rem;
		margin-top: 0.5rem;
	}

	.guest-card__image {
		max-width: 38.136%;
	}

	.guest-card__image::before {
		padding-top: 77.778%;
	}

	.guest-card__text {
		margin-top: 2.5rem;
	}

	.header {
		height: 5.625rem;
	}

	.header__inner {
		padding: 0 2.5rem;
	}

	.header__logoLink {
		width: 8.875rem;
	}

	.header__drawer {
		display: none;
	}

	.header__pc-nav {
		display: block;
	}

	.header__sp-nav {
		display: none;
	}

	.single-column__contents {
		flex-direction: row;
		gap: 40px;
	}

	.single-column__sidebar {
		width: 18.375rem;
	}

	.card-list--2col {
		grid-gap: 5rem 2.5rem;
		display: grid;
		gap: 5rem 2.5rem;
		grid-template-columns: repeat(2, 1fr);
		max-width: none;
	}

	.information__contents {
		align-items: center;
		display: flex;
		margin-top: 2.5rem;
	}

	.information__image {
		width: 50%;
	}

	.information__image::before {
		padding-top: 65.926%;
	}

	.information__content {
		margin-top: 0;
		padding-left: 2.8125rem;
		width: 50%;
	}

	.information__title {
		font-size: 1.5rem;
		line-height: 1;
		padding-bottom: 0.5rem;
	}

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

	.loader-title {
		font-size: 5rem;
		line-height: 1.25;
	}

	.mv__img--sp {
		display: none;
	}

	.mv__img--pc {
		display: block;
	}

	.mv__img::before {
		padding-top: 53.333%;
	}

	.nav-contents__left,
	.nav-contents__right {
		display: flex;
	}

	.nav-contents__right {
		padding-left: 1rem;
	}

	.nav-contents__items {
		width: 50%;
	}

	.nav-contents__left .nav-contents__items:nth-child(2) {
		margin-top: 0;
		padding-left: 1rem;
	}

	.nav-contents__right .nav-contents__items:nth-child(2) {
		margin-top: 0;
		padding-left: 0.5rem;
	}

	.news-card {
		max-width: 20.875rem;
	}

	.news-card__image::before {
		padding-top: 66.967%;
	}

	.news-card__content {
		padding: 1.5rem 1rem 2.5rem;
	}

	.news-card__tag p {
		padding: 0.375rem 1rem;
	}

	.news-card__title {
		margin-top: 0.125rem;
	}

	.news-card__price-text {
		font-size: 1rem;
		line-height: 1.5;
		margin-top: 0.875rem;
		padding-right: 1.25rem;
	}

	.news-card__price-before {
		font-size: 1.5rem;
		padding-top: 0.875rem;
	}

	.news-card__price-after {
		font-size: 2.5rem;
		padding-left: 1.5rem;
	}

	.news__boxes {
		flex-direction: row;
	}

	.news__latest {
		width: 60%;
	}

	.news__media {
		width: 40%;
	}

	.page-404__breadcrumb {
		top: 1.125rem;
	}

	.page-404__box {
		top: 55%;
	}

	.page-404__title {
		font-size: 9.375rem;
		text-indent: 4.6875rem;
	}

	.page-404__text {
		margin-top: 2.5rem;
	}

	.page-404__button {
		margin-top: 5rem;
	}

	.page-aboutus__images {
		display: block;
		padding-bottom: 3.75rem;
	}

	.page-aboutus__right {
		top: 5rem;
		width: 81.481%;
	}

	.page-aboutus__contents {
		gap: 4.0625rem;
		right: 2.1875rem;
		top: 11rem;
	}

	.page-aboutus__title {
		position: relative;
	}

	.page-aboutus__text {
		padding-top: 3.125rem;
	}

	.page-news-card {
		max-width: 20.875rem;
		max-width: none;
		width: 100%;
	}

	.page-news-card__image::before {
		padding-top: 66.967%;
	}

	.page-news-card__content {
		padding: 1.5rem 1.5rem 2.5rem;
	}

	.page-news-card__content-header {
		padding-bottom: 0.375rem;
	}

	.page-news-card__tag p {
		padding: 0.375rem 1rem;
	}

	.page-news-card__content-title p {
		font-size: 1.375rem;
		letter-spacing: 0.1em;
	}

	.page-news-card__price-pop {
		margin-top: 0;
	}

	.page-news-card__price-text {
		font-size: 1rem;
		line-height: 1.5;
		margin-top: 1.5rem;
		padding-right: 1.25rem;
	}

	.page-news-card__price-before {
		font-size: 1.5rem;
		padding-top: 0.875rem;
	}

	.page-news-card__price-after {
		font-size: 2.5rem;
		padding-left: 2.5rem;
	}

	.page-news-card__message {
		color: #300c0c;
		font-size: 1rem;
		font-weight: 400;
		line-height: 1.5;
		margin-top: 1.5rem;
	}

	.page-news-card__comment {
		color: #d63638;
		margin-top: 2rem;
		text-align: center;
	}

	.page-news-card__date {
		font-family: "Lato", sans-serif;
		font-size: 1rem;
		font-weight: 700;
		letter-spacing: 0.03em;
		line-height: 1.125;
		text-indent: -0.9375rem;
	}

	.page-news-card__button-text {
		font-size: 0.875rem;
		font-weight: 400;
		line-height: 1.286;
		margin-top: 0.3125rem;
	}

	.page-news__card-list {
		grid-column-gap: 2.5rem;
		grid-row-gap: 5rem;
		grid-template-columns: repeat(2, 1fr);
	}

	.page-news__content-item+.page-news__content-item {
		margin-top: 0;
	}

	.page-company-profile__list {
		margin-top: 5rem;
	}

	.page-faq__inner {
		max-width: 46.875rem;
	}

	.page-navi {
		clear: both;
		text-align: center;
	}

	.page-price__inner {
		max-width: 46.875rem;
	}

	.page-service__image {
		margin-top: 2.5rem;
	}

	.page-service__youtube {
		margin-top: 2.5rem;
	}

	.page-service__title {
		margin-top: 5rem;
	}

	.page-service__image--2col {
		margin-top: 2.5rem;
	}

	.page-service__contents {
		gap: 2.5rem;
		margin-top: 2.5rem;
	}

	.page-service__contents--2col {
		align-items: center;
		flex-direction: row;
		gap: 2.5rem;
		margin-top: 2.5rem;
	}

	.page-service__item--2col {
		gap: 1rem;
	}

	.page-service__contents img {
		width: 60%;
	}

	.page-service__button {
		margin-top: 5rem;
	}

	.page-service__box table {
		display: table;
	}

	.page-service__box tr {
		display: table-row;
	}

	.page-service__box th,
	.page-service__box td {
		display: table-cell;
	}

	.page-service__box th {
		width: 20%;
	}

	.page-service__box td {
		width: 80%;
	}

	.page-siteMAP__inner {
		max-width: 1180px;
	}

	.page-siteMAP__content-left {
		padding-left: 1.875rem;
	}

	.page-siteMAP__content-left .nav-contents__items:nth-child(2) {
		padding-left: 2.5rem;
	}

	.page-siteMAP__content-right {
		padding-left: 4.25rem;
	}

	.page-siteMAP__content-right .nav-contents__items:nth-child(2) {
		margin-top: 0;
		padding-left: 2.8125rem;
	}

	.page-thanks__messege {
		line-height: 1.42;
	}

	.page-thanks__footer {
		margin-top: 7.5rem;
	}

	.page-transfer__list {
		flex-direction: row;
	}

	.price-box {
		display: flex;
	}

	.price-box__header {
		align-items: center;
		flex-direction: column;
		width: 28.571%;
	}

	.price-box__header img {
		height: 4rem;
		width: 4rem;
	}

	.price-box table {
		width: 71.429%;
	}

	.price-box td {
		height: 3.6875rem;
	}

	.price-box td.title {
		padding-left: 0.9375rem;
		text-align: left;
		width: 66.275%;
	}

	.price-boxes {
		gap: 5rem;
	}

	.price__contents {
		display: flex;
		flex-direction: row-reverse;
		justify-content: space-between;
		margin-top: 2.5rem;
	}

	.price__image {
		width: 30.75rem;
	}

	.price__image::before {
		padding-top: 151.626%;
	}

	.price__content {
		margin-top: 0;
		width: 30.75rem;
	}

	.price__list-item li {
		font-size: 1rem;
		line-height: 1.5;
	}

	.price__button {
		margin-top: 5rem;
		position: relative;
		z-index: 50;
	}

	.record__button {
		margin-right: 1.875rem;
		margin-top: 2.5rem;
	}

	.section-header {
		flex-direction: row;
		gap: 1.875rem;
	}

	.section-header__title {
		font-size: 2rem;
		padding: 1rem;
	}

	.section-header__comment {
		font-size: 1.5rem;
	}

	.service-title {
		flex-direction: row;
		gap: 1.875rem;
	}

	.service-title__title {
		font-size: 2rem;
		padding: 1rem;
	}

	.sheet-list {
		grid-column-gap: 2.5rem;
		grid-row-gap: 5rem;
		display: grid;
		grid-template-columns: repeat(2, 1fr);
	}

	.sheet-list__item+.sheet-list__item {
		margin-top: 0;
	}

	.sidebar {
		margin-top: 0;
		width: 18.375rem;
	}

	.sidebar-news .news-card__image::before {
		padding-top: 63.967%;
	}

	.sidebar-news .news-card__content {
		padding: 0.75rem 1.375rem 1.5rem;
	}

	.single-content__title {
		font-size: 2rem;
		margin-top: 0.5rem;
	}

	.single-content__image {
		margin-top: 2.5rem;
	}

	.single-content__image--2col {
		margin-top: 2.5rem;
	}

	.single-content__entry {
		gap: 2.5rem;
		margin-top: 2.5rem;
	}

	.skills-list__item {
		flex-direction: row;
	}

	.skills-list__title {
		width: 30%;
	}

	.skills-list__triangle {
		width: 70%;
	}

	.sub-info__title p {
		font-size: 2rem;
	}

	.sub-info__text-box ol {
		font-size: 1.375rem;
	}

	.sub-mv__inner {
		height: 34.25rem;
	}

	.sub-mv__img img {
		aspect-ratio: 548/1440;
		height: 34.25rem;
	}

	.sub-mv__header {
		top: 59%;
	}

	.sub-mv__title {
		font-size: 2.5rem;
		line-height: 1.25;
	}

	.tab-info__items {
		gap: 6rem;
	}

	.tab-info__header {
		align-items: center;
		display: flex;
		font-size: 1.5rem;
		gap: 0.5rem;
		justify-content: center;
	}

	.tab-info__header .whale {
		-webkit-mask-image: url(../images/common/whale.png);
		-webkit-mask-repeat: no-repeat;
		-webkit-mask-position: center;
		-webkit-mask-size: cover;
		background-color: #d63638;
		display: inline-block;
		height: 4rem;
		mask-image: url(../images/common/whale.png);
		mask-position: center;
		mask-repeat: no-repeat;
		mask-size: cover;
		width: 4rem;
	}

	.tab-info__header:hover .whale {
		background-color: #fff;
	}

	.tab-info__header .shark {
		-webkit-mask-image: url(../images/common/shark.png);
		-webkit-mask-repeat: no-repeat;
		-webkit-mask-position: center;
		-webkit-mask-size: cover;
		background-color: #d63638;
		display: inline-block;
		height: 3.9375rem;
		mask-image: url(../images/common/shark.png);
		mask-position: center;
		mask-repeat: no-repeat;
		mask-size: cover;
		width: 3.9375rem;
	}

	.tab-info__header:hover .shark {
		background-color: #fff;
	}

	.tab-info__header .small-fish {
		-webkit-mask-image: url(../images/common/small-fish.png);
		-webkit-mask-repeat: no-repeat;
		-webkit-mask-position: center;
		-webkit-mask-size: cover;
		background-color: #d63638;
		display: inline-block;
		height: 4rem;
		mask-image: url(../images/common/small-fish.png);
		mask-position: center;
		mask-repeat: no-repeat;
		mask-size: cover;
		width: 4rem;
	}

	.tab-info__header:hover .small-fish {
		background-color: #fff;
	}

	.tab-info__content.is-active {
		align-items: center;
		border: 1px solid #d63638;
		display: flex;
		justify-content: space-between;
		margin-top: 1.5rem;
	}

	.tab-info__text {
		width: calc((100% - 48px) / 2);
	}

	.tab-info__image {
		margin-top: 0;
		width: calc((100% - 48px) / 2);
	}

	.tab-info__image img {
		aspect-ratio: 492/313;
	}

	.tab-menu__list {
		gap: 1rem 2rem;
	}

	.team-section__photos,
	.team-section__photos--right,
	.team-section__photos--left {
		justify-content: center;
		padding: 0 0;
	}

	.team-section__descriptionRight,
	.team-section__descriptionRight--planning,
	.team-section__descriptionRight--manufacturing {
		padding-right: 1.875rem;
		top: 6.25rem;
	}

	.team-section__descriptionLeft,
	.team-section__descriptionLeft--management,
	.team-section__descriptionLeft--salesDevelopment {
		padding-left: 1.875rem;
		top: 6.25rem;
	}

	.top-up {
		bottom: 1.25rem;
		right: 1.25rem;
	}

	.top-up__circle {
		height: 5rem;
		width: 5rem;
	}

	.top-up__yazirusi {
		left: 1.25rem;
		width: 2.5rem;
	}

	.topic__contents {
		gap: 2.5rem;
	}

	.voice__items {
		margin-top: 2.5rem;
	}

	.voice__items::before {
		background-image: url(../images/common/voice-fish.png);
		background-position: center;
		background-repeat: no-repeat;
		background-size: contain;
		content: "";
		height: 8.625rem;
		left: calc(50% - max(22.6875rem, min(32.64vw, 29.375rem)));
		position: absolute;
		top: -3.5rem;
		transform: translateX(-50%);
		width: 18.8125rem;
	}

	.voice__items::after {
		background-image: url(../images/common/voice-tatunootosigo.png);
		background-position: center;
		background-repeat: no-repeat;
		background-size: contain;
		bottom: -1.8125rem;
		content: "";
		height: 10.125rem;
		position: absolute;
		right: calc(50% - max(32rem, min(44.24vw, 39.8125rem)));
		width: 4.4375rem;
	}

	.voice__button {
		margin-top: 5rem;
	}

	.works-info__item {
		flex-direction: row;
	}

	.works-info__title {
		width: 30%;
	}

	.works-info__content {
		width: 70%;
	}

	.contact-badge {
		bottom: 7.5rem;
		height: 5rem;
		right: 1.25rem;
		width: 5rem;
	}

	.contact-badge__icon {
		font-size: 2.2rem;
	}

	.contact-badge__text {
		bottom: 1.25rem;
		font-size: 1rem;
		left: 50%;
		line-height: 1.2;
		opacity: 0;
		position: absolute;
		transform: translateX(-50%);
		transition: opacity 0.3s ease;
		writing-mode: vertical-rl;
	}

	.contact-badge:hover {
		border-radius: 1.875rem;
		height: 10rem;
	}

	.contact-badge:hover .contact-badge__icon {
		top: 1.5rem;
	}

	.contact-badge:hover .contact-badge__text {
		opacity: 1;
	}

	.development-3d__controlWrapper {
		margin-top: 2.5rem;
	}

	.development-3d__tabContent {
		padding: 2rem;
	}

	.development-3d__textureGroup {
		padding-bottom: 1rem;
		padding-top: 1rem;
	}

	.development-3d__tabButton {
		padding: 0.5rem 1rem;
	}

	.development-3d__textureLabel {
		font-size: 1rem;
	}

	.development-3d__sizeButton {
		padding: 0.5rem 0;
		font-size: 1rem;
	}

	.development-details__table th,
	.development-details__table td {
		display: table-cell;
		padding: 1rem;
		text-align: left;
		vertical-align: top;
		width: auto;
	}

	.development-details__table th {
		border-bottom: 1px solid #ddd;
		color: #333;
		text-align: center;
		width: 11.25rem;
	}

	.development-details__label {
		display: inline-block;
		min-width: 6em;
		white-space: nowrap;
	}

	.development-details__coloned {
		display: inline;
	}

	.development-details__indent {
		display: inline-block;
		padding-left: 7em;
	}

	.development-info__title {
		font-size: 1.5rem;
		margin-top: 2.5rem;
	}

	.development-info__explanation {
		margin-top: 0.5rem;
	}

	.development-info__reference-price {
		font-size: 1.25rem;
		margin-top: 0.5rem;
	}

	.development-info__header {
		font-size: 1.75rem;
	}

	.development-info__table {
		display: table;
		margin-top: 1.5rem;
	}

	.development-info__table tbody {
		display: table-row-group;
	}

	.development-info__table tr {
		display: table-row;
	}

	.development-info__table th,
	.development-info__table td {
		border: 1px solid #ddd;
		display: table-cell;
		font-size: 1.125rem;
		padding: 1rem 2rem;
		width: auto;
	}

	.development-info__table th {
		width: 25%;
	}

	.development-section-title {
		font-size: 1.5rem;
		margin-bottom: 2.5rem;
	}

	.home-categry__list {
		flex-direction: row;
		flex-wrap: wrap;
		gap: 2rem 1rem;
		justify-content: flex-start;
	}

	.home-categry__list li {
		width: calc(25% - 0.75rem);
	}

	.keyword-column__header {
		font-size: 1.75rem;
	}

	.keyword-column__dots {
		font-size: 1rem;
	}

	.keyword-column__list {
		gap: 1.25rem;
	}

	.popularity-column__header {
		font-size: 1.75rem;
	}

	.popularity-column__dots {
		font-size: 1rem;
	}

	.popularity-column__list {
		display: flex;
		flex-wrap: wrap;
		gap: 1.1875rem;
		margin-top: 3.75rem;
	}

	.popularity-column__item {
		box-sizing: border-box;
		width: calc(25% - 15px);
	}

	.single-column__text {
		margin-top: 3.75rem;
	}

	.single-column__copy {
		font-size: 1rem;
	}

	.single-column__author-list {
		gap: 0.5rem;
		margin-top: 3.75rem;
	}

	.single-column__author-item {
		font-size: 1rem;
	}

	.single-column__header {
		align-items: center;
		display: flex;
		flex-direction: row;
	}

	.single-column__entry h3 {
		margin: 3.75rem 0;
	}

	.single-column__entry h4 {
		margin: 2.5rem 0;
	}

	.single-column__entry p {
		margin: 1.875rem 0;
	}

	.single-column__entry li {
		margin: 1rem 0;
	}

	.single-column__entry figure {
		margin: 3.75rem 0;
	}

	.single-development__series {
		font-size: 1rem;
		letter-spacing: 0.03em;
		line-height: 1.5;
	}

	.single-development__title {
		font-size: 2.25rem;
		letter-spacing: 0.03em;
		line-height: 1.5;
	}

	.single-development__3d {
		margin-top: 3.75rem;
	}

	.single-development__image {
		margin-top: 3rem;
	}

	.single-development__explanation {
		margin-top: 3.75rem;
	}

	.single-development__explanation p+p {
		margin-top: 1rem;
	}

	.single-development__info {
		margin-top: 3.75rem;
	}

	.single-development__cta {
		margin-top: 3.75rem;
	}

	.single-faq {
		margin-top: 5rem;
	}

	.single-nav {
		gap: 2.5rem;
		justify-content: center;
	}

	.single-people__content {
		flex-direction: row;
		gap: 2.5rem;
		justify-content: space-between;
	}

	.single-people__box {
		width: 30%;
	}

	.single-people__image {
		width: 100%;
	}

	.single-people__heading {
		font-size: 1.5rem;
		margin-bottom: 2.5rem;
		padding-bottom: 0.75rem;
	}

}

@media (min-width: 1080px) {

	html {
		font-size: 16px;
	}

}

@media (max-width: 900px) {

	.archive-works-development__item,
	.development-card {
		flex: 1 1 calc(50% - 2rem);
		max-width: calc(50% - 2rem);
	}

}

@media (max-width: 600px) {

	.archive-works-development__item,
	.development-card {
		flex: 1 1 100%;
		max-width: 100%;
	}

}

@media (max-width: 375px) {

	html {
		font-size: 4.2666666667vw;
	}

}

@keyframes fade {

	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}

}

/* 画像モーダルの前後ボタン */
.development-image__modalPrev,
.development-image__modalNext {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: rgba(0, 0, 0, 0.5);
	color: white;
	border: none;
	font-size: 24px;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	cursor: pointer;
	z-index: 1001;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background-color 0.3s ease;
}

.development-image__modalPrev:hover,
.development-image__modalNext:hover {
	background: rgba(0, 0, 0, 0.7);
}

.development-image__modalPrev {
	left: 20px;
}

.development-image__modalNext {
	right: 20px;
}

/* 画像カウンター */
.development-image__modalCounter {
	position: absolute;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
	background: rgba(0, 0, 0, 0.7);
	color: white;
	padding: 8px 16px;
	border-radius: 20px;
	font-size: 14px;
	z-index: 1001;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {

	.development-image__modalPrev,
	.development-image__modalNext {
		width: 40px;
		height: 40px;
		font-size: 20px;
	}

	.development-image__modalPrev {
		left: 10px;
	}

	.development-image__modalNext {
		right: 10px;
	}

	.development-image__modalCounter {
		bottom: 10px;
		font-size: 12px;
		padding: 6px 12px;
	}
}


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