.bs-text-sp {
  display: none;
}

.brand-search {
  background: #2d2d2d;
  color: #fff;
  padding: clamp(24px, 5vw, 48px) 0 0;
}
/* 1カラムでOK（この後ろに会社情報などを足す場合も問題なし） */
.brand-search .container {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(16px, 3vw, 36px);
}

/* タイトル行：左=タイトル、右=検索ボタン */
.bs-head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  column-gap: clamp(12px, 2vw, 20px);
}

.bs-title {
  margin: 0;
  font-weight: 800;
  font-size: 30px;
  line-height: 1.45;
}

.bs-desc {
  margin: 0;
  font-size: clamp(13px, 1.2vw, 16px);
  line-height: 1.8;
  color: rgba(255, 255, 255, 0.85);
}

/* 検索ボタンを大きく */
.bs-search {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: transform 0.12s ease, opacity 0.15s ease, background 0.15s ease;
}
.bs-search img {
  display: block;
  width: 70%;
  height: auto;
}
.bs-search:hover {
  transform: translateY(-1px);
  opacity: 0.95;
  background: rgba(255, 255, 255, 0.18);
}

/* タブレット以下は縦積み＆中央 */
@media (max-width: 768px) {
  .bs-text {
    display: none;
  }
  .bs-text-sp {
    display: block;
    padding: 0 20px;
  }

  /* SPは縦並びに（タイトル → 説明 → 検索ボタン） */
  .bs-text-sp .bs-head {
    display: flex; /* 基本スタック */
    flex-direction: column; /* 縦並び */
    align-items: center; /* 中央寄せ */
    gap: 10px;
  }

  /* 体裁微調整（サイズはお好みで） */
  .bs-text-sp .bs-title {
    margin: 0;
    font-size: 25px;
    line-height: 1.5;
    text-align: left;
  }
  .bs-text-sp .bs-desc {
    margin: 0;
    font-size: 14px;
    line-height: 1.8;
    text-align: left; /* センターが良ければ center に */
  }

  /* 検索ボタンは中央に大きめ */
  .bs-text-sp .bs-search {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .bs-text-sp .bs-search img {
    display: block;
    width: 100%;
    height: auto;
  }
}

/* 既存の .brand-search .container は 1fr | auto の2カラム。
   下の2ブロックは全幅に広げる */
.company-block,
.brand-foot {
  grid-column: 1 / -1;
}

/* 会社情報 + 地図：左=テキスト / 右=地図 */
.company-block {
  margin-top: clamp(20px, 4vw, 40px);
  display: grid;
  grid-template-columns: 1fr minmax(380px, 750px);
  align-items: start;
  gap: clamp(16px, 3vw, 40px);
}

/* テキスト側 */
.company-name {
  margin: 0 0 8px;
  font-size: clamp(18px, 2vw, 28px);
  font-weight: 800;
  color: #fff;
}
.company-addr,
.company-telfax,
.company-url {
  margin: 4px 0;
  font-size: clamp(12px, 1.2vw, 16px);
  line-height: 1.8;
  color: rgba(255, 255, 255, 0.9);
}
.company-telfax a,
.company-telfax a:link,
.company-telfax a:visited,
.company-telfax a:hover,
.company-telfax a:active {
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
}
.company-telfax a:hover { opacity: .9; } 

.company-url a {
  color: rgba(255, 255, 255, 0.95);
  text-decoration: none;
}
.company-url a:hover {
  text-decoration: underline;
}

/* 地図側 */
.company-map iframe {
  display: block;
  width: 100%;
  height: clamp(180px, 32vw, 340px);
  border: 0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
}

/* フッター行：左ロゴ / 右コピーライト */
.brand-foot {
  margin-top: clamp(28px, 5vw, 56px);
  padding-top: clamp(16px, 3vw, 24px);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.footer-logo {
  display: block;
  height: auto;
}
.copyright {
  font-size: clamp(11px, 1vw, 14px);
  color: rgba(255, 255, 255, 0.85);
}

/* タブレット以下は縦積み＆中央寄せ */
@media (max-width: 767px) {
  .company-block {
    grid-template-columns: 1fr;
  }
  .brand-foot {
    gap: 9px;
    text-align: center;
    margin: 0 auto;
    padding-top: 0;
    padding: 10px 20px 20px;
    align-items: baseline;
  }
  .brand-search .container {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .bs-search {
    margin: 8px auto 0;
  }
  .company-name {
    font-size: 40px;
  }
  .company-text {
    text-align: center;
    padding: 0 50px;
  }
  .company-social {
    justify-content: center;
  }
  .footer-logo {
    width: 70%;
  }
  .company-url {
    text-align: left;
    padding-left: 16%;
  }
}

@media (max-width: 414px) {
  .company-url {
    padding-left: 14%;
  }
}

@media (max-width: 390px) {
  .bs-text-sp .bs-title {
    font-size: 21px;
  }
  .company-name {
    font-size: 36px;
  }
  .company-url {
    padding-left: 11%;
  }
}

@media (max-width: 375px) {
  .company-url {
    padding-left: 9%;
  }
}

.company-social {
  margin-top: 18px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.cs-link {
  display: inline-flex;
  width: clamp(36px, 3.6vw, 44px); /* アイコンの大きさはここで調整 */
  height: clamp(36px, 3.6vw, 44px);
}
.cs-link img {
  display: block;
  width: 100%;
  height: auto;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.25));
  transition: transform 0.12s ease, opacity 0.15s ease;
}
.cs-link:hover img {
  transform: translateY(-1px);
  opacity: 0.95;
}
