/**
* Theme Name: 琉球Bloomin
* Template: vogue_tcd051
* Theme URI: https://tcd-theme.com/tcd051
* Author: B'Me LLC
* Author URI: https://bme-official.com/
* Version: 2.1.6
* Requires at least: 6.0
* Requires PHP: 7.4
*/

body {
	word-break: auto-phrase;
}

.l-contents {
	background: #fff !important;
}

.l-secondary {
	display: none;
}

.p-page-header__title {
	padding: 0.5rem;
}

.p-entry__title {
	color: #ff8e43;
}

.wp-block-table {
	margin: 0;
}

@media (min-width: 1280px) {

	.l-primary {
		width: 100%;
		padding-right: 0;
	}

}

/*--------------------------------------------------------------
スプラッシュページ
--------------------------------------------------------------*/

.p-splash__desc {
	text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.4);
}

@media  (max-width: 767px){

	.p-splash__catch img {
		width: 100%;
		max-width: 70svw;
	}

}

/*--------------------------------------------------------------
ヘッダー
--------------------------------------------------------------*/

@media (max-width: 1024px) {

	.p-menu-button.is-active,
	.p-global-nav {
		background: #64cdd2;
	}

}

/*--------------------------------------------------------------
フッター
--------------------------------------------------------------*/

.p-footer-widget .menu li {
	display: inline-block;
}

.p-footer-widget .menu li:not(:last-child) {
	margin-right: 1.5rem;
}

@media (min-width: 768px) {

	.p-footer-widget .menu li:not(:last-child) {
		margin-right: 1.5rem;
	}

}

@media  (max-width: 767px) {

	.p-widget-area__inner {
		display: block !important;
	}

	.p-footer-widget {
		width: 100% !important;
	}

}

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

/* MV */
.slick-list,
.slick-slider,
.slick-track {
	height: 100%;
}

.p-hero-header__nav-item a::before,
.p-hero-header__slider-item a::before {
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	content: '';
	background: linear-gradient(to top, rgba(0, 0, 0, 0.1) 20%, transparent);
}

.p-hero-header__nav-item-title,
.p-hero-header__slider-item-title {
	text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.4);
}

/* キャッチフレーズと説明文 */
.p-content01__catch {
	color: #ff8e43;
}

/* メインイメーシ */

@media (max-width: 767px) {

	.p-main-image__title {
		margin-bottom: 1rem;
		font-size: 24px !important;
	}

	.p-main-image__img {
		padding-bottom: 50% !important;
	}

	.p-main-image__content {
		padding: 30px;
	}

}

/* お知らせ */
.p-content03 {
	height: auto;
}

.p-content03__blog {
	display: none;
}

.p-content03__news {
	width: 100%;
}

.p-article05__date,
.p-article05__title,
.p-content03__news-archive-link {
	color: #000;
}

.p-content03__news-catch {
	color: #ff8e43;
}

.p-article05__title {
	padding-bottom: 1rem;
	border-bottom: 1px solid #000;
}

/* サービス内容 */
#cb_3 {
	background: #f6f6f6;
}

.service {
	max-width: 1150px;
	width: 90%;
	margin: 0 auto;
	padding: 90px 0;
}

.service h2 {
	margin-bottom: 2.5rem;
	color: #ff8e43;
	font-size: 36px !important;
	text-align: center;
}

.service-list {
	list-style: none !important;
	margin-left: 0 !important;
	display: grid;
	gap: 1rem;
	text-align: center;
}

.service-list li {
	padding: 1rem;
	border-radius: 0.5rem;
	box-shadow: 0px 0px 1.5rem 0px rgba(172, 172, 172, 0.3);
	background: #fff;
}

.service-list img {
	width: 5rem;
	margin-bottom: 1rem;
}

.service-list h3 {
	margin-bottom: 1rem !important;
}

.service-list p {
	margin-bottom: 0 !important;
}

@media (min-width: 768px) {

	.service-list {
		grid-template-columns: repeat(2, 1fr);
		gap: 2rem;
	}

}

@media (max-width: 768px) {

	.p-main-image__content {
		position: relative!important;
	}

}

/* 清掃までの流れ */
.flow {
	max-width: 1150px;
	width: 90%;
	margin: 0 auto;
	padding: 90px 0;
}

.flow h2 {
	color: #ff8e43;
	font-size: 36px !important;
	text-align: center;
}

.flow-list {
	max-width: 960px;
	width: 100%;
	margin: 0 auto !important;
	padding-left: 0;
	counter-reset: number;
	list-style: none !important;
}

.flow-list li {
	padding-top: 2rem;
	position: relative;
}

.flow-list li::before {
	width: 2rem;
	height: 2rem;
	border-radius: 50%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	counter-increment: number 1;
	content: counter(number);
	color: #fff;
	font-size: 1.25em;
	line-height: 2rem;
	text-align: center;
	background: #00afcc;
}

.flow-list li::after {
	width: 2px;
	height: 100%;
	position: absolute;
	top: 0;
	left: calc(1rem - 1px);
	display: block;
	content: '';
	background: #00afcc;
}

.flow-list-inner {
	margin-left: 2.5rem;
	padding: 1.5rem;
	display: grid;
	gap: 1rem;
	background: #f6f6f6;
}

.flow-list-inner h3 {
	margin-bottom: 0.5rem !important;
	color: #00afcc;
	font-size: 1.25em;
}

@media (min-width: 768px) {

	.flow-list li {
		padding-top: 3rem;
	}

	.flow-list li::before {
		width: 3rem;
		height: 3rem;
		line-height: 3rem;
	}

	.flow-list-inner {
		margin-left: 3.5rem;
		grid-template-columns: 2fr 1fr;
	}

	.flow-list li::after {
		left: calc(1.5rem - 1px);
	}

}

/*--------------------------------------------------------------
メニュー紹介
--------------------------------------------------------------*/

.plan-list {
	margin-left: 0 !important;
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	gap: 1rem;
	list-style: none !important;
}

.plan-list li {
	padding: 1.5rem;
	border-radius: 0.5rem;
	box-shadow: 0px 0px 1.5rem 0px rgba(172, 172, 172, 0.3);
}

.plan-list li img {
	width: 100%;
	height: auto;
	margin-bottom: 1rem;
	object-fit: cover;
}

.plan-list h2 {
	margin-bottom: 1rem !important;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid #000;
}

.plan-list p {
	margin-bottom: 0 !important;
}

.plan-list a {
	position: relative;
}

.plan-list a::after {
	width: 1.5rem;
	height: 0.5rem;
	border-right: 1px solid #ff8e43;
	border-bottom: 1px solid #ff8e43;
	position: absolute;
	right: -2rem;
	top: 50%;
	transform: skewX(45deg) translateY(-50%);
	content: '';
	display: block;
}

@media (min-width: 768px) {

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

	.plan-list li {
		margin: 1rem;
	}

}

/*--------------------------------------------------------------
ご予約・お問い合わせ
--------------------------------------------------------------*/

.wp-block-buttons>.wp-block-button {
	width: 100%;
}

.wp-block-buttons .wp-block-button__link {
	padding: 1.5rem 0;
	border: 1px solid #00afcc;
	color: #00afcc;
	background: none;
}

.contact-form dd {
	margin-left: 0;
}

.contact-form .send-button {
	width: 100%;
	max-width: 40rem;
	margin: 0 auto;
	padding: 1.5rem 2.5rem;
	border: none;
	border-radius: 10rem;
	display: block;
	transition: opacity 0.3s;
	color: #fff;
	font-weight: bold;
	background: #ff8e43;
}

.contact-form .send-button:hover {
	opacity: 0.7;
}