/**
 * =====================================================
 * 共通レスポンシブユーティリティ
 * =====================================================
 * 
 * 全モジュール共通のレスポンシブ対応スタイル
 * 
 * ブレークポイント:
 * - sm: 480px (モバイル)
 * - md: 768px (タブレット)
 * - lg: 1024px (デスクトップ)
 */

/* =====================================================
   CSS カスタムプロパティ
   ===================================================== */

:root {
    /* ブレークポイント（参照用） */
    --breakpoint-sm: 480px;
    --breakpoint-md: 768px;
    --breakpoint-lg: 1024px;
    
    /* タッチターゲット最小サイズ */
    --touch-target-min: 44px;
    
    /* セーフエリア */
    --safe-area-inset-top: env(safe-area-inset-top, 0px);
    --safe-area-inset-bottom: env(safe-area-inset-bottom, 0px);
    --safe-area-inset-left: env(safe-area-inset-left, 0px);
    --safe-area-inset-right: env(safe-area-inset-right, 0px);
}

/* =====================================================
   テーブルレスポンシブ
   ===================================================== */

.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin-bottom: 1rem;
}

.table-responsive::-webkit-scrollbar {
    height: 6px;
}

.table-responsive::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 3px;
}

.table-responsive::-webkit-scrollbar-thumb {
    background: #c1c1c1;
    border-radius: 3px;
}

.table-responsive::-webkit-scrollbar-thumb:hover {
    background: #a1a1a1;
}

/* スクロールヒント（テーブルが横にあふれる場合） */
.table-responsive::after {
    content: '';
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    width: 20px;
    background: linear-gradient(to right, transparent, rgba(0,0,0,0.05));
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s;
}

.table-responsive.has-scroll::after {
    opacity: 1;
}

/* =====================================================
   タッチターゲット対応
   ===================================================== */

@media (hover: none) and (pointer: coarse) {
    /* タッチデバイスでのボタン・リンク最小サイズ */
    button,
    .btn,
    a.btn,
    input[type="button"],
    input[type="submit"],
    input[type="reset"] {
        min-height: var(--touch-target-min);
        padding-top: 0.5rem;
        padding-bottom: 0.5rem;
    }
    
    /* チェックボックス・ラジオボタンのタップ領域拡大 */
    input[type="checkbox"],
    input[type="radio"] {
        width: 20px;
        height: 20px;
        cursor: pointer;
    }
    
    /* セレクトボックス */
    select {
        min-height: var(--touch-target-min);
        padding: 0.5rem;
    }
    
    /* テキスト入力 */
    input[type="text"],
    input[type="search"],
    input[type="email"],
    input[type="number"],
    textarea {
        min-height: var(--touch-target-min);
        font-size: 16px; /* iOS ズーム防止 */
    }
}

/* =====================================================
   モバイルナビゲーション
   ===================================================== */

/* モバイルメニューボタン */
.mobile-menu-btn {
    display: none;
    padding: 0.5rem;
    min-width: var(--touch-target-min);
    min-height: var(--touch-target-min);
    background: transparent;
    border: none;
    cursor: pointer;
}

@media (max-width: 768px) {
    .mobile-menu-btn {
        display: flex;
        align-items: center;
        justify-content: center;
    }
    
    .desktop-nav {
        display: none;
    }
}

/* =====================================================
   レイアウトユーティリティ
   ===================================================== */

/* モバイルで非表示 */
@media (max-width: 768px) {
    .hide-mobile {
        display: none !important;
    }
}

/* デスクトップで非表示 */
@media (min-width: 769px) {
    .hide-desktop {
        display: none !important;
    }
}

/* モバイルで縦並び */
@media (max-width: 768px) {
    .stack-mobile {
        flex-direction: column !important;
    }
    
    .stack-mobile > * {
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
}

/* フルワイド（モバイル） */
@media (max-width: 768px) {
    .full-width-mobile {
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }
}

/* =====================================================
   セーフエリア対応（ノッチ付きデバイス）
   ===================================================== */

@supports (padding: env(safe-area-inset-top)) {
    .safe-area-top {
        padding-top: var(--safe-area-inset-top);
    }
    
    .safe-area-bottom {
        padding-bottom: var(--safe-area-inset-bottom);
    }
    
    .safe-area-left {
        padding-left: var(--safe-area-inset-left);
    }
    
    .safe-area-right {
        padding-right: var(--safe-area-inset-right);
    }
}

/* =====================================================
   アクセシビリティ
   ===================================================== */

/* アニメーション軽減設定 */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

/* ハイコントラストモード */
@media (prefers-contrast: high) {
    button,
    .btn,
    input,
    select {
        border: 2px solid currentColor !important;
    }
}

/* =====================================================
   印刷対応
   ===================================================== */

@media print {
    .no-print {
        display: none !important;
    }
    
    .table-responsive {
        overflow: visible;
    }
    
    body {
        font-size: 12pt;
        line-height: 1.4;
    }
}

/* =====================================================
   ページヘッダースタイル
   ===================================================== */

/* 
 * ヘッダー関連スタイルは header.css に移動しました
 * @see css/shared/header.css
 * 
 * 含まれるクラス:
 * - .page-title-wrapper, .page-subtitle, .page-title
 * - .header-controls, .header-icon-btn
 * - .language-select-header
 * - #feedback-toggle-btn
 */

