@charset "utf-8";
#pageHeader {
	/* background-image: url("https://cvcjapan.plavel.jp/wp-content/uploads/2025/10/h_img-1.jpg"); */
	background-size: cover;
	color: #fff;
	display: none;
}
#pageHeader h2:after {
	display: none;
}
/* .ichsystem #pageHeader,
.business #pageHeader {
	background-image: url("https://cvcjapan.plavel.jp/wp-content/uploads/2025/10/h_img.jpg");
} */
.news #pageHeader {
	background-image: url("../img/lower/h_img_news.jpg");
}
.privacy #pageHeader {
	background-image: url("https://cvcjapan.plavel.jp/wp-content/uploads/2025/10/h_img_privacy.jpg");
}
.inq #pageHeader {
	background-image: url("../img/lower/h_img_inq.jpg");
}
.recruit #pageHeader {
	background-image: url("https://cvcjapan.plavel.jp/wp-content/uploads/2025/10/h_img_recruit.jpg");
}
#pageHeader h2 {
	font-weight: 400;
	padding: 2.6em 0;
	margin-bottom: 0;
	text-shadow:0px 0px 10px #000000;
}
#pageHeader h2 em {
	display: block;
	font-size: 1.6rem;
	font-family: 'Open Sans', sans-serif;
	margin-bottom: 1.75em;
	letter-spacing: 0.08em;
}
.pankuzu {
	max-width:1200px;
	margin: 0 auto;
	display: flex;
	justify-content: flex-end;
	padding: 1em 0;
	flex-wrap: wrap;
	line-height: 1.3;
}
.pankuzu li {
	list-style: none;
	font-size: 1.4rem;
}
.pankuzu li {
	display: block;
	position: relative;
	padding-right: 2.8em;
}
.pankuzu li:after {
	content: " ";
width: 0;
height: 0;
border-style: solid;
border-width: 4px 0 4px 7px;
border-color: transparent transparent transparent #000;
	position: absolute;
	right:1.2em;
	top: 0.4em;
}
.pankuzu li a:link,
.pankuzu li a:visited {
	color:#999999;
}
.pankuzu li:last-child {
	padding-right: 0;
}
.pankuzu li:last-child:after {
	display: none;
}
.pankuzu + .section {
	border-top: solid 1px #d6d6d6;
}
.bg-gray {
	background-color: #efefef;
}
h2.about b {
	font-weight: 800;
}
p.logoImage {
	text-align: center;
	margin-bottom:3.5em;
}
#indexLinks {
	max-width: 600px;
	margin: 5.6em auto 0;
}
#indexLinks li {
	list-style: none;
	margin-bottom:2.3em;
	font-size: 2.4rem;
}
#indexLinks li a {
	display: block;
	/* background-image: url("https://cvcjapan.plavel.jp/wp-content/uploads/2025/10/indexbg-1.jpg"); */
	background-size: cover;
	color: #fff;
	padding: 2.3em 0 2.3em 3em;
	position: relative;
	box-sizing: border-box;
	border: solid 1px #afafaf;
}
#indexLinks li a span {
	display: block;
	font-size:1.6rem;
	margin-top: 1.3em;
}
#indexLinks li a:after {
	/* background-image: url("https://cvcjapan.plavel.jp/wp-content/uploads/2025/10/indexbg-1.jpg"); */
	background-size: 100% auto;
	content: " ";
	width:27px;
	padding-top:51px;
	height: 0;
	overflow: hidden;
	position: absolute;
	right: 3em;
	top:50%;
	margin-top:-25px;
}
#indexLinks li:nth-child(2) a {
	/* background-image: url("https://cvcjapan.plavel.jp/wp-content/uploads/2025/10/indexbg-2.jpg"); */
}
#indexLinks li:nth-child(3) a {
	/* background-image: url("https://cvcjapan.plavel.jp/wp-content/uploads/2025/10/indexbg-3.jpg"); */
}
#indexLinks li:nth-child(4) a {
	/* background-image: url("https://cvcjapan.plavel.jp/wp-content/uploads/2025/10/indexbg-4.jpg"); */
}
.signature {
	display: flex;
	justify-content: flex-end;
}

.signature p {
	margin-bottom: 0;
}
.signature p:last-child {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.signature p:last-child b,
.signature p:last-child span {
	display: block;
}

/*imgReplace*/
.signature p:last-child b {
 background-size: 100% auto;
 background-repeat: no-repeat;
 height: 0px;
 line-height: 2;
 overflow: hidden;
 display: block;
}
.signature p:last-child b {
	/* background-image: url("https://cvcjapan.plavel.jp/wp-content/uploads/2025/10/signature.png"); */
	width: 178px;
	padding-top: 38px;
	margin-left: 1em;
}
.purpose {
	background-image: url("https://cvcjapan.plavel.jp/wp-content/uploads/2025/10/purpose_bg.png");
	background-repeat: no-repeat;
	background-position: top right;
	margin: 0 auto;
	max-width: 870px;
	padding: 3em 0 2em;
}
.purpose li,
.performanceWrap dd li {
	list-style: none;
	line-height: 1.5;
	margin-bottom: 0.8em;
	padding-left: 3em;
	position: relative;
}
.purpose li b,
.performanceWrap dd li b {
	font-weight: 300;
	position: absolute;
	left: 0;
	top: 0;
}
.purpose-tokyo {
	background-image: url("https://cvcjapan.plavel.jp/wp-content/uploads/2025/10/purpose_bg2.jpg");
	background-size: cover;
	background-position: center bottom;
}
.purpose-tokyo .purpose {
	background-image: none;
}
.summary-map {
	max-width: 1050px;
	margin: 0 auto;
}
.summary-map > p span {
	font-weight: 500;
	margin-right: 1em;
}
.map {
	margin:1.4em 0; 
	/*display: flex;
	justify-content:space-between;*/
}
.map p {
	width:27.6%;
}
.map img {
	width: 100%;
}
.iframeWrap {
	position: relative;
	/*width:68.57%;*/
	width: 100%;
	padding-top:24em;
	height: 0;
	overflow: hidden;
}
.iframeWrap iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top:0;
}
#summaryWrap {
	/*background-image: url("../img/about/summary_bg.jpg");
	background-size: cover;
	background-position: center top;*/
}
#summaryWrap dl {
	max-width: 780px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	line-height: 2;
}
#summaryWrap dt {
	width:20%;
	font-weight: 700;
}
#summaryWrap dd {
	width: 80%;	
	margin-bottom: 1.6em;
}
#summaryWrap dd.office span {
	display: inline-block;
	margin-right: 2em;
}
#summaryWrap dd.director p,
#summaryWrap dd.adviser p {
	position: relative;
	padding-left:7em;
}
#summaryWrap dd.adviser p {
	padding-left: 13em;
}
#summaryWrap dd.director p span,
#summaryWrap dd.adviser p span {
	position: absolute;
	left: 0;
	top: 0;
}
#summaryWrap dd.org {
	display: flex;
	justify-content: space-between;
}
#summaryWrap dd.org li {
	list-style: none;
}
#summaryWrap dd.org li ul {
	padding-left: 1em;
}
#summaryWrap dd.number table th,
#summaryWrap dd.number table td {
	text-align: left;
	padding-right: 20px;
}
#summaryWrap dd.licence {
	width: 100%;
	margin-top: 1em;
}
.flexwrap {
	display: flex;
	width: 100%;
}
#summaryWrap dd.licence ul {
	margin-bottom: 2em;
}
#summaryWrap dd.licence .flexwrap ul:nth-child(odd) {
	width: 65%;
}
#summaryWrap dd.licence .flexwrap ul:nth-child(even) {
	width: 35%;
}
#summaryWrap dd.licence li {
	list-style: none;
}
/* .performanceWrap {
	max-width:970px;
	margin: 0 auto;
}
.performanceWrap dt {
	font-size:3.6rem;
	margin-bottom: 1.4em;
}
.performanceWrap dd {
	display: flex;
}
.performanceWrap dd ul:nth-child(odd) {
	width:100%;
	padding-right: 2em;
	box-sizing: border-box;
} */
#system_outline {
	max-width:1198px;
	margin: 0 auto 5em;
	width:85.57vw;
	position: relative;
}
#system_outline img {
	width: 100%;
}
#system_outline + p {
	text-align: center;
}
#system_outline + p img {
	max-width:1187px;
	width: 100%;
}
.pageNav {
	max-width: 870px;
	margin: 8em auto 0;
}
.pageNav p {
	text-align: center;
}
.pageNav ul {
	margin:1.5em auto 0;
	display: flex;
	justify-content: center;
}
.pageNav ul li {
	margin:0 1em;
	list-style: none;
}
.goback {
	margin: -3em 0 3.5em;
}
article.news h2 {
	font-size:1.6rem;
	font-weight: 700;
	margin-bottom: 5em;
}
article.news h2:after {
	display: none;
}
.textwrap article.news p {
	margin-bottom: 3em;
}
article.news .nextPrev {
	display: flex;
	justify-content: space-between;
	margin-top: 10em;
}
article.news .nextPrev.navStart {
	justify-content: flex-end;
}
article.news .nextPrev.navEnd {
	justify-content: flex-start;
}
article.news .nextPrev li {
	list-style: none;
}
article.news .nextPrev li a {
	display: inline-block;
	padding: 1em;
	width: 280px;
	box-sizing: border-box;
	background-color: #666666;
	color: #fff;
	text-align: center;
	font-weight: 300;
}
article.news .nextPrev li a::before {
    left: inherit;
    right: 26px;
    width: 4px;
    height: 4px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
article.news .nextPrev li a.prev::before {
	border-bottom: 1px solid #fff;
    border-left: 1px solid #fff;
	border-top:none;
	border-right:none;
	right: inherit;
	left: 26px;
}
.privacy dl {
	max-width: 1010px;
	margin: 0 auto;
	line-height: 2.25;
}
.privacy dt {
	font-weight: 700;
}
.privacy dd {
	margin-bottom: 2em;
}

.privacy dd li {
	list-style: none;
	text-indent: -1em;
	margin-left: 1em;
}
.privacy adress {
	background-color: #fff;
	padding:1em 2em;
	display: inline-block;
	margin-top: 2em;
}
.business .textwrap {
	max-width: 860px;
}
.business .textwrap img {
	width: 100%;
}
.business ol {
	padding-left: 3em;
	margin-bottom: 1.5em;
}
.business ol li {
	line-height: 2.25;
	list-style: decimal;
}
.f_manage {
	display: flex;
	justify-content: center;
}
.golink-btn.f_manage a:link, .golink-btn.f_manage a:visited {
	margin: 0;
}
.golink-btn.f_manage a.ich:link, .golink-btn.f_manage a.ich:visited {
	background-color: #3141b9;
	margin-left: 2.5em;
}
.inqlead {
	max-width:660px;
	margin: 0 auto;
	line-height: 2;
}
#content.inq i,
.error,
i.caution,
.inqWrap dt i {
	color:#d30000;
	font-style: normal;
}
.inqWrap {
	display: flex;
	flex-wrap: wrap;
	max-width: 860px;
	margin: 4em auto 0;
	line-height: 2.8;
}
.inqWrap dt {
	width: 33%;
	margin-bottom: 2.25em;
	position: relative;
}
.inqWrap.conf dt {
	font-weight: 500;
}
.inqWrap dt i {
	position: absolute;
	right: 2.75em;
	top: 0;
}
.inqWrap dd {
	width: 67%;
	margin-bottom: 2.25em;
}
.inqWrap dd p {
	margin-bottom: 0;
}
.inqWrap dd p + p {
	margin-top: 0.5em;
}
.inqWrap dd p + p.error {
	margin-top: 0;
}
.inqWrap input,
.inqWrap textarea {
	line-height: 2;
	box-sizing: border-box;
	padding: 0.3em;
	background-color: transparent;
	border: solid 1px #848484;
}
.inqWrap dd label {
	margin-right:0.6em;
}
.inqWrap dd input + label {
	margin-left: 0.6em;
}
.input-w1 {
	width: 75%;
}
.input-w2 {
	width: 28%;
}
.input-w3 {
	width: 100%;
}
.inqWrap textarea {
	width: 100%;
	height:15em;
	vertical-align: bottom;
}
.sendbtn {
	border: none;
	background:#3141b9;
	color: #fff;
	position: relative;
	font-size: 2rem;
	padding: 1.6em 1em;
	box-sizing:border-box;
	line-height: 1;
	width: 290px;
	position: relative;
	background-image: url("../img/common/btn_w_arrow.png");
	background-repeat: no-repeat;
	background-position: center right 55px;
}
.sendbtn.back {
	background-image: none;
	background:#848484;
	width:200px;
	margin-right: 45px;
	color: #fff;
	text-align: center;
}

.inq-btn1 .sendbtn {
	margin-left: 33%;
}
.inq-btn2 {
	margin: 4em auto 0;
	display: flex;
	justify-content: center;
}
.inqlead.thaks {
	text-align: center;
	line-height: 2.5;
}
.inqlead.thaks + p {
	display: flex;
	justify-content: center;
	margin: 4em auto 0;
}
.inqlead.thaks + p .sendbtn {
	background-image: none;
}
.recWrap {
	max-width: 790px;
	margin: 0 auto 2em;
}
.recWrap h3 {
	background-color:#333333;
	color: #fff;
	padding: 0.5em 1.2em;
	font-weight: 500;
	letter-spacing: 0.1em;
	margin-bottom: 0;
}
.recWrap dl {
	background:#fff;
	padding: 2.5em;
	display: flex;
	flex-wrap: wrap;
	line-height: 2.25;
}
.recWrap dt {
	width: 15%;
	font-weight: 500;
}
.recWrap dd {
	width: 85%;
}
.inqWrap dd.note {
	width: 100%;
	padding: 2em 0 5em;
}
.inqWrap dd.note p {
	margin: 0;
	line-height: 2;
}
.recWrap strong {
	font-weight: 600;
}
.recWrap em {
	font-style: italic;
}
.reclead {
	max-width: 525px;
	margin: 0 auto;
	line-height: 2;
}
.introresult figcaption {
	margin-bottom: 0.7em;
}
select {
	padding: 0.5em 0.3em;
	font-size: 1.6rem;
}
.fm-detail {
	padding:3.5em 0 5.5em;
	margin-bottom: -4.6em;
}
.fm-detail h3 {
	font-weight: 600;
	margin-bottom: 1em;
	position: relative;
	padding-left: 2em;
}
.fm-detail h3 span {
	position: absolute;
	left: 0;
	top: 0;
}
.fm-detail ul {
	display: flex;
	max-width: 810px;
	margin:0 0 2.8em 2em;
}
.fm-detail ul li {
	list-style: none;
}



@media screen and (min-width:769px) {
	.sendbtn:hover {
		opacity: 0.5;
	}
}
@media screen and (max-width: 768px) {
	.pankuzu {
		padding: 1em;
		box-sizing: border-box;
	}
	.performanceWrap,
	.pageNav,
	.privacy dl,
	.inqlead,
	.reclead {
		width: 86%;
	}
	.introresult figure img {
		max-width: 100%;
	}
	#summaryWrap dd.number table th,
	#summaryWrap dd.number table td {
		display: block;
	}
	#summaryWrap dd.number table td {
		text-indent: 1em;
	}
	#summaryWrap dd.number table td:last-child {
		padding-bottom: 1em;
	}
}
@media screen and (max-width: 425px) {
	#pageHeader {
		background-size: auto 100%;
	}
	#pageHeader h2 em {
    font-size: 1.2rem;
    margin-bottom: 0.5em;
	}
	p.logoImage {
		margin-bottom:2em;
	}
	p.logoImage img {
		width: 70%;
	}
	.pankuzu li,
	#indexLinks li a span {
		font-size: 1rem;
	}
	.pankuzu li:after {
    border-width: 3px 0 3px 5px;
	}
	#indexLinks {
		width: 86%;
		margin-top: 3em;
	}
	#indexLinks li {
	font-size: 2rem;
		margin-bottom: 1em;
	}
	#indexLinks li a {
		padding: 2em 0 2em 1.5em;
	}
	#indexLinks li a:after {
    width: 13px;
    padding-top: 25px;
	right: 1.5em;
    margin-top: -12px;
	}

	.signature p:last-child b {
    width: 89px;
    padding-top: 19px;
}
	.purpose {
		width: 86%;
		background-size: 100% auto;
		padding-top: 0;
	}
	.summary-map,
	#summaryWrap dl {
		width: 90%;
	}
	.summary-map > p {
		line-height: 1.5;
	}
	.summary-map > p span {
		display: block;
	}
	#summaryWrap dl,
	#summaryWrap dd.org,
	.licence .flexwrap {
		display: block;
	}
	#summaryWrap dt ,
	#summaryWrap dd,
	.licence .flexwrap ul {
		width: 100% !important;
	}
	.licence .flexwrap ul + ul {
		margin-top: -2em;
	}
	#summaryWrap dd.director p, #summaryWrap dd.adviser p {
		padding-left:1em;
		line-height: 1.8;
	}
	#summaryWrap dd.director p span, #summaryWrap dd.adviser p span {
		position: inherit;
		display: block;
		margin-bottom: -0.5em;
		margin-left: -1em;
	}
	.performanceWrap dd {
		display: block;
	}
	.performanceWrap dd ul:nth-child(odd) {
		width: 100%;
		padding-right: 0;
	}
	.performanceWrap dt {
		font-size: 6.7vw;
		margin-bottom: 1em;
	}
	#system_outline {
		width: 90%;
	}
	article.news h2 {
		line-height: 1.5;
		font-size: 1.2rem;
	}
	.textwrap p.goback {
		margin:-1em 0 1em;
	}
	article.news h2 {
		margin-bottom: 3em;
	}
	.textwrap article.news p {
		margin-bottom: 2em;
	}
	article.news .nextPrev li {
		width: 45%;
	}
	article.news .nextPrev li a {
		width: 100%;
	}
	article.news .nextPrev li a::before {
    right: 1em;
	}
	article.news .nextPrev li a.prev::before {
		left: 1em;
	}
	.golink-btn.f_manage a.ich:link, .golink-btn.f_manage a.ich:visited {
	margin-left: 2em;
}
	.inqWrap {
		display: block;
	}
	.inqWrap dt {
		margin-bottom: 0;
		width: 100%;
	}
	.inqWrap dd {
		margin-bottom: 1.5em;
		width: 100%;
	}
	.inqWrap dt i {
		position: inherit;
		right: inherit;
	}
	.sendbtn,
	.inq-btn1 .sendbtn {
		width: 67%;
		font-size: 1.3rem;
		margin: 3em auto;
		display: block;
		background-position: center right 30px;
	}
	.inq-btn2,
	.inqlead.thaks + p {
		margin: 0;
	}
	.sendbtn.back {
		margin-right: 2em;
		width: 35%;
	}
	.fm-detail ul li:last-child {
		display: none;
}
}
@media screen and (max-width: 375px) {}
@media screen and (max-width: 320px) {

}

/* コンテナ・見出しは従来どおり */
.performanceWrap {
  max-width: 970px;
  margin: 0 auto;
}
.performanceWrap dt {
  font-size: 3.6rem;
  line-height: 1.2;
  margin-bottom: 1.4em;
}

/* ここから新レイアウト用：dd 内は単一の <ul class="perf-list"> */
.performanceWrap dd {
  display: block;            /* 旧: flex をリセット */
  margin: 0;
}

/* 2カラム化（幅によって折り返し） */
.performanceWrap dd ul {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 5px;
  list-style: none;
  margin: 0;
  padding: 0;
  /* background-color: gray; */
}

/* 2列（PC） */
.performanceWrap dd ul li {
  width: 44%;
  line-height: 1.8;
  /* background-color: #d30000; */
}

/* 連番の見た目 */
.performanceWrap dd .perf-list > li > b {
  display: inline-block;
  margin-right: .4em;
  font-weight:300;
}

/* スマホ対応（1列） */
@media (max-width: 768px) {
  .performanceWrap dd .perf-list {
    gap: 8px 0;              /* スマホは縦だけ余白 */
  }
  .performanceWrap dd .perf-list > li {
    width: 100%;
  }
  .performanceWrap dt {
    font-size: 2.4rem;
    margin-bottom: 1.2em;
  }
}

/* タブレット微調整（任意） */
@media (max-width: 1024px) and (min-width: 769px) {
  .performanceWrap dd .perf-list {
    gap: 6px 16px;
  }
  .performanceWrap dd .perf-list > li {
    width: calc(50% - 8px);
  }
}

/* 旧指定の影響を打ち消す（安全のため） */
.performanceWrap dd ul:nth-child(odd) {
  width: auto;
  padding-right: 0;
  box-sizing: content-box;
}

/* =======================================
* Contact form 7 
* CSS デザイン
======================================= */

.contact-form {
	width: 760px;
	margin: 0 auto;
}

/* 既存 .error 風に */
.wpcf7-not-valid-tip {
  color: #c0392b;
  margin-top: .4em;
  font-size: .95em;
}
.wpcf7 form .wpcf7-response-output {
  border: 1px solid #c0392b;
  padding: .8em 1em;
}

/* ==============================
   Hotel Cleaning 共通
   ============================== */
.hotel-cleaning {
    font-size: 16px;
    line-height: 1.8;
}

.hotel-cleaning .section {
    padding: 60px 0;
}

@media (max-width: 767px) {
    .hotel-cleaning .section {
        padding: 40px 0;
    }
}

/* ==============================
   H2-1 背景画像セクション（intro-section）
   ============================== */

.intro-section {
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    position: relative;
    padding: 120px 0;  /* 高さは調整可 */
    color: #333;       /* 白文字に */
}

@media (max-width: 767px) {
    .intro-section {
        padding: 80px 0;
    }
}

/* オーバーレイ(必要ならON) */
.intro-section::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 1;
}

/* 内側のテキストエリア */
.intro-section__inner {
    position: relative;
    z-index: 2;
    max-width: 860px;
    margin: 0 auto;
    padding: 0 20px;
    text-align: center;
}

/* 見出し */
.intro-section__title {
    font-size: 32px;
    margin-bottom: 20px;
    letter-spacing: 0.08em;
}

@media (max-width: 767px) {
    .intro-section__title {
        font-size: 26px;
    }
}

/* 本文 */
.intro-section__body {
    font-size: 17px;
    line-height: 1.9;
    margin-top: 20px;
}

@media (max-width: 767px) {
    .intro-section__body {
        font-size: 15px;
    }
}

/* ==============================
   H2-2：ホテル清掃が選ばれる理由
   ============================== */

/* セクション背景をグレーに */
.hotel-cleaning .hotel-features {
    background-color: #fff;
}

/* 横並びレイアウト：2列＋自動折り返し */
/* .hotel-cleaning .hotel-features .textwrap {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    justify-content: center;
	width: 1000px;
	background-color: red;
} */

/* 横並びレイアウト：2列＋自動折り返し */
/* ラップ：2列flexをやめて縦積みに */
.hotel-features__wrap {
  display: block;
  max-width: 1200px;
  margin: 0 auto;
}

/* 横長パネル：左右2カラム */
.hotel-cleaning .hotel-feature-item {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.06);

  display: flex;
  align-items: stretch;
  gap: 24px;

  padding: 22px 24px;
  margin: 0 0 24px;
}

/* 画像 */
.hotel-cleaning .hotel-feature-media {
  flex: 0 0 42%;
  max-width: 42%;
  margin-right: 20px;
}

/* 偶数（画像が右）の場合は逆側に余白 */
.hotel-cleaning .hotel-feature-item--even .hotel-feature-media {
  margin-right: 0;
  margin-left: 16px;
}

.hotel-cleaning .hotel-feature-media img {
  width: 100%;
  height: 100%;
  min-height: 220px;
  object-fit: cover;
  border-radius: 10px;
  display: block;
}

/* テキスト */
.hotel-cleaning .hotel-feature-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* 奇数：画像左（デフォルト） */
.hotel-cleaning .hotel-feature-item--odd {
  flex-direction: row;
}

/* 偶数：画像右 */
.hotel-cleaning .hotel-feature-item--even {
  flex-direction: row-reverse;
}

/* タイトル（番号 + 文言） */
.hotel-cleaning .hotel-feature-title {
  font-size: 24px;
  margin: 0 0 20px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: #0d47a1;
}

/* 番号バッジ（既存のままでもOK） */
.hotel-cleaning .feat-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: #0d47a1;
  color: #fff;
  font-size: 14px;
  font-weight: bold;
}

/* 本文 */
.hotel-cleaning .hotel-feature-body {
  font-size: 15px;
  line-height: 1.8;
}

/* ==========================
   SP：パネル表示（縦並び）
   タイトル → 画像 → 本文
========================== */
@media (max-width: 767px) {
  .hotel-cleaning .hotel-feature-item {
    flex-direction: column; /* 1列 */
    gap: 14px;
    padding: 18px 16px;
  }

  .hotel-cleaning .hotel-feature-media {
    flex: none;
    max-width: none;
    order: 2; /* 画像を2番目に */
  }

  .hotel-cleaning .hotel-feature-content {
    order: 1; /* テキスト（タイトル+本文）は先に */
  }

  /* タイトル→画像→本文の順にしたいので、本文を画像の後へ */
  .hotel-cleaning .hotel-feature-title { order: 1; }
  .hotel-cleaning .hotel-feature-body { order: 3; }

  .hotel-cleaning .hotel-feature-media img {
    min-height: 180px;
  }
}


/* ==============================
   H2-3：主なサービス内容
   ============================== */

.hotel-sevices {
    background-color: red;
}

/* 横並びレイアウト：3カラム＋自動折り返し */
.hotel-cleaning .hotel-services__list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: space-between;
    max-width: 1200px;  /* 好みで調整 */
    margin: 0 auto;
}

/* カード本体 */
.hotel-cleaning .hotel-service-item {
    background: #fff;
    border-radius: 12px;
    padding: 20px 24px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.06);
    display: flex;
    flex-direction: column;
    text-align: left;

    /* PC：3カラム */
    /* width: calc(33.333% - 16px); */
	width: 330px;

}

/* タブレット：2カラム */
@media (max-width: 1024px) {
    .hotel-cleaning .hotel-service-item {
        width: calc(50% - 12px);
    }
}

/* スマホ：1カラム */
@media (max-width: 767px) {
    .hotel-cleaning .hotel-service-item {
        width: 100%;
    }
}

/* タイトル */
.hotel-cleaning .hotel-service-item h3 {
    font-size: 18px;
    font-weight: normal;
    margin: 0 0 16px;
    text-align: center;
    background-color: #0d47a1;
    color: #fff;
    padding: 10px 0;
    border-radius: 8px;
    text-shadow:0px 0px 10px #382c18;
}

/* 画像 */
.hotel-cleaning .hotel-service-img {
    margin: 0 0 12px;
    text-align: center;
}

.hotel-cleaning .hotel-service-img img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    object-fit: cover;
}

/* 本文 */
.hotel-cleaning .hotel-service-body {
    font-size: 15px;
    line-height: 1.8;
}


/* ==============================
   H2-4：導入の流れ（タイムライン）
   ============================== */

.hotel-cleaning .hotel-flow {
    background-color: #f7f7f7;
}

.hotel-cleaning .hotel-flow-list {
    list-style: none;
    margin: 40px auto 0;
    padding: 0;
    max-width: 900px;
    position: relative;
}

/* 縦ライン */
.hotel-cleaning .hotel-flow-list::before {
    content: '';
    position: absolute;
    left: 32px; /* 丸番号の中心に合わせる */
    top: 0;
    bottom: 0;
    width: 2px;
    background: #ddd;
}

.hotel-cleaning .hotel-flow-item {
    display: flex;
    gap: 24px;
    position: relative;
    padding-bottom: 32px;
}

@media (max-width: 767px) {
    .hotel-cleaning .hotel-flow-item {
        gap: 16px;
        padding-bottom: 24px;
    }
}

/* 左側の番号丸 */
.hotel-cleaning .hotel-flow-step {
    position: relative;
    z-index: 2; /* ラインより手前に */
    padding-top: 4px;
}

.hotel-cleaning .hotel-flow-step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #333;
    color: #fff;
    font-weight: 700;
    font-size: 14px;
}

/* 右側の内容カード */
.hotel-cleaning .hotel-flow-content {
    background: #fff;
    border-radius: 12px;
    padding: 16px 20px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
    flex: 1;
}

.hotel-cleaning .hotel-flow-title {
    font-size: 18px;
    margin: 0 0 8px;
}

.hotel-cleaning .hotel-flow-body {
    font-size: 15px;
    line-height: 1.8;
}

/* SP時はライン位置を少し内側に寄せてもOK */
@media (max-width: 767px) {
    .hotel-cleaning .hotel-flow-list::before {
        left: 24px;
    }
    .hotel-cleaning .hotel-flow-step-num {
        width: 34px;
        height: 34px;
        font-size: 13px;
    }
}

/* ==============================
   H2-5：対応施設・対応エリア
   ============================== */

/* セクション全体 */
.hotel-cleaning .hotel-coverage {
    background-color: #fff;
    /* background-color: #f0f8fe; */
}

/* H3の共通デザイン（ラベル感） */
.hotel-cleaning .hotel-coverage-heading {
    font-size: 18px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin: 0 0 16px;
    padding-left: 10px;
    border-left: 4px solid #333;
}

/* 対応施設：4カラムレイアウト */
.hotel-cleaning .hotel-coverage-facilities__list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    max-width: 1200px;
    margin: 0 auto 100px auto;
}

.hotel-cleaning .hotel-facility-item {
    background: #fff;
    border-radius: 10px;
    padding: 16px 12px;
    width: 250px; /* PCで4つ並ぶ想定 */
    text-align: center;
    box-shadow: 0 4px 10px rgba(0,0,0,0.05);
}

.hotel-cleaning .hotel-facility-img {
    margin: 0 0 8px;
}

.hotel-cleaning .hotel-facility-img img {
    max-width: 100%;
    height: auto;
    border-radius: 6px;
}



.hotel-cleaning .hotel-facility-item h4 {
    font-size: 15px;
    margin: 0;
}

/* タブレット〜スマホ：2列→1列に落とす感じ */
@media (max-width: 1024px) {
    .hotel-cleaning .hotel-facility-item {
        width: calc(50% - 20px);
    }
}

@media (max-width: 767px) {
    .hotel-cleaning .hotel-facility-item {
        width: 100%;
    }
}

/* ==============================
   対応エリア：左テキスト + 右画像
   ============================== */

.hotel-cleaning .hotel-coverage-area__row{
  display: flex;
  align-items: center;
  gap: 24px;
  position: relative;
}

/* 左：テキスト */
.hotel-cleaning .hotel-coverage-area__textBox{
  flex: 0 0 42%;
  max-width: 42%;
  color: #3c3c3c;
  font-size: 20px;
  line-height: 1.9;
  font-weight: bold;

  /* ボックスデザイン */
  /* background: rgba(146, 211, 255, 0.25); */
  background: rgba(255, 255, 255, 0.6);
  /* border: 1px solid rgba(146, 211, 255, 0.55); */
  padding: 18px 20px;

  /* 画像に少し重ねる（ここがポイント） */
  position: relative;
  z-index: 2;
  margin-right: -40px; /* ←重なり量。好みで -20〜-60px */
  border-radius: 12px;
}

/* 右：画像（背景） */
.hotel-cleaning .hotel-coverage-area__visual{
  flex: 1;
  border-radius: 12px;
  overflow: hidden;

  background-size: contain;       /* 地図は切らない方が良い */
  background-repeat: no-repeat;
  background-position: center;

  height: 380px;                  /* 基本高さ */
  max-height: 500px;              /* 最大500px */
  background-color: #fff;         /* 余白が出ても白で馴染ませる */
  /* border: 1px solid #e8e8e8; */
}

/* タブレット以下：少し高さを下げる */
@media (max-width: 1024px){
  .hotel-cleaning .hotel-coverage-area__visual{
    height: 320px;
  }
  .hotel-cleaning .hotel-coverage-area__textBox{
    flex-basis: 48%;
    max-width: 48%;
    margin-right: -28px;
  }
}

/* スマホ：縦積み（テキスト→画像） */
@media (max-width: 767px){
  .hotel-cleaning .hotel-coverage-area__row{
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }

  .hotel-cleaning .hotel-coverage-area__textBox{
    max-width: 100%;
    flex-basis: auto;
    margin-right: 0;     /* 重なりは解除 */
  }

  .hotel-cleaning .hotel-coverage-area__visual{
    height: 220px;
    max-height: none;
  }
}

.hotel-coverage-facilities h3,
.hotel-coverage-area h3 {
    position: relative;
    font-size: 28px;
    font-weight: 600;
    padding-left: 32px;
    margin-bottom: 20px;
    letter-spacing: 0.05em;
}

/* チェックマーク */
/* .hotel-coverage-facilities h3::before,
.hotel-coverage-area h3::before {
    content: "✔";
    position: absolute;
    left: 0;
    top: 0;
    font-size: 20px;
    line-height: 1;
    color: #2c8f4e; 
    font-weight: 700;
} */

/* ==============================
   H2-6：よくあるご質問（Q赤 / A青）
   ============================== */

.hotel-cleaning .hotel-faq-list {
    max-width: 900px;
    margin: 32px auto 0;
}

/* カード全体 */
.hotel-cleaning .hotel-faq-item {
    border-radius: 12px;
    border: 1px solid #e3e3e3;
    padding: 16px 20px;
    margin-bottom: 16px;
    background: #fff;
    box-shadow: 0 4px 10px rgba(0,0,0,0.03);
}

/* ◆ 質問（Q）— 赤アイコン */
.hotel-cleaning .hotel-faq-question {
    position: relative;
    margin: 0 0 20px;
    padding-left: 44px;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.6;
}

/* Qアイコン（赤） */
.hotel-cleaning .hotel-faq-question::before {
    content: "Q";
    position: absolute;
    left: 0;
    top: 0px;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #d9534f; /* 赤系 */
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ◆ 回答（A）— 青アイコン＋背景 */
.hotel-cleaning .hotel-faq-answer {
    position: relative;
    margin-top: 8px;
    padding: 12px 16px 10px 44px;
    background: #eef4ff;      /* 淡い青背景で読みやすく */
    border-radius: 8px;
    font-size: 16px;
    line-height: 1.8;
    color: #333;
}

/* Aアイコン（青） */
.hotel-cleaning .hotel-faq-answer::before {
    content: "A";
    position: absolute;
    left: 10px;
    top: 18px;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: #0275d8; /* ブルー */
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* スマホ調整 */
@media (max-width: 767px) {
    .hotel-cleaning .hotel-faq-item {
        padding: 14px 14px;
    }
    .hotel-cleaning .hotel-faq-question {
        padding-left: 40px;
    }
    .hotel-cleaning .hotel-faq-answer {
        padding-left: 40px;
    }
}

/* ==============================
   H2-7：ホテル清掃お問い合わせ（カード幅900px）
   ============================== */

.hotel-cleaning .hotel-contact {
    background: #f7f7f7;
    padding: 40px 0;
}

/* 本文（中央揃え） */
.hotel-cleaning .hotel-contact-body {
    text-align: center;
    max-width: 700px;
    margin: 0 auto 32px;
    font-size: 17px;
    line-height: 1.9;
    color: #333;
}

/* ▼ 電話・フォーム共通：カードスタイル（FAQと幅を統一） */
.hotel-cleaning .hotel-contact-phone,
.hotel-cleaning .hotel-contact-form {
    background: #fff;
    border-radius: 12px;
    padding: 24px 32px;
    max-width: 900px;     /* ← FAQのカード幅に合わせる */
    margin: 0 auto 24px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

/* h3：中央＋下線 */
.hotel-cleaning .hotel-contact-heading {
    text-align: center;
    font-size: 20px;
    font-weight: 600;
    margin: 0 0 16px;
    padding-bottom: 8px;
    border-bottom: 2px solid #ddd;
    letter-spacing: 0.05em;
}

/* 電話番号 */
.hotel-cleaning .hotel-contact-phone-number {
    text-align: center;
    margin: 0;
}

.hotel-cleaning .hotel-contact-phone-number a {
    font-size: 26px;
    font-weight: 700;
    text-decoration: none;
    color: #222;
    letter-spacing: 0.02em;
}

.hotel-cleaning .hotel-contact-phone-number a:hover {
    opacity: 0.8;
}

/* フォーム（CF7） */
.hotel-cleaning .hotel-contact-form .wpcf7 {
    margin-top: 8px;
}

/* スマホ対応 */
@media (max-width: 767px) {
    .hotel-cleaning .hotel-contact-phone,
    .hotel-cleaning .hotel-contact-form {
        padding: 20px 16px;
        max-width: 100%; /* 画面幅に合わせる */
    }

    .hotel-cleaning .hotel-contact-phone-number a {
        font-size: 22px;
    }
}


/* =========================================================
   共通設定
========================================================= */
/* =========================
   PC / SP 切り替え
========================= */
.pc-only { display: block; }
.sp-only { display: none; }

/* スマホ切替 */
@media (max-width: 768px) {
    .pc-only { display: none !important; }  /* PC要素は確実に消す */
    .sp-only { display: block; }            /* 基本は block。flex は個別で指定 */
}

/* =========================
   上段（PC）※ここは以前のままでOK
========================= */
/* 固定ヘッダー化 */
.cvc-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background: #ffffff;
}

/* ヘッダーの下に薄い線（お好みで） */
.cvc-header .header-bottom {
    border-bottom: 1px solid #ddd;
}




.cvc-header .header-top {
    background: #ffffff;
    border-bottom: 1px solid #ddd;
}

.header-top-inner {
    max-width: 1100px;
    margin: 0 auto;
    padding: 12px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.header-brand {
    display: flex;
    align-items: center;
    gap: 14px;
}

.header-brand .logo img {
    height: 80px;
    width: auto;
}

.header-brand .site-title {
    font-family:
        "Yu Gothic",
        "YuGothic",
        "Yu Gothic UI",
        "Segoe UI",
        Helvetica,
        Arial,
        sans-serif;
    font-weight: 700;
    -webkit-text-stroke: 1px #333;
    letter-spacing: 1.2px;
    font-size: 28px;
    margin: 0;
}


.header-brand .site-title a {
    text-decoration: none;
    color: #333;
}

.header-contact-area {
    display: flex;
    align-items: center;
    gap: 16px;
}

.header-tel-inline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    /* background: transparent; 白背景を活かす */
    /* color: #8a6f3b !important; */
    color: #8d1919 !important;          
    font-size: 36px;         /* 大きめで上品に */
    font-family: "Times New Roman", serif;
    font-weight: 400;
    text-decoration: none;
    padding: 6px 0;          /* 余白少なめで文字デザインを活かす */
    /* transition: color .25s ease; */
}

.header-tel-inline i {
    font-size: 24px;
    color: inherit; /* 文字色と統一 */
}

.header-tel-inline:hover {
    color: #6e572e; /* ホバー時に少し濃金へ */
}

.header-contact-area a {
    color: #fff;
    text-decoration: none;
}

.header-contact-btn i {
    margin-right: 8px;
    font-size: 16px;
    color: inherit; /* ボタンの文字色をそのまま使う */
}

.header-contact-btn {
    display: inline-block;
    padding: 18px 26px;
    /* background: #8a6f3b;  */
    /* border: 1px solid #8a6f3b; */
    background: #8a6f3b;  
    border: 1px solid #8a6f3b;
    text-decoration: none;
    font-size: 16px;
    color: #fff;
    border-radius: 3px;
}

.header-contact-btn:hover {
    background: #6e572e; /* ホバー時：より濃い金（深いゴールド） */
    border-color: #6e572e;
    color: #fff; /* 文字は白で視認性UP */
}

/* =========================
   下段（PCナビ）
========================= */
.header-bottom {
    background: #f7f7f7;
    border-bottom: 1px solid #ddd;
}

.global-nav .menu {
    display: flex;
    justify-content: center;
    gap: 32px;
    list-style: none;
    padding: 12px 0;
    margin: 0;
}

.global-nav .menu > li > a {
    text-decoration: none;
    font-size: 1rem;
    color: #333;
    padding: 4px 0;
	font-size: 14px;
}

.global-nav .menu > li > a:hover {
    opacity: 0.7;
}

#gNav .sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 230px;
  display: none;
  background: #fff;
  /* border: 1px solid #e5e5e5; */
  z-index: 1000;
  padding: 10px 10px;
}

#gNav .sub-menu li a {
  font-size: 14px;
  color: #333;
}

/* =========================
   スマホヘッダー（上段）
========================= */
@media (max-width: 768px) {

    .header-top-inner {
        padding: 10px 12px;
    }

    .header-brand .logo img {
        height: 40px;
    }

    /* 右側：電話アイコン + メールアイコン + トグル */
    .header-sp-icons {
        display: flex;               /* ← ここだけ flex にする */
        align-items: center;
        gap: 16px;
    }

    .sp-icon i {
        font-size: 22px;
        color: #333;
    }

    /* ハンバーガートグル */
    .sp-nav-toggle {
        background: none;
        border: none;
        cursor: pointer;
        display: flex;
        flex-direction: column;
        gap: 4px;
        padding: 4px;
    }

    .sp-nav-bar {
        width: 24px;
        height: 2px;
        background: #333;
        display: block;
        transition: .3s;
    }

    .sp-nav-toggle.is-open .sp-nav-bar:nth-child(1) {
        transform: translateY(6px) rotate(45deg);
    }
    .sp-nav-toggle.is-open .sp-nav-bar:nth-child(2) {
        opacity: 0;
    }
    .sp-nav-toggle.is-open .sp-nav-bar:nth-child(3) {
        transform: translateY(-6px) rotate(-45deg);
    }

    /* =====================
       SPナビ（トグルで開閉）
    ====================== */

	.sp-nav {
        position: absolute;      /* ヘッダー（.cvc-header）基準で絶対配置 */
        top: 100%;               /* ヘッダーのすぐ下から出る */
        left: 0;
        right: 0;
        background: #ffffff;
        border-top: 1px solid #eee;

        /* スライドイン用初期状態（上に隠しておく） */
        transform: translateY(-100%);
        opacity: 0;
        pointer-events: none;

        transition: transform .3s ease, opacity .3s ease;
    }

    .sp-nav.is-open {
        transform: translateY(0);    /* 下へスライドして表示 */
        opacity: 1;
        pointer-events: auto;
    }

    .sp-menu {
        list-style: none;
        padding: 0;
        margin: 0;
        display: flex;
        flex-direction: column;
    }

    .sp-menu > li > a {
        padding: 14px;
        text-align: center;
        border-bottom: 1px solid #eee;
        text-decoration: none;
        color: #333;
        font-size: 1rem;
        display: block;
    }

    .sp-menu > li > a:hover {
        background: #fafafa;
    }
}

/* ==============================
   CTA
============================== */
.cvc-cta{
  position: relative;
  width: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  margin: 60px 0;
}

.cvc-cta__overlay{
  /* background: rgba(0,0,0,0.55); */
  padding: 120px 20px;
}

.cvc-cta__inner{
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
}

.cvc-cta__title{
  color: #fff;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: .03em;
  margin: 0 0 40px;
}

/* ボタン2つ：左TEL / 右メール */
.cvc-cta__actions{
  display: flex;
  justify-content: space-between;
  gap: 18px;
  max-width: 820px;
  margin: 0 auto;
}

.cvc-cta__btn,
.cvc-cta__btn:link,
.cvc-cta__btn:visited {
  /* flex: 1; */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;

  padding: 10px 80px;
  color: #fff;
  text-decoration: none;

  border: 1px solid rgba(255,255,255,1.0);
  background: rgba(255,255,255,0.06);
  transition: .2s;
  margin-bottom: 20px;
}

.cvc-cta__btn i{
  font-size: 26px;
  line-height: 1;
}

/* メイン文字 */
.cvc-cta__btnMain{
  font-size: 24px; /* ← 大きく */
  font-weight: 700;
  letter-spacing: .04em;
  color: #fff;
}

/* 補足文言（ボタンの下） */
.cvc-cta__btnSub{
  font-size: 16px;
  color: #fff;
  opacity: .9;
  letter-spacing: .03em;
}


/* hover */
.cvc-cta__btn:hover{
  background: rgba(255,255,255,0.18);
  border-color: rgba(255,255,255,0.8);
}

/* TELだけ少し強調したい場合（任意） */
.cvc-cta__btn--tel .cvc-cta__btnText{
  font-size: 20px;
}

/* SP：縦積み */
@media (max-width: 767px){
  .cvc-cta__overlay{
    padding: 64px 16px;
  }
  .cvc-cta__title{
    font-size: 20px;
    margin-bottom: 18px;
  }
  .cvc-cta__actions{
    flex-direction: column;
    gap: 12px;
  }
  .cvc-cta__btn{
    padding: 18px 20px;
  }
  .cvc-cta__btnMain{
    font-size: 18px;
  }
  .cvc-cta__btnSub{
    font-size: 13px;
  
  }
}

/* CTA リード文 */
.cvc-cta__lead{
  margin: 0 auto 60px;
  max-width: 900px;
  text-align: center;
  color: #fff;
}

.cvc-cta__lead p{
  margin: 0 0 12px;
  font-size: 18px;
  line-height: 1.9;
}

.cvc-cta__lead p:last-child{
  margin-bottom: 0;
}

/* 強調（CVC・JAPAN） */
.cvc-cta__lead strong{
  font-weight: 700;
  letter-spacing: .05em;
}

/* SP調整 */
@media (max-width: 767px){
  .cvc-cta__lead{
    margin-bottom: 28px;
  }
  .cvc-cta__lead p{
    font-size: 15px;
    line-height: 1.8;
  }
}