.tab-nav {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
    border-radius: 0.75rem;
}

.tab-button {
    padding: 0.75rem 0.5rem;
    border: solid 2px #95D4F9;
    background-color: #FFF;
    border-radius: 6px;
    cursor: pointer;
    color: #202020;
    text-align: center;
    white-space: nowrap;
    transition: all 0.2s ease-in-out;
}

.tab-button:hover {
    background-color: #C1E8FE;
    transform: translateY(-3px);
}

/* aria-selected="true" をセレクタに使用します。
  .active クラスはJSでの識別のために残しても良いですが、
  CSSはARIA属性に連動させると堅牢です。
*/
.tab-button[aria-selected="true"] {
    background-color: #95D4F9;
    /* font-weight: 600; */
}

/* キーボードフォーカス時のスタイルを追加します。
  :focus-visible は、キーボード操作時のみに適用される擬似クラスです。
*/
.tab-button:focus-visible {
    outline: 3px solid #005A9C;
    outline-offset: 2px;
    box-shadow: 0 0 0 3px #fff, 0 0 0 6px #005A9C;
}

.tab-content {
    padding: 30px;
    margin-top: 1rem;
    background-color: #ffffff;
    border-radius: 0.75rem;
}

/*
  .tab-panel の display: none; は削除します。
  代わりに hidden 属性で表示・非表示を制御します。
*/
.tab-panel[hidden] {
    display: none;
}

/* .tab-panel.active の代わりに :not([hidden]) を使います。
*/
.tab-panel:not([hidden]) {
    display: block;
}

/* タブパネルがフォーカスを受け取ったときのアウトライン。
  （パネル内にコンテンツがなくても、スクリーンリーダーユーザーが
  「Tabキー」でパネルに移動したことがわかるように）
*/
.tab-panel:focus-visible {
    outline: 3px solid #005A9C;
    outline-offset: 2px;
}


@media (max-width: 640px) {
    .container {
        max-width: 100%;
    }

    .tab-nav {
        padding: 0.75rem 0px;
        gap: 0.5rem;
        grid-template-columns: repeat(3, 1fr);
        border-radius: 0;
        box-shadow: none;
    }

    #tab-container {
        width: 100%;
    }
}