/* ==========================================================================
   fff-foundation — pages/insights.css
   INSIGHTS 固定ページ専用（slug=insights で自動読み込み）
   8グリッドベース。コンテンツ(お知らせ/カルーセル/YouTube/SNS)は
   固定高のグリッドブロック内に収め、カルーセルは中で横スクロール。
   ========================================================================== */

/* グリッド本体（.fff-8grid に付与）。上下に少し余白 */
.fff-insights {
    margin-top: clamp(1rem, 4vw, 3rem);
    margin-bottom: var(--fff-space-5);
}

/* 各コンテンツブロックは固定高。中身がはみ出さないようにする土台 */
.fff-ins-news,
.fff-ins-carousel,
.fff-ins-sns {
    overflow: hidden;
}

.fff-insights__empty {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    padding: var(--fff-space-3);
    text-align: center;
    color: var(--fff-color-muted);
    font-size: var(--fff-fs-sm);
}

/* ==========================================================================
   お知らせリスト（白ブロック内）
   ========================================================================== */
.fff-ins-news {
    overflow-y: auto;
}
.fff-news-list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.fff-news-list__item + .fff-news-list__item {
    border-top: 1px solid var(--fff-color-line);
}
.fff-news-list__item a {
    display: flex;
    align-items: baseline;
    gap: var(--fff-space-3);
    padding: var(--fff-space-3) var(--fff-block-padding);
    text-decoration: none;
    color: var(--fff-color-ink);
    transition: background 0.2s ease;
}
.fff-news-list__item a:hover {
    background: var(--fff-color-gray-soft);
}
.fff-news-list__date {
    flex: 0 0 auto;
    font-family: var(--fff-font-accent);
    font-size: var(--fff-fs-xs);
    color: var(--fff-color-muted);
    letter-spacing: var(--fff-ls-wide);
}
.fff-news-list__title {
    font-size: var(--fff-fs-sm);
    line-height: var(--fff-lh-normal);
}

/* ==========================================================================
   カルーセル（カテゴリ別・横スクロール / 白ブロック内）
   ========================================================================== */
.fff-ins-carousel {
    display: flex;
    flex-direction: column;
    gap: var(--fff-space-2);
    padding: var(--fff-block-padding);
}
.fff-carousel__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--fff-space-3);
    flex: 0 0 auto;
}
.fff-carousel__cat {
    font-family: var(--fff-font-heading);
    font-size: var(--fff-fs-md);
    color: var(--fff-color-ink);
    margin: 0;
    position: relative;
    padding-left: 16px;
}
.fff-carousel__cat::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 8px;
    height: 8px;
    background: var(--fff-color-accent);
}
.fff-carousel__nav {
    display: flex;
    align-items: center;
    gap: var(--fff-space-2);
}
.fff-carousel__arrow {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--fff-fs-sm);
    color: var(--fff-color-ink);
    background: var(--fff-color-paper);
    border: 1px solid var(--fff-color-line);
    border-radius: var(--fff-radius-pill);
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.fff-carousel__arrow:hover {
    background: var(--fff-color-black);
    color: var(--fff-color-paper);
    border-color: var(--fff-color-black);
}
.fff-carousel__arrow:disabled {
    opacity: 0.3;
    cursor: default;
}
.fff-carousel.is-static .fff-carousel__arrow {
    display: none;
}
.fff-carousel__more {
    font-family: var(--fff-font-accent);
    font-size: var(--fff-fs-xs);
    letter-spacing: var(--fff-ls-wide);
    color: var(--fff-color-ink);
    text-decoration: none;
    margin-left: var(--fff-space-1);
}
.fff-carousel__more:hover { color: var(--fff-color-accent); }

/* 横スクロールのトラック（残りの高さいっぱい）*/
.fff-carousel__track {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    gap: var(--fff-space-3);
    overflow-x: auto;
    overflow-y: hidden;
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}
.fff-carousel__track::-webkit-scrollbar { height: 6px; }
.fff-carousel__track::-webkit-scrollbar-thumb {
    background: var(--fff-color-gray-soft);
    border-radius: var(--fff-radius-pill);
}

/* 記事カード（トラックの高さいっぱい）*/
.fff-ins-card {
    flex: 0 0 auto;
    width: 240px;
    height: 100%;
    scroll-snap-align: start;
    background: var(--fff-color-paper);
    border: 1px solid var(--fff-color-line);
    text-decoration: none;
    color: var(--fff-color-ink);
    display: flex;
    flex-direction: column;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.fff-ins-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 18px rgba(0,0,0,0.08);
}
.fff-ins-card__thumb {
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
    background: var(--fff-color-gray-soft);
}
.fff-ins-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.fff-ins-card__body {
    flex: 0 0 auto;
    padding: var(--fff-space-3);
    display: flex;
    flex-direction: column;
    gap: var(--fff-space-1);
}
.fff-ins-card__cat {
    font-family: var(--fff-font-accent);
    font-size: var(--fff-fs-xs);
    letter-spacing: var(--fff-ls-wide);
    color: var(--fff-color-accent);
}
.fff-ins-card__title {
    font-family: var(--fff-font-heading);
    font-size: var(--fff-fs-sm);
    line-height: var(--fff-lh-normal);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.fff-ins-card__date {
    font-size: var(--fff-fs-xs);
    color: var(--fff-color-muted);
}

/* ==========================================================================
   YouTube（最新6本・個別ブロック / 各カードが8グリッドの1ブロック）
   ========================================================================== */
.fff-yt-card {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: var(--fff-color-ink);
    min-height: 0;
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.fff-yt-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 18px rgba(0,0,0,0.08);
}

.fff-yt-card__thumb {
    position: relative;
    flex: 1 1 auto;        /* サムネがブロックの余った高さいっぱい */
    min-height: 0;
    overflow: hidden;
    background: var(--fff-color-black);
}
.fff-yt-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
/* 再生ボタン（中央） */
.fff-yt-card__play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 42px;
    height: 42px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.55);
    border-radius: var(--fff-radius-pill);
    color: #fff;
    transition: background 0.2s ease;
}
.fff-yt-card:hover .fff-yt-card__play {
    background: var(--fff-color-accent);
    color: var(--fff-color-black);
}
.fff-yt-card__play svg { width: 20px; height: 20px; margin-left: 2px; }

.fff-yt-card__body {
    flex: 0 0 auto;
    padding: var(--fff-space-2);
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.fff-yt-card__title {
    font-family: var(--fff-font-heading);
    font-size: var(--fff-fs-sm);
    line-height: var(--fff-lh-normal);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.fff-yt-card__date {
    font-family: var(--fff-font-accent);
    font-size: var(--fff-fs-xs);
    color: var(--fff-color-muted);
    letter-spacing: var(--fff-ls-wide);
}

/* 準備中プレースホルダ（API未設定 / 動画ゼロ時）*/
.fff-youtube__placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--fff-space-2);
    width: 100%;
    height: 100%;
    min-height: 160px;
    background: var(--fff-color-black);
    color: var(--fff-color-paper);
}
.fff-youtube__placeholder-mark svg { width: 48px; height: 48px; opacity: 0.7; }
.fff-youtube__placeholder-text {
    font-family: var(--fff-font-accent);
    font-size: var(--fff-fs-sm);
    letter-spacing: var(--fff-ls-wide);
    opacity: 0.7;
}

/* ==========================================================================
   SNS ボタン（白ブロック内）
   ========================================================================== */
.fff-ins-sns {
    display: flex;
    align-items: center;
    padding: var(--fff-block-padding);
}
.fff-sns-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: var(--fff-space-3);
}
.fff-sns-buttons__item {
    display: flex;
    align-items: center;
    gap: var(--fff-space-2);
    padding: var(--fff-space-2) var(--fff-space-3);
    background: var(--fff-color-paper);
    border: 1px solid var(--fff-color-line);
    color: var(--fff-color-ink);
    text-decoration: none;
    font-family: var(--fff-font-accent);
    font-size: var(--fff-fs-sm);
    letter-spacing: var(--fff-ls-wide);
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.fff-sns-buttons__item:hover {
    background: var(--fff-color-black);
    color: var(--fff-color-paper);
    border-color: var(--fff-color-black);
}
.fff-sns-buttons__icon { display: flex; }
.fff-sns-buttons__icon svg { width: 20px; height: 20px; }

/* ==========================================================================
   タブレット / スマホのカード幅
   ========================================================================== */
@media (min-width: 768px) and (max-width: 1023px) {
    .fff-ins-card { width: 220px; }
}
@media (max-width: 767px) {
    .fff-ins-card { width: 64vw; max-width: 260px; }
    .fff-carousel__more { display: none; }
    /* YouTube はSPだと3列は窮屈 → 2列 */
    .fff-yt-grid { grid-template-columns: repeat(2, 1fr); gap: var(--fff-space-2); }

    /* SNS 個別ブロック（SP）: 各SNS=1ブロック。アイコン+ラベル中央 */
    .fff-ins-sns-item {
        display: flex;
        align-items: center;
        gap: var(--fff-space-2);
        padding: var(--fff-block-padding);
        text-decoration: none;
        color: var(--fff-color-ink);
        transition: background 0.2s ease, color 0.2s ease;
    }
    .fff-ins-sns-item:hover {
        background: var(--fff-color-black);
        color: var(--fff-color-paper);
    }
    .fff-ins-sns-item__icon { display: flex; flex: 0 0 auto; }
    .fff-ins-sns-item__icon svg { width: 22px; height: 22px; }
    .fff-ins-sns-item__label {
        font-family: var(--fff-font-accent);
        font-size: var(--fff-fs-sm);
        letter-spacing: var(--fff-ls-wide);
    }
}
