/* ==========================================================
   CYCLE LaB - Mobile Optimization CSS v50
   ========================================================== */

/* ============================================
   ヘッダー（共通）
   ============================================ */

.header {
  background-color: var(--bg-base);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  height: 60px;
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 60px;
  padding: 0 1rem;
}

.header .logo {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  text-decoration: none;
  flex-shrink: 0;
}

.header .logo-icon-img {
  width: 38px;
  height: 38px;
  max-width: 38px;
  min-width: 38px;
  object-fit: contain;
  flex-shrink: 0;
}

.header .logo-text {
  display: flex;
  flex-direction: column;
  white-space: nowrap;
}

.header .logo-main {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--text-dark);
  line-height: 1.1;
}

.header .logo-sub {
  font-size: 0.55rem;
  color: var(--text-muted);
  letter-spacing: 0.06em;
}


/* ============================================
   ダークモード対応（Apple HIG準拠）
   ============================================ */

/* ダーク背景セクションの文字色を白に */
.hero,
.hero-content,
.cta-section {
  color: #fff;
}

.hero h1,
.hero h2,
.hero p,
.hero span,
.hero-label,
.hero-desc,
.cta-section h2,
.cta-section p,
.cta-hours,
.cta-phone {
  color: #fff;
}

.hero a,
.cta-section a:not(.btn) {
  color: #fff;
}

/* ============================================
   ダークモード（prefers-color-scheme: dark）
   ============================================ */

@media (prefers-color-scheme: dark) {
  
  /* 基本背景・文字色 */
  body {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  /* ヘッダー */
  .header {
    background-color: var(--bg-dark);
    border-bottom: 1px solid var(--border);
  }
  
  .header .logo-icon-img {
    /* ダークモードでもサイズ維持 */
    width: 38px;
    height: 38px;
  }
  
  .header .logo-main {
    color: var(--text-primary);
  }
  
  .header .logo-sub {
    color: var(--text-muted);
  }
  
  .logo-main,
  .logo-sub,
  .nav-link {
    color: var(--text-primary);
  }
  
  .mobile-menu-btn span {
    background-color: var(--text-primary);
  }
  
  /* セクション背景 */
  section {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  /* セクションヘッダー */
  .section-header h2,
  .section-title,
  h2 {
    color: var(--text-primary);
  }
  
  .section-label {
    color: var(--primary);
  }
  
  .section-desc {
    color: var(--text-muted);
  }
  
  /* 会社概要ページ */
  .mission-section,
  .values-section,
  .info-section,
  .areas-section {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .mission-section h2,
  .values-section h2,
  .info-section h2,
  .areas-section h2 {
    color: var(--text-primary);
  }
  
  .mission-text {
    color: var(--text-primary);
  }
  
  .mission-desc {
    color: var(--text-muted);
  }
  
  .value-card {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
    color: var(--text-primary);
  }
  
  .value-card h3 {
    color: var(--text-primary);
  }
  
  .value-card p {
    color: var(--text-muted);
  }
  
  .info-table {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
  }
  
  .info-row {
    border-color: var(--border);
  }
  
  .info-label {
    background-color: var(--primary);
    color: #fff;
  }
  
  .info-value {
    background-color: var(--bg-dark-soft);
    color: var(--text-primary);
  }
  
  /* カード系 */
  .hero-feature-card,
  .feature-card,
  .review-card,
  .news-item,
  .job-card,
  .service-card,
  .pricing-card,
  .case-card,
  .contact-card,
  .menu-card,
  .symptom-card,
  .stat-card,
  .choice-card,
  .flow-card-v2,
  .flow-item,
  .faq-item,
  .area-card,
  .value-card {
    background-color: var(--bg-dark-soft);
    color: var(--text-primary);
    border-color: var(--border);
  }
  
  /* カード内見出し */
  .hero-feature-card h3,
  .feature-card h3,
  .review-card h3,
  .job-card h3,
  .service-card h3,
  .pricing-card h3,
  .case-card h3,
  .menu-card h3,
  .choice-card h3,
  .flow-item h3,
  .review-title,
  .news-title {
    color: var(--text-primary);
  }
  
  /* カード内本文 */
  .hero-feature-card p,
  .feature-card p,
  .review-card p,
  .job-card p,
  .service-card p,
  .pricing-card p,
  .case-card p,
  .menu-card p,
  .choice-card p,
  .review-content,
  .menu-desc,
  .job-desc,
  .news-excerpt {
    color: var(--text-muted);
  }
  
  /* テーブル */
  table {
    background-color: var(--bg-dark-soft);
  }
  
  th {
    background-color: var(--primary);
    color: #fff;
  }
  
  td {
    background-color: var(--bg-dark-soft);
    color: var(--text-primary);
    border-color: var(--border);
  }
  
  /* FAQ */
  .faq-item {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
  }
  
  .faq-item summary,
  .faq-item p {
    color: var(--text-primary);
  }
  
  /* 入力フォーム */
  input,
  textarea,
  select {
    background-color: var(--bg-dark-soft);
    color: var(--text-primary);
    border-color: var(--border);
  }
  
  input::placeholder,
  textarea::placeholder {
    color: var(--text-muted);
  }
  
  /* フィルターボタン */
  .filter-btn {
    background-color: var(--bg-elevated);
    color: var(--text-primary);
  }
  
  .filter-btn.active {
    background-color: var(--primary);
    color: #fff;
  }
  
  /* リンク */
  a {
    color: var(--primary);
  }
  
  a:hover {
    color: var(--accent, var(--primary));
  }
  
  /* ボタン */
  .btn-outline {
    border-color: var(--primary);
    color: var(--primary);
  }
  
  /* 採用ページ特徴 */
  .feature-item {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
    color: var(--text-primary);
  }
  
  .feature-item h3 {
    color: var(--text-primary);
  }
  
  /* 統計カード */
  .stat-number {
    color: var(--primary);
  }
  
  .stat-label {
    color: var(--text-muted);
  }
  
  /* メニューメタ情報 */
  .menu-meta {
    color: var(--text-muted);
  }
  
  .menu-meta .price {
    color: var(--primary);
  }
  
  /* ============================================
     追加ダークモード対応（全ページ共通）
     ============================================ */
  
  /* 採用ページ about-section */
  .about-section {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .about-section h2,
  .about-section h3,
  .about-section p {
    color: var(--text-primary);
  }
  
  /* 採用ページ jobs-section */
  .jobs-section {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .jobs-section h2 {
    color: var(--text-primary);
  }
  
  /* 採用カード */
  .job-card {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
    color: var(--text-primary);
  }
  
  .job-card h3,
  .job-title {
    color: var(--text-primary);
  }
  
  .job-card p,
  .job-desc {
    color: var(--text-muted);
  }
  
  .job-meta,
  .job-tag {
    color: var(--text-muted);
  }
  
  /* 採用特徴カード（番号付き） */
  .feature-item,
  .recruit-feature {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
    color: var(--text-primary);
  }
  
  .feature-item h3,
  .feature-item p,
  .recruit-feature h3,
  .recruit-feature p {
    color: var(--text-primary);
  }
  
  .feature-number {
    color: var(--primary);
  }
  
  /* お客様の声 review-card */
  .review-card,
  .voice-card {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
    color: var(--text-primary);
  }
  
  .review-card h3,
  .review-title,
  .voice-card h3 {
    color: var(--text-primary);
  }
  
  .review-card p,
  .review-content,
  .review-text,
  .voice-card p {
    color: var(--text-muted);
  }
  
  .review-meta,
  .review-author,
  .review-date {
    color: var(--text-muted);
  }
  
  .review-rating {
    color: var(--primary);
  }
  
  /* お客様の声 統計セクション */
  .stats-section,
  .reviews-stats {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .stat-item,
  .stat-card {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .stat-number,
  .stat-value {
    color: var(--primary);
  }
  
  .stat-label,
  .stat-text {
    color: var(--text-muted);
  }
  
  /* お知らせページ */
  .news-section {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .news-item,
  .news-card {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
    color: var(--text-primary);
  }
  
  .news-item h3,
  .news-title,
  .news-card h3 {
    color: var(--text-primary);
  }
  
  .news-item p,
  .news-excerpt,
  .news-card p {
    color: var(--text-muted);
  }
  
  .news-date,
  .news-meta {
    color: var(--text-muted);
  }
  
  .news-category,
  .news-tag {
    background-color: var(--primary);
    color: #fff;
  }
  
  /* フィルターボタン強化 */
  .filter-btn,
  .category-btn,
  .tab-btn {
    background-color: var(--bg-elevated);
    color: var(--text-primary);
    border-color: var(--border);
  }
  
  .filter-btn.active,
  .category-btn.active,
  .tab-btn.active {
    background-color: var(--primary);
    color: #fff;
  }
  
  /* FAQページ強化 */
  .faq-section {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .faq-category {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .faq-category h2,
  .faq-category h3 {
    color: var(--text-primary);
  }
  
  .faq-item {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
  }
  
  .faq-item summary {
    color: var(--text-primary);
  }
  
  .faq-question,
  .q-text {
    color: var(--text-primary);
  }
  
  .faq-answer,
  .faq-answer-inner,
  .a-text {
    color: var(--text-muted);
    background-color: var(--bg-dark-soft);
  }
  
  .q-mark,
  .a-mark {
    color: var(--primary);
  }
  
  /* カテゴリナビ */
  .category-nav {
    background-color: var(--bg-dark);
  }
  
  .nav-item {
    color: var(--text-primary);
  }
  
  .nav-item.active {
    color: var(--primary);
  }
  
  /* CTAセクション強化 */
  .cta-section {
    color: #fff;
  }
  
  .cta-section h2,
  .cta-section h3,
  .cta-section p {
    color: #fff;
  }
  
  .cta-note {
    color: rgba(255,255,255,0.7);
  }
  
  /* contact-cta */
  .contact-cta {
    background-color: var(--bg-dark-soft);
    color: var(--text-primary);
  }
  
  .contact-cta h3,
  .contact-cta p {
    color: var(--text-primary);
  }
  
  /* 修理メニューページ */
  .symptoms-section,
  .menu-section {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .symptom-card,
  .menu-card {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
    color: var(--text-primary);
  }
  
  .symptom-card h3,
  .menu-card h3 {
    color: var(--text-primary);
  }
  
  .symptom-card p,
  .menu-card p {
    color: var(--text-muted);
  }
  
  /* 料金ページ */
  .pricing-section {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .pricing-card {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
    color: var(--text-primary);
  }
  
  .pricing-card h3 {
    color: var(--text-primary);
  }
  
  .pricing-card p,
  .price-desc {
    color: var(--text-muted);
  }
  
  .price-value,
  .price-amount {
    color: var(--primary);
  }
  
  /* ご利用の流れページ */
  .flow-section {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .flow-item,
  .flow-card {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
    color: var(--text-primary);
  }
  
  .flow-item h3,
  .flow-card h3 {
    color: var(--text-primary);
  }
  
  .flow-item p,
  .flow-card p {
    color: var(--text-muted);
  }
  
  .flow-number {
    background-color: var(--primary);
    color: #fff;
  }
  
  /* 修理実績ページ */
  .cases-section {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .case-card {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
    color: var(--text-primary);
  }
  
  .case-card h2,
  .case-card h3 {
    color: var(--text-primary);
  }
  
  .case-card p,
  .case-content p {
    color: var(--text-muted);
  }
  
  .case-meta,
  .case-brand,
  .case-area {
    color: var(--text-muted);
  }
  
  .case-price {
    color: var(--primary);
  }
  
  .case-badge {
    background-color: var(--primary);
    color: #fff;
  }
  
  /* エリアページ */
  .area-section {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .area-card {
    background-color: var(--bg-dark-soft);
    border-color: var(--border);
    color: var(--text-primary);
  }
  
  .area-card h3 {
    color: var(--text-primary);
  }
  
  /* Google口コミセクション */
  .google-reviews {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .google-reviews h2,
  .google-reviews p {
    color: var(--text-primary);
  }
  
  /* back-section */
  .back-section {
    background-color: var(--bg-dark);
  }
  
  .back-link {
    color: var(--primary);
  }
  
  /* recruit-section */
  .recruit-section {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  /* 求人サイトセクション */
  .external-jobs {
    background-color: var(--bg-dark);
    color: var(--text-primary);
  }
  
  .external-jobs h2 {
    color: var(--text-primary);
  }
}

/* ============================================
   フッター アコーディオン（トップページと同じ）
   ============================================ */



/* ============================================
   フッター ロゴサイズ修正
   ============================================ */

.footer-logo-icon-img {
  width: 40px;
  height: 40px;
  max-width: 40px;
}

.footer-logo {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

@media (max-width: 768px) {

  /* ============================================
     基本設定
     ============================================ */
  
  section {
    padding: 1.25rem 0;
  }
  
  .container {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  
  h2 {
    font-size: 1.25rem;
    margin-bottom: 1rem;
  }

  /* ============================================
     会社概要 - 大切にしていること（アイコンなし2列）
     ============================================ */
  
  .values-section .values-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.625rem;
  }
  
  .values-section .value-card {
    padding: 0.875rem;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.08);
  }
  
  .values-section .value-card h3 {
    font-size: 0.9rem;
    font-weight: 600;
    margin-bottom: 0.375rem;
    color: var(--text-primary);
  }
  
  .values-section .value-card p {
    font-size: 0.75rem;
    line-height: 1.55;
    color: var(--text-secondary);
    margin: 0;
  }
  
  .value-icon {
    display: none;
  }

  /* ============================================
     会社概要 - サービス展開エリア（3列コンパクト）
     ============================================ */
  
  .areas-section .areas-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
  }
  
  .areas-section .area-card {
    padding: 0.75rem 0.5rem;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
    text-align: center;
    text-decoration: none;
  }
  
  .areas-section .area-card h3 {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--text-primary);
    margin: 0;
  }
  
  .areas-section .area-card .emoji,
  .areas-section .area-card p {
    display: none;
  }

  /* ============================================
     会社概要 - 会社情報テーブル（コンパクト）
     ============================================ */
  
  .info-section .info-table {
    border-radius: 10px;
    overflow: hidden;
  }
  
  .info-section .info-row {
    display: flex;
    flex-direction: column;
    border-bottom: 1px solid var(--border);
  }
  
  .info-section .info-row:last-child {
    border-bottom: none;
  }
  
  .info-section .info-label {
    padding: 0.5rem 0.75rem;
    font-size: 0.7rem;
    font-weight: 600;
    background: var(--primary);
    color: #fff;
  }
  
  .info-section .info-value {
    padding: 0.5rem 0.75rem;
    font-size: 0.8rem;
    background: #fff;
  }

  /* ============================================
     会社概要 - ミッションセクション
     ============================================ */
  
  .mission-section {
    padding: 1.25rem 0;
  }
  
  .mission-section .mission-title {
    font-size: 1.1rem;
    text-align: center;
    margin-bottom: 0.75rem;
  }
  
  .mission-section .mission-desc {
    font-size: 0.85rem;
    line-height: 1.65;
    text-align: left;
  }
  
  .mission-section .mission-desc br {
    display: none;
  }

  /* ============================================
     CTAセクション
     ============================================ */
  
  .cta-section {
    padding: 1.25rem 1rem;
  }
  
  .cta-section h2 {
    font-size: 1.1rem;
    margin-bottom: 0.5rem;
  }
  
  .cta-section p {
    font-size: 0.8rem;
    margin-bottom: 0.75rem;
  }
  
  .cta-buttons {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
  }
  
  .cta-buttons .btn {
    width: 100%;
    max-width: 280px;
    padding: 0.75rem 1rem;
    font-size: 0.9rem;
    text-align: center;
  }

  /* ============================================
     採用ページ - モダンな会社の特徴
     ============================================ */

  .company-features {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 1.25rem;
  }
  
  .company-feature {
    display: flex;
    align-items: flex-start;
    gap: 0.875rem;
    padding: 1rem;
    background: linear-gradient(135deg, var(--bg-elevated) 0%, var(--bg-section) 100%);
    border-radius: 12px;
    border-left: 3px solid var(--primary);
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  }
  
  .company-feature .feature-num {
    font-family: 'Outfit', sans-serif;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--primary);
    line-height: 1;
    flex-shrink: 0;
  }
  
  .company-feature .feature-content {
    flex: 1;
  }
  
  .company-feature .feature-content h4 {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 0.25rem 0;
  }
  
  .company-feature .feature-content p {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin: 0;
    line-height: 1.5;
  }

  /* 採用ページ 業務提携セクション */
  .contact-cta h3 {
    font-size: 1.1rem;
    line-height: 1.4;
    margin-bottom: 0.5rem;
  }
  
  .contact-cta p {
    font-size: 0.85rem;
    margin-bottom: 0.75rem;
  }
  
  .cta-email {
    display: inline-block;
    font-size: 0.9rem;
    color: var(--primary);
    text-decoration: underline;
    word-break: break-all;
  }

  /* ============================================
     フッター下部余白追加
     ============================================ */
  
  .footer-bottom {
    padding: 1.25rem 0;
  }
  
  .footer-bottom-inner {
    padding-bottom: 1rem;
  }
  
  .footer-copy {
    margin-top: 0.75rem;
    padding-bottom: env(safe-area-inset-bottom, 0.5rem);
  }

  /* ============================================
     採用ページ - 特徴3列
     ============================================ */
  
  .features,
  .recruit-features {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
  }
  
  .feature-item {
    padding: 0.625rem 0.25rem;
    text-align: center;
  }
  
  .feature-icon {
    font-size: 1.5rem;
    margin-bottom: 0.25rem;
  }
  
  .feature-item h3 {
    font-size: 0.65rem;
    line-height: 1.35;
    margin: 0;
  }

  /* ============================================
     FAQページ
     ============================================ */
  
  .faq-categories {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.375rem;
  }
  
  .faq-category {
    padding: 0.5rem 0.25rem;
    text-align: center;
  }
  
  .faq-category-icon {
    font-size: 1.25rem;
    margin-bottom: 0.125rem;
  }
  
  .faq-category-label {
    font-size: 0.55rem;
    line-height: 1.3;
    display: block;
  }
  
  .faq-question,
  .accordion-header {
    font-size: 0.85rem;
    line-height: 1.5;
    text-align: left;
  }

  /* ============================================
     お客様の声ページ
     ============================================ */
  
  .stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.625rem;
  }
  
  .stat-card {
    padding: 0.75rem;
  }
  
  .stat-number {
    font-size: 1.5rem;
  }
  
  .stat-label {
    font-size: 0.7rem;
  }
  
  .review-card {
    padding: 0.875rem;
  }
  
  .review-content {
    font-size: 0.8rem;
    line-height: 1.6;
    text-align: left;
  }

  /* ============================================
     法人ページ
     ============================================ */
  
  .cases-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
  }
  
  .case-card {
    padding: 0.75rem;
  }
  
  .case-icon {
    font-size: 1.5rem;
    margin-bottom: 0.25rem;
  }
  
  .case-card h3 {
    font-size: 0.8rem;
    margin-bottom: 0.25rem;
  }
  
  .case-card ul {
    font-size: 0.7rem;
    padding-left: 0.75rem;
    margin: 0;
  }
  
  .features-grid:not(.hero-features-grid) {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
  }
  
  .feature-card {
    padding: 0.75rem;
  }
  
  .feature-card h3 {
    font-size: 0.8rem;
  }
  
  .feature-card p {
    font-size: 0.7rem;
    text-align: left;
  }
  
  .flow-item {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.625rem 0.75rem;
  }
  
  .flow-arrow {
    display: none;
  }

  /* ============================================
     修理ページ
     ============================================ */
  
  .symptoms-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
  }
  
  .symptom-card {
    padding: 0.625rem;
  }

  /* ============================================
     お知らせページ
     ============================================ */
  
  .filter-buttons {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 0.375rem;
    -webkit-overflow-scrolling: touch;
  }
  
  .filter-btn {
    flex-shrink: 0;
    white-space: nowrap;
    padding: 0.5rem 0.75rem;
    font-size: 0.8rem;
  }
}

/* ============================================
   375px以下
   ============================================ */

@media (max-width: 375px) {
  .features,
  .recruit-features {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .areas-section .areas-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  
  .faq-categories {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (prefers-color-scheme: dark) {
  .values-section .value-card {
    background: var(--bg-elevated);
  }
  .values-section .value-card h3 {
    color: var(--text-primary);
  }
  .values-section .value-card p {
    color: var(--text-secondary);
  }
  .areas-section .area-card {
    background: var(--bg-elevated);
  }
  .areas-section .area-card h3 {
    color: var(--text-primary);
  }
  .info-section .info-value {
    background: var(--bg-elevated);
  }
  .company-feature {
    background: linear-gradient(135deg, var(--bg-elevated) 0%, var(--bg-section) 100%);
  }
}

/* ==========================================================
   共通ヒーローセクション（修理実績スタイル）
   ========================================================== */
.page-hero {
  background: var(--bg-dark, #1c1917);
  padding: 4rem 1.5rem;
  text-align: center;
}
.page-hero .label,
.page-hero .hero-label,
.hero-label {
  color: var(--primary, #d97706);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 0.5rem;
  display: block;
}
.page-hero h1 {
  color: #fff;
  font-size: 1.8rem;
  margin-bottom: 0.5rem;
  font-weight: 700;
}
.page-hero p {
  color: rgba(255,255,255,0.7);
  font-size: 0.95rem;
  margin: 0;
}

/* 共通ヒーローセクション */
.hero {
  background: var(--bg-dark, #1c1917);
  padding: 4rem 1.5rem;
  text-align: center;
}
.hero h1 {
  color: #fff;
  font-size: 1.8rem;
  margin-bottom: 0.5rem;
  font-weight: 700;
}
.hero p {
  color: rgba(255,255,255,0.7);
  font-size: 0.95rem;
  margin: 0;
}


/* フッターカラム幅調整（長いリンクテキスト対応） */
@media (min-width: 901px) {
  .footer-grid {
    grid-template-columns: 1.4fr 1.3fr 1fr 1fr 1fr;
  }
  .footer-col a {
    white-space: nowrap;
  }
}


/* ============================================
   ヘッダー チャット相談ボタン
   ============================================ */
.header-chat-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  min-height: 44px;
  padding: 0.5rem 1rem;
  border-radius: var(--radius-full);
  font-weight: 600;
  font-size: 0.8rem;
  background: transparent;
  color: var(--primary);
  border: 1.5px solid var(--primary);
  cursor: pointer;
  transition: all var(--transition);
  white-space: nowrap;
}
.header-chat-btn:hover {
  background: var(--primary);
  color: #fff;
}
.header-chat-btn svg {
  flex-shrink: 0;
}
/* SP用チャットボタン（PCでは非表示） */
.header-chat-btn-sp {
  display: none;
}
@media (max-width: 768px) {
  /* PCチャットボタン非表示 */
  .header-chat-btn:not(.header-chat-btn-sp) {
    display: none;
  }
  /* SP用チャットボタン表示 */
  .header-chat-btn-sp {
    display: flex;
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
    font-size: 0.75rem;
    padding: 0.35rem 0.75rem;
    min-height: 34px;
  }
  /* SPヘッダー: ハンバーガー左端 */
  .header-inner {
    padding: 0 0.75rem;
  }
  .mobile-menu-btn {
    order: -1;
    margin-right: 4px;
  }
  .logo {
    flex: 1;
  }
}

/* ハンバーガーメニュー内チャット予約ボタン */
.mobile-cta-btn.chat {
  background: var(--primary);
  color: #fff;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: .95rem;
  font-weight: 600;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: 1rem;
  border-radius: var(--radius);
}
.mobile-cta-btn.chat:hover {
  background: var(--primary-dark);
}

/* ===== 特徴セクション ===== */
.features-section {
  padding: 5rem 0;
  background: var(--bg-base);
}
.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-top: 3rem;
}
.feature-card {
  background: var(--bg-elevated);
  border-radius: var(--radius-xl);
  padding: 2rem 1.5rem;
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: var(--transition-all);
}
.feature-card:hover {
  box-shadow: var(--shadow);
  transform: translateY(-4px);
}
.feature-icon {
  width: 72px;
  height: 72px;
  background: var(--primary-light);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.25rem;
  color: var(--primary);
}
.feature-card h3 {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: .75rem;
}
.feature-card p {
  font-size: .875rem;
  color: var(--text-muted);
  line-height: 1.7;
  margin-bottom: 1rem;
}
.feature-checks {
  list-style: none;
  padding: 0;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: .4rem;
}
.feature-checks li {
  font-size: .825rem;
  color: var(--text-secondary);
  padding-left: 1.25rem;
  position: relative;
}
.feature-checks li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--primary);
  font-weight: 700;
}

/* ===== 選ばれる理由セクション ===== */
.reasons-section {
  padding: 5rem 0;
  background: var(--bg-section);
}
.reasons-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-top: 3rem;
}
.reason-card {
  background: var(--bg-elevated);
  border-radius: var(--radius-xl);
  padding: 2rem 1.5rem;
  box-shadow: var(--shadow-sm);
}
.reason-num {
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--primary-light);
  line-height: 1;
  font-family: var(--font-display);
  margin-bottom: .5rem;
}
.reason-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 1rem;
  line-height: 1.4;
}
.reason-img {
  width: 100%;
  aspect-ratio: 16/9;
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: 1.25rem;
  background: var(--bg-section);
  position: relative;
}
.reason-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.reason-card p {
  font-size: .875rem;
  color: var(--text-muted);
  line-height: 1.7;
  margin-bottom: 1rem;
}
.reason-checks {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .4rem;
}
.reason-checks li {
  font-size: .825rem;
  color: var(--text-secondary);
  padding-left: 1.25rem;
  position: relative;
}
.reason-checks li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--success);
  font-weight: 700;
}

@media (max-width: 768px) {
  .features-grid, .reasons-grid { grid-template-columns: 1fr; }
  .features-section, .reasons-section { padding: 3rem 0; }
}

/* ============================================
   特徴・選ばれる理由セクション
   ============================================ */
.features-section {
  padding: 5rem 0;
  background: var(--bg-elevated);
}
.features-lead {
  text-align: center;
  color: var(--text-muted);
  font-size: 1rem;
  line-height: 1.8;
  margin-bottom: 3rem;
}
.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-bottom: 2.5rem;
}
.feature-card {
  text-align: center;
  padding: 2rem 1.5rem;
  background: var(--bg-base);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
}
.feature-icon {
  width: 80px;
  height: 80px;
  background: var(--primary-light);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.25rem;
  color: var(--primary);
}
.feature-card h3 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: .75rem;
}
.feature-card > p {
  font-size: .875rem;
  color: var(--text-muted);
  line-height: 1.7;
  margin-bottom: 1rem;
}
.feature-checks {
  list-style: none;
  padding: 0;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: .4rem;
}
.feature-checks li {
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  font-size: .825rem;
  color: var(--text-secondary);
  line-height: 1.5;
}
.feature-checks li::before {
  content: '';
  width: 16px;
  height: 16px;
  background: var(--success);
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 1px;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='8' cy='8' r='8' fill='%2316a34a'/%3E%3Cpath d='M4.5 8l2.5 2.5 4.5-5' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}
.features-cta {
  text-align: center;
  margin-top: 2rem;
}

/* 選ばれる理由 */
.reasons-section {
  padding: 5rem 0;
  background: var(--bg-section);
}
.reasons-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-bottom: 2.5rem;
}
.reason-card {
  background: var(--bg-elevated);
  border-radius: var(--radius-lg);
  padding: 2rem 1.5rem;
  box-shadow: var(--shadow-sm);
}
.reason-num {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--primary-light);
  line-height: 1;
  margin-bottom: .5rem;
  font-family: var(--font-display);
}
.reason-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 1.25rem;
  line-height: 1.4;
}
.reason-img {
  margin-bottom: 1rem;
}
.reason-card > p {
  font-size: .875rem;
  color: var(--text-muted);
  line-height: 1.7;
  margin-bottom: 1rem;
}
.reason-checks {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .4rem;
}
.reason-checks li {
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  font-size: .825rem;
  color: var(--text-secondary);
  line-height: 1.5;
}
.reason-checks li::before {
  content: '';
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  margin-top: 1px;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='8' cy='8' r='8' fill='%2316a34a'/%3E%3Cpath d='M4.5 8l2.5 2.5 4.5-5' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

@media (max-width: 768px) {
  .features-grid { grid-template-columns: 1fr; gap: 1rem; }
  .reasons-grid { grid-template-columns: 1fr; gap: 1.25rem; }
  .features-section, .reasons-section { padding: 3rem 0; }
}

/* ============================================
   特徴・選ばれる理由セクション
   ============================================ */
.features-section {
  padding: 5rem 0;
  background: var(--bg-elevated);
}
.features-section .label {
  display: block;
  text-align: center;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--primary);
  text-transform: uppercase;
  margin-bottom: .75rem;
}
.features-section h2 {
  text-align: center;
  font-size: clamp(1.4rem, 3vw, 1.875rem);
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 1rem;
}
.features-lead {
  text-align: center;
  color: var(--text-muted);
  font-size: .95rem;
  line-height: 1.8;
  margin-bottom: 3rem;
}
.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-bottom: 2.5rem;
}
.feature-card {
  text-align: center;
  padding: 2rem 1.5rem;
  background: var(--bg-base);
  border-radius: var(--radius-xl);
}
.feature-icon {
  width: 80px;
  height: 80px;
  background: var(--primary-light);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.25rem;
  color: var(--primary);
}
.feature-card h3 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: .75rem;
}
.feature-card p {
  font-size: .875rem;
  color: var(--text-muted);
  line-height: 1.7;
  margin-bottom: .75rem;
}
.feature-list {
  list-style: none;
  padding: 0;
  text-align: left;
  display: inline-block;
}
.feature-list li {
  font-size: .825rem;
  color: var(--text-secondary);
  padding: .2rem 0;
  display: flex;
  align-items: flex-start;
  gap: .4rem;
}
.feature-list li::before {
  content: '✓';
  color: var(--primary);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: .05rem;
}
.features-cta {
  text-align: center;
}

/* 選ばれる理由 */
.reasons-section {
  padding: 5rem 0;
  background: var(--bg-base);
}
.reasons-section .label {
  display: block;
  text-align: center;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--primary);
  text-transform: uppercase;
  margin-bottom: .75rem;
}
.reasons-section h2 {
  text-align: center;
  font-size: clamp(1.4rem, 3vw, 1.875rem);
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 3rem;
}
.reasons-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-bottom: 2.5rem;
}
.reason-card {
  background: var(--bg-elevated);
  border-radius: var(--radius-xl);
  padding: 2rem 1.5rem;
  box-shadow: var(--shadow-sm);
}
.reason-num {
  font-size: 2rem;
  font-weight: 800;
  color: var(--primary-light);
  font-family: var(--font-display);
  line-height: 1;
  margin-bottom: .5rem;
}
.reason-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 1rem;
  line-height: 1.5;
}
.reason-img {
  aspect-ratio: 16/9;
  background: var(--bg-section);
  border-radius: var(--radius-lg);
  margin-bottom: 1rem;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  position: relative;
}
.reason-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
}
.reason-img img:not([src]), .reason-img img[src=""] {
  display: none;
}
.reason-card p {
  font-size: .875rem;
  color: var(--text-muted);
  line-height: 1.7;
  margin-bottom: .75rem;
}

@media (max-width: 768px) {
  .features-grid { grid-template-columns: 1fr; gap: 1rem; }
  .reasons-grid { grid-template-columns: 1fr; gap: 1.25rem; }
  .features-section, .reasons-section { padding: 3rem 0; }
}

/* ============================================
   選ばれる理由 スマホカルーセル
   ============================================ */
.reasons-carousel-nav {
  display: none;
  align-items: center;
  justify-content: space-between;
  margin-top: 1rem;
  margin-bottom: .5rem;
}
.reasons-dots {
  display: flex;
  gap: 6px;
  align-items: center;
}
.reasons-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--border);
  cursor: pointer;
  transition: all .2s;
  display: block;
}
.reasons-dot.active {
  background: var(--primary);
  width: 20px;
  border-radius: 4px;
}
.reasons-counter {
  font-size: 12px;
  color: var(--text-muted);
}
.reasons-btns {
  display: flex;
  gap: 6px;
}
.reasons-btn {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1.5px solid var(--border);
  background: var(--bg-elevated);
  font-size: 18px;
  color: var(--text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transition: all .15s;
}
.reasons-btn.reasons-next {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

@media (max-width: 768px) {
  .reasons-grid {
    display: block;
  }
  .reason-card {
    display: none;
  }
  .reason-card.reasons-card-active {
    display: block;
  }
  .reasons-carousel-nav {
    display: flex;
  }
}

/* カルーセル ゲージ */
.reasons-carousel-nav {
  flex-direction: column;
  gap: 10px;
  padding: 0 4px;
}
.reasons-progress {
  width: 100%;
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
}
.reasons-progress-bar {
  height: 100%;
  background: var(--primary);
  border-radius: 2px;
  width: 33.3%;
  transition: width .3s ease;
}
.reasons-dots {
  justify-content: center;
}

/* ============================================
   特徴セクション スマホ 縦積みコンパクト（案3）
   ============================================ */
@media (max-width: 768px) {
  .features-section .features-lead {
    display: none;
  }
  .features-grid {
    grid-template-columns: 1fr;
    gap: 0;
    background: var(--bg-elevated);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
  }
  .feature-card {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 14px;
    padding: 16px;
    text-align: left;
    background: var(--bg-elevated);
    border-radius: 0;
    border-bottom: 1px solid var(--border);
  }
  .feature-card:last-child {
    border-bottom: none;
  }
  .feature-icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    flex-shrink: 0;
    margin: 0;
  }
  .feature-icon svg {
    width: 20px;
    height: 20px;
  }
  .feature-card h3 {
    font-size: .95rem;
    margin-bottom: 4px;
  }
  .feature-card p {
    font-size: .82rem;
    margin-bottom: 0;
  }
  .feature-card .feature-list {
    display: none;
  }
}

/* ============================================
   特徴セクション SP専用縦積みリスト
   ============================================ */
.features-list-sp { display: none; }
.features-grid-pc { display: grid; }

@media (max-width: 768px) {
  .features-grid-pc { display: none !important; }
  .features-section .features-lead { display: none; }
  .features-list-sp {
    display: block;
    background: var(--bg-elevated);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
    margin-bottom: 1.5rem;
  }
  .features-list-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px;
    border-bottom: 1px solid var(--border);
  }
  .features-list-item:last-child { border-bottom: none; }
  .features-list-icon {
    width: 44px;
    height: 44px;
    background: var(--primary-light);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--primary);
  }
  .features-list-title {
    font-size: .9rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 3px;
  }
  .features-list-desc {
    font-size: .8rem;
    color: var(--text-muted);
    line-height: 1.5;
  }
}

.features-title-sp { display: none; }
@media (max-width: 768px) {
  .features-title-pc { display: none; }
  .features-title-sp { display: block; }
}

/* price-card 内余白 */
@media (max-width: 768px) {
  .price-card {
    padding: 1.75rem 1.5rem;
    background: var(--bg-elevated);
    border-radius: var(--radius-lg);
  }
  .price-item {
    padding: .875rem 0;
  }
}

/* flow-section-v2 ダークモード文字色強制 */
@media (prefers-color-scheme: dark) {
  .flow-section-v2 .flow-header-v2 h2,
  .flow-section-v2 .flow-subtitle,
  .flow-section-v2 .flow-card-v2 h3 {
    color: #ffffff !important;
  }
  .flow-section-v2 .flow-card-v2 p {
    color: rgba(255,255,255,.75) !important;
  }
}

/* case-section タイトル余白削除済み */

/* ハンバーガーメニュー ダークモード対応 */
@media (prefers-color-scheme: dark) {
  .mobile-menu {
    background: var(--bg-elevated);
  }
  .mobile-nav-link {
    color: var(--text-primary);
    border-bottom-color: var(--border);
  }
  .mobile-nav-link:hover {
    color: var(--primary);
    background: var(--bg-section);
  }
}

/* reason-num ダークモードで濃いオレンジに */
@media (prefers-color-scheme: dark) {
  .reason-num {
    color: var(--primary) !important;
  }
}

/* case-header スマホで縦積みに */
@media (max-width: 768px) {
  .case-header {
    display: block;
  }
  .case-header > div {
    width: 100%;
  }
}
