/* ========================================
   横スクロール問題の修正
   ======================================== */

/* グローバル横スクロール防止 */
html {
    overflow-x: hidden;
    width: 100%;
}

body {
    overflow-x: hidden;
    width: 100%;
    position: relative;
}

/* すべての要素の最大幅を制限 */
* {
    max-width: 100vw;
}

/* メインコンテナの制限 */
.main {
    overflow-x: hidden;
    width: 100%;
}

/* セクション要素の制限 */
section {
    overflow-x: hidden;
    width: 100%;
}

/* コンテナ要素の修正 */
.container {
    max-width: 100%;
    overflow-x: hidden;
    box-sizing: border-box;
}

/* ========================================
   モバイル専用修正 (768px以下)
   ======================================== */
@media (max-width: 768px) {
    
    /* ヒーローセクション修正 */
    .hero {
        width: 100%;
        overflow-x: hidden;
    }
    
    .hero-container {
        width: 100%;
        max-width: 100%;
        padding: 0 16px;
        box-sizing: border-box;
    }
    
    .hero-content {
        width: 100%;
        max-width: 100%;
    }
    
    .hero-buttons {
        width: 100%;
        max-width: 100%;
        padding: 0;
        display: flex;
        flex-direction: column;
        gap: 12px;
    }
    
    .hero-buttons .btn {
        width: 100%;
        max-width: 100%;
        margin: 0;
    }
    
    /* 統計情報修正 */
    .hero-stats {
        width: 100%;
        max-width: 100%;
        padding: 0;
        justify-content: space-around;
    }
    
    .stat-item {
        flex: 1;
        min-width: 0;
        text-align: center;
    }
    
    /* カテゴリセクション修正 */
    .categories {
        width: 100%;
        overflow-x: hidden;
    }
    
    .category-grid {
        width: 100%;
        max-width: 100%;
        padding: 0;
        margin: 0;
        display: flex;
        flex-direction: column;
        gap: 16px;
    }
    
    .category-card {
        width: 100%;
        max-width: 100%;
        margin: 0;
    }
    
    /* 商品スライダー修正 */
    .featured-products {
        width: 100%;
        overflow-x: hidden;
    }
    
    .product-slider {
        width: 100%;
        max-width: 100%;
        padding: 0;
        margin: 0;
        overflow-x: hidden;
    }
    
    .product-card {
        width: 100%;
        max-width: 100%;
        margin: 0;
    }
    
    /* 記事グリッド修正 */
    .latest-articles {
        width: 100%;
        overflow-x: hidden;
    }
    
    .article-grid {
        width: 100%;
        max-width: 100%;
        padding: 0;
        margin: 0;
        display: flex;
        flex-direction: column;
        gap: 16px;
    }
    
    .article-card {
        width: 100%;
        max-width: 100%;
        margin: 0;
    }
    
    /* 理由セクション修正 */
    .why-choose-us {
        width: 100%;
        overflow-x: hidden;
    }
    
    .reason-grid {
        width: 100%;
        max-width: 100%;
        padding: 0;
        margin: 0;
        display: flex;
        flex-direction: column;
        gap: 24px;
    }
    
    .reason-card {
        width: 100%;
        max-width: 100%;
        padding: 16px;
        margin: 0;
    }
    
    /* フッター修正 */
    .footer {
        width: 100%;
        overflow-x: hidden;
    }
    
    .footer-content {
        width: 100%;
        max-width: 100%;
        padding: 0 16px;
        box-sizing: border-box;
    }
    
    .footer-section {
        width: 100%;
        max-width: 100%;
    }
    
    /* ニュースレター修正 */
    .newsletter {
        width: 100%;
        max-width: 100%;
        flex-direction: column;
    }
    
    .newsletter-form {
        width: 100%;
        max-width: 100%;
        flex-direction: column;
    }
    
    .newsletter input {
        width: 100%;
        max-width: 100%;
        margin: 0;
    }
    
    /* その他の要素 */
    .more-articles {
        width: 100%;
        max-width: 100%;
        flex-direction: column;
        padding: 0;
    }
    
    /* テーブル要素の修正 */
    table {
        width: 100%;
        max-width: 100%;
        overflow-x: auto;
        display: block;
    }
    
    /* 画像の修正 */
    img {
        max-width: 100%;
        height: auto;
    }
    
    /* アイコンとボタンの修正 */
    .reason-icon {
        margin: 0 auto 16px;
    }
    
    /* 絶対配置要素の修正 */
    [style*="position: absolute"] {
        max-width: 100%;
    }
    
    /* フレックスボックス修正 */
    .flex-container {
        flex-wrap: wrap;
    }
    
    /* グリッド修正 */
    [class*="grid"] {
        grid-template-columns: 1fr;
    }
}

/* ========================================
   小画面 (480px以下) 追加修正
   ======================================== */
@media (max-width: 480px) {
    
    /* さらに厳格な制限 */
    .container {
        padding: 0 12px;
    }
    
    .hero-container,
    .category-grid,
    .product-slider,
    .article-grid,
    .reason-grid {
        padding: 0;
    }
    
    /* ボタングループ修正 */
    .btn-group,
    .button-group {
        flex-direction: column;
        width: 100%;
    }
    
    .btn-group .btn,
    .button-group .btn {
        width: 100%;
        margin: 4px 0;
    }
    
    /* カード内のパディング調整 */
    .card-content {
        padding: 12px;
    }
    
    /* 長いテキストの折り返し */
    h1, h2, h3, h4, h5, h6,
    .title, .heading {
        word-wrap: break-word;
        overflow-wrap: break-word;
    }
}

/* ========================================
   デバッグ用（問題の要素を特定）
   ======================================== */
@media (max-width: 768px) {
    /* 問題のある要素を赤枠で表示（開発時のみ使用） */
    /*
    *:not(html):not(body) {
        outline: 1px solid red !important;
    }
    */
}

/* ========================================
   強制的な横スクロール防止
   ======================================== */
@media (max-width: 768px) {
    /* すべての直接の子要素 */
    body > * {
        max-width: 100%;
        overflow-x: hidden;
    }
    
    /* よくある問題要素 */
    pre, code {
        max-width: 100%;
        overflow-x: auto;
        word-wrap: break-word;
    }
    
    /* フォーム要素 */
    input, select, textarea {
        max-width: 100%;
        box-sizing: border-box;
    }
}