@charset "UTF-8";


/* ハンバーガーメニュー */
.hamburger {
    font-size: 30px;
    cursor: pointer;
    position: absolute;
    right: 20px;
    top: 15px;
    z-index: 1000;
}

.hamburger .icon {
  font-size: 30px;
}


/* メニューの共通スタイル */
.menu {
    padding: 10px;
    text-align: center;
}

/* PCサイズではハンバーガーメニューは非表示 */
@media (min-width: 769px) {
   .hamburger {
        display: none;
    }
   .menu {
        display: none;
    }
}

/* スマホサイズではハンバーガーメニューにする */
@media (max-width: 768px) {
    .menu {
        display: none; /* ← 初期状態で非表示に戻す */
/*       display: flex;*/
        flex-wrap: wrap;              /* ← ここで折り返し可能に */
        justify-content: center;      /* ← 横中央揃え */
/*        display: none;
        flex-direction: column;*/
       gap: 10px; /* ← 間隔を開ける（marginよりスマート） */
        position: absolute;
        top: 60px;
        left: 0;
        width: 100%;
	padding:10px;
        background-color: white;
        box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    }

    .menu.show {
        display: flex;/* ← show クラスで表示される */
    }

    .menu a {
        display: block;
/*       display: inline-block;
        width: 30%;*/                   /* ← 2列なら45%、3列なら30%程度に 
        margin: 5px;*/
        padding: 10px 15px;                /* ← 高さ調整（この中で高さも表現） */
        text-align: center;
        background: white;
        color: gray;
        font-weight: bold;
        text-decoration: none;
        border: 1px solid #ddd;
        border-radius: 5px;

       /* ここがポイント */
        width: auto;
        min-width: 20%;  /* 30%短すぎを防止、2～3個で折り返しやすく */
        max-width: 100%; /* 長すぎを防止 */
        white-space: nowrap; /* テキスト折り返し防止 */

/*        display: block;
	width:100%;
        padding: 15px;
        background: white;
        color: gray;
        font-weight: bold;
        text-decoration: none;
        border-bottom: 1px solid #ddd;*/
    }

    .menu a:hover {
        background: darkorange;
        color: white;
    }
}

