/* Custom CSS - カスタムスタイルをここに記述してください */

/* ナビゲーションメニューのフォントファミリーをh1と同じにする */
.navbar-nav.me-auto {
  font-family: "Poppins", sans-serif;
}

/* leadテキストのフォントファミリーをh1と同じにする */
p.lead.mb-5 {
  font-family: "Poppins", sans-serif;
}

/* スマホでleadテキストを白枠文字にする */
@media (max-width: 767.98px) {
  .hero-section-ng p.lead.mb-4 {
    color: #222222 !important;
    text-shadow: 
      -1px -1px 0 #ffffff,
      1px -1px 0 #ffffff,
      -1px 1px 0 #ffffff,
      1px 1px 0 #ffffff,
      -2px -2px 0 #ffffff,
      2px -2px 0 #ffffff,
      -2px 2px 0 #ffffff,
      2px 2px 0 #ffffff,
      -1px 0 0 #ffffff,
      1px 0 0 #ffffff,
      0 -1px 0 #ffffff,
      0 1px 0 #ffffff;
  }
  
  /* スマホで「事務所について」ボタンの背景を白にする */
  .hero-section-ng .btn-outline-primary {
    background-color: #ffffff !important;
    border-color: #004dbf !important;
    color: #004dbf !important;
  }
  
  .hero-section-ng .btn-outline-primary:hover {
    background-color: #004dbf !important;
    color: #ffffff !important;
  }

  .display-5 {
    font-size: calc(1.425rem + 1.4vw);
  }
}

/* ボタンのフォントファミリーをh1と同じにする */
.btn {
  font-family: "Poppins", sans-serif;
}

/* ヒーローセクションのcontainerの背景画像 */
.hero-section-ng .container {
  background-image: url('../images/top/main01.webp');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
}

.header-wrapper .header-logo img {
    height: 64px;
    transition: all 0.3s ease;
}
.header-wrapper .header-top-row {
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

/* ヘッダー連絡先情報のスタイル */
.header-wrapper .header-contact {
    font-family: "Poppins", sans-serif;
}

.header-wrapper .header-phone {
    color: #1c1c1c;
    font-size: 1.1rem;
    transition: all 0.3s ease;
}

.header-wrapper .header-phone:hover {
    color: #004dbf;
    transform: translateY(-1px);
}

.header-wrapper .header-phone i {
    font-size: 1.2rem;
    color: #004dbf;
}

.header-wrapper .header-phone .fw-bold {
    font-weight: 600;
    letter-spacing: 0.5px;
}

.header-wrapper .header-hours {
    font-size: 0.85rem;
    margin-top: 0.25rem;
    color: #6c757d;
}

.header-wrapper .header-hours i {
    font-size: 0.9rem;
}

/* ページヒーロー（控えめ） */
.page-hero {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 30vh; /* スマホ */
  padding: 3rem 0;
  color: #1c1c1c;
  overflow: hidden;
}

@media (min-width: 992px) {
  .page-hero {
    min-height: 16vh; /* TOPヒーローの約50〜60%目安 */
    padding: 2.0rem 0;
  }
}

/* 背景：薄いグラデ＋写真を淡く */
.page-hero--about {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #FFFFFF;
}

.page-hero .breadcrumb {
  background: transparent;
  justify-content: center;
}

.page-hero .breadcrumb a {
  color: #004dbf;
  text-decoration: none;
}

.page-hero .breadcrumb a:hover {
  text-decoration: underline;
}

.page-hero .breadcrumb .active {
  color: rgba(28, 28, 28, 0.7);
}

.page-hero__subtitle {
  color: rgba(28, 28, 28, 0.78);
  max-width: 48rem;
  margin-left: auto;
  margin-right: auto;
}

.display-4{
  font-size: 2.5rem;
}
/* ナビゲーションメニューの1つ目の<li>の表示制御（デスクトップナビゲーションのみ） */
.header-wrapper .navbar .navbar-collapse .navbar-nav .nav-item:first-child {
  display: none;
}

.header-wrapper .navbar.sticky .navbar-collapse .navbar-nav .nav-item:first-child {
  display: block;
}

/* スマホでヘッダーを1段にする */
@media (max-width: 991.98px) {
  .header-wrapper .navbar {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
  }
  
  .header-wrapper .navbar .container {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    width: 100%;
  }
  
  .header-wrapper .navbar .navbar-brand {
    flex-shrink: 0;
    margin-right: auto;
  }
  
  .header-wrapper .navbar .header-actions {
    flex-shrink: 0;
    margin-left: auto;
  }
  
  .header-wrapper .navbar .navbar-collapse {
    flex-basis: 100%;
    flex-grow: 0;
  }
}

/* text-muted mb-0のフォントファミリーをh1と同じにする */
.text-muted.mb-0 {
  font-family: "Poppins", sans-serif;
}

.text-muted {
    font-family: "Poppins", sans-serif;
  }

.services-section .service-card h3, .services-section .service-card .h3 {
    position: relative;
    padding-bottom: 0rem;
    margin-bottom: 1rem;
}
.services-section .service-card {
    padding: 1.5rem 1.5rem;
}

.service-icon2 {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    font-size: 1rem;
    transition: all 0.5s ease;
}

/* Bootstrapに無いレスポンシブユーティリティ（lg以上で境界線を消す） */
@media (min-width: 992px) {
  .border-lg-0 {
    border: 0 !important;
  }
  .border-bottom-lg-0 {
    border-bottom: 0 !important;
  }
}

/* 
事務所についてページのスタイル
*/
.about-page .service-icon2 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-size: 1rem;
  transition: all 0.5s ease;
}

/* 
サービスページのスタイル
*/
.service-page .service-icon2 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-size: 1rem;
  transition: all 0.5s ease;
}
.service-page h6 {
  font-family: "Poppins", sans-serif;
}
.service-page .text-muted {
  font-family: "Poppins", sans-serif;
}
.service-page .blog-category {
  font-family: "Poppins", sans-serif;
}

/* 
料金ページのスタイル
*/
.price-page .service-icon2 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-size: 1rem;
  transition: all 0.5s ease;
}

/*
お問い合わせフォームのエラー表示
*/
.input-group.is-invalid .input-group-text {
  border: 1px solid #dc3545;
  border-right: none;
}

.input-group.is-invalid .form-control.is-invalid {
  border: 1px solid #dc3545;
  border-left: none;
}

.input-group.is-invalid .form-control.is-invalid:focus {
  border-color: #dc3545;
  border-left: none;
  box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.25);
}

/* textareaや通常のform-controlのエラー表示 */
.form-control.is-invalid:not(.input-group .form-control),
textarea.form-control.is-invalid {
  border: 1px solid #dc3545;
}

.form-control.is-invalid:focus:not(.input-group .form-control),
textarea.form-control.is-invalid:focus {
  border-color: #dc3545;
  box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.25);
}

/* 
フッターのスタイル
*/
.footer a {
  color: rgba(var(--bs-dark-rgb), var(--bs-text-opacity)) !important;
}
.footer .border-top2 {
  border-color: rgba(0, 0, 0, 1.0) !important;
  border-top: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}
