/* ===================================
   デバイス別表示制御CSS
   PC版とスマホ版を完全分離
   =================================== */

/* ===================================
   基本の表示制御
   =================================== */

/* モバイル版のみ表示（767px以下） */
@media (max-width: 767px) {
  .pc-only {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
  }
  
  .mobile-only {
    display: block !important;
  }
  
  .mobile-only-flex {
    display: flex !important;
  }
  
  .mobile-only-grid {
    display: grid !important;
  }
}

/* PC版のみ表示（768px以上） */
@media (min-width: 768px) {
  .mobile-only,
  .mobile-only-flex,
  .mobile-only-grid {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
  }
  
  .pc-only {
    display: block !important;
  }
  
  .pc-only-flex {
    display: flex !important;
  }
  
  .pc-only-grid {
    display: grid !important;
  }
}

/* ===================================
   スマホ版の最適な状態を保持
   =================================== */
@media (max-width: 767px) {
  /* ヒーローセクション */
  .mobile-only .hero-text-mobile {
    font-size: 0.95rem !important;
    line-height: 1.6 !important;
    text-align: center !important;
    white-space: normal !important;
  }
  
  .mobile-only .hero-line-1,
  .mobile-only .hero-line-2 {
    display: block !important;
    margin: 0.3rem 0 !important;
  }
  
  /* 緊急アラート */
  .mobile-only .alert-title-mobile {
    font-size: 1rem !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  
  .mobile-only .alert-text-mobile {
    font-size: 0.9rem !important;
    line-height: 1.5 !important;
  }
  
  .mobile-only .alert-break {
    display: block !important;
  }
  
  /* メリットテキスト */
  .mobile-only .merit-text {
    display: inline !important;
    white-space: normal !important;
    word-break: keep-all !important;
  }
  
  /* FAQ */
  .mobile-only .faq-question {
    padding: 1rem !important;
    font-size: 0.9rem !important;
  }
  
  .mobile-only .faq-answer {
    padding: 1rem !important;
    font-size: 0.85rem !important;
  }
  
  /* ボタン */
  .mobile-only .btn {
    font-size: 0.95rem !important;
    padding: 0.8rem 1.5rem !important;
  }
  
  /* フォーム */
  .mobile-only .form-label {
    font-size: 0.9rem !important;
  }
  
  .mobile-only .form-control {
    font-size: 0.9rem !important;
  }
}

/* ===================================
   PC版の新規最適化
   =================================== */
@media (min-width: 768px) {
  /* コンテナ幅 */
  .pc-only .container {
    max-width: 1400px !important;
    margin: 0 auto !important;
    padding: 0 2rem !important;
  }
  
  /* ヒーローセクション */
  .pc-only .hero {
    text-align: center !important;
    padding: 4rem 0 !important;
  }
  
  .pc-only .card-header {
    text-align: center !important;
  }
  
  .pc-only .card-title {
    text-align: center !important;
    margin: 0 auto !important;
  }
  
  .pc-only .hero-text {
    font-size: 1.3rem !important;
    line-height: 1.8 !important;
    margin: 1.5rem auto !important;
    text-align: center !important;
    display: block !important;
    width: 100% !important;
  }
  
  .pc-only .hero-stats {
    display: flex !important;
    justify-content: center !important;
    gap: 4rem !important;
    margin: 2rem auto !important;
    max-width: 800px !important;
  }
  
  /* 事務所グリッド - 2列表示 */
  .pc-only .offices-grid-pc {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 2rem !important;
    max-width: 1000px !important;
    margin: 0 auto !important;
  }
  
  .pc-only .office-card {
    padding: 2rem !important;
    text-align: center !important;
    background: #fff !important;
    border: 1px solid #e5e5e5 !important;
    border-radius: 10px !important;
  }
  
  /* 5番目のカードを中央に */
  .pc-only .office-card-wide {
    grid-column: 1 / -1 !important;
    max-width: 500px !important;
    margin: 0 auto !important;
  }
  
  /* 債務整理タイプ - 3列表示 */
  .pc-only .types-grid-pc {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 2rem !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
  }
  
  /* FAQ中央配置 */
  .pc-only .faq-container-pc {
    max-width: 900px !important;
    margin: 0 auto !important;
  }
  
  .pc-only .faq-question {
    text-align: center !important;
    padding: 1.5rem !important;
    font-size: 1.1rem !important;
    background: #f8f9fa !important;
    border: none !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    border-bottom: 1px solid #e5e5e5 !important;
  }
  
  .pc-only .faq-question-text {
    flex: 1 !important;
  }
  
  .pc-only .faq-icon {
    margin-left: 1rem !important;
    font-size: 1.5rem !important;
  }
  
  .pc-only .faq-answer {
    max-width: 800px !important;
    margin: 0 auto !important;
    padding: 2rem !important;
    background: white !important;
    border: none !important;
    border-radius: 0 !important;
    margin-top: 0 !important;
  }
  
  .pc-only .faq-item {
    border: 1px solid #e5e5e5 !important;
    border-radius: 8px !important;
    margin-bottom: 1rem !important;
    overflow: hidden !important;
  }
  
  /* ボタン */
  .pc-only .btn {
    font-size: 1.1rem !important;
    padding: 1rem 2.5rem !important;
    display: inline-block !important;
  }
  
  /* セクション間隔 */
  .pc-only section {
    padding: 4rem 0 !important;
  }
  
  /* 見出し */
  .pc-only h1 {
    font-size: 2.5rem !important;
  }
  
  .pc-only h2 {
    font-size: 2rem !important;
    margin-bottom: 3rem !important;
  }
  
  .pc-only h3 {
    font-size: 1.5rem !important;
  }
}

/* ===================================
   超大画面対応（1920px以上）
   =================================== */
@media (min-width: 1920px) {
  .pc-only .container {
    max-width: 1600px !important;
  }
  
  /* 事務所グリッド - 3列に変更 */
  .pc-only .offices-grid-pc {
    grid-template-columns: repeat(3, 1fr) !important;
    max-width: 1400px !important;
  }
  
  .pc-only .office-card-wide {
    grid-column: auto !important;
    max-width: none !important;
  }
}