/* news-banners-carousel.css */
/* ニュースバナーカルーセル（Slick.js）のスタイル - 独立ファイル */

/* ============================================
   ニュースバナーカルーセル（Slick.js）
   ============================================ */

.news-banners-container {
    width: 100%;
    margin: 0 auto;
}

.news-banners-carousel-wrapper {
    position: relative;
    background: var(--color-bg-white, #ffffff);
    border: 2px solid var(--color-accent-sky, #0ea5e9);
    border-radius: 8px;
    padding: 1.5em;
    margin: 1em 0;
}

@media (max-width: 768px) {
    .news-banners-carousel-wrapper {
        margin-left: 1.5rem;
        margin-right: 1.5rem;
        width: calc(100% - 3rem);
    }
}

/* Slick.js用のスタイル調整 */
.news-banners-carousel {
    position: relative;
}

.news-banners-carousel .slick-list {
    overflow: hidden;
}

.news-banners-carousel .slick-track {
    display: flex;
    align-items: center;
}

.news-banner-slide {
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    opacity: 1;
    padding: 0;
    margin: 0 0.1em;
}

.news-banner-slide a {
    background-color: white;
    display: block;
    width: 100%;
    text-align: center;
}

.news-banner-slide img {
    width: 100%;
    max-width: 100%;
    height: 200px;
    object-fit: contain;
    display: block;
    margin: 0 auto;
}

/* Slick.jsデフォルト矢印をすべて非表示 */
.news-banners-carousel .slick-prev,
.news-banners-carousel .slick-next {
    display: none !important;
}

/* Slick.jsの:before疑似要素を非表示 */
.news-banners-carousel .slick-prev:before,
.news-banners-carousel .slick-next:before {
    display: none !important;
    content: none !important;
}

/* カスタムボタンのみ表示 */
.news-banners-carousel .slick-prev.news-banners-carousel-prev,
.news-banners-carousel .slick-next.news-banners-carousel-next {
    display: flex !important;
}

/* Slick.jsカスタムボタンスタイル */
.news-banners-carousel-prev,
.news-banners-carousel-next,
.news-banners-carousel .slick-prev.news-banners-carousel-prev,
.news-banners-carousel .slick-next.news-banners-carousel-next {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 2 !important;
    background: var(--color-accent-sky-light, rgba(224, 242, 254, 0.5)) !important;
    border: 2px solid #0ea5e9 !important;
    border-radius: 50% !important;
    width: 44px !important;
    height: 44px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    color: #0ea5e9 !important;
    transition: all 0.2s ease !important;
    padding: 0 !important;
    font-size: 0 !important;
    line-height: 0 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* 無効化状態でも表示 */
.news-banners-carousel-prev.slick-disabled,
.news-banners-carousel-next.slick-disabled,
.news-banners-carousel .slick-prev.news-banners-carousel-prev.slick-disabled,
.news-banners-carousel .slick-next.news-banners-carousel-next.slick-disabled {
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
    cursor: pointer !important;
}

.news-banners-carousel-prev,
.news-banners-carousel .slick-prev.news-banners-carousel-prev {
    left: -50px !important;
}

.news-banners-carousel-next,
.news-banners-carousel .slick-next.news-banners-carousel-next {
    right: -50px !important;
}

.news-banners-carousel-prev:hover,
.news-banners-carousel-next:hover {
    background: #0ea5e9;
    color: var(--color-bg-white, #ffffff);
    transform: translateY(-50%) scale(1.1);
}

/* 非アクティブなprev/nextアイコン（薄いグレー） */
.news-banners-carousel-prev i,
.news-banners-carousel-next i,
.news-banners-carousel .slick-prev.news-banners-carousel-prev i,
.news-banners-carousel .slick-next.news-banners-carousel-next i {
    font-size: 20px !important;
    color: var(--color-border-gray, #cbd5e1) !important;
}

/* アクティブなprev/nextアイコン（青色） */
.news-banners-carousel-prev:not(.slick-disabled) i,
.news-banners-carousel-next:not(.slick-disabled) i,
.news-banners-carousel .slick-prev.news-banners-carousel-prev:not(.slick-disabled) i,
.news-banners-carousel .slick-next.news-banners-carousel-next:not(.slick-disabled) i {
    color: #0ea5e9 !important;
}

.news-banners-carousel-prev:hover i,
.news-banners-carousel-next:hover i,
.news-banners-carousel .slick-prev.news-banners-carousel-prev:hover i,
.news-banners-carousel .slick-next.news-banners-carousel-next:hover i {
    color: #ffffff !important;
}

/* Slick.jsドットスタイル */
.news-banners-carousel-dots {
    display: flex !important;
    justify-content: center;
    align-items: center;
    gap: 0.5em;
    margin-top: 1em;
    list-style: none;
    padding: 0;
    opacity: 1 !important;
    visibility: visible !important;
}

.news-banners-carousel-dots li {
    margin: 0;
    padding: 0;
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* 非アクティブなdots（薄いグレー） */
.news-banners-carousel-dots li button {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--color-border-gray, #cbd5e1) !important;
    cursor: pointer;
    transition: all 0.2s ease;
    border: none;
    padding: 0;
    font-size: 0;
    line-height: 0;
    text-indent: -9999px;
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* アクティブなdots（青色、サイズ20px） */
.news-banners-carousel-dots li.slick-active button {
    background: var(--color-accent-sky, #0ea5e9) !important;
    width: 20px !important;
    height: 20px !important;
    border-radius: 50% !important;
    min-width: 20px !important;
    min-height: 20px !important;
    max-width: 20px !important;
    max-height: 20px !important;
}

@media (max-width: 768px) {
    .news-banner-slide img {
        height: 150px;
    }
    .news-banners-carousel-prev,
    .news-banners-carousel-next,
    .news-banners-carousel .slick-prev.news-banners-carousel-prev,
    .news-banners-carousel .slick-next.news-banners-carousel-next {
        width: 32px !important;
        height: 32px !important;
    }
    .news-banners-carousel-prev i,
    .news-banners-carousel-next i,
    .news-banners-carousel .slick-prev.news-banners-carousel-prev i,
    .news-banners-carousel .slick-next.news-banners-carousel-next i {
        font-size: 14px !important;
    }
    .news-banners-carousel-prev,
    .news-banners-carousel .slick-prev.news-banners-carousel-prev {
        left: 8px !important;
    }
    .news-banners-carousel-next,
    .news-banners-carousel .slick-next.news-banners-carousel-next {
        right: 8px !important;
    }
}

