@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: 870px;
  margin: 0 auto;
  padding: 0 20px;
  text-align: center;
}

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

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

/* 本文 */
.intro-section__body {
  font-size: 16px;
  line-height: 2.5;
  text-align: left;
}

@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;
  display: flex;
  align-items: stretch;
  gap: 24px;
  border: solid 1px rgba(0, 0, 0, .08);
  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: 2.5;
}

/* ==========================
   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;
  padding: 20px 24px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
  display: flex;
  flex-direction: column;
  text-align: left;
  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;
  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;
  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: #f5f5f5;
  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; */
}

.hotel-coverage-facilities-inner {
  max-width: 980px;
  margin: 0 auto;
}

/* 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;
  margin: 0 auto 100px auto;
}

.hotel-cleaning .hotel-facility-item {
  background: #fff;
  padding: 16px 12px;
  width: 280px;
  text-align: center;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
} */

/* 対応施設：3カラム固定（PC） */
.hotel-cleaning .hotel-coverage-facilities__list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 30px;
  margin: 0 auto 100px auto;
}

/* カード */
.hotel-cleaning .hotel-coverage-facilities__list .hotel-facility-item {
  width: auto;
  /* ← 以前の width:280px を殺す */
  background: #fff;
  padding: 0 0 20px 0;
  text-align: left;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}


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

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



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

@media (max-width: 1024px) {
  .hotel-cleaning .hotel-coverage-facilities__list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 600px) {
  .hotel-cleaning .hotel-coverage-facilities__list {
    grid-template-columns: 1fr;
  }
}

/* ==============================
   対応エリア：背景画像の上に文字を重ねる
============================== */

.hotel-cleaning .hotel-coverage-area__row.is-bg {
  position: relative;
  overflow: hidden;
  min-height: 340px;
  padding: 28px;
  display: flex;
  align-items: center;

  /* 背景画像 */
  background-size: cover;
  /* 全面に */
  background-position: center;
  background-repeat: no-repeat;

  /* 画像がない時の保険 */
  background-color: #f2f2f2;
}

/* 読みやすくするための暗いオーバーレイ */
.hotel-cleaning .hotel-coverage-area__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .2);
  z-index: 1;
}

/* 文字ボックス */
.hotel-cleaning .hotel-coverage-area__textBox {
  position: absolute;
  z-index: 2;
  width: 600px;
  color: #333;
  font-size: 18px;
  line-height: 1.9;
  font-weight: 700;
  padding: 18px 20px;
  /* background: rgba(0,0,0,.35); */
  /* もう少し上品にしたいなら下を使うのもOK */
  background: rgba(255, 255, 255, .45);
  backdrop-filter: blur(6px);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* 既存の右画像ブロックは使わない */
.hotel-cleaning .hotel-coverage-area__visual {
  display: none;
}

/* タブレット */
@media (max-width: 1024px) {
  .hotel-cleaning .hotel-coverage-area__row.is-bg {
    min-height: 300px;
    padding: 22px;
  }

  .hotel-cleaning .hotel-coverage-area__textBox {
    max-width: 520px;
    font-size: 17px;
  }
}

/* スマホ */
@media (max-width: 767px) {
  .hotel-cleaning .hotel-coverage-area__row.is-bg {
    min-height: 240px;
    padding: 16px;
    align-items: flex-end;
    /* 下寄せにするとそれっぽい */
  }

  .hotel-cleaning .hotel-coverage-area__textBox {
    max-width: 100%;
    font-size: 16px;
  }
}

.hotel-coverage-facilities h3,
.hotel-coverage-area h3 {
  position: relative;
  font-size: 28px;
  font-weight: 600;
  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: 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: 0px 0px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  /* background-color: rgb(176, 94, 94); */
}

.header-brand a {
  display: flex;
  align-items: center;
  gap: 14px;
  color: #5968d8;
}

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

.header-brand .site-title {
  font-family: "Noto Sans JP", 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: #222;
}

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

.header-tel-inline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #505050;
  font-size: 16px;
  font-weight: 400;
  text-decoration: none;
  padding: 0;
}

.header-tel-inline i {
  font-size: 15px;
  color: #1A4472;
  /* 文字色と統一 */
}

/* .header-tel-inline:hover {
  opacity: 0.8;
  
} */

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

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

.header-contact-btn {
  display: inline-block;
  padding: 0;
  /* background: #8a6f3b;  */
  /* border: 1px solid #8a6f3b; */
  /* background: #1A4472; */
  /* background: linear-gradient(160deg, #29619d 0%, #29619d 50%, #1A4472 50%, #1A4472 100%); */
  /* border: 1px solid #1A4472; */
  text-decoration: none;
  font-size: 16px;
  /* color: #1A4472; */
  color: #222;
  /* border-radius: 3px; */
}

.header-contact-btn:hover {
  opacity: 0.8;
}

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

.header-bottom-inner {
  width: 1100px;
  margin: 0 auto;
}


.global-nav .menu {
  display: flex;
  justify-content: right;
  gap: 40px;
  list-style: none;
  margin: 0;
  /* background-color: red; */
}


.global-nav .menu>li>a {
  text-decoration: none;
  color: #222;
  padding: 12px 0 16px;
  font-size: 16px;
  font-weight: 600;
  /* background-color: #2e7d32; */
  display: block;
}

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

/* ▼ PCメインメニュー：末尾に▶︎/▼を付与 */
#gNav .menu>li>a {
  position: relative;
  padding-right: 0em;
  /* アイコン分の余白 */
}

/* サブメニューなし → ▶︎ */
#gNav .menu>li:not(.menu-item-has-children)>a::after {
  content: "\f0da";
  /* fa-caret-right */
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  display: inline-block;
  margin-left: .4em;
  color: #1A4472;
  font-size: 0.7em;
  transform: translateY(-2px);
}

/* サブメニューあり → ▼ */
#gNav .menu>li.menu-item-has-children>a::after {
  content: "\f0d7";
  /* fa-caret-down */
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  display: inline-block;
  margin-left: .4em;
  color: #1A4472;
  font-size: 0.7em;
  transform: translateY(-2px);
}


/* ==============================
   gNav サブメニュー（横並び）
============================== */

/* 親liを基準に配置（そのまま） */
#gNav .menu>li {
  position: relative;
}

/* サブメニュー本体（通常は非表示） */
#gNav .sub-menu {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  display: none;
  justify-content: flex-start;
  gap: 50px;
  padding: 20px 20px 20px 52vw;
  margin: 0;
  list-style: none;
  background: #fff;
  z-index: 1000;
  box-shadow: none;
  /* 念のため */
}

/* ホバー時：全画面基準に切り替える（ここが肝） */
#gNav .menu>li:hover>.sub-menu {
  display: flex;
  position: fixed;
  /* viewport基準 */
  left: 0;
  right: 0;
  top: 100px;
  width: 100vw;
  transform: none;
}

/* 子liのリセット */
#gNav .sub-menu li {
  margin: 0;
  padding: 0;
}

/* リンク */
#gNav .sub-menu li a {
  display: block;
  font-size: 14px;
  color: #333;
  white-space: nowrap;
}

/* サブメニュー：FAアイコンを先頭に追加 */
#gNav .sub-menu li a {
  position: relative;
  padding-left: 1.2em;
  /* ▶ 分の余白 */
}

/* ▶ アイコン */
#gNav .sub-menu li a::before {
  content: "\f0da";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  /* solid */
  color: #1A4472;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-45%);
  font-size: 0.7em;
}

/* =========================
   スマホヘッダー（上段）+ SPナビ（サブメニューは「＋」で開閉）
   ※コピペ完全版（既存の @media (max-width:768px) はこれに置き換え）
========================= */
@media (max-width: 768px) {

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

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

  .header-brand .site-title {
    font-size: 18px;
  }

  /* 右側：電話アイコン + メールアイコン + トグル */
  .header-sp-icons {
    display: 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;
    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;
  }

  /* liの区切り線を統一（aだけにborderを持たせない） */
  .sp-menu>li {
    position: relative;
    border-bottom: 1px solid #eee;
  }

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

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

  /* =========================
     サブメニュー（＋で開閉）
     ・親に menu-item-has-children が付く前提（WP標準 assumed）
     ・JSで li に is-sub-open を付け外しする
  ========================= */

  /* 親リンクの右側に「＋」ボタン領域を確保 */
  .sp-menu>li.menu-item-has-children>a {
    padding-right: 56px;
  }

  /* 「＋」ボタン（JSで挿入される想定） */
  .sp-sub-toggle {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    width: 36px;
    height: 36px;
    border: 1px solid #ddd;
    background: #fff;
    cursor: pointer;
    display: grid;
    place-items: center;
  }

  /* ＋の線 */
  .sp-sub-toggle::before,
  .sp-sub-toggle::after {
    content: "";
    position: absolute;
    width: 14px;
    height: 2px;
    background: #333;
  }

  .sp-sub-toggle::after {
    transform: rotate(90deg);
  }

  /* 開いてる時は「−」にする */
  .sp-menu>li.is-sub-open>.sp-sub-toggle::after {
    opacity: 0;
  }

  /* サブメニュー本体（初期は閉じる） */
  .sp-menu .sub-menu {
    display: none;
    list-style: none;
    margin: 0;
    padding: 8px 0;
    background: #fafafa;
  }

  /* 開いてる時に表示 */
  .sp-menu>li.is-sub-open>.sub-menu {
    display: block;
  }

  /* サブメニューのリンク */
  .sp-menu .sub-menu li a {
    display: block;
    padding: 12px 14px;
    text-align: center;
    text-decoration: none;
    color: #1A4472;
    font-size: 14px;
  }

  .sp-menu .sub-menu li a:hover {
    background: #f2f2f2;
  }
}

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


/* =============================

新問合せフォーム

============================== */

/* =========================================================
   CVC CF7 (square / chic) v2
========================================================= */

/* ---------- Wrapper (square) ---------- */
.cvcf7-form {
  max-width: 900px;
  margin: 0 auto;
  padding: 40px 48px;
  background: #fff;
  border: 1px solid #e6e6e6;
  border-radius: 0;
  box-sizing: border-box;
}

@media (max-width: 767px) {
  .cvcf7-form {
    padding: 28px 20px;
    width: 100%;
  }
}

/* ---------- DL grid ---------- */
.cvcf7-dl {
  margin: 0 0 50px 0;
  padding: 0;
  display: grid;
  grid-template-columns: 240px 1fr;
  column-gap: 28px;
  row-gap: 22px;
}



.cvcf7-dt,
.cvcf7-dd {
  padding: 20px 0 50px 0;
  border-bottom: 1px solid #ededed;
}


.cvcf7-dd {
  border-bottom: 1px solid #ededed;
}

.cvcf7-dt p {
  font-weight: bold;
}

.cvcf7-dd:last-of-type {
  border-bottom: 0;
  padding-bottom: 0;
}

.cvcf7-dt {
  font-size: 15px;
  font-weight: bold !important;
  color: #333;
  line-height: 1.6;
  padding-top: 12px;
  row-gap: 30px;
  letter-spacing: .02em;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* 必須＝赤い「※」 */
.cvcf7-dt.required::after {
  content: "※";
  /* display: inline-block; */
  margin-left: 0px;
  color: #c40000;
  font-weight: 900;
  font-size: 16px;
  line-height: 1;
  transform: translateY(-1px);
}

/* SP: 縦並び */
@media (max-width: 767px) {
  .cvcf7-dl {
    grid-template-columns: 1fr;
    row-gap: 14px;
  }

  /* .cvcf7-dt{ padding-top: 0; } */

  .cvcf7-dt {
    border-bottom: none;
    /* background-color: red; */
    padding: 0;
    margin-bottom: 0;
  }

  .cvcf7-dd {
    padding-bottom: 25px;
    padding-top: 0;
    border-bottom: none;
    /* background-color: blue; */
  }

  .cvcf7-dd:last-of-type {
    border-bottom: 0;
    padding-bottom: 0;
  }
}

/* ---------- sub label / notes ---------- */
.cvcf7-sublabel {
  display: block;
  margin: 0 0 0px;
  font-size: 14px;
  font-weight: 700;
  color: #555;
}

.cvcf7-note {
  margin: 8px 0 0;
  font-size: 13px;
  color: #777;
  line-height: 1.6;
}

.cvcf7-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
}

/* ---------- inputs (square) ---------- */
.cvcf7-input,
.cvcf7-textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 14px 14px;
  border: 1px solid #cfcfcf;
  border-radius: 0;
  background: #fff;
  color: #222;
  font-size: 16px;
  line-height: 1.5;
  outline: none;
  transition: border-color .15s, box-shadow .15s, background .15s;
}

.cvcf7-textarea {
  min-height: 170px;
  resize: vertical;
}

.cvcf7-input:focus,
.cvcf7-textarea:focus {
  border-color: #12438a;
  box-shadow: 0 0 0 3px rgba(12, 87, 139, .16);
}

.cvcf7-input::placeholder,
.cvcf7-textarea::placeholder {
  color: #aaa;
}


/* 4) selectをtextと同じ見た目に（角丸なし/高さ/枠） */
.cvcf7-select {
  -webkit-appearance: none;
  appearance: none;
  border-radius: 0;
  background-color: #fff;
  border: 1px solid #cfcfcf;
  padding: 14px 44px 14px 14px;
  /* 右の矢印ぶん */
  line-height: 1.5;
  width: 100%;
}

/* selectの矢印を自前で出す（右側） */
.cvcf7-dd {
  position: relative;
  /* dd内のselect矢印配置に使う */
}

.cvcf7-dd:has(.cvcf7-select)::after {
  content: "";
  position: absolute;
  right: 16px;
  top: 40px;
  width: 8px;
  height: 8px;
  border-right: 2px solid #666;
  border-bottom: 2px solid #666;
  transform: rotate(45deg);
  pointer-events: none;
}

/* focus時も統一 */
.cvcf7-select:focus {
  border-color: #8a6f3b;
  box-shadow: 0 0 0 3px rgba(138, 111, 59, .16);
}

/* ---------- counter ---------- */
.cvcf7-counter {
  margin-top: 8px;
  font-size: 12px;
  color: #777;
  text-align: right;
}

/* ---------- address rows (3 lines) ---------- */
.cvcf7-address-rows {
  display: grid;
  gap: 12px;
}

.cvcf7-address-row {
  margin-bottom: 20px;
}

/* ---------- checkbox (urgent) spacing ---------- */
.cvcf7-dd .wpcf7-list-item {
  margin: 0;
}

.cvcf7-dd .wpcf7-list-item-label {
  font-size: 15px;
  color: #333;
}

/* ---------- privacy ---------- */
.cvcf7-privacy {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

/* ---------- validation colors ---------- */
.cvcf7-form .wpcf7-not-valid {
  border-color: #d9534f !important;
  background: #fff6f6 !important;
}

.cvcf7-form .wpcf7-not-valid-tip {
  margin-top: 6px;
  font-size: 13px;
  color: #d9534f;
}

/* requiredのブラウザ判定（CF7のrequiredが反映される環境向け） */
.cvcf7-form input[required]:valid,
.cvcf7-form textarea[required]:valid {
  border-color: #2e7d32;
  background: #f6fff6;
}

.cvcf7-form input[required]:invalid,
.cvcf7-form textarea[required]:invalid {
  border-color: #d9534f;
}

/* ---------- upload UI (square) ---------- */
.cvcf7-uploadGrid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

@media (max-width: 767px) {
  .cvcf7-uploadGrid {
    grid-template-columns: 1fr;
  }

  .cvcf7-dd:has(.cvcf7-select)::after {
    content: "";
    position: absolute;
    right: 16px;
    top: 20px;
    width: 8px;
    height: 8px;
    border-right: 2px solid #666;
    border-bottom: 2px solid #666;
    transform: rotate(45deg);
    pointer-events: none;
  }
}

.cvcf7-uploadBox {
  position: relative;
  display: block;
  min-width: 0;
}

.cvcf7-uploadBox input[type="file"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  z-index: 2;
}

.cvcf7-uploadUI {
  height: 140px;
  border: 1px dashed #bdbdbd;
  border-radius: 0;
  background: #fafafa;
  color: #666;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 7px;
  transition: background .15s, border-color .15s;
  user-select: none;
}

.cvcf7-plus {
  width: 46px;
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #bdbdbd;
  border-radius: 0;
  font-size: 28px;
  line-height: 1;
  color: #666;
}

.cvcf7-uploadText {
  font-size: 14px;
  font-weight: 800;
  color: #444;
  letter-spacing: .03em;
}

.cvcf7-fileName {
  display: block;
  font-size: 12px;
  color: #777;
  max-width: 100%;
  min-width: 0;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cvcf7-uploadBox:hover .cvcf7-uploadUI {
  background: #f4f4f4;
  border-color: #8a6f3b;
}

.cvcf7-uploadBox:focus-within .cvcf7-uploadUI {
  outline: 2px solid rgba(138, 111, 59, .25);
  outline-offset: 2px;
}

/* 選択済みの枠を少し強調（任意） */
.cvcf7-uploadBox.is-selected .cvcf7-uploadUI {
  border-color: #333;
}

.cvcf7-uploadBox.is-selected .cvcf7-plus {
  display: none;
  /* + を消したければ */
}

/* ---------- actions (square) ---------- */
.cvcf7-actions {
  margin-top: 30px;
  text-align: center;
  width: 100%;
  /* background-color: lightgray; */
  padding: 0;
}

.cvcf7-actions p {
  margin: 0;
  padding: 0;
  text-align: center;
}


.cvcf7-actions .wpcf7-spinner {
  display: none !important;
}

.cvcf7-submit {
  display: inline-block;
  padding: 14px 24px;
  min-width: 250px;
  border: 1px solid #1A4472;
  border-radius: 0;
  background: #1A4472;
  color: #fff;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: filter .15s;
}

.cvcf7-submit:hover {
  filter: brightness(1.08);
}

.cvcf7-submit:disabled {
  opacity: .45;
  cursor: not-allowed;
  filter: none;
}

/* ---------- confirm modal (square) ---------- */
.cvcf7-confirm {
  display: none;
}

.cvcf7-confirm.is-open {
  display: block;
  position: fixed;
  inset: 0;
  z-index: 9999;
}

.cvcf7-confirm__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .55);
}

.cvcf7-confirm__panel {
  position: relative;
  max-width: 760px;
  margin: 6vh auto;
  background: #fff;
  border-radius: 0;
  padding: 20px 18px;
  border: 1px solid #e6e6e6;
  box-shadow: 0 10px 30px rgba(0, 0, 0, .25);
}

@media (max-width: 767px) {
  .cvcf7-confirm__panel {
    margin: 4vh 14px;
    max-width: none;
  }
}

.cvcf7-confirm__title {
  margin: 0 0 12px;
  font-size: 18px;
  font-weight: 900;
  color: #222;
}

.cvcf7-confirm__body {
  font-size: 14px;
  line-height: 1.8;
  color: #333;
}

.cvcf7-confirm__body dl {
  margin: 0;
}

.cvcf7-confirm__body dt {
  font-weight: 900;
  margin-top: 12px;
}

.cvcf7-confirm__body dd {
  margin: 4px 0 0;
  color: #444;
  word-break: break-word;
}

.cvcf7-confirm__actions {
  display: flex;
  justify-content: center;
  /* 中央寄せ */
  align-items: center;
  gap: 16px;
  /* ボタン間の余白 */
  padding: 16px 24px;
  border-top: 1px solid rgba(0, 0, 0, .08);
  background: #fff;
}

.cvcf7-confirm__btn {
  min-width: 160px;
  padding: 14px 20px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid #333;
  background: #fff;
  color: #333;
  transition: .2s ease;
}

/* 戻る */
.cvcf7-confirm__btn--back {
  background: #fff;
  border: none;
}

.cvcf7-confirm__btn--send {
  background: #8a6f3b;
  border-color: #8a6f3b;
  color: #fff;
}

.cvcf7-confirm__btn--send:hover {
  opacity: .85;
}

/* スマホ対応 */
@media (max-width: 767px) {
  .cvcf7-confirm__actions {
    flex-direction: column;
  }

  .cvcf7-confirm__btn {
    width: 100%;
    max-width: 320px;
  }
}

/* =========================
   Confirm：actions を横並び固定
========================= */
.cvcf7-confirm.is-open .cvcf7-confirm__actions {
  display: flex !important;
  flex-direction: row !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 16px !important;
  /* ← ボタン間の余白 */
  padding: 18px 24px !important;
  box-sizing: border-box;
}

/* ボタン共通（横幅と余白） */
.cvcf7-confirm.is-open .cvcf7-confirm__btn {
  display: inline-flex !important;
  justify-content: center;
  align-items: center;
  min-width: 170px;
  padding: 14px 20px;
  box-sizing: border-box;
}

/* もしどこかで block + width:100% にされていたら潰す */
.cvcf7-confirm.is-open .cvcf7-confirm__btn {
  width: auto !important;
  max-width: none !important;
}

.cvcf7-confirm.is-open .cvcf7-confirm__actions .cvcf7-confirm__btn {
  position: static !important;
}

/* =========================
   Confirm：パネルの高さと下余白
========================= */
.cvcf7-confirm.is-open .cvcf7-confirm__panel {
  /* 画面上下に余白を作る */
  top: 50%;
  transform: translate(-50%, -50%);
  max-height: calc(100vh - 140px) !important;
  /* ← 下に余白を増やす */
  padding-bottom: 28px;
  /* ← 最下部の詰まり防止 */
}

/* iPhone Safari対策：100vh のズレ回避（保険） */
@supports (height: 100dvh) {
  .cvcf7-confirm.is-open .cvcf7-confirm__panel {
    max-height: calc(100dvh - 140px) !important;
  }
}

/* ボタンをパネル下に固定（おすすめ） */
.cvcf7-confirm.is-open .cvcf7-confirm__actions {
  position: sticky;
  bottom: 0;
  background: #fff;
  border-top: 1px solid rgba(0, 0, 0, .08);
  margin-top: 18px;
}

/* =========================
   カスタムチェックボックス（CVCF7）
   - 角丸なし（四角）
   - タップしやすい大きさ
========================= */

/* 包み（件名内の緊急／同意どちらも共通） */
.cvcf7-check-wrap {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border: 1px solid #ddd;
  background: #fff;
  width: auto;
}

/* クリックしやすく（label要素に反映） */
.cvcf7-check-wrap label {
  display: flex;
  align-items: center;
  gap: 14px;
  cursor: pointer;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  color: #333;
  margin: 0;
}

/* CF7の余計な余白を潰す */
.cvcf7-check-wrap .wpcf7-list-item {
  margin: 0;
}

/* チェック本体（完全カスタム） */
.cvcf7-check-wrap input[type="checkbox"] {
  margin: 0;
  appearance: none;
  -webkit-appearance: none;
  width: 22px;
  height: 22px;
  border: 2px solid #6f8263;
  background: #fff;
  position: relative;
  cursor: pointer;
  flex: 0 0 auto;
}

/* ON */
.cvcf7-check-wrap input[type="checkbox"]:checked {
  background: #6f8263;
  border-color: #6f8263;
}

/* ✓ */
.cvcf7-check-wrap input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  left: 6px;
  top: 2px;
  width: 6px;
  height: 12px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}

/* フォーカス（キーボード操作対応） */
.cvcf7-check-wrap input[type="checkbox"]:focus-visible {
  outline: 2px solid rgba(111, 130, 99, .6);
  outline-offset: 2px;
}

/* =========================
   緊急用（件名内）
========================= */
.cvcf7-check-wrap--urgent {
  margin-top: 12px;
  border-color: #b00000;
  background: #fff;
}

.cvcf7-check-wrap--urgent label,
.cvcf7-check-wrap--urgent .wpcf7-list-item-label {
  color: #b00000;
}

.cvcf7-check-wrap--urgent input[type="checkbox"] {
  border-color: #b00000;
}

.cvcf7-check-wrap--urgent input[type="checkbox"]:checked {
  background: #b00000;
  border-color: #b00000;
}

/* チェックON時の✓ */
.cvcf7-check-wrap--urgent input[type="checkbox"]:checked::after {
  border-color: #fff;
}

/* チェックON時のテキスト色 */
.cvcf7-check-wrap--urgent input[type="checkbox"]:checked~.wpcf7-list-item-label {
  color: #fff;
}

/* label全体を反転させたい場合（保険） */
.cvcf7-check-wrap--urgent:has(input[type="checkbox"]:checked) {
  background: #b00000;
}

/* =========================
   同意（重要）
========================= */

/* =========================
   プライバシーポリシー同意（送信前・最終版）
========================= */

/* 全体ラップ */
.cvcf7-privacy-wrap {
  margin: 32px 0 24px;
  text-align: center;
}

/* チェック＋文言の箱 */
.cvcf7-privacy {
  display: inline-flex;
  align-items: center;
  gap: 18px;
  /* チェックと文字の間隔 */
  padding: 16px 22px;
  /* border: 1px solid #333; */
  background: #f7f7f7;
  cursor: pointer;
}

/* チェック本体（緊急と同サイズ・四角） */
.cvcf7-privacy input[type="checkbox"] {
  margin: 0;
  appearance: none;
  -webkit-appearance: none;
  width: 22px;
  height: 22px;
  border: 2px solid #b0b0b0;
  background: #fff;
  position: relative;
  cursor: pointer;
  transform: translateY(-2px);
}

/* チェックON */
.cvcf7-privacy input[type="checkbox"]:checked {
  background: #0c578b;
  border-color: #0c578b;
}

/* ✓ マーク */
.cvcf7-privacy input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  left: 6px;
  top: 2px;
  width: 6px;
  height: 12px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}

/* ラベル文字 */
.cvcf7-privacy span {
  font-size: 17px;
  font-weight: 600;
  color: #222;
  line-height: 1.4;
}

/* 注釈テキスト */
.cvcf7-privacy-wrap .cvcf7-note {
  margin-top: 10px;
  font-size: 14px;
  color: #555;
}

/* フォーカス可視化（キーボード対応） */
.cvcf7-privacy input[type="checkbox"]:focus-visible {
  outline: 2px solid rgba(0, 0, 0, .4);
  outline-offset: 2px;
}

/* スマホ微調整 */
@media (max-width: 767px) {
  .cvcf7-privacy {
    padding: 14px 18px;
  }

  .cvcf7-privacy span {
    font-size: 16px;
  }

}

/* =========================
   Confirm modal
   ========================= */

/* ラッパー：画面全体に固定（初期は非表示） */
.cvcf7-confirm {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: none;
}

/* 開いた時だけ表示 */
.cvcf7-confirm.is-open {
  display: block;
}

/* 背景（黒） */
.cvcf7-confirm__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .55);
}

/* パネル本体 */
.cvcf7-confirm__panel {
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(900px, calc(100% - 32px));
  max-height: calc(100vh - 80px);
  overflow: auto;

  background: #fff;
  border: 1px solid rgba(0, 0, 0, .15);
  box-shadow: 0 12px 40px rgba(0, 0, 0, .35);
  padding: 24px;
}

/* 念のため：変なCSSに負けないよう最低限だけ担保 */
.cvcf7-confirm.is-open .cvcf7-confirm__panel {
  opacity: 1;
  visibility: visible;
}

.cvcf7-confirm-list {
  margin: 16px 0 0;
}

.cvcf7-confirm-row {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 12px 18px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(0, 0, 0, .08);
}

.cvcf7-confirm-row dt {
  font-weight: 700;
  color: #222;
}

.cvcf7-confirm-row dd {
  margin: 0;
  color: #333;
  line-height: 1.7;
  word-break: break-word;
}

@media (max-width: 767px) {
  .cvcf7-confirm-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }
}

/* =========================================================
   Confirm modal (final / stable)
   - パネルは上下余白ありで中央
   - 本文だけスクロール
   - ボタンは横並び＋中央＋間隔
========================================================= */

.cvcf7-confirm {
  display: none;
}

.cvcf7-confirm.is-open {
  display: block;
  position: fixed;
  inset: 0;
  z-index: 99999;
}

/* 背景 */
.cvcf7-confirm__backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .55);
}

/* パネル：中央＋上下余白（パネル自体はスクロールさせない） */
.cvcf7-confirm__panel {
  position: fixed !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -55%) !important;

  width: min(900px, calc(100% - 32px)) !important;
  max-height: calc(100dvh - 140px) !important;
  /* 下余白確保 */
  background: #fff !important;
  border: 1px solid rgba(0, 0, 0, .15) !important;
  box-shadow: 0 12px 40px rgba(0, 0, 0, .35) !important;

  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  /* ← 重要：パネルは隠す */
  padding: 24px !important;
  box-sizing: border-box !important;
}

/* タイトル */
.cvcf7-confirm__title {
  margin: 0 0 12px !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  color: #1A4472;
}

/* 本文だけスクロール */
.cvcf7-confirm__body {
  overflow: auto !important;
  max-height: calc(100dvh - 320px) !important;
  /* タイトル+ボタン分を引く */
  padding-right: 8px;
  box-sizing: border-box;
}

/* ボタンエリア：横並び固定（重なり対策で全部潰す） */
.cvcf7-confirm__actions p {
  margin-top: 18px !important;
  padding-top: 16px !important;
  border-top: 1px solid rgba(0, 0, 0, .08) !important;

  display: flex !important;
  flex-direction: row !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 16px !important;
}

/* ボタン共通：margin潰しが重要 */
.cvcf7-confirm__btn {
  position: static !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  margin: 0 !important;
  /* ← 重要 */
  min-width: 170px !important;
  padding: 14px 20px !important;

  border: 1px solid #333 !important;
  background: #fff !important;
  color: #333 !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  box-sizing: border-box !important;
}

/* 送信 */
.cvcf7-confirm__btn--send {
  background: #1A4472 !important;
  border-color: #1A4472 !important;
  color: #fff !important;
}

/* SPは縦 */
@media (max-width: 767px) {
  .cvcf7-confirm__panel {
    width: calc(100% - 24px) !important;
    max-height: calc(100dvh - 100px) !important;
  }

  .cvcf7-confirm__actions {
    flex-direction: column !important;
  }

  .cvcf7-confirm__btn {
    width: 100% !important;
    max-width: 320px !important;
  }
}

/* =========================================================

サンクスページ用

========================================================= */

/* Thanks 専用 */
.cvc-thanks {
  padding: 64px 16px;
  /* color: #fff; */
}

.cvc-thanks__inner {
  max-width: 870px;
  margin: 0 auto;
  /* background: #0c578b; */
  padding: 32px 20px;
}

.cvc-thanks__inner p {
  font-size: 16px;
  line-height: 1.6;
}

.cvc-thanks__title {
  margin: 0 0 60px;
  font-size: 36px;
  line-height: 1.3;
  text-align: center;
  /* color: #fff; */
}

.cvc-thanks p {
  margin: 0 0 40px;
}

.cvc-thanks__call {
  margin-top: 100px;
  margin-bottom: 100px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items: center;
  border: solid 1px #fff;
  background-color: #fff;
}

.cvc-thanks__callLeft {
  font-size: 16px;
  line-height: 1.6;
  opacity: 0.95;
  padding: 40px;
}

.cvc-thanks__callLeft h3 {
  font-size: 18px;
  text-align: center;
}

.cvc-thanks__callRight {
  background: rgba(255, 255, 255, 0.10);
  padding: 40px;
  text-align: center;
  padding: 20px;
}

.cvc-thanks__callRight a {
  color: #1A4472;
}

.cvc-thanks__tel {
  display: inline-block;
  font-size: 36px;
  /* 電話番号大きく */
  font-weight: 800;
  color: #fff;
  text-decoration: none;
  line-height: 1.1;
  color: #0c578b;
  margin-bottom: 10px;
}

.cvc-thanks__tel i {
  margin-right: 10px;
  font-size: 30px;
}

.cvc-thanks__telSub {
  margin-top: 6px;
  font-size: 16px;
  opacity: 0.95;
}

.cvc-thanks__back {
  margin: 50px 0 0;
  text-align: center;
}

.cvc-thanks__back a {
  background-color: #1A4472;
  color: #fff;
}

.cvc-thanks__btn {
  display: inline-block;
  padding: 30px 60px;
  font-size: 18px;
  text-decoration: none;
}

.cvc-thanks__btn:visited {
  color: #fff;
}

/* スマホは縦積み */
@media (max-width: 640px) {
  .cvc-thanks__inner {
    /* padding: 28px 16px; */
    width: 90%;
  }

  .cvc-thanks__title {
    font-size: 24px;
  }

  .cvc-thanks__call {
    grid-template-columns: 1fr;
    margin: 50px auto;
    display: block;
    padding-bottom: 40px;
  }

  .cvc-thanks__tel {
    font-size: 28px;
  }

  .cvc-thanks__btn {
    color: #fff;
  }

  .cvc-thanks__btn:visited {
    color: #fff;
  }
}

/* スマホは縦積み */
@media (max-width: 640px) {

  .contact_text {
    font-size: 14px;
  }

  .contact_text b {
    font-weight: bold;
  }
}


/* ===================================

NEW footer nav

==================================== */

/* ==========================
フッター　ロゴ
========================== */

.footer_logo_wrap {
  display: block;
  width: 100%;
  margin: 0 auto 50px auto;
}

.footer_logo_wrap img {
  width: 100px;
  display: block;
  margin: 0 auto 50px;
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, .25));
}

/* =========================
   Footer ロゴ下 英字テキスト
========================= */

.footer_logo_wrap .co_name {
  margin-top: 14px;
  text-align: center;
  font-size: 28px;
  letter-spacing: 0.08em;
}

.footer_logo_wrap .co_name a {
  font-family: "Noto Sans JP", system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  font-weight: 300;
}

.footer_logo_wrap .co_name b {
  font-family: "Noto Sans JP", system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  font-weight: 700;
}

/* 通常文字：細く */
.footer_logo_wrap .co_name a {
  color: rgba(255, 255, 255, .75);
  text-decoration: none;
  font-weight: 300;
  /* ← 細字 */
  font-family: "Helvetica Neue", Arial, sans-serif;
}

/* bタグだけ太く */
.footer_logo_wrap .co_name b {
  font-weight: 700;
  /* ← 太字 */
  color: #fff;
  /* 少しだけ強調 */
}


.footer_nav_wrap {
  width: 1000px;
  margin: 100px auto 100px auto;
  display: flex;
  justify-content: space-between;
  /* gap: 32px; */
}

.footer_nav_wrap div {
  width: 30%;
  /* background-color: #0275d8; */
}

.footer_bussines .footer_bussines_title,
.footer_about .footer_about_title,
.footer_company .footer_company_title {
  display: block;
  margin-bottom: 20px;
  padding-left: 0;
  padding-bottom: 10px;
  border-bottom: solid 1px #fff;
  font-size: 16px;
  width: 90%;
}

.footer_company .company_name {
  font-size: 16px;
  margin: 40px auto 20px auto;
  width: 100%;
}

.footer_company .company_address {
  display: block;
  margin-bottom: 20px;
  width: 100%;
}

.footer_company .company_address p {
  margin-bottom: 10px;
  font-size: 14px;
}

.footer_company .company_tel {
  display: block;
  margin-bottom: 20px;
  width: 100%;
}

.footer_company .company_tel p {
  margin-bottom: 10px;
  font-size: 14px;
}

/* =========================
   Footer company contact (match footer style)
========================= */

.footer_company .company_contact {
  margin-top: 22px;
}

/* ボタン本体 */
.footer_company .company_contact a {
  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 15px 50px;
  background: transparent;
  /* ← 白ベタやめる */
  color: #fff;
  text-decoration: none;

  border: 1px solid rgba(255, 255, 255, .85);
  /* 細い白枠 */
  border-radius: 0;
  /* 角丸なし */

  font-size: 14px;
  font-weight: 600;
  letter-spacing: .04em;

  transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
}

/* アイコン */
.footer_company .company_contact a i {
  color: #fff;
  font-size: 14px;
}

/* hover：反転（上品に） */
.footer_company .company_contact a:hover {
  background: #fff;
  color: #000;
  border-color: #fff;
  transform: translateY(-1px);
}

.footer_company .company_contact a:hover i {
  color: #000;
}



/* =========================
   Footer ナビ：文字折り返し防止
========================= */

/* すべての footer 内リンクを折り返さない */
.footer_nav_wrap a {
  white-space: nowrap;
}

/* 念のため ul のデフォルト余白リセット */
.footer_nav_wrap ul {
  margin: 0 0 0 5px;
  padding: 0;
  list-style: none;
}

/* li をアイコン分だけインデント */
.footer_nav_wrap li {
  position: relative;
  padding-left: 18px;
  /* ← アイコン分 */
  margin: 40px 0;
  font-size: 14px;
}

/* Font Awesome f105（angle-right） */
.footer_nav_wrap li::before {
  content: "\f0da";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  /* ← solid 必須 */
  position: absolute;
  left: 0;
  top: 0.1em;
  /* 縦位置微調整 */
  color: #fff;
  font-size: 14px;
  /* サイズ調整 */
}

.footer_nav_wrap ul li ul {
  margin-left: 10px;
}


/* ===================================
   NEW footer nav（SP）
==================================== */
@media (max-width: 768px) {

  .footer_nav_wrap {
    width: 80%;
    margin: 40px auto 60px;
    display: flex;
    flex-direction: column;
    gap: 28px;
    /* ブロック間の余白 */
  }

  /* 3カラム → 1カラム */
  .footer_nav_wrap div {
    width: 100%;
    margin-bottom: 40px;
  }

  /* 見出しの幅を100%に */
  .footer_bussines .footer_bussines_title,
  .footer_about .footer_about_title,
  .footer_company .footer_company_title {
    width: 100%;
    margin-bottom: 14px;
  }

  /* 会社情報の余白を少し詰める */
  .footer_company .company_name {
    margin-bottom: 14px;
  }

  .footer_company .company_address,
  .footer_company .company_tel {
    margin-bottom: 14px;
  }

  .footer_company .company_address p,
  .footer_company .company_tel p {
    margin-bottom: 8px;
  }

  /* スマホは横幅が狭いので折り返し許可（はみ出し防止） */
  .footer_nav_wrap a {
    white-space: normal;
    /* ← ここがポイント */
    word-break: break-word;
  }

  /* リストの余白調整 */
  .footer_nav_wrap ul {
    margin: 0;
  }

  .footer_nav_wrap li {
    margin: 16px 0;
    /* PCの40pxは大きいので縮める */
    font-size: 14px;
    padding-left: 18px;
    /* アイコン分は維持 */
  }

  /* サブリストは少しインデント */
  .footer_nav_wrap ul li ul {
    margin-left: 10px;
    margin-top: 6px;
  }
}



/* ===================================

   ビルメンテナンス

   ==================================== */




/* ==============================
   BM管理：強みセクション
============================== */

.bm-strength__inner {
  max-width: 1100px;
  margin: 0 auto;
}

.bm-strength__h2 {
  margin: 0 0 60px 0 !important;
}

.bm-strength__grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 40px;
  align-items: stretch;
  margin-bottom: 80px;
}

/* 左：文章エリア */
.bm-strength__left {
  position: relative;
  padding: 40px 36px;
  background: #f6f7f9;
  overflow: hidden;
}

/* 薄いPOINT表示 */
.bm-strength__left::before {
  content: attr(data-point);
  position: absolute;
  left: 24px;
  top: 10px;
  font-size: 80px;
  font-weight: 800;
  letter-spacing: 0.05em;
  color: rgba(0, 0, 0, 0.05);
  line-height: 1;
  pointer-events: none;
}

/* h3 */
.bm-strength__h3 {
  margin: 0 0 16px 0;
  font-size: 26px;
  line-height: 1.4;
}

/* 本文 */
.bm-strength__p {
  margin: 0;
  font-size: 15px;
  line-height: 2;
}



/* 右：写真 */
.bm-strength__ph {
  width: 100%;
  height: 100%;
  min-height: 300px;
  background: #d9d9d9;
}

.bm-strength__ph img {
  width: 100%;
}

/* =====================
   SP対応
===================== */
@media (max-width: 768px) {

  .bm-strength__grid {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-bottom: 50px;
  }

  .bm-strength__left {
    padding: 28px 20px;
  }

  .bm-strength__left::before {
    font-size: 50px;
  }

  .bm-strength__h3 {
    font-size: 20px;
  }

  .bm-strength__ph {
    min-height: 200px;
  }
}

/* ===================================
   BM管理：対応できる主な業務（セクション）
   ※ HTML: .bm-ops〜 に対応
==================================== */

.bm-ops {
  padding: 70px 0;
}

.bm-ops__inner {
  /* 既存の .textwrap が幅管理している想定だけど、
     セクション内だけ少し読みやすくするなら max-width を追加してOK */
  max-width: 980px;
  margin: 0 auto;
}

.bm-ops__h2 {
  line-height: 1.35;
  margin: 0 0 60px 0 !important;
  letter-spacing: .02em;
}

.bm-ops__lead {
  margin: 0 auto 80px auto !important;
  font-size: 15px;
  line-height: 1.9;
  color: #333;
  max-width: 870px;
}

/* ---- ブロック（清掃管理など） ---- */
.bm-ops__block {
  border-top: 1px solid rgba(0, 0, 0, .12);
  padding-top: 26px;
  margin-top: 26px;
}

.bm-ops__h3 {
  font-size: 28px;
  line-height: 1.4;
  margin: 0 0 30px 0;
  letter-spacing: .02em;
}

.bm-ops__desc {
  margin: 0 0 60px 0 !important;
  font-size: 15px;
  line-height: 1.9;
  color: #333;
}

/* ---- サブカテゴリ（建物内部清掃 / 外部清掃） ---- */
.bm-ops__sub {
  padding: 18px 0 50px;
  border-top: 1px solid rgba(0, 0, 0, .08);
}

.bm-ops__sub:first-of-type {
  border-top: none;
  padding-top: 0;
}

.bm-ops__h4 {
  font-size: 22px;
  line-height: 1.45;
  margin: 0 0 18px;
  letter-spacing: .02em;
}

.bm-ops__subdesc {
  margin: 0 0 16px;
  font-size: 14px;
  line-height: 1.9;
  color: #333;
}

/* ---- 写真グリッド（4枚横→折り返し） ---- */
.bm-ops__photos {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-top: 14px;
}

/* 1枚（figure） */
.bm-ops__photo {
  margin: 0;
}

.bm-ops__photo img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  filter: brightness(0.95);
}


/* 仮画像（グレーの箱） */
.bm-ops__ph {
  width: 100%;
  aspect-ratio: 4 / 3;
  /* 写真比率の目安 */
  background: #d9d9d9;
  /* 仮置きグレー */
  border: 1px solid rgba(0, 0, 0, .08);
}

/* 画像下のキャプション */
.bm-ops__cap {
  margin-top: 8px;
  font-size: 13px;
  line-height: 1.5;
  color: #222;
}

/* ===================================
   レスポンシブ
==================================== */

/* タブレット：2列 */
@media (max-width: 1024px) {
  .bm-ops__inner {
    max-width: 92%;
  }

  .bm-ops__photos {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* スマホ：1列 */
@media (max-width: 600px) {
  .bm-ops {
    padding: 50px 0;
  }

  .bm-ops__h2 {
    font-size: 24px;
  }

  .bm-ops__h3 {
    font-size: 20px;
  }

  .bm-ops__h4 {
    font-size: 17px;
  }

  .bm-ops__photos {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .bm-ops__cap {
    font-size: 13px;
  }
}

/* =====================================
   BM管理：マネジメント対象施設（主要3 + 連携2）
   ※他CSSを壊さないよう .bm-facilities 配下に限定
===================================== */

.bm-facilities {
  padding: 100px 0;
}

/* 既存の .inner がある前提（無ければ max-width/ padding をここに足してOK） */
.bm-facilities .inner {
  max-width: 980px;
  margin: 0 auto;
}

/* 見出し（共通の section-title を壊さない） */
.bm-facilities .section-title {
  margin: 0 0 60px 0 !important;
  text-align: center;
}

/* リード文 */
.bm-facilities__lead {
  max-width: 920px;
  margin: 0 auto 56px auto;
  text-align: center;
  font-size: 16px;
  line-height: 1.9;
  color: #444;
}

/* 連携説明文（リードより弱め） */
.bm-facilities__sublead {
  max-width: 820px;
  margin: 0 auto 44px auto;
  text-align: center;
  font-size: 15px;
  line-height: 1.9;
  color: #666;
}

/* グリッド共通 */
.bm-facilities__grid {
  display: grid;
  gap: 40px;
  margin: 0;
  padding: 0;
}

/* 主要：3カラム */
.bm-facilities__grid--primary {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 56px;
}

/* 連携：2カラム */
.bm-facilities__grid--secondary {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* カード */
.bm-facilities__item {
  display: flex;
  flex-direction: column;
  /* もし他CSSで box-shadow / border が入って崩れるならここで整える */
  background: transparent;
}

.bm-facilities__item img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
  margin-bottom: 10px;
}

/* 画像（後で差し替える前提のグレー） */
.bm-facilities__img {
  width: 100%;
  height: 220px;
  background: #e5e5e5;
  margin: 0 0 18px 0 !important;
  /* 画像を入れるなら background-image で対応できる */
  background-size: cover;
  background-position: center;
}

/* タイトル */
.bm-facilities__item h3 {
  margin: 0 0 10px 0 !important;
  font-size: 19px;
  font-weight: 600;
  line-height: 1.4;
  color: #222;
}

/* 説明文 */
.bm-facilities__item p {
  margin: 0;
  font-size: 14px;
  line-height: 1.9;
  color: #555;
}

/* ====== SP（スマホ） ====== */
@media (max-width: 768px) {

  .bm-facilities {
    padding: 70px 0;
  }

  .bm-facilities__lead {
    margin-bottom: 40px;
    font-size: 15px;
  }

  .bm-facilities__sublead {
    margin-bottom: 36px;
    font-size: 14px;
  }

  .bm-facilities__grid--primary,
  .bm-facilities__grid--secondary {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .bm-facilities__img {
    height: 200px;
  }

  .bm-facilities__item h3 {
    font-size: 18px;
  }
}

/* ====== さらに小さい端末 ====== */
@media (max-width: 420px) {

  .bm-facilities {
    padding: 60px 0;
  }

  .bm-facilities__img {
    height: 180px;
  }
}

/* ==========================================
   BM管理の対応範囲（big-gray）
========================================== */

.bm-coverage-scope {
  padding: 100px 0;
}

.bm-coverage-scope .inner {
  width: 1100px;
  max-width: 92%;
  margin: 0 auto;
}

/* =====================
   タイトル・リード
===================== */

.bm-coverage-scope .section-title {
  text-align: center;
  font-size: 34px;
  letter-spacing: 1.5px;
  margin-bottom: 30px;
}

.bm-coverage-scope__lead {
  text-align: center;
  font-size: 16px;
  line-height: 1.9;
  max-width: 820px;
  margin: 0 auto 70px auto;
  color: #444;
}

/* =====================
   3カラムカード
===================== */

.bm-coverage-scope__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  margin-bottom: 80px;
}

/* カード本体 */
.bm-coverage-scope__card {
  background: #fff;
  padding: 50px 35px 40px 35px;
  position: relative;
  border: 1px solid #e5e5e5;
  transition: all .3s ease;
}

/* ホバーは控えめ（高級感） */
.bm-coverage-scope__card:hover {
  transform: translateY(-6px);
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.06);
}

/* 大きな番号 */
.bm-coverage-scope__num {
  position: absolute;
  top: -28px;
  left: 30px;
  font-size: 72px;
  font-weight: 700;
  color: rgba(12, 87, 139, 0.08);
  /* 薄いブルー */
  letter-spacing: 4px;
}

/* h3 */
.bm-coverage-scope__title {
  font-size: 20px;
  line-height: 1.6;
  margin-bottom: 20px;
  font-weight: 600;
}

/* 本文 */
.bm-coverage-scope__text {
  font-size: 15px;
  line-height: 1.9;
  margin-bottom: 20px;
  color: #444;
}

/* リスト */
.bm-coverage-scope__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.bm-coverage-scope__list li {
  font-size: 14px;
  margin-bottom: 10px;
  padding-left: 16px;
  position: relative;
}

.bm-coverage-scope__list li::before {
  content: "▸";
  position: absolute;
  left: 0;
  color: #0c578b;
  font-size: 12px;
  top: 2px;
}

/* =====================
   下段帯（統括強調）
===================== */

.bm-coverage-scope__band {
  background: #0c578b;
  padding: 50px 60px;
  text-align: center;
  color: #fff;
}

.bm-coverage-scope__bandTitle {
  font-size: 20px;
  letter-spacing: 1px;
  margin-bottom: 18px;
  font-weight: 600;
}

.bm-coverage-scope__bandText {
  font-size: 15px;
  line-height: 1.9;
  opacity: 0.95;
}

/* =====================
   レスポンシブ
===================== */

@media (max-width: 1024px) {

  .bm-coverage-scope__grid {
    grid-template-columns: 1fr;
    gap: 50px;
  }

  .bm-coverage-scope__card {
    padding: 60px 30px 40px 30px;
  }

  .bm-coverage-scope__num {
    font-size: 60px;
  }

  .bm-coverage-scope__band {
    padding: 40px 30px;
  }

}


/* ==================================================
   AMページ：不動産売買・アセットマネジメント
   ※ BMの共通(.section/.textwrap/big-gray等)は流用
   ※ ここはAM専用クラスのみでデザイン
================================================== */

.am-page {
  /* 必要ならページ全体の微調整 */
}

/* -------------------------
  Hero
------------------------- */
.am-hero {
  /* 既存の .pageHeader.business を前提に、必要なら上書き */
}

.am-hero .pageHeader__inner h2 em {
  display: block;
  font-style: normal;
  letter-spacing: 0.08em;
  font-size: 14px;
  opacity: 0.85;
  margin-bottom: 6px;
}

/* -------------------------
  Intro（H2-1）
------------------------- */
.am-intro__h2 {
  margin: 0 0 60px 0 !important;
}

/* .am-intro__grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 28px;
  align-items: center;
} */

.am-intro__lead {
  font-size: 16px;
  line-height: 1.9;
  margin: 0 0 14px 0;
}

.am-intro__note {
  margin-top: 14px;
  font-size: 13px;
  opacity: 0.85;
}

.am-intro__ph {
  width: 100%;
  aspect-ratio: 4 / 3;
  background: #d9d9d9;
  border-radius: 0;
}

/* -------------------------
  Strength（H2-2：BMと同型）
------------------------- */

.am-strength__inner {
  max-width: 1100px;
  margin: 0 auto;
}

.am-strength__h2 {
  margin: 0 0 60px 0;
}

.am-strength__lead {
  margin: 0 auto 56px auto !important;
  line-height: 1.9;
  opacity: 0.95;
  text-align: center;
  max-width: 870px;
}

/* bm-strength と同じ“左右：文章/写真”をAM側でも使えるように */
.am-strength__grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 40px;
  align-items: stretch;
  margin-top: 80px;
}

.am-strength__left {
  position: relative;
  background: #f6f7f9;
  padding: 40px 36px;
  overflow: hidden;
}

.am-strength__left::before {
  content: attr(data-point);
  position: absolute;
  left: 24px;
  top: 10px;
  font-size: 80px;
  font-weight: 800;
  letter-spacing: 0.05em;
  color: rgba(0, 0, 0, 0.05);
  line-height: 1;
  pointer-events: none;
}

.am-strength__h3 {
  margin: 0 0 16px 0;
  font-size: 26px;
  line-height: 1.4;
}

.am-strength__p {
  margin: 0;
  font-size: 15px;
}

.am-strength__right {
  display: block;
}

.am-strength__right img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
}

.am-strength__ph {
  width: 100%;
  height: 100%;
  min-height: 300px;
  background: #d9d9d9;
  border-radius: 0;
}

/* -------------------------
  主な業務領域（H2-3）
------------------------- */

.am-ops_inner {
  max-width: 980px;
  margin: 0 auto;
}

.am-ops__h2 {
  margin: 0 0 60px 0 !important;
}

.am-ops__lead {
  margin: 0 auto 56px auto !important;
  line-height: 1.9;
  opacity: 0.95;
  text-align: center;
  max-width: 870px;
}

.am-ops__block {
  display: grid;
  gap: 18px;
}

.am-ops__main {
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.02);
  padding: 18px 18px 16px 18px;
}

.am-ops__h3 {
  font-size: 18px;
  margin: 0 0 16px 0 !important;
  border-bottom: solid 1px #333;
  padding-bottom: 10px;
  display: inline-block;
}

.am-ops__p {
  margin: 0;
  line-height: 1.9;
}

.am-ops__subGrid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-top: 14px;
}

.am-ops__sub {
  border: 1px solid rgba(255, 255, 255, 0.10);
  background: rgba(255, 255, 255, 0.02);
  padding: 14px 14px 12px 14px;
}

.am-ops__h4 {
  margin: 0 0 8px 0;
  font-size: 15px;
}

.am-ops__subp {
  margin: 0;
  line-height: 1.8;
  font-size: 14px;
  opacity: 0.95;
}

/* -------------------------
  主な取扱アセット（H2-4）
------------------------- */

.am-assets_inner {
  max-width: 980px;
  margin: 0 auto;
}

.am-assets__h2 {
  margin: 0 0 60px 0 !important;
}

.am-assets__lead {
  margin: 0 0 56px 0 !important;
  line-height: 1.9;
  text-align: center;
  color: #444;
}

.am-assets__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}

.am-asset-card {
  background: #ffffff;
}

.am-asset-card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
  margin-bottom: 10px;
}

.am-asset-card__ph {
  width: 100%;
  aspect-ratio: 4 / 3;
  background: #d9d9d9;
  margin-bottom: 10px;
}

.am-asset-card__title {
  margin: 0 0 10px 0 !important;
  font-size: 19px;
}

.am-asset-card__desc {
  margin: 0;
  line-height: 1.8;
  font-size: 14px;
  opacity: 0.95;
}

.am-assets__note {
  margin-top: 14px;
  font-size: 13px;
  opacity: 0.85;
}

/* -------------------------
  フィー（H2-5）
------------------------- */

.am-fee_inner {
  max-width: 980px;
  margin: 0 auto;
}

.am-fee__h2 {
  margin: 0 0 60px 0 !important;
}

.am-fee__box {
  background: #fff;
  padding: 18px 18px 10px 18px;
}

.am-fee__h3 {
  margin: 0 0 8px 0;
  font-size: 17px;
}

.am-fee__p {
  margin: 0 0 14px 0;
  line-height: 1.9;
}

/* -------------------------
  相談（H2-6） big-gray 内で映える
------------------------- */
.am-contact__h2 {
  margin: 0 0 10px 0;
}

.am-contact__lead {
  margin: 0 0 16px 0;
  line-height: 1.9;
  opacity: 0.95;
}

.am-contact__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 10px;
}

.am-contact__telBox,
.am-contact__btnBox {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  padding: 16px;
}

.am-contact__telLabel {
  font-size: 13px;
  opacity: 0.9;
  margin-bottom: 8px;
}

.am-contact__tel {
  display: inline-block;
  font-size: 26px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #fff;
  text-decoration: none;
}

.am-contact__telNote,
.am-contact__btnNote {
  margin-top: 6px;
  font-size: 12px;
  opacity: 0.9;
}

.am-contact__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  background: #fff;
  color: #1A4472;
  text-decoration: none;
  font-weight: 700;
  border-radius: 0;
  /* 角丸なし */
  border: none;
}

.am-contact__btn i {
  color: #1A4472;
}

/* -------------------------
  Responsive
------------------------- */
@media (max-width: 980px) {
  .am-intro__grid {
    grid-template-columns: 1fr;
  }

  .am-strength__grid {
    grid-template-columns: 1fr;
  }

  .am-strength__ph {
    min-height: 220px;
  }

  .am-assets__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .am-ops__subGrid {
    grid-template-columns: 1fr;
  }

  .am-assets__grid {
    grid-template-columns: 1fr;
  }

  .am-contact__row {
    grid-template-columns: 1fr;
  }

  .am-contact__tel {
    font-size: 24px;
  }
}



/* -------------------------
  business.php 新しいリンク
------------------------- */
/* =========================
   Business：リンクボックス（2列・右に ＞）
========================= */
.biz-sec1-links {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  /* ← 2列 */
  gap: 18px;
}

/* カード本体 */
.biz-linkCard {
  display: block;
  min-height: 160px;
  background: #d9d9d9;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  text-decoration: none;
  color: #fff;
  /* ← 白 */
  position: relative;
  overflow: hidden;
}

/* 背景を擬似要素にコピーしてズームさせる */
.biz-linkCard::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: inherit;
  /* ← 親の background-image を引き継ぐ */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transform: scale(1);
  transition: transform .45s ease;
  z-index: 0;
}

/* visitedも白（上書きされがちなので明示） */
.biz-linkCard:visited {
  color: #fff;
}

.biz-linkCard:hover {
  opacity: .92;
  /* 任意：いらなければ消してOK */
}

/* hoverで背景だけ拡大 */
.biz-linkCard:hover::before {
  transform: scale(1.06);
}

/* 文字は上寄せにする（上合わせ） */
.biz-linkCard__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 16px 44px 16px 16px;
  /* 右側に「＞」の余白 */
  background: linear-gradient(to bottom, rgba(0, 0, 0, .55), rgba(0, 0, 0, .15));
}

/* タイトル／説明 */
.biz-linkCard__title {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
  color: #fff;
}

.biz-linkCard__desc {
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.6;
  color: #fff;
  opacity: .95;
}

/* 右端の「＞」 */
.biz-linkCard::after {
  content: "\f105";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
  pointer-events: none;
  opacity: .9;
}

/* スマホ：1列に */
@media (max-width: 768px) {
  .biz-sec1-links {
    grid-template-columns: 1fr;
  }
}