/**
 * @file public/css/responsive.css
 * @description BA54-c グローバル スマホ対応 (追加型・既存CSS非破壊)
 *
 * 設計原則:
 *   - 既存セレクタは書き換えない。詳細度を上げて追加上書きのみ
 *   - !important は極力使わず、詳細度 (body 修飾子等) で勝つ
 *   - body.salon-page は既存 .salon-hamburger / #salon-mobile-menu 実装あり
 *     → 新規 .mobile-nav-toggle / .mobile-nav-overlay は表示しない
 *   - ブレークポイント: 320 / 390 / 768 / 1024+
 *   - 1024px 以上は既存デザインを完全維持
 */

/* ========================================
   グローバル基礎 (全画面共通・全幅)
   ======================================== */
img, video, iframe, svg, canvas {
  max-width: 100%;
  height: auto;
}

iframe {
  border: 0;
}

/* ========================================
   新規ハンバーガー (mobile-nav.js が動的挿入)
   ベースは display:none、767px 以下でのみ表示
   ======================================== */
.mobile-nav-toggle {
  display: none;
  position: fixed;
  top: 12px;
  right: 12px;
  z-index: 1000;
  width: 44px;
  height: 44px;
  padding: 8px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  cursor: pointer;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  gap: 5px;
}

.mobile-nav-toggle span {
  display: block;
  height: 2px;
  background: #333;
  border-radius: 2px;
  transition: transform 0.2s ease, opacity 0.2s ease;
  transform-origin: center;
}

.mobile-nav-toggle.is-open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.mobile-nav-toggle.is-open span:nth-child(2) {
  opacity: 0;
}

.mobile-nav-toggle.is-open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* オーバーレイ (mobile-nav.js が動的挿入) */
.mobile-nav-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 998;
  background: rgba(0, 0, 0, 0.5);
  opacity: 0;
  transition: opacity 0.2s ease;
}

.mobile-nav-overlay.is-open {
  opacity: 1;
}

/* salon ページでは既存ハンバーガーがあるので新規は非表示 */
body.salon-page .mobile-nav-toggle,
body.salon-page .mobile-nav-overlay {
  display: none !important;
}

/* ========================================
   ≦ 1023px (タブレット以下) の軽微調整
   ======================================== */
@media (max-width: 1023px) {
  /* 横スクロール許容 */
  html, body {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
  }
}

/* ========================================
   ≦ 767px メイン (スマホ)
   ======================================== */
@media (max-width: 767px) {
  /* 新規ハンバーガー表示 (salon-page を除く) */
  body:not(.salon-page) .mobile-nav-toggle {
    display: flex;
  }
  body:not(.salon-page) .mobile-nav-overlay {
    display: block;
  }

  /* iOS タップで自動ズーム防止 (16px 以上必須) */
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="number"],
  input[type="tel"],
  input[type="url"],
  input[type="search"],
  input[type="date"],
  input[type="time"],
  input[type="datetime-local"],
  input[type="month"],
  input[type="week"],
  textarea,
  select {
    font-size: 16px;
  }

  /* タップ領域 44px 確保 */
  button,
  .btn,
  a.btn,
  input[type="button"],
  input[type="submit"],
  input[type="reset"] {
    min-height: 44px;
  }

  /* テーブルは横スクロール */
  table {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* タブナビ・横並びリストの横スクロール */
  .tab-nav,
  .tabs,
  [role="tablist"],
  .acc-tabs,
  .nav-tabs,
  .app-tab-nav {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    flex-wrap: nowrap;
    white-space: nowrap;
  }
  .tab-nav::-webkit-scrollbar,
  .tabs::-webkit-scrollbar,
  [role="tablist"]::-webkit-scrollbar,
  .acc-tabs::-webkit-scrollbar,
  .nav-tabs::-webkit-scrollbar,
  .app-tab-nav::-webkit-scrollbar {
    display: none;
  }

  /* モーダル: フルスクリーン化 (汎用パターン) */
  .modal,
  .modal-content,
  .acc-modal,
  .dialog {
    position: fixed;
    inset: 0;
    width: 100vw;
    max-width: 100vw;
    max-height: 100vh;
    margin: 0;
    border-radius: 0;
    overflow-y: auto;
  }

  /* モーダル背景 */
  .modal-backdrop,
  .modal-overlay {
    position: fixed;
    inset: 0;
  }

  /* グリッド類: 2列以上は1列化 */
  .grid-2,
  .grid-3,
  .grid-4,
  .acc-ai-extracted {
    display: block;
  }
  .grid-2 > *,
  .grid-3 > *,
  .grid-4 > *,
  .acc-ai-extracted > * {
    width: 100%;
    margin-bottom: 8px;
  }

  /* コンテナ全幅化 */
  .container,
  .wrap,
  .wrapper,
  .page-wrap,
  .acc-wrap {
    max-width: 100vw;
    padding-left: 12px;
    padding-right: 12px;
    box-sizing: border-box;
  }

  /* カード/パネルの余白詰め */
  .card,
  .panel,
  .acc-panel,
  .news-card,
  .qa-card {
    border-radius: 8px;
  }

  /* グローバルナビ汎用: 既存ナビをドロワー化
     mobile-nav.js が .mobile-open を付与して表示 */
  .global-nav,
  .lp-nav,
  .news-sidebar,
  .app-sidebar,
  body:not(.salon-page) > .nav,
  body:not(.salon-page) > header > .nav {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 80vw;
    max-width: 320px;
    transform: translateX(100%);
    transition: transform 0.25s ease;
    background: #ffffff;
    box-shadow: -4px 0 16px rgba(0, 0, 0, 0.15);
    z-index: 999;
    overflow-y: auto;
    padding: 56px 16px 16px;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
  }

  .global-nav.mobile-open,
  .lp-nav.mobile-open,
  .news-sidebar.mobile-open,
  .app-sidebar.mobile-open,
  body:not(.salon-page) > .nav.mobile-open,
  body:not(.salon-page) > header > .nav.mobile-open {
    transform: translateX(0);
  }

  /* ドロワー内項目はブロック表示で縦並び */
  .global-nav > *,
  .lp-nav > *,
  .news-sidebar > *,
  .app-sidebar > * {
    width: 100%;
    text-align: left;
    padding: 12px 8px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  }

  /* bottom-nav は元の場所のまま (既存固定底ナビ) */
  .bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 100;
  }

  /* nav-cta (応募ボタン等) は折り返し */
  .nav-cta,
  .nav-actions {
    flex-wrap: wrap;
    gap: 6px;
  }

  /* h1/h2 のフォントサイズ抑制 */
  h1 { font-size: 1.5rem; line-height: 1.3; }
  h2 { font-size: 1.25rem; line-height: 1.3; }
  h3 { font-size: 1.125rem; line-height: 1.3; }

  /* Pre / code は横スクロール */
  pre, code {
    overflow-x: auto;
    white-space: pre;
    word-wrap: normal;
  }

  /* form 要素の幅確保 */
  input:not([type="checkbox"]):not([type="radio"]),
  textarea,
  select {
    max-width: 100%;
    box-sizing: border-box;
  }

  /* DM / メッセージ系の高さ調整 */
  .dm-list,
  .messages-list {
    max-height: 60vh;
  }

  /* ファイルアップロード領域 */
  .upload-area,
  .acc-upload {
    padding: 16px 8px;
  }

  /* グラフ/チャートは横スクロール */
  .chart,
  .chart-container,
  .pl-chart {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Toast / 通知の位置 */
  .toast,
  .notification {
    left: 8px;
    right: 8px;
    width: auto;
    max-width: none;
  }
}

/* ========================================
   ≦ 480px (小型スマホ)
   ======================================== */
@media (max-width: 480px) {
  /* コンテナ詰め */
  .container,
  .wrap,
  .wrapper,
  .page-wrap,
  .acc-wrap {
    padding-left: 8px;
    padding-right: 8px;
  }

  /* カード余白詰め */
  .card,
  .panel,
  .acc-panel {
    padding: 10px;
  }

  /* タブ余白詰め */
  .tab-nav > *,
  .tabs > *,
  [role="tablist"] > *,
  .acc-tabs > * {
    padding: 8px 12px;
    font-size: 0.875rem;
  }

  /* ボタン余白詰め */
  button,
  .btn,
  a.btn {
    padding: 8px 12px;
    font-size: 0.875rem;
  }

  /* h1/h2 さらに抑制 */
  h1 { font-size: 1.25rem; }
  h2 { font-size: 1.125rem; }
  h3 { font-size: 1rem; }
}

/* ========================================
   ≦ 390px (iPhone 12 mini など)
   ======================================== */
@media (max-width: 390px) {
  /* ハンバーガーをやや小さく */
  .mobile-nav-toggle {
    width: 40px;
    height: 40px;
    top: 8px;
    right: 8px;
  }

  /* ドロワー幅を広げる */
  .global-nav,
  .lp-nav,
  .news-sidebar,
  .app-sidebar,
  body:not(.salon-page) > .nav,
  body:not(.salon-page) > header > .nav {
    width: 90vw;
  }
}

/* ========================================
   ≦ 320px (iPhone SE 1st gen など)
   ======================================== */
@media (max-width: 320px) {
  body {
    font-size: 14px;
  }

  .container,
  .wrap,
  .wrapper,
  .page-wrap,
  .acc-wrap {
    padding-left: 6px;
    padding-right: 6px;
  }
}

/* ========================================
   ランドスケープ短小高 (横向きスマホ)
   ======================================== */
@media (max-height: 480px) and (orientation: landscape) {
  .modal,
  .modal-content,
  .acc-modal,
  .dialog {
    max-height: 100vh;
  }

  .global-nav,
  .lp-nav,
  .news-sidebar,
  .app-sidebar {
    padding-top: 16px;
  }
}

/* ========================================
   印刷時はハンバーガー類を非表示
   ======================================== */
@media print {
  .mobile-nav-toggle,
  .mobile-nav-overlay {
    display: none !important;
  }
}
