.splide__container{box-sizing:border-box;position:relative}.splide__list{backface-visibility:hidden;display:-ms-flexbox;display:flex;height:100%;margin:0!important;padding:0!important}.splide.is-initialized:not(.is-active) .splide__list{display:block}.splide__pagination{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-pack:center;justify-content:center;margin:0;pointer-events:none}.splide__pagination li{display:inline-block;line-height:1;list-style-type:none;margin:0;pointer-events:auto}.splide:not(.is-overflow) .splide__pagination{display:none}.splide__progress__bar{width:0}.splide{position:relative;visibility:hidden}.splide.is-initialized,.splide.is-rendered{visibility:visible}.splide__slide{backface-visibility:hidden;box-sizing:border-box;-ms-flex-negative:0;flex-shrink:0;list-style-type:none!important;margin:0;position:relative}.splide__slide img{vertical-align:bottom}.splide__spinner{animation:splide-loading 1s linear infinite;border:2px solid #999;border-left-color:transparent;border-radius:50%;bottom:0;contain:strict;display:inline-block;height:20px;left:0;margin:auto;position:absolute;right:0;top:0;width:20px}.splide__sr{clip:rect(0 0 0 0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.splide__toggle.is-active .splide__toggle__play,.splide__toggle__pause{display:none}.splide__toggle.is-active .splide__toggle__pause{display:inline}.splide__track{overflow:hidden;position:relative;z-index:0}@keyframes splide-loading{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.splide__track--draggable{-webkit-touch-callout:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.splide__track--fade>.splide__list>.splide__slide{margin:0!important;opacity:0;z-index:0}.splide__track--fade>.splide__list>.splide__slide.is-active{opacity:1;z-index:1}.splide--rtl{direction:rtl}.splide__track--ttb>.splide__list{display:block}.splide__arrow{-ms-flex-align:center;align-items:center;background:#ccc;border:0;border-radius:50%;cursor:pointer;display:-ms-flexbox;display:flex;height:2em;-ms-flex-pack:center;justify-content:center;opacity:.7;padding:0;position:absolute;top:50%;transform:translateY(-50%);width:2em;z-index:1}.splide__arrow svg{fill:#000;height:1.2em;width:1.2em}.splide__arrow:hover:not(:disabled){opacity:.9}.splide__arrow:disabled{opacity:.3}.splide__arrow:focus-visible{outline:3px solid #0bf;outline-offset:3px}.splide__arrow--prev{left:1em}.splide__arrow--prev svg{transform:scaleX(-1)}.splide__arrow--next{right:1em}.splide.is-focus-in .splide__arrow:focus{outline:3px solid #0bf;outline-offset:3px}.splide__pagination{bottom:.5em;left:0;padding:0 1em;position:absolute;right:0;z-index:1}.splide__pagination__page{background:#ccc;border:0;border-radius:50%;display:inline-block;height:8px;margin:3px;opacity:.7;padding:0;position:relative;transition:transform .2s linear;width:8px}.splide__pagination__page.is-active{background:#fff;transform:scale(1.4);z-index:1}.splide__pagination__page:hover{cursor:pointer;opacity:.9}.splide__pagination__page:focus-visible{outline:3px solid #0bf;outline-offset:3px}.splide.is-focus-in .splide__pagination__page:focus{outline:3px solid #0bf;outline-offset:3px}.splide__progress__bar{background:#ccc;height:3px}.splide__slide{-webkit-tap-highlight-color:rgba(0,0,0,0)}.splide__slide:focus{outline:0}@supports(outline-offset:-3px){.splide__slide:focus-visible{outline:3px solid #0bf;outline-offset:-3px}}@media screen and (-ms-high-contrast:none){.splide__slide:focus-visible{border:3px solid #0bf}}@supports(outline-offset:-3px){.splide.is-focus-in .splide__slide:focus{outline:3px solid #0bf;outline-offset:-3px}}@media screen and (-ms-high-contrast:none){.splide.is-focus-in .splide__slide:focus{border:3px solid #0bf}.splide.is-focus-in .splide__track>.splide__list>.splide__slide:focus{border-color:#0bf}}.splide__toggle{cursor:pointer}.splide__toggle:focus-visible{outline:3px solid #0bf;outline-offset:3px}.splide.is-focus-in .splide__toggle:focus{outline:3px solid #0bf;outline-offset:3px}.splide__track--nav>.splide__list>.splide__slide{border:3px solid transparent;cursor:pointer}.splide__track--nav>.splide__list>.splide__slide.is-active{border:3px solid #000}.splide__arrows--rtl .splide__arrow--prev{left:auto;right:1em}.splide__arrows--rtl .splide__arrow--prev svg{transform:scaleX(1)}.splide__arrows--rtl .splide__arrow--next{left:1em;right:auto}.splide__arrows--rtl .splide__arrow--next svg{transform:scaleX(-1)}.splide__arrows--ttb .splide__arrow{left:50%;transform:translate(-50%)}.splide__arrows--ttb .splide__arrow--prev{top:1em}.splide__arrows--ttb .splide__arrow--prev svg{transform:rotate(-90deg)}.splide__arrows--ttb .splide__arrow--next{bottom:1em;top:auto}.splide__arrows--ttb .splide__arrow--next svg{transform:rotate(90deg)}.splide__pagination--ttb{bottom:0;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;left:auto;padding:1em 0;right:.5em;top:0}

/* --- Splide 矢印ボタンのカスタマイズ --- */

/* 1. ボタン全体のサイズと背景色 */
.splide__arrow {
    width: 50px !important;    /* ボタンの横幅 */
    height: 50px !important;   /* ボタンの高さ */
    background: rgba(0, 66, 148, 0.8) !important; /* 濃い青（透過80%）背景 */
    opacity: 1 !important;     /* 常にハッキリ表示 */
    transition: all 0.3s;
}

/* 2. 矢印アイコン（SVG）のサイズと色 */
.splide__arrow svg {
    width: 24px !important;    /* 矢印を大きく */
    height: 24px !important;
    fill: #fff !important;     /* 矢印を白に */
}

/* 3. ホバー（マウスを乗せた時）の反応 */
.splide__arrow:hover {
    background: rgba(0, 66, 148, 1) !important; /* 透過をなくして濃くする */
    transform: scale(1.1); /* 少しだけ膨らむ演出 */
}

/* 4. 位置の微調整（画像の中央にくるように） */
.splide__arrow--prev {
    left: -25px !important; /* 左ボタンを少し外側へ */
}
.splide__arrow--next {
    right: -25px !important; /* 右ボタンを少し外側へ */
}

/* スマホでの調整：画面からはみ出さないように */
@media screen and (max-width: 768px) {
    .splide__arrow {
        width: 40px !important;
        height: 40px !important;
    }
    .splide__arrow--prev {
        left: 5px !important;
    }
    .splide__arrow--next {
        right: 5px !important;
    }
}

/* PCなど、マウス操作ができるデバイスのみホバーを適用 */
@media (hover: hover) {
  .splide__arrow:hover {
    background: rgba(0, 66, 148, 1) !important;
    transform: scale(1.1) translateY(-50%) !important;
  }
}

/* --- ページネーション（ドット）のカスタマイズ --- */

/* 1. PC版でも表示し、位置をスライダーの外側（下）へ移動 */
.splide__pagination {
    bottom: -30px !important; /* マイナスの値でスライダーの下側に追い出します */
    position: absolute;
    display: flex !important; /* スマホだけでなくPCでも強制的に表示 */
    padding: 0;
}

/* スライダー全体の余白を調整（ドットが下の要素に被らないように） */
#topics-slider {
    margin-bottom: 70px !important; /* 下にドット用のスペースを確保 */
}

/* 2. ドット自体の見た目と色 */
.splide__pagination__page {
    background: #ccc !important; /* 通常時の色（少し濃いめのグレー） */
    opacity: 1 !important;        /* 透けないように固定 */
    width: 10px;
    height: 10px;
    margin: 0 5px;
    transition: transform 0.3s;
}

/* 3. 現在地（アクティブ）の色を濃くする */
.splide__pagination__page.is-active {
    background: #004294 !important; /* そうごう様のブルーなど、ハッキリした色に */
    transform: scale(1.3);          /* 現在地を少し大きくして目立たせる */
}

/* スマホ表示の際の微調整（必要であれば） */
@media screen and (max-width: 768px) {
    .splide__pagination {
        bottom: -25px !important;
    }
}

/* スライダー全体のエリア調整 */
.news-topics-slider-area {
    margin-bottom: 50px; /* 下のテーブルとの間隔 */
    margin-top: 50px;
}

/* スライダー内のカードデザイン */
.topic-item {
    display: block;
    text-decoration: none;
    color: #333;
    background: #fff; /* 背景グレーの中で白カードが際立ちます */
    border: 1px solid #e0e0e0;
    transition: 0.3s ease;
}

.topic-item:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    opacity: 1; /* aタグの標準的な不透明度変化をリセット */
}

/* 画像とテキストのバランス */
.topic-image img {
    width: 100%;
    height: auto;
    vertical-align: bottom;
}

.topic-text {
    padding: 15px;
    background: #fff;
}

.topic-category {
    font-size: 11px;
    font-weight: bold;
    color: #004294; /* コーポレートカラー */
    display: block;
    margin-bottom: 5px;
}

.topic-title {
    font-size: 14px;
    line-height: 1.4;
    font-weight: bold;
}

/* 1. スライダーの外枠を inner の幅に強制する */
.news-topics-slider-area {
    width: 100%;
    max-width: 100%; /* 親要素(inner)からはみ出さない */
    overflow: hidden; /* 万が一はみ出しても隠す */
    margin-bottom: 50px;
    box-sizing: border-box;
}

/* 2. Splide自体の幅を100%に固定 */
#topics-slider {
    width: 100% !important;
}

/* 3. ニューステーブルが伸びるのを防ぐ */
.news-scroll {
    width: 100%;
    overflow-x: auto; /* スマホでテーブルがはみ出してもスクロール可能に */
}

.table-basic {
    width: 100% !important;
    table-layout: fixed; /* 列の幅を固定し、横伸びを防止 */
}

/* テーブルの1列目（日付）の幅を固定 */
.table-basic td:first-child {
    width: 120px;
}

/* スライド内のリンク（カード本体）も親の幅に従わせる */
.topic-item {
    width: 100% !important;
    display: block;
    overflow: hidden; /* 画像がはみ出さないように */
}

/* スライダーの親枠を画面幅に固定する */
.news-topics-slider-area {
    width: 100%;
    max-width: 100vw; /* 画面の横幅を超えないように */
    overflow: hidden;
    margin-left: auto;
    margin-right: auto;
}

/* Splideのリスト要素がはみ出るのを防ぐ */
.splide__list {
    display: flex !important;
    width: 100% !important;
}

/* スマホ時のスライド1枚の幅を「画面幅」に強制する */
@media screen and (max-width: 768px) {
    .splide__slide {
        width: 100% !important;
        max-width: 100% !important;
    }
    
    /* 画像を「枠」の幅に完全に従わせる */
    .topic-image img {
        width: 100% !important;
        height: auto !important;
        object-fit: cover; /* 比率を保ちつつ枠いっぱいに */
        display: block;
    }
}

/* ② 矢印ボタンの位置調整（内側に入れる） */
.splide__arrow--prev {
    left: 10px !important; /* マイナス値をやめて、内側に配置 */
}
.splide__arrow--next {
    right: 10px !important;
}

/* ③ 各要素を角丸にする */
.topic-item {
    border-radius: 10px; /* 角丸の大きさ（お好みで） */
    overflow: hidden;    /* 中の画像も一緒に角を丸くするために必須 */
    border: 1px solid #eee; 
    background: #fff;
    display: block;
}

/* 画像自体の角も念のため */
.topic-image img {
    border-radius: 10px 10px 0 0; /* 上側だけ角丸にする場合 */
    width: 100%;
    display: block;
}

/* 1. スライダーの外枠が「はみ出したボタン」を隠さないようにする */
#topics-slider {
    overflow: visible !important; /* これが重要です！ */
}

/* 2. 矢印ボタンを外側へ半分ずらす */
/* ボタンの幅が約40pxの場合、-20px前後で見え方が変わります */
.splide__arrow--prev {
    left: -25px !important; /* 数値はお好みで調整してください */
}

.splide__arrow--next {
    right: -25px !important;
}

/* 3. スマホでは画面からはみ出さないよう、少し内側に戻す（必要に応じて） */
@media screen and (max-width: 768px) {
    .splide__arrow--prev {
        left: -10px !important;
    }
    .splide__arrow--next {
        right: -10px !important;
    }
}

/* --- PC版（画面が広い時）の設定 --- */
@media screen and (min-width: 769px) {
    .news-topics-slider-area {
        padding: 0 45px !important; /* ボタンが収まる分だけ余白を作る */
        box-sizing: border-box;
    }
}

/* --- スマホ版（画面が狭い時）の設定 --- */
@media screen and (max-width: 768px) {
    .news-topics-slider-area {
        padding: 0 !important; /* 余白をなくして横幅をフルに使う */
    }
    /* ボタンを少し内側に入れて、画像に少し被る程度にする（見切れ防止） */
    .splide__arrow--prev {
        left: 5px !important;
    }
    .splide__arrow--next {
        right: 5px !important;
    }
    /* もしスマホでボタンが邪魔なら、いっそ消してスワイプのみにしてもOKです */
    /* .splide__arrows { display: none; } */
}

/* 共通設定：はみ出したボタンを見えるようにする */
#topics-slider {
    overflow: visible !important;
}
.splide__track {
    overflow: hidden !important; /* スライド自体はここでお行儀よく隠す */
}