/*
Theme Name: ヌキドコ
Theme URI: https://nukidoko.net
Author: ECDAO
Description: ヌキドコ — DLsite・FANZA同人特化AIまとめサイト
Version: 1.0.0
*/

/* ============================================
   Google Fonts - ヌキドコ v3（2026-04-21 確定）
   Max Weight 700 — Kiwi Maru + Noto Sans JP ハイブリッド
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Kiwi+Maru:wght@300;400;500&family=Inter:wght@400;500;700&family=Montserrat:wght@300;400;500;600;700&family=Noto+Sans+JP:wght@300;400;500;700&family=Noto+Serif+JP:wght@400;500;700&display=swap');

:root {
    /* ======= ヌキドコ ブランドカラー ======= */
    /* ベースは純白 */
    --bg:          #ffffff;
    --bg-soft:     #fafafc;
    --bg-cream:    #fdfcf9;
    --bg-card:     #ffffff;
    --bg2:         #fafafc;
    --bg3:         #f3f3f7;
    --bg4:         #ececf0;
    --card:        #ffffff;
    --card-hover:  #fafafc;
    --glass:       rgba(255,255,255,0.7);
    --glass-border:rgba(255,255,255,0.5);

    /* アクセント：淡ピンク（さらに薄め・v3.1）*/
    --pink:        #fbc2d3;  /* 基準ピンク（さらに淡く）*/
    --pink-soft:   #fdf0f5;  /* 背景用 ほぼ白に近い */
    --pink-deep:   #f2a6bd;  /* 少し濃いめ（ボタン/ラインアート）*/
    --pink-dark:   #d87ca0;  /* 最も濃い文字色でもビビッドにしない */
    --pink-glow:   rgba(251, 194, 211, 0.15);
    --pink-subtle: rgba(251, 194, 211, 0.06);

    /* 淡レインボーグラデ用 */
    --rainbow-1:   #fce7ee;  /* 淡ピンク */
    --rainbow-2:   #fde8f0;  /* 淡ピンクライト */
    --rainbow-3:   #e7e9fd;  /* 淡ラベンダー */
    --rainbow-4:   #e0f2fe;  /* 淡ブルー */
    --rainbow-5:   #ecfccb;  /* 淡ライム */
    --rainbow-6:   #fef3c7;  /* 淡イエロー */
    --rainbow-7:   #fef9e7;  /* 淡クリーム */

    /* ブランド互換（旧ダレコレ変数のマッピング） */
    --red:         var(--pink-deep);
    --red-dark:    var(--pink-dark);
    --red-light:   var(--pink);
    --red-glow:    var(--pink-glow);
    --red-subtle:  var(--pink-subtle);
    --orange:      #e8621a;
    --gold:        #d4930a;
    --purple:      #c88ad4;
    --purple-soft: #d8a7e3;
    --teal:        #5dbbc0;
    --green:       #6cba7a;

    /* FANZA/DLsite ブランドカラー（CTAボタン用） */
    --fanza:       #d1345e;
    --fanza-light: #ffe7ed;
    --dlsite:      #b8630a;
    --dlsite-light:#ffeed4;

    /* テキスト */
    --t1:          #1a1a24;  /* 濃グレー（黒より柔らか）*/
    --t2:          #4a4a56;
    --t3:          #8a8a96;
    --t4:          #b8b8c0;

    /* ボーダー */
    --line:        #ececf0;
    --line-soft:   #f4f4f7;
    --b1:          var(--line-soft);
    --b2:          var(--line);
    --b3:          #dadae0;

    /* シャドウ（白基調用・軽め） */
    --s1:          0 1px 4px rgba(0,0,0,0.04);
    --s2:          0 4px 20px rgba(0,0,0,0.04);
    --s3:          0 12px 32px rgba(0,0,0,0.06);
    --s-pink:      0 8px 24px var(--pink-glow);

    /* レイアウト */
    --max-w:       1280px;
    --pad-x:       40px;
    --pad-x-sp:    16px;
    --r1:          6px;
    --r2:          10px;
    --r3:          14px;
    --r4:          20px;
    --r5:          28px;
    --r-full:      999px;

    /* トランジション */
    --t-fast:      0.1s ease;
    --t-base:      0.2s ease;
    --t-slow:      0.3s ease;

    /* ===== フォント（v3.1 Lightweight Elegant・Max Weight 500）===== */
    --font-kiwi:   'Kiwi Maru', 'Noto Sans JP', sans-serif;        /* ロゴ・キャッチ */
    --font-sans:   'Noto Sans JP', -apple-system, sans-serif;       /* 本文・見出し */
    --font-serif:  'Noto Serif JP', serif;                          /* 引用 */
    --font-inter:  'Inter', 'Noto Sans JP', sans-serif;             /* 数字・英字 */
    --font-mont:   'Montserrat', 'Inter', sans-serif;               /* キッカー・英語見出し */
    --font:        var(--font-sans);

    /* ヘッダー高さ */
    --h-bar:       28px;
    --h-main:      60px;
    --h-gnav:      40px;
    --h-total:     128px;
}

/* ============================================
   リセット & ベース
   ============================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }


/* ============================================
   Interフォント（数字・カウント系）
   ============================================ */
.rank-num, .stat-num, .view-count, .like-count,
.section-count, .meta-chip, .card-views,
.api-count, .page-num,
[class*="count"], [class*="num"], [class*="stat"] {
    font-family: var(--font-inter);
    font-variant-numeric: tabular-nums;
}

html {
    font-size: 15px;
    scroll-behavior: smooth;
    color-scheme: light;
    overflow-x: hidden;
}

body {
    font-family: var(--font);
    background: var(--bg);
    color: var(--t1);
    line-height: 1.6;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
    width: 100%;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
button { cursor: pointer; font-family: var(--font); }

/* ============================================
   上部バー
   ============================================ */
#top-bar {
    height: var(--h-bar);
    background: var(--bg2);
    border-bottom: 1px solid var(--b1);
    display: flex;
    align-items: center;
}

.tb-inner {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 0 20px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.tb-left { display: flex; align-items: center; gap: 8px; }
.tb-badge {
    font-size: 10px;
    font-weight: 600;
    background: var(--red);
    color: #fff;
    padding: 1px 7px;
    border-radius: var(--r-full);
    letter-spacing: 0.3px;
}
.tb-copy { font-size: 10px; color: var(--t3); }
.tb-right { display: none; }
@media (min-width: 768px) { .tb-right { display: flex; gap: 12px; } }
.tb-right a { font-size: 11px; color: var(--t3); transition: var(--t-base); }
.tb-right a:hover { color: var(--t2); }

/* ============================================
   メインヘッダー
   ============================================ */
#site-header {
    position: sticky;
    top: 0;
    z-index: 500;
    background: rgba(13,17,23,0.95);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--b1);
}

/* 1行目：ロゴ＋ナビ */
.hd-row1 {
    height: var(--h-main);
    display: flex;
    align-items: center;
    padding: 0 20px;
    gap: 12px;
    max-width: var(--max-w);
    margin: 0 auto;
    overflow: hidden;
    width: 100%;
}

/* ロゴ */
.site-logo {
    display: flex;
    align-items: center;
    text-decoration: none;
    flex-shrink: 0;
}

.logo-img {
    height: 24px;
    width: auto;
    display: block;
}


@media (min-width: 540px) { .logo-sub { display: inline; } }

/* PC検索（デスクトップのみ） */
.hd-search-pc {
    flex: 1;
    max-width: 700px;
    display: none;
}

@media (min-width: 768px) { .hd-search-pc { display: block; } }

/* ナビボタン群 */
.hd-actions {
    display: flex;
    align-items: center;
    gap: 5px;
    margin-left: auto;
    flex-shrink: 0;
    min-width: 0;
}

.hd-btn {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    font-weight: 500;
    color: var(--t2);
    padding: 7px 10px;
    border-radius: var(--r2);
    border: 1px solid var(--b2);
    background: var(--glass);
    transition: var(--t-base);
    white-space: nowrap;
    cursor: pointer;
    text-decoration: none;
    flex-shrink: 0;
    position: relative;
}

.hd-btn:hover { color: var(--t1); border-color: var(--b3); background: rgba(255,255,255,0.07); }

.hd-btn-icon { width: 14px; height: 14px; flex-shrink: 0; }

/* スマホではラベルテキストを隠す（検索トグルなど一部を除き常時表示） */
.hd-btn-label { display: inline; }

/* スマホ：ボタンをアイコン＋小ラベルの正方形に */
@media (max-width: 767px) {
    .hd-actions {
        gap: 2px;
    }
    .hd-btn {
        flex-direction: column;
        justify-content: center;
        gap: 3px;
        width: 48px;
        height: 48px;
        padding: 0;
        border: none;
        background: none;
        font-size: 8px;
        font-weight: 600;
        border-radius: 10px;
    }
    .hd-btn:hover {
        background: rgba(255,255,255,0.05);
        border: none;
    }
    .hd-btn-icon {
        width: 20px;
        height: 20px;
    }
    .hd-btn-label {
        display: block;
        font-size: 8px;
        font-weight: 600;
        line-height: 1;
        white-space: nowrap;
        text-align: center;
        color: var(--t3);
    }
    /* バッジをアイコン右上に浮かせる */
    .hd-btn-count {
        display: flex;
        position: absolute;
        top: 5px;
        right: 5px;
        min-width: 16px;
        height: 16px;
        border-radius: 8px;
        padding: 0 3px;
        border: 1.5px solid var(--bg1);
        font-size: 9px;
    }
}

/* お気に入りカウントバッジ */
.hd-btn-count {
    display: none;
    background: var(--red);
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    padding: 1px 5px;
    border-radius: var(--r-full);
    margin-left: 2px;
    font-family: var(--font-inter);
    line-height: 1.6;
}

/* スマホでは「保存済み」「ランキング」ボタンを隠す */
.hd-btn--hide-sp { display: none; }
@media (min-width: 480px) { .hd-btn--hide-sp { display: flex; } }

.hd-btn--red {
    background: var(--red);
    border-color: var(--red);
    color: #fff;
    font-weight: 700;
}

.hd-btn--red:hover { background: var(--red-dark); border-color: var(--red-dark); color: #fff; }

/* モバイルのみ表示するサーチトグル */
.hd-btn--search-toggle { display: flex; }
@media (min-width: 768px) { .hd-btn--search-toggle { display: none; } }

/* 2行目：モバイル検索（スマホのみ） */
.hd-row2 {
    display: block;
    padding: 8px 12px;
    border-top: 1px solid var(--b1);
}

@media (min-width: 768px) { .hd-row2 { display: none; } }

/* 検索フォーム共通 */
.search-form {
    display: flex;
    height: 38px;
    background: var(--bg3);
    border: 1px solid var(--b2);
    border-radius: var(--r2);
    overflow: hidden;
    transition: var(--t-base);
}

.search-form:focus-within {
    border-color: var(--red);
    box-shadow: 0 0 0 3px var(--red-glow);
}

.search-icon-wrap {
    display: flex;
    align-items: center;
    padding: 0 12px;
    color: var(--t3);
    flex-shrink: 0;
}

.search-form input {
    flex: 1;
    background: none;
    border: none;
    outline: none;
    color: var(--t1);
    font-size: 13px;
    font-family: var(--font);
    padding: 0 8px 0 0;
    min-width: 0;
}

.search-form input::placeholder { color: var(--t3); }

.search-form button {
    background: var(--red);
    border: none;
    padding: 0 16px;
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    font-family: var(--font);
    display: flex;
    align-items: center;
    gap: 4px;
    white-space: nowrap;
    transition: var(--t-base);
    flex-shrink: 0;
}

.search-form button:hover { background: var(--red-dark); }

/* ============================================
   ジャンルナビ
   ============================================ */
#genre-nav {
    background: var(--bg2);
    border-bottom: 1px solid var(--b1);
    overflow-x: auto;
    scrollbar-width: none;
    height: var(--h-gnav);
}

#genre-nav::-webkit-scrollbar { display: none; }

.gnav-inner {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    height: 100%;
    align-items: center;
    gap: 2px;
}

.gnav-item {
    font-size: 12px;
    font-weight: 500;
    color: var(--t3);
    padding: 5px 12px;
    border-radius: var(--r-full);
    white-space: nowrap;
    transition: var(--t-base);
    border: 1px solid transparent;
}

.gnav-item:hover { color: var(--t1); background: var(--glass); border-color: var(--b1); }
.gnav-item.active { color: var(--red); background: var(--red-subtle); border-color: rgba(232,0,45,0.3); font-weight: 700; }

/* 人気検索キーワード */
.gnav-item--keyword {
    color: var(--t3);
    gap: 4px;
    display: inline-flex;
    align-items: center;
}
.gnav-item--keyword svg { color: var(--red); opacity: 0.7; flex-shrink: 0; }
.gnav-item--keyword:hover { color: var(--red); }
.gnav-item--keyword.active { color: var(--red); background: var(--red-subtle); border-color: rgba(232,0,45,0.3); }

/* 区切り線 */
.gnav-sep {
    width: 1px;
    height: 16px;
    background: var(--b2);
    flex-shrink: 0;
    margin: 0 4px;
    align-self: center;
}

/* ============================================
   ヒーローバナー
   ============================================ */
#hero {
    position: relative;
    overflow: hidden;
    border-bottom: 1px solid var(--b1);
    background: var(--bg);
}

/* ===== 背景画像 ===== */
#hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: var(--hero-bg);
    background-size: cover;
    background-position: center top;
    filter: blur(0px) saturate(0.8);
    z-index: 0;
    transform: scale(1.3) skewX(3deg) skewY(4deg);
}

/* ===== オーバーレイ（暗転） ===== */
.hero-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(105deg, rgb(13 17 23 / 73%) 0%, rgba(13, 17, 23, 0.55) 40%, rgba(13, 17, 23, 0.88) 65%, rgb(13 17 23 / 31%) 100%), linear-gradient(to bottom, rgb(13 17 23 / 77%) 0%, rgb(13 17 23 / 58%) 25%, rgb(13 17 23 / 54%) 70%, rgb(13 17 23 / 99%) 100%);
}

/* ===== コンテンツ ===== */
.hero-inner {
    position: relative;
    z-index: 2;
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 250px 20px 250px;
}

.hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 700;
    color: var(--red);
    background: var(--red-subtle);
    border: 1px solid rgba(232,0,45,0.25);
    padding: 4px 10px;
    border-radius: var(--r-full);
    margin-bottom: 14px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.hero-heading {
    font-size: clamp(26px, 4vw, 41px);
    font-weight: 600;
    color: #fff;
    line-height: 1.3;
    margin-bottom: 12px;
    letter-spacing: -0.5px;
    text-shadow: 0 2px 16px rgba(0, 0, 0, 0.6);
}

@media (max-width: 600px) {
.hero-heading {
text-align: center;
}
}

.hero-heading em {
    font-style: normal;
}

.hero-sub {
    font-size: 14px;
    color: rgb(255 255 255 / 85%);
    font-weight: 400;
    line-height: 1.75;
    max-width: 560px;
    margin-bottom: 18px;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.5);
}

@media (max-width: 600px) {
.hero-sub {
    font-size: 11px;
    text-align: center;
}
}

.hero-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

@media (max-width: 600px) {
.hero-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    justify-content: center;
}
}

.hero-tag {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    font-weight: 500;
    color: rgb(255 255 255 / 91%);
    background: rgba(255, 255, 255, 0.07);
    border: 1px solid rgb(255 255 255 / 42%);
    padding: 5px 11px;
    border-radius: var(--r-full);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.hero-tag svg {
    color: rgb(255 255 255 / 76%);
    flex-shrink: 0;
}
.hero-tag.accent { color: var(--red); border-color: rgba(232,0,45,0.4); background: rgba(184,16,32,0.15); }
.hero-tag.accent svg { color: var(--red); }

/* ===== タイル（非表示） ===== */
.hero-tiles { display: none; }

@media (max-width: 600px) {
        .hero-inner {
        padding: 120px 10px 120px;
        margin: 0 auto;
        text-align: center;
    }
}

/* ============================================
   メインレイアウト
   ============================================ */
#main-wrapper {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 20px 14px;
    display: block;
    width: 100%;
    box-sizing: border-box;
    overflow: hidden;
}

@media (min-width: 1024px) {
    #main-wrapper {
        display: grid;
        grid-template-columns: 1fr 300px;
        gap: 20px;
        padding: 20px 20px;
    }
}

/* ============================================
   AIレコメンドバナー
   ============================================ */
.ai-pill-banner {
    display: flex;
    align-items: center;
    gap: 10px;
    background: linear-gradient(135deg, rgba(124,58,237,0.12), rgba(59,130,246,0.08));
    border: 1px solid rgba(124,58,237,0.25);
    border-radius: var(--r3);
    padding: 12px 16px;
    margin-bottom: 20px;
}

.ai-pill-dot {
    width: 8px;
    height: 8px;
    background: var(--purple-soft);
    border-radius: 50%;
    flex-shrink: 0;
    animation: pulse-dot 2s ease-in-out infinite;
}

@keyframes pulse-dot {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.5; transform: scale(0.8); }
}

.ai-pill-text { font-size: 12px; color: var(--purple-soft); font-weight: 500; }
.ai-pill-text strong { font-weight: 700; }

/* ============================================
   セクションヘッダー
   ============================================ */
.section-hd {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--b1);
}

.section-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 400;
    color: var(--t1);
    letter-spacing: -0.2px;
}

.section-icon {
    width: 26px;
    height: 26px;
    background: var(--red-subtle);
    border: 1px solid rgba(184,16,32,0.2);
    border-radius: var(--r1);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    flex-shrink: 0;
}

.section-count {
    font-size: 12px;
    font-weight: 400;
    color: var(--t3);
}

.section-more {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    font-weight: 600;
    color: var(--t3);
    padding: 4px 10px;
    border: 1px solid var(--b2);
    border-radius: var(--r-full);
    transition: var(--t-base);
    background: var(--glass);
    white-space: nowrap;
}

.section-more:hover { color: var(--t1); border-color: var(--b3); }

/* ============================================
   動画グリッド
   ============================================ */
.video-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}

@media (min-width: 500px)  { .video-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 768px)  { .video-grid { grid-template-columns: repeat(4, 1fr); } }

/* ============================================
   動画カード
   ============================================ */
.video-card {
    background: var(--card);
    border: 1px solid var(--b1);
    border-radius: var(--r2);
    overflow: hidden;
    transition: border-color var(--t-base), transform var(--t-base), box-shadow var(--t-base);
    position: relative;
    will-change: transform;
}

.video-card:hover {
    border-color: rgba(184,16,32,0.5);
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.4), 0 0 0 1px rgba(184,16,32,0.15);
    background: var(--card-hover);
}

/* サムネイル */
.card-thumb {
    position: relative;
    aspect-ratio: 16/11;
    overflow: hidden;
    background: var(--bg3);
}

.card-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.35s ease;
}

.video-card:hover .card-thumb img { transform: scale(1.06); }

/* グラデーションオーバーレイ */
.card-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to bottom,
        rgba(0,0,0,0) 40%,
        rgba(0,0,0,0.7) 100%
    );
    pointer-events: none;
}

/* 上部バッジ群 */
.card-badges-top {
    position: absolute;
    top: 6px;
    left: 6px;
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}

.badge {
    font-size: 9px;
    font-weight: 800;
    padding: 2px 6px;
    border-radius: 3px;
    letter-spacing: 0.3px;
    font-family: var(--font);
}

.badge-ai     { background: rgba(124,58,237,0.9); color: #fff; backdrop-filter: blur(4px); }
.badge-new    { background: rgba(232,0,45,0.9); color: #fff; backdrop-filter: blur(4px); }
.badge-hot    { background: rgba(255,107,53,0.9); color: #fff; backdrop-filter: blur(4px); }
.badge-ranked { background: rgba(245,166,35,0.9); color: #000; backdrop-filter: blur(4px); }

/* NEWバッジ（動画カード左上・独立型） */
.card-badge-new {
    position: absolute;
    top: 6px;
    left: 6px;
    font-size: 9px;
    font-weight: 800;
    padding: 2px 7px;
    border-radius: 3px;
    letter-spacing: 0.5px;
    background: rgba(232,0,45,0.92);
    color: #fff;
    backdrop-filter: blur(4px);
    z-index: 5;
    font-family: var(--font-inter);
    line-height: 1.6;
}

/* いいねボタン（右上） */
.card-like-btn {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 28px;
    height: 28px;
    background: rgba(0,0,0,0.5);
    backdrop-filter: blur(4px);
    border: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: var(--t-base);
    opacity: 0;
    color: rgba(255,255,255,0.7);
}

.video-card:hover .card-like-btn { opacity: 1; }
.card-like-btn:hover { background: rgba(232,0,45,0.8); color: #fff; transform: scale(1.1); }
.card-like-btn.liked { opacity: 1; background: rgba(232,0,45,0.85); color: #fff; }
.card-like-btn.liked svg { fill: currentColor; }

/* お気に入りボタン（右上・いいねの隣） */
.card-save-btn {
    position: absolute;
    top: 6px;
    right: 40px;
    width: 28px;
    height: 28px;
    background: rgba(0,0,0,0.5);
    backdrop-filter: blur(4px);
    border: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: var(--t-base);
    opacity: 0;
    color: rgba(255,255,255,0.7);
}

.video-card:hover .card-save-btn { opacity: 1; }
.card-save-btn:hover { background: rgba(245,166,35,0.8); color: #fff; transform: scale(1.1); }
.card-save-btn.saved { opacity: 1; background: rgba(245,166,35,0.85); color: #fff; }
.card-save-btn.saved svg { fill: currentColor; }

/* 女優名（下部） */
.actress-badge {
    position: absolute;
    bottom: 5px;
    left: 7px;
    right: 7px;
    font-size: 11px;
    font-weight: 700;
    color: #fff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-shadow: 0 1px 3px rgba(0,0,0,0.8);
    display: flex;
    align-items: center;
    gap: 4px;
}

.actress-badge svg { flex-shrink: 0; color: var(--red); }

.actress-badge.unknown {
    color: rgba(255,255,255,0.5);
    cursor: pointer;
    font-weight: 500;
    font-size: 10px;
}

.actress-badge.unknown:hover { color: var(--red); }

/* カード情報 */
.card-info { padding: 10px; }

.card-title {
    font-size: 12px;
    font-weight: 500;
    line-height: 1.5;
    color: var(--t1);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 8px;
    min-height: 36px;
    transition: var(--t-base);
}

.card-title:hover { color: var(--red); }

/* AIスコアバー */
.card-ai-score {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 7px;
}

.ai-score-label {
    font-size: 9px;
    font-weight: 700;
    color: var(--purple-soft);
    white-space: nowrap;
}

.ai-score-bar {
    flex: 1;
    height: 3px;
    background: var(--b1);
    border-radius: 2px;
    overflow: hidden;
}

.ai-score-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--purple), var(--purple-soft));
    border-radius: 2px;
    transition: width 0.6s ease;
}

.ai-score-num {
    font-size: 9px;
    font-weight: 700;
    color: var(--purple-soft);
    white-space: nowrap;
}

/* カードフッター */
.card-footer {
    display: flex;
    align-items: center;
    gap: 6px;
}

.card-actress-link {
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
    font-weight: 600;
    color: var(--red);
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    transition: var(--t-base);
}

.card-actress-link:hover { opacity: 0.8; }
.card-actress-link.none { color: var(--t3); font-weight: 400; }

.fanza-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 10px;
    font-weight: 700;
    color: #fff;
    background: var(--fanza);
    padding: 4px 9px;
    border-radius: var(--r1);
    white-space: nowrap;
    border: none;
    flex-shrink: 0;
    transition: var(--t-base);
    font-family: var(--font);
    box-shadow: 0 2px 8px rgba(200,0,31,0.3);
}

.fanza-btn:hover { background: var(--fanza-dark); transform: translateY(-1px); }

/* 特定ボタン */
.identify-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    background: var(--glass);
    border: 1px dashed rgba(232,0,45,0.3);
    border-radius: var(--r2);
    padding: 6px;
    font-size: 11px;
    font-weight: 500;
    color: var(--t3);
    margin-top: 7px;
    transition: var(--t-base);
    gap: 5px;
    font-family: var(--font);
}

.identify-btn:hover {
    border-color: var(--red);
    color: var(--red);
    background: var(--red-subtle);
}

/* ============================================
   AIレビュー要約エリア（個別カード内）
   ============================================ */
.card-ai-review {
    margin-top: 8px;
    padding: 8px 10px;
    background: rgba(124,58,237,0.06);
    border: 1px solid rgba(124,58,237,0.15);
    border-radius: var(--r2);
    display: none; /* 個別ページで表示 */
}

.card-ai-review-header {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 9px;
    font-weight: 700;
    color: var(--purple-soft);
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.card-ai-review-text {
    font-size: 11px;
    color: var(--t2);
    line-height: 1.6;
}

/* ============================================
   女優特定モーダル
   ============================================ */
.modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.75);
    backdrop-filter: blur(6px);
    z-index: 2000;
    align-items: center;
    justify-content: center;
    padding: 16px;
}

.modal-overlay.active { display: flex; }

.modal-box {
    background: var(--bg3);
    border: 1px solid var(--b2);
    border-radius: var(--r4);
    width: 100%;
    max-width: 460px;
    max-height: 85vh;
    overflow-y: auto;
    box-shadow: var(--s3);
}

.modal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 20px;
    border-bottom: 1px solid var(--b1);
}

.modal-title-wrap { display: flex; align-items: center; gap: 10px; }

.modal-title-icon {
    width: 32px;
    height: 32px;
    background: var(--red-subtle);
    border: 1px solid rgba(232,0,45,0.25);
    border-radius: var(--r2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    flex-shrink: 0;
}

.modal-title { font-size: 15px; font-weight: 700; color: var(--t1); }

.modal-close-x {
    background: var(--glass);
    border: 1px solid var(--b1);
    border-radius: 50%;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--t3);
    transition: var(--t-base);
    flex-shrink: 0;
}

.modal-close-x:hover { color: var(--t1); border-color: var(--b3); }

.modal-body { padding: 18px 20px; }

.modal-hint {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: rgba(124,58,237,0.08);
    border: 1px solid rgba(124,58,237,0.2);
    border-radius: var(--r2);
    padding: 10px 12px;
    margin-bottom: 14px;
}

.modal-hint svg { color: var(--purple-soft); flex-shrink: 0; margin-top: 1px; }
.modal-hint p { font-size: 12px; color: var(--t2); line-height: 1.6; }

.modal-search-wrap {
    position: relative;
    margin-bottom: 12px;
}

.modal-search-wrap svg {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--t3);
    pointer-events: none;
}

.modal-search-wrap input {
    width: 100%;
    background: var(--bg2);
    border: 1px solid var(--b2);
    border-radius: var(--r2);
    padding: 10px 12px 10px 38px;
    font-size: 14px;
    font-family: var(--font);
    color: var(--t1);
    outline: none;
    transition: var(--t-base);
}

.modal-search-wrap input:focus {
    border-color: var(--red);
    box-shadow: 0 0 0 3px var(--red-glow);
}

.modal-search-wrap input::placeholder { color: var(--t3); }

.actress-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-height: 280px;
    overflow-y: auto;
}

.actress-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--glass);
    border: 1px solid var(--b1);
    border-radius: var(--r2);
    cursor: pointer;
    transition: var(--t-base);
}

.actress-item:hover { border-color: rgba(232,0,45,0.4); background: var(--red-subtle); }

.actress-thumb {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    object-fit: cover;
    background: var(--bg2);
    flex-shrink: 0;
    border: 1px solid var(--b2);
}

.actress-info { flex: 1; min-width: 0; }
.actress-name { font-size: 13px; font-weight: 700; color: var(--t1); }
.actress-meta { font-size: 10px; color: var(--t3); margin-top: 1px; }

.vote-btn {
    background: var(--red);
    color: #fff;
    border: none;
    border-radius: var(--r2);
    padding: 6px 14px;
    font-size: 12px;
    font-weight: 700;
    font-family: var(--font);
    flex-shrink: 0;
    transition: var(--t-base);
    display: flex;
    align-items: center;
    gap: 4px;
}

.vote-btn:hover { background: var(--red-dark); }

.modal-close-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    margin-top: 12px;
    padding: 10px;
    background: var(--glass);
    border: 1px solid var(--b1);
    border-radius: var(--r2);
    color: var(--t2);
    font-size: 13px;
    font-family: var(--font);
    transition: var(--t-base);
    cursor: pointer;
}

.modal-close-btn:hover { border-color: var(--b3); color: var(--t1); }

/* ============================================
   サイドバー
   ============================================ */
#sidebar {
    display: flex;
    flex-direction: column;
    gap: 14px;
    position: sticky;
    top: calc(var(--h-main) + var(--h-gnav) + 20px);
    min-width: 0;
    overflow: hidden;
}

@media (max-width: 600px) {
#sidebar {
margin: 30px 0 0 0;
}
}

.sw {
    background: var(--card);
    border: 1px solid var(--b1);
    border-radius: var(--r3);
    overflow: hidden;
    max-width: 100%;
    width: 100%;
}

.sw-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    border-bottom: 1px solid var(--b1);
    background: var(--glass);
}

.sw-title {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 13px;
    font-weight: 700;
    color: var(--t1);
}

.sw-icon {
    width: 22px;
    height: 22px;
    background: var(--red-subtle);
    border: 1px solid rgba(232,0,45,0.2);
    border-radius: var(--r1);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    flex-shrink: 0;
}

.sw-more { font-size: 11px; color: var(--t3); transition: var(--t-base); }
.sw-more:hover { color: var(--t1); }

/* ランキング */
.rank-list { padding: 6px 0; }

.rank-item {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 8px 10px;
    transition: var(--t-base);
    cursor: pointer;
    border-radius: var(--r2);
    margin: 0 4px 6px;
    background: var(--card);
    border: 1px solid var(--b1);
    overflow: hidden;
}

.rank-item:hover { border-color: rgba(184,16,32,0.35); background: var(--card-hover); }

.rank-num {
    display: none; /* 三角バッジに移行したため非表示 */
}

/* ランキング三角バッジ（左上コーナー） */
.rank-corner {
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    z-index: 10;
}
.rank-corner span {
    position: absolute;
    top: -20px;
    left: 2px;
    color: #fff;
    font-size: 11px !important;
    font-weight: 800 !important;
    font-family: var(--font-inter) !important;
    letter-spacing: -0.5px;
    line-height: 1;
    text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}
.rank-corner.r1 { border-top: 22px solid #d4920a; border-right: 22px solid transparent; }
.rank-corner.r2 { border-top: 22px solid #8090a8; border-right: 22px solid transparent; }
.rank-corner.r3 { border-top: 22px solid #96622e; border-right: 22px solid transparent; }
.rank-corner.r4 { border-top: 22px solid rgba(70,82,104,0.9); border-right: 22px solid transparent; }

.rank-thumb {
    width: 100%;
    height: auto;
    aspect-ratio: 16/11;
    object-fit: cover;
    border-radius: var(--r1);
    flex-shrink: 0;
    background: var(--bg3);
    display: block;
}

/* サムネなしのプレースホルダー */
div.rank-thumb {
    width: 100%;
    aspect-ratio: 16/11;
    border-radius: var(--r1);
}

.rank-info {
    padding: 7px 2px 2px;
    min-width: 0;
}

.rank-title {
    font-size: 12px;
    line-height: 1.45;
    color: var(--t1);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-weight: 500;
    transition: var(--t-base);
    word-break: break-all;
    overflow-wrap: break-word;
}

.rank-title:hover { color: var(--red); }

.rank-actress {
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: 10px;
    color: var(--red);
    margin-top: 4px;
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* タグクラウド */
.tag-cloud {
    padding: 10px 12px;
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.tag-item {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
    font-weight: 400;
    padding: 4px 10px;
    border-radius: var(--r-full);
    border: 1px solid var(--b1);
    color: var(--t2);
    background: var(--glass);
    transition: var(--t-base);
    white-space: nowrap;
}

.tag-item:hover {
    background: var(--red-subtle);
    border-color: rgba(232,0,45,0.3);
    color: var(--red);
}

/* ============================================
   ページネーション
   ============================================ */
.pagination {
    display: flex;
    justify-content: center;
    gap: 5px;
    margin-top: 28px;
    flex-wrap: wrap;
}

.page-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 8px;
    background: var(--card);
    border: 1px solid var(--b1);
    border-radius: var(--r2);
    font-size: 13px;
    font-weight: 500;
    color: var(--t2);
    transition: var(--t-base);
}

.page-btn:hover { border-color: var(--red); color: var(--red); }
.page-btn.active { background: var(--red); border-color: var(--red); color: #fff; font-weight: 700; }

/* ============================================
   フッター
   ============================================ */
/* ============================================
   ソートバー（プルダウン）
   ============================================ */
.sort-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.sort-label {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    font-weight: 600;
    color: var(--t3);
    white-space: nowrap;
    letter-spacing: 0.3px;
}

.sort-select-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.sort-select-wrap svg {
    position: absolute;
    right: 9px;
    pointer-events: none;
    color: var(--t3);
}

.sort-select {
    appearance: none;
    -webkit-appearance: none;
    background: var(--bg3);
    border: 1px solid var(--b2);
    border-radius: var(--r-full);
    color: var(--t1);
    font-size: 12px;
    font-weight: 600;
    font-family: var(--font);
    padding: 6px 28px 6px 14px;
    cursor: pointer;
    transition: var(--t-base);
    outline: none;
    min-width: 100px;
}
.sort-select:hover { border-color: var(--b3); background: var(--bg4); }
.sort-select:focus { border-color: rgba(184,16,32,0.5); box-shadow: 0 0 0 2px var(--red-glow); }
.sort-select option { background: var(--bg3); color: var(--t1); font-weight: 500; }

/* ============================================
   アーカイブヘッダー
   ============================================ */
.archive-header {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 20px;
    padding-bottom: 18px;
    border-bottom: 1px solid var(--b1);
}

.archive-icon {
    width: 44px;
    height: 44px;
    background: var(--red-subtle);
    border: 1px solid rgba(184,16,32,0.25);
    border-radius: var(--r3);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    flex-shrink: 0;
}

.archive-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--t1);
    margin-bottom: 3px;
}

.archive-count {
    font-size: 13px;
    color: var(--t3);
}

/* ============================================
   フッター（充実版）
   ============================================ */
#site-footer {
    background: var(--bg2);
    border-top: 1px solid var(--b1);
    margin-top: 60px;
}

.footer-inner {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 0 20px;
}

.footer-top {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    padding: 32px 0 24px;
    border-bottom: 1px solid var(--b1);
}

@media (min-width: 640px) {
    .footer-top { grid-template-columns: 1.5fr repeat(3, 1fr); gap: 32px; padding: 40px 0 32px; }
}

/* スマホでfooter-brandを全幅に */
@media (max-width: 639px) {
    .footer-brand { grid-column: 1 / -1; }
}

.footer-brand {}

.footer-logo-link { display: inline-block; margin-bottom: 14px; }
.footer-logo-img { height: 24px; width: auto; opacity: 0.8; }

.footer-tagline {
    font-size: 12px;
    color: var(--t3);
    line-height: 1.7;
    margin-bottom: 14px;
}

.footer-badges { display: none; }

.footer-links-col {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.footer-link-title {
    font-size: 11px;
    font-weight: 700;
    color: var(--t2);
    text-transform: uppercase;
    letter-spacing: 0.8px;
    margin-bottom: 4px;
}

.footer-links-col a {
    font-size: 13px;
    color: var(--t3);
    transition: var(--t-base);
}
.footer-links-col a:hover { color: var(--t1); }

.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px;
    padding: 16px 0;
}

.footer-notice {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 10px;
    color: var(--t4);
}

.footer-copy {
    font-size: 10px;
    color: var(--t4);
    font-family: var(--font-inter);
}


/* ============================================
   ランキングTOP3：PC/スマホ完全書き分け
   ============================================ */

/* 共通：グリッドコンテナ */
.ranking-top3 {
    display: grid;
    gap: 8px;
    margin-bottom: 24px;
    width: 100%;
}

/* ===== スマホ（〜599px）：横並びリスト形式 ===== */
.ranking-top3-item {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--card);
    border: 1px solid var(--b1);
    border-radius: var(--r2);
    overflow: hidden;
    text-decoration: none;
    transition: var(--t-base);
    padding: 0;
}
.ranking-top3-item:hover { border-color: rgba(232,0,45,.4); }

.ranking-top3-thumb {
    position: relative;
    flex-shrink: 0;
    width: 120px;
    height: 80px;
    overflow: hidden;
}
.ranking-top3-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.ranking-top3-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(transparent 40%, rgba(0,0,0,.5) 100%);
}
.ranking-top3-actress {
    position: absolute;
    bottom: 4px;
    left: 4px;
    font-size: 9px;
    font-weight: 700;
    color: #fff;
    background: rgba(232,0,45,.85);
    padding: 1px 6px;
    border-radius: 999px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: calc(100% - 8px);
}
.ranking-top3-info {
    flex: 1;
    min-width: 0;
    padding: 8px 10px 8px 0;
}
.ranking-top3-title {
    font-size: 12px;
    font-weight: 500;
    color: var(--t1);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.45;
    margin-bottom: 6px;
    word-break: break-all;
}
.ranking-top3-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 10px;
    color: var(--t3);
    font-family: var(--font-inter);
}
.ranking-top3-rank-label {
    font-weight: 800;
    font-size: 11px;
}

/* ===== PC（600px〜）：3列カード形式 ===== */
@media (min-width: 600px) {
    .ranking-top3 {
        grid-template-columns: repeat(3, 1fr);
        gap: 12px;
    }
    .ranking-top3-item {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
    }
    .ranking-top3-thumb {
        width: 100%;
        height: 0;
        padding-bottom: 68.75%; /* 16:11 */
        position: relative;
    }
    .ranking-top3-thumb img {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .ranking-top3-overlay {
        position: absolute;
        inset: 0;
    }
    .ranking-top3-info {
        padding: 8px 10px;
    }
    .ranking-top3-title {
        font-size: 13px;
        min-height: 38px;
    }
}
/* ============================================
   広告バナー・サイドバーフッター
   ============================================ */
/* 審査中のため広告枠を非表示 */
.ad-banner-wrap {
    width: 100%;
    background: var(--card);
    border: 1px dashed rgba(255, 255, 255, 0.1);
    border-radius: var(--r3);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    transition: var(--t-base);
    padding: 8px;
    box-sizing: border-box;
}
#top-ad {
    min-height: 90px;
    margin-bottom: 24px;
}
#sidebar-ad {
    min-height: 250px;
    margin-bottom: 14px;
}
.sw-footer {
    padding: 8px 10px 10px;
    border-top: 1px solid var(--b1);
}
.sw-more-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    padding: 9px 12px;
    background: var(--glass);
    border: 1px solid var(--b2);
    border-radius: var(--r2);
    font-size: 12px;
    font-weight: 600;
    color: var(--t2);
    transition: var(--t-base);
    text-decoration: none;
}
.sw-more-btn:hover {
    background: var(--card-hover);
    color: var(--t1);
    border-color: var(--b1);
}

/* ============================================
   FANZA特集セクション
   ============================================ */
.fanza-feature-section {
    margin-bottom: 32px;
    background: linear-gradient(135deg, rgba(232,0,45,.06), rgba(245,166,35,.04));
    border: 1px solid rgba(232,0,45,.2);
    border-radius: var(--r3);
    padding: 16px;
}
.fanza-feature-hd {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(232,0,45,.15);
}
.fanza-feature-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 15px;
    font-weight: 800;
    color: var(--red);
}
.fanza-feature-title svg { flex-shrink: 0; }
.fanza-feature-more {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--t3);
    text-decoration: none;
    transition: var(--t-base);
}
.fanza-feature-more:hover { color: var(--red); }
.fanza-feature-badge {
    position: absolute;
    top: 6px;
    right: 6px;
    background: var(--red);
    color: #fff;
    font-size: 9px;
    font-weight: 800;
    padding: 2px 6px;
    border-radius: 4px;
    letter-spacing: 0.5px;
}

/* ============================================
   サイドバー：人気女優・注目の女優
   ============================================ */
.sw-actress-list {
    padding: 10px 10px 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.sw-actress-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 8px;
    border-radius: var(--r2);
    transition: var(--t-base);
    text-decoration: none;
}
.sw-actress-item:hover { background: var(--glass); }

.sw-actress-avatar {
    position: relative;
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: var(--bg3);
    border: 2px solid var(--b2);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.sw-actress-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
    display: block;
}
.sw-actress-initial {
    font-size: 14px;
    font-weight: 700;
    color: var(--t2);
}
.sw-actress-rank {
    position: absolute;
    top: -4px;
    right: -4px;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    font-size: 9px;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-family: var(--font-inter);
    border: 1px solid var(--bg1);
}
.sw-actress-rank.r1 { background: #d4900a; }
.sw-actress-rank.r2 { background: #808090; }
.sw-actress-rank.r3 { background: #8a5028; }
.sw-actress-rank.r4,
.sw-actress-rank.r5,
.sw-actress-rank.r6,
.sw-actress-rank.r7,
.sw-actress-rank.r8,
.sw-actress-rank.r9,
.sw-actress-rank.r10 { background: var(--bg3); color: var(--t3); }

.sw-actress-meta {
    flex: 1;
    min-width: 0;
}
.sw-actress-name {
    font-size: 12px;
    font-weight: 600;
    color: var(--t1);
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sw-actress-count {
    font-size: 10px;
    color: var(--t3);
    font-family: var(--font-inter);
}

/* ============================================
   TOPページ：注目の女優チップ修正
   ============================================ */
.featured-actress-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 4px 0 8px;
}
.featured-actress-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--card);
    border: 1px solid var(--b1);
    border-radius: var(--r-full);
    padding: 5px 12px 5px 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--t1);
    transition: var(--t-base);
    text-decoration: none;
}
.featured-actress-chip:hover { border-color: rgba(232,0,45,.3); color: var(--red); }
.featured-actress-chip-avatar {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--bg3);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    font-weight: 700;
    color: var(--t2);
    flex-shrink: 0;
    overflow: hidden;
}
.featured-actress-chip-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

/* ============================================
   FANZAバッジ：スマホでサムネに被らないよう調整
   ============================================ */
.fanza-feature-badge {
    position: absolute;
    top: 6px;
    right: 6px;
    background: var(--red);
    color: #fff;
    font-size: 9px;
    font-weight: 800;
    padding: 2px 6px;
    border-radius: 4px;
    letter-spacing: 0.5px;
    z-index: 3;
    pointer-events: none;
}
/* スマホではバッジを小さく */
@media (max-width: 599px) {
    .fanza-feature-badge {
        font-size: 8px;
        padding: 1px 4px;
        top: 4px;
        right: 4px;
    }
    /* カードのFANZAボタンはサムネ外に */
    .video-card .fanza-btn {
        position: static;
    }
}

/* ============================================
   動画ページ：RSS由来プレイヤー風サムネ（16:9）
   FANZA由来は iframe なのでこれとは別（影響しない）
   ============================================ */
.single-thumb-wrap {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #000;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
    cursor: pointer;
    isolation: isolate;
}

.single-thumb-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain;      /* 画像全体を表示（上下が切れない） */
    object-position: center;
    display: block;
    transition: transform 0.6s cubic-bezier(.22, .61, .36, 1), filter 0.3s ease;
}

/* ホバー時の背景ズーム */
.single-thumb-wrap:hover .single-thumb-img {
    transform: scale(1.06);
    filter: brightness(0.7);
}

/* 暗幕オーバーレイ（グラデーションで下部にタイトルが置ける余地を残す） */
.single-thumb-wrap::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0) 0%,
        rgba(0, 0, 0, 0.15) 40%,
        rgba(0, 0, 0, 0.55) 100%
    );
    pointer-events: none;
    z-index: 1;
    transition: opacity 0.3s ease;
}

.single-thumb-wrap:hover::before {
    opacity: 0.7;
}

/* 再生ボタンのラッパー */
.play-btn-wrap {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    z-index: 2;
}

/* 再生ボタン本体 */
.play-btn-circle {
    width: 86px;
    height: 86px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.95);
    color: #e8002d;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow:
        0 0 0 12px rgba(255, 255, 255, 0.15),
        0 10px 40px rgba(0, 0, 0, 0.5);
    transition:
        transform 0.3s cubic-bezier(.22, .61, .36, 1),
        background 0.3s ease,
        box-shadow 0.3s ease;
    backdrop-filter: blur(6px);
}

.play-btn-circle svg {
    width: 36px;
    height: 36px;
    margin-left: 4px; /* 三角形の視覚的中央補正 */
    transition: transform 0.3s ease;
}

/* ホバー時の再生ボタン：大きく・赤く */
.single-thumb-wrap:hover .play-btn-circle {
    transform: scale(1.12);
    background: #e8002d;
    color: #fff;
    box-shadow:
        0 0 0 18px rgba(232, 0, 45, 0.2),
        0 12px 48px rgba(232, 0, 45, 0.4);
}

.single-thumb-wrap:hover .play-btn-circle svg {
    transform: scale(1.05);
}

/* アクティブ（クリック時）のフィードバック */
.single-thumb-wrap:active .play-btn-circle {
    transform: scale(1.02);
}

/* 右下に「再生」ラベル（プレイヤー感の演出） */
.single-thumb-wrap::after {
    content: '▶ 動画を見る';
    position: absolute;
    right: 12px;
    bottom: 12px;
    background: rgba(0, 0, 0, 0.75);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 5px 10px;
    border-radius: 4px;
    z-index: 2;
    letter-spacing: 0.02em;
    opacity: 0.9;
    transition: opacity 0.3s ease, background 0.3s ease;
    pointer-events: none;
}

.single-thumb-wrap:hover::after {
    opacity: 1;
    background: rgba(232, 0, 45, 0.95);
}

/* リンク先が無い時は「▶動画を見る」疑似要素を非表示 */
.single-thumb-wrap.no-click {
    cursor: default;
}
.single-thumb-wrap.no-click::after {
    display: none;
}
.single-thumb-wrap.no-click::before {
    display: none;
}
.single-thumb-wrap.no-click:hover .single-thumb-img {
    transform: none;
    filter: none;
}

/* モバイル調整 */
@media (max-width: 767px) {
    .single-thumb-wrap {
        border-radius: 8px;
    }
    .play-btn-circle {
        width: 68px;
        height: 68px;
        box-shadow:
            0 0 0 8px rgba(255, 255, 255, 0.15),
            0 8px 24px rgba(0, 0, 0, 0.5);
    }
    .play-btn-circle svg {
        width: 28px;
        height: 28px;
    }
    .single-thumb-wrap::after {
        font-size: 10px;
        padding: 4px 8px;
        right: 8px;
        bottom: 8px;
    }
}

/* ============================================
   注目の女優チップ（TOPページ）
   ============================================ */
.actress-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 4px 0 8px;
}
.actress-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--card);
    border: 1px solid var(--b1);
    border-radius: var(--r-full);
    padding: 4px 14px 4px 4px;
    font-size: 12px;
    font-weight: 600;
    color: var(--t1);
    transition: var(--t-base);
    text-decoration: none;
}
.actress-chip:hover { border-color: rgba(232,0,45,.3); color: var(--red); }
.actress-chip-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--bg3);
    border: 2px solid var(--b2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 700;
    color: var(--t2);
    flex-shrink: 0;
    overflow: hidden;
}
.actress-chip-name {
    font-size: 12px;
    font-weight: 600;
    color: inherit;
}
.actress-chip-count {
    font-size: 10px;
    color: var(--t3);
    font-family: var(--font-inter);
}

/* AI推薦セクション */
#ai-sections-wrap {
    margin-bottom: 28px;
}
.ai-dyn-section {
    margin-bottom: 28px;
}

/* ============================================
   固定ページ共通スタイル
   ============================================ */
.page-article {
    background: var(--card);
    border: 1px solid var(--b1);
    border-radius: var(--r3);
    padding: 28px 24px;
    margin-bottom: 24px;
}
.page-title {
    font-size: 22px;
    font-weight: 700;
    color: var(--t1);
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--b1);
}
.page-content {
    font-size: 14px;
    line-height: 1.9;
    color: var(--t2);
}
.page-content h2 {
    font-size: 17px;
    font-weight: 700;
    color: var(--t1);
    margin: 24px 0 12px;
    padding-left: 10px;
    border-left: 3px solid var(--red);
}
.page-content p { margin-bottom: 14px; }
.page-content a { color: var(--red); text-decoration: underline; }
.page-content ul { padding-left: 20px; margin-bottom: 14px; }
.page-content li { margin-bottom: 8px; }
.page-content strong { color: var(--t1); font-weight: 700; }

/* info-card */
.info-card {
    border-radius: var(--r3);
    padding: 20px 24px;
    margin-bottom: 32px;
    margin-top: 8px;
}
.info-card--red {
    background: linear-gradient(135deg, rgba(232,0,45,.08), rgba(245,166,35,.04));
    border: 1px solid rgba(232,0,45,.2);
}
.info-card--purple {
    background: linear-gradient(135deg, rgba(109,40,217,.08), rgba(59,130,246,.04));
    border: 1px solid rgba(109,40,217,.2);
}
.info-card-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--t1);
    margin-bottom: 10px;
}
.info-card-body {
    font-size: 13px;
    color: var(--t2);
    line-height: 1.8;
    margin: 0;
}

/* conditions-box */
.conditions-box {
    background: var(--card);
    border: 1px solid var(--b1);
    border-radius: var(--r3);
    padding: 18px 20px;
    margin-bottom: 28px;
}
.conditions-title {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 13px;
    font-weight: 700;
    color: var(--t1);
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--b1);
}
.conditions-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.conditions-list li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 13px;
    color: var(--t2);
    line-height: 1.6;
    padding-left: 4px;
}
.conditions-list li::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--purple-soft);
    flex-shrink: 0;
    margin-top: 7px;
}

/* CF7フォームラップ */
.cf7-wrap {
    background: var(--card);
    border: 1px solid var(--b1);
    border-radius: var(--r3);
    padding: 24px;
}

/* ============================================
   Contact Form 7 スタイル統一
   ============================================ */
.cf7-wrap .wpcf7 { width: 100%; }
.cf7-wrap .wpcf7-form { display: flex; flex-direction: column; gap: 16px; }

.cf7-wrap .wpcf7-form p {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.cf7-wrap .wpcf7-form label {
    font-size: 13px;
    font-weight: 600;
    color: var(--t2);
}
.cf7-wrap .wpcf7-form input[type="text"],
.cf7-wrap .wpcf7-form input[type="email"],
.cf7-wrap .wpcf7-form input[type="tel"],
.cf7-wrap .wpcf7-form input[type="url"],
.cf7-wrap .wpcf7-form select,
.cf7-wrap .wpcf7-form textarea {
    width: 100%;
    background: var(--bg2);
    border: 1px solid var(--b2);
    border-radius: var(--r2);
    color: var(--t1);
    font-size: 13px;
    font-family: var(--font);
    padding: 10px 14px;
    transition: var(--t-base);
    box-sizing: border-box;
    outline: none;
    appearance: auto;
}
.cf7-wrap .wpcf7-form input:focus,
.cf7-wrap .wpcf7-form select:focus,
.cf7-wrap .wpcf7-form textarea:focus {
    border-color: var(--red);
    background: var(--bg3);
}
.cf7-wrap .wpcf7-form textarea {
    min-height: 140px;
    resize: vertical;
    line-height: 1.7;
}
.cf7-wrap .wpcf7-form select {
    cursor: pointer;
}
.cf7-wrap .wpcf7-form input[type="submit"],
.cf7-wrap .wpcf7-form .wpcf7-submit {
    width: auto;
    background: var(--red);
    color: #fff;
    border: none;
    border-radius: var(--r2);
    padding: 12px 32px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: var(--t-base);
    font-family: var(--font);
    align-self: flex-start;
}
.cf7-wrap .wpcf7-form input[type="submit"]:hover {
    background: var(--red-dark);
    transform: translateY(-1px);
}
.cf7-wrap .wpcf7-not-valid-tip {
    font-size: 11px;
    color: var(--red);
    margin-top: 4px;
}
.cf7-wrap .wpcf7-response-output {
    font-size: 13px;
    padding: 10px 14px;
    border-radius: var(--r2);
    margin-top: 8px;
    border: 1px solid var(--b1);
}

/* ============================================
   推しメーター
   ============================================ */
.heat-meter-wrap {
    margin-top: 16px;
    background: var(--glass);
    border: 1px solid var(--b1);
    border-radius: var(--r2);
    padding: 12px 14px;
    /* PCで横幅を制限 */
    max-width: 400px;
}
.heat-meter-title {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 700;
    color: var(--t2);
    margin-bottom: 10px;
    letter-spacing: 0.3px;
}
.heat-meter-chart {
    display: flex;
    align-items: flex-end;
    gap: 4px;
    height: 70px;
}
.heat-bar-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    height: 100%;
    max-width: 48px;
}
.heat-bar-track {
    flex: 1;
    width: 100%;
    background: rgba(255,255,255,.08);
    border-radius: 4px;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
}
.heat-bar-fill {
    width: 100%;
    background: linear-gradient(to top, #e8002d, #ff6b6b);
    border-radius: 4px;
    min-height: 2px;
    transition: height 0.6s ease;
    box-shadow: 0 0 6px rgba(232,0,45,.4);
}
.heat-bar-label {
    font-size: 9px;
    color: var(--t3);
    font-family: var(--font-inter);
    white-space: nowrap;
}

/* ============================================
   ムードベース検索
   ============================================ */
.mood-quick-wrap {
    background: var(--card);
    border: 1px solid var(--b1);
    border-radius: var(--r3);
    padding: 16px;
    margin-bottom: 16px;
}
.mood-quick-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--t3);
    margin-bottom: 10px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.mood-quick-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.mood-quick-btn {
    background: var(--glass);
    border: 1px solid var(--b2);
    border-radius: var(--r-full);
    color: var(--t1);
    font-size: 13px;
    font-weight: 600;
    padding: 8px 16px;
    cursor: pointer;
    transition: var(--t-base);
    font-family: var(--font);
}
.mood-quick-btn:hover {
    background: var(--red-subtle);
    border-color: rgba(232,0,45,.3);
    color: var(--red);
}
.mood-selector-wrap {
    background: var(--card);
    border: 1px solid var(--b1);
    border-radius: var(--r3);
    padding: 16px;
    margin-bottom: 16px;
}
.mood-selector-title {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 700;
    color: var(--t3);
    margin-bottom: 12px;
}
.mood-tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.mood-tag-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: var(--glass);
    border: 1px solid var(--b1);
    border-radius: var(--r-full);
    color: var(--t2);
    font-size: 12px;
    padding: 5px 12px;
    cursor: pointer;
    transition: var(--t-base);
    font-family: var(--font);
}
.mood-tag-btn:hover { border-color: rgba(232,0,45,.3); color: var(--red); }
.mood-tag-btn.active {
    background: var(--red-subtle);
    border-color: var(--red);
    color: var(--red);
    font-weight: 700;
}
.mood-tag-count {
    font-size: 10px;
    color: var(--t4);
    font-family: var(--font-inter);
}
.mood-search-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    background: var(--card);
    border: 1px solid rgba(232,0,45,.2);
    border-radius: var(--r3);
    padding: 14px 16px;
    margin-bottom: 16px;
    position: sticky;
    bottom: 16px;
    z-index: 10;
    box-shadow: var(--s3);
}
.mood-selected-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    flex: 1;
}
.mood-selected-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--red-subtle);
    border: 1px solid rgba(232,0,45,.3);
    color: var(--red);
    font-size: 12px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: var(--r-full);
}
.mood-selected-chip button {
    background: none;
    border: none;
    color: var(--red);
    cursor: pointer;
    font-size: 14px;
    padding: 0;
    line-height: 1;
    font-family: var(--font);
}
.mood-search-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--red);
    color: #fff;
    border: none;
    border-radius: var(--r2);
    padding: 10px 20px;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    transition: var(--t-base);
    font-family: var(--font);
    white-space: nowrap;
}
.mood-search-btn:hover { background: var(--red-dark); }
.mood-reset-btn {
    background: none;
    border: 1px solid var(--b2);
    border-radius: var(--r2);
    color: var(--t3);
    font-size: 12px;
    padding: 10px 16px;
    cursor: pointer;
    font-family: var(--font);
    transition: var(--t-base);
}
.mood-reset-btn:hover { color: var(--t1); border-color: var(--b3); }

/* AI推薦バッジ・アイコン */
.ai-sec-badge {
    display: inline-flex;
    align-items: center;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.5px;
    padding: 2px 7px;
    border-radius: var(--r-full);
    background: linear-gradient(90deg, var(--purple), var(--purple-soft));
    color: #fff;
    margin-left: 8px;
    font-family: var(--font-inter);
    text-transform: uppercase;
    vertical-align: middle;
}
.section-icon.ai-icon {
    background: linear-gradient(135deg, rgba(109, 40, 217, 0.25), rgba(139, 92, 246, 0.15));
    border-color: rgba(109, 40, 217, 0.3);
    color: var(--purple-soft);
}
/* ============================================
   他の作品グリッド
   PC: 5列×1行（6件目を非表示にして5件表示）
   スマホ: 3列×2行（6件すべて表示）
   ============================================ */
.other-works-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 8px;
    margin-bottom: 4px;
}
@media (min-width: 768px) {
    .other-works-grid {
        grid-template-columns: repeat(5, 1fr) !important;
        gap: 10px;
    }
    /* PC時は6件目を非表示（5列1行にピッタリ収める） */
    .other-works-grid > *:nth-child(6) {
        display: none !important;
    }
}

/* ============================================
   広告3カラム（動画ページ・おすすめセクション下）
   ============================================ */
.ad-row-3col {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin: 28px 0;
    align-items: start;
}

.ad-row-3col .ad-slot {
    margin: 0 !important;
    min-height: 250px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg2);
    border: 1px solid var(--b1);
    border-radius: 8px;
    overflow: hidden;
}

.ad-row-3col .ad-slot img,
.ad-row-3col .ad-slot iframe {
    max-width: 100%;
    height: auto;
}

/* モバイル：1列に変更 */
@media (max-width: 767px) {
    .ad-row-3col {
        grid-template-columns: 1fr;
        gap: 16px;
        margin: 20px 0;
    }
    .ad-row-3col .ad-slot {
        min-height: auto;
    }
}

/* ============================================
   メインカラム最下部・広告3カラム（under-footer）
   コンテンツとの視覚的な区切りを明確にするため上部余白を多めに
   ============================================ */
.ad-row-3col.ad-row-3col--footer {
    margin-top: 48px;
    margin-bottom: 24px;
    padding-top: 24px;
    border-top: 1px solid var(--b1);
}

@media (max-width: 767px) {
    .ad-row-3col.ad-row-3col--footer {
        margin-top: 32px;
        padding-top: 16px;
    }
}

/* ============================================================
   ヌキドコ v4 コンポーネントCSS
   2026-04-21 追加 — index.php / single-work.php / taxonomy-*.php 用
   ============================================================ */

/* ======= 共通コンテナ ======= */
.container {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 0 var(--pad-x);
}
@media (max-width: 768px) {
    .container { padding: 0 var(--pad-x-sp); }
}

body {
    font-family: var(--font-sans);
    background: var(--bg);
    color: var(--t1);
    line-height: 1.7;
}

/* ======= サイトヘッダー ======= */
.site-header {
    position: sticky; top: 0; z-index: 100;
    background: rgba(255,255,255,0.92);
    backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid var(--line);
}
.header-inner {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 14px var(--pad-x);
    display: flex; align-items: center; justify-content: space-between;
    gap: 32px;
}
.logo {
    display: flex; align-items: center; gap: 10px;
    font-family: var(--font-kiwi); font-weight: 500;
    font-size: 20px; color: var(--t1);
    text-decoration: none;
    flex-shrink: 0;
}
.logo-mark {
    width: 34px; height: 34px;
    background: linear-gradient(135deg, var(--pink) 0%, var(--pink-deep) 100%);
    color: #fff; font-family: var(--font-kiwi); font-weight: 500;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 16px;
}
.main-nav {
    display: flex;
    gap: 24px;
    flex-wrap: nowrap;
    justify-content: center;
    flex: 1 1 auto;
    min-width: 0;
    overflow-x: auto;
    scrollbar-width: none;
}
.main-nav::-webkit-scrollbar { display: none; }
.main-nav a {
    color: var(--t2); font-size: 14px; font-weight: 500;
    text-decoration: none; padding: 6px 0;
    transition: color var(--t-base);
    position: relative;
    white-space: nowrap;
    flex-shrink: 0;
}
.main-nav a:hover { color: var(--pink-dark); }
.main-nav a.active { color: var(--pink-dark); }
.main-nav a.active::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -4px;
    height: 2px; background: var(--pink); border-radius: 2px;
}
@media (max-width: 900px) {
    .main-nav { gap: 16px; }
    .main-nav a { font-size: 13px; }
    .search-btn-label { display: none; }
    .search-btn { padding: 8px 10px; }
    .logo { font-size: 18px; }
}
@media (max-width: 640px) {
    .header-inner { padding: 12px 16px; gap: 12px; }
    .main-nav { gap: 14px; }
    .main-nav a { font-size: 12px; }
    .logo-mark { width: 30px; height: 30px; font-size: 14px; }
    .logo { font-size: 16px; }
}
.header-right { display: flex; align-items: center; gap: 12px; }
.search-btn {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 16px;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: var(--r-full);
    color: var(--t2);
    font-size: 13px;
    font-family: inherit;
    cursor: pointer;
    transition: all var(--t-base);
}
.search-btn:hover {
    background: var(--pink-soft);
    border-color: var(--pink);
    color: var(--pink-dark);
}

/* ======= 検索モーダル ======= */
.header-search-modal {
    position: fixed; inset: 0;
    background: rgba(0,0,0,0.4);
    z-index: 200; display: none;
    align-items: flex-start; justify-content: center;
    padding-top: 80px;
}
.header-search-modal.open { display: flex; }
.header-search-modal-inner {
    background: #fff; border-radius: var(--r4);
    padding: 32px; max-width: 600px; width: 92%;
    position: relative; box-shadow: var(--s3);
}
.modal-close {
    position: absolute; top: 16px; right: 16px;
    width: 32px; height: 32px;
    border: none; background: transparent;
    font-size: 24px; color: var(--t3);
    cursor: pointer;
}
.modal-title {
    font-family: var(--font-kiwi); font-size: 20px;
    margin: 0 0 18px; color: var(--t1);
}
.modal-search-form { display: flex; gap: 8px; margin-bottom: 14px; }
.modal-search-form input {
    flex: 1; padding: 12px 16px;
    border: 1px solid var(--line);
    border-radius: var(--r2);
    font-size: 15px;
    font-family: inherit;
}
.modal-search-form input:focus {
    outline: none; border-color: var(--pink);
}
.modal-search-form button {
    padding: 12px 28px;
    background: var(--pink-deep); color: #fff;
    border: none; border-radius: var(--r2);
    font-family: inherit; font-weight: 700; cursor: pointer;
}
.modal-popular-keywords { font-size: 13px; color: var(--t3); }
.modal-popular-label { margin-right: 8px; }
.modal-popular-keywords a {
    display: inline-block; padding: 4px 10px;
    background: var(--bg-soft);
    border-radius: var(--r-full);
    color: var(--t2); text-decoration: none;
    margin-right: 6px; margin-bottom: 4px;
    font-size: 12px;
}

/* ======= ヒーロー ======= */
.hero {
    padding: 80px var(--pad-x) 100px;
    background: linear-gradient(180deg, var(--bg-cream) 0%, #fff 100%);
    position: relative;
    overflow: hidden;
}
.hero::before {
    content: ""; position: absolute; inset: 0;
    background:
      radial-gradient(circle at 10% 20%, var(--rainbow-1) 0%, transparent 30%),
      radial-gradient(circle at 90% 10%, var(--rainbow-3) 0%, transparent 30%),
      radial-gradient(circle at 50% 90%, var(--rainbow-4) 0%, transparent 30%);
    opacity: 0.6; z-index: 0;
}
.hero-inner {
    max-width: 860px; margin: 0 auto;
    position: relative; z-index: 1; text-align: center;
}
.hero-badge {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 6px 16px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r-full);
    font-size: 12px; color: var(--t2);
    margin-bottom: 24px;
}
.hero-badge-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--pink);
    box-shadow: 0 0 0 3px var(--pink-glow);
}
.hero-h1 {
    font-family: var(--font-kiwi); font-weight: 500;
    font-size: clamp(32px, 5vw, 52px);
    line-height: 1.3; letter-spacing: -0.02em;
    color: var(--t1); margin-bottom: 16px;
}
.hero-desc {
    font-size: clamp(14px, 2vw, 16px);
    color: var(--t2); line-height: 1.8;
    margin-bottom: 36px;
}
.hero-search {
    display: flex; gap: 8px; align-items: center;
    background: #fff;
    border: 2px solid var(--line);
    border-radius: var(--r-full);
    padding: 6px 6px 6px 24px;
    max-width: 640px; margin: 0 auto 24px;
    transition: border-color var(--t-base);
}
.hero-search:focus-within { border-color: var(--pink); }
.hero-search svg { color: var(--t3); flex-shrink: 0; }
.hero-search input {
    flex: 1; border: none; outline: none;
    padding: 12px 8px;
    font-size: 15px; font-family: inherit;
    background: transparent;
}
.hero-search button {
    display: flex; align-items: center; gap: 6px;
    padding: 12px 24px;
    background: linear-gradient(135deg, var(--pink) 0%, var(--pink-deep) 100%);
    color: #fff; border: none;
    border-radius: var(--r-full);
    font-weight: 700; cursor: pointer;
    font-family: inherit;
    transition: all var(--t-base);
}
.hero-search button:hover {
    transform: translateY(-1px);
    box-shadow: var(--s-pink);
}
.hero-quick {
    display: flex; flex-wrap: wrap; justify-content: center;
    align-items: center; gap: 8px;
    font-size: 12px;
}
.hero-quick-label { color: var(--t3); }
.hero-quick-tag {
    padding: 4px 12px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r-full);
    color: var(--t2);
    text-decoration: none;
    font-size: 12px;
    transition: all var(--t-base);
}
.hero-quick-tag:hover {
    background: var(--pink-soft);
    border-color: var(--pink);
    color: var(--pink-dark);
}

/* ======= 共通セクション ======= */
section { padding: 64px var(--pad-x); }
@media (max-width: 768px) { section { padding: 40px var(--pad-x-sp); } }

.section-head {
    display: flex; align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 32px;
    max-width: var(--max-w); margin-left: auto; margin-right: auto;
}
.section-head-left { flex: 1; }
.section-kicker {
    font-family: var(--font-mont); font-weight: 700;
    font-size: 11px; letter-spacing: 0.15em;
    color: var(--pink-dark); margin-bottom: 8px;
    text-transform: uppercase;
}
.section-title {
    font-family: var(--font-sans); font-weight: 400;
    font-size: clamp(22px, 3vw, 28px);
    color: var(--t1); line-height: 1.3;
    margin-bottom: 8px;
}
.section-title .accent {
    background: linear-gradient(135deg, var(--pink-deep) 0%, var(--pink-dark) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.section-desc {
    font-size: 13px; color: var(--t3);
}
.section-more {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 20px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r-full);
    color: var(--t2);
    text-decoration: none;
    font-size: 13px; font-weight: 500;
    transition: all var(--t-base);
    flex-shrink: 0;
}
.section-more:hover {
    border-color: var(--pink);
    color: var(--pink-dark);
}

/* ======= 作品カード ======= */
.work-card {
    display: block; text-decoration: none;
    color: var(--t1);
    transition: transform var(--t-base);
}
.work-card:hover { transform: translateY(-3px); }
.work-thumb {
    aspect-ratio: 210 / 297;
    background: linear-gradient(135deg, var(--rainbow-1), var(--rainbow-3));
    border-radius: var(--r3);
    margin-bottom: 10px;
    position: relative; overflow: hidden;
}
.work-badge {
    position: absolute; top: 8px; left: 8px;
    padding: 3px 10px;
    background: var(--pink-deep); color: #fff;
    border-radius: var(--r-full);
    font-family: var(--font-inter); font-weight: 700;
    font-size: 10px; letter-spacing: 0.05em;
}
.work-badge.new { background: var(--pink-deep); }
.work-badge.hot { background: #e86a1a; }
.work-type {
    font-family: var(--font-mont); font-weight: 500;
    font-size: 10px; color: var(--pink-dark);
    margin-bottom: 4px; letter-spacing: 0.05em;
}
.work-title {
    font-weight: 500; font-size: 13px;
    line-height: 1.5;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 4px;
    color: var(--t1);
}
.work-circle {
    font-size: 11px; color: var(--t3); margin-bottom: 6px;
}
.work-meta {
    display: flex; align-items: center; gap: 8px;
    font-size: 11px;
}
.work-price {
    font-family: var(--font-inter); font-weight: 700;
    color: var(--pink-dark);
}
.work-rating { color: #e8a521; font-weight: 600; }

/* ======= FEATURED ======= */
.featured-section { padding: 48px var(--pad-x); }
.featured-card {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; grid-template-columns: 1.1fr 1fr;
    gap: 40px;
    background: #fff;
    border-radius: var(--r4);
    padding: 40px;
    border: 1px solid var(--line);
    box-shadow: var(--s2);
    position: relative;
    overflow: hidden;
}
.featured-card::before {
    content: ""; position: absolute; top: 0; left: 0; right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--rainbow-1), var(--rainbow-3), var(--rainbow-4), var(--rainbow-5));
}
.featured-visual {
    aspect-ratio: 16 / 10;
    background: linear-gradient(135deg, var(--rainbow-1), var(--rainbow-3));
    border-radius: var(--r3);
    position: relative;
}
.featured-label {
    position: absolute; top: 16px; left: 16px;
    padding: 6px 14px;
    background: rgba(255,255,255,0.95);
    backdrop-filter: blur(8px);
    border-radius: var(--r-full);
    display: flex; align-items: center; gap: 6px;
    font-family: var(--font-inter); font-weight: 700;
    font-size: 11px; color: var(--pink-dark);
}
.featured-body { display: flex; flex-direction: column; justify-content: center; }
.featured-kicker {
    font-family: var(--font-mont); font-weight: 700;
    font-size: 11px; color: var(--pink-dark);
    letter-spacing: 0.1em; margin-bottom: 8px;
}
.featured-title {
    font-family: var(--font-sans); font-weight: 400;
    font-size: clamp(24px, 3vw, 32px);
    line-height: 1.3; color: var(--t1);
    margin-bottom: 16px;
}
.featured-lead {
    font-size: 14px; color: var(--t2);
    line-height: 1.9; margin-bottom: 20px;
}
.featured-meta {
    display: flex; flex-wrap: wrap; gap: 16px;
    padding: 14px 0;
    border-top: 1px solid var(--line-soft);
    border-bottom: 1px solid var(--line-soft);
    margin-bottom: 20px;
    font-size: 12px; color: var(--t2);
}
.featured-meta-item { display: flex; align-items: center; gap: 4px; }
.featured-actions { display: flex; gap: 12px; }
.btn-primary {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 12px 24px;
    background: linear-gradient(135deg, var(--pink) 0%, var(--pink-deep) 100%);
    color: #fff;
    text-decoration: none;
    border-radius: var(--r-full);
    font-weight: 700; font-size: 13px;
    transition: all var(--t-base);
}
.btn-primary:hover { transform: translateY(-1px); box-shadow: var(--s-pink); }

@media (max-width: 768px) {
    .featured-card { grid-template-columns: 1fr; padding: 24px; gap: 24px; }
}

/* ======= タイプタブ ======= */
.type-shelf-section { background: var(--bg-cream); }
.type-tabs {
    display: flex; gap: 8px; overflow-x: auto;
    padding-bottom: 8px;
    margin-bottom: 24px;
    max-width: var(--max-w); margin-left: auto; margin-right: auto;
}
.type-tab {
    display: inline-flex; flex-direction: column;
    align-items: flex-start;
    padding: 14px 24px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r3);
    text-decoration: none;
    color: var(--t2);
    transition: all var(--t-base);
    flex-shrink: 0;
}
.type-tab.active {
    background: linear-gradient(135deg, var(--pink-soft) 0%, var(--rainbow-3) 100%);
    border-color: var(--pink);
    color: var(--pink-dark);
}
.type-tab-name { font-weight: 700; font-size: 13px; margin-bottom: 2px; }
.type-tab-count {
    font-family: var(--font-inter);
    font-size: 11px; color: var(--t3);
}
.type-tab.active .type-tab-count { color: var(--pink-deep); }

.type-shelf-row {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; grid-template-columns: repeat(5, 1fr);
    gap: 20px;
}
@media (max-width: 960px) {
    .type-shelf-row { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 560px) {
    .type-shelf-row { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}

/* ======= ムードタグ ======= */
.mood-section { background: #fff; }
.mood-tags-wrap { max-width: var(--max-w); margin: 0 auto; }
.mood-tags {
    display: flex; flex-wrap: wrap; gap: 8px;
    justify-content: center;
}
.mood-tag {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 18px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r-full);
    color: var(--t2);
    text-decoration: none;
    font-size: 13px; font-weight: 500;
    transition: all var(--t-base);
}
.mood-tag:hover {
    background: var(--pink-soft);
    border-color: var(--pink);
    color: var(--pink-dark);
}
.mood-tag.popular {
    background: linear-gradient(135deg, var(--pink-soft) 0%, var(--rainbow-3) 100%);
    border-color: var(--pink);
    color: var(--pink-dark);
    font-weight: 700;
}
.mood-tag-count {
    font-family: var(--font-inter);
    font-size: 10px; color: var(--t3);
}
.mood-tag.popular .mood-tag-count { color: var(--pink-deep); }

/* ======= 新着グリッド ======= */
.new-grid {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; grid-template-columns: repeat(5, 1fr);
    gap: 20px;
}
@media (max-width: 960px) {
    .new-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 560px) {
    .new-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}

/* ======= サークルグリッド ======= */
.circle-section { background: var(--bg-cream); }
.circle-grid {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; grid-template-columns: repeat(5, 1fr);
    gap: 16px;
}
.circle-card {
    display: block; padding: 20px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r3);
    text-decoration: none;
    transition: all var(--t-base);
}
.circle-card:hover {
    transform: translateY(-2px);
    border-color: var(--pink);
    box-shadow: var(--s2);
}
.circle-avatar {
    width: 60px; height: 60px; border-radius: 50%;
    background: linear-gradient(135deg, var(--rainbow-1), var(--rainbow-4));
    margin: 0 auto 12px;
    position: relative;
}
.circle-heat {
    position: absolute; top: -4px; right: -10px;
    padding: 2px 8px;
    background: #fff;
    border: 1px solid var(--pink);
    border-radius: var(--r-full);
    font-size: 10px; font-weight: 700;
    color: var(--pink-dark);
    white-space: nowrap;
}
.circle-name {
    font-weight: 700; font-size: 13px;
    text-align: center;
    color: var(--t1); margin-bottom: 4px;
}
.circle-type {
    font-size: 11px; color: var(--t3);
    text-align: center; margin-bottom: 8px;
}
.circle-stats {
    display: flex; justify-content: center; gap: 12px;
    font-size: 11px; color: var(--t3);
}
.circle-stat strong {
    font-family: var(--font-inter); font-weight: 700;
    color: var(--pink-dark);
}
@media (max-width: 960px) {
    .circle-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 560px) {
    .circle-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ======= ジャンル特集 ======= */
.genre-feature-section {}
.genre-feature-grid {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.genre-feature-card {
    display: flex; flex-direction: column;
    justify-content: space-between;
    padding: 32px;
    background: linear-gradient(135deg, var(--rainbow-1) 0%, var(--rainbow-3) 100%);
    border: 1px solid var(--line);
    border-radius: var(--r4);
    text-decoration: none;
    color: var(--t1);
    min-height: 240px;
    transition: transform var(--t-base);
}
.genre-feature-card:hover { transform: translateY(-3px); }
.genre-feature-kicker {
    font-family: var(--font-mont); font-weight: 700;
    font-size: 11px; color: var(--pink-dark);
    letter-spacing: 0.1em; margin-bottom: 12px;
}
.genre-feature-title {
    font-family: var(--font-sans); font-weight: 400;
    font-size: 20px; line-height: 1.4;
    margin-bottom: 10px;
}
.genre-feature-desc {
    font-size: 13px; color: var(--t2);
    line-height: 1.7;
}
.genre-feature-link {
    color: var(--pink-dark);
    font-weight: 700; font-size: 13px;
    text-decoration: none;
}
@media (max-width: 768px) {
    .genre-feature-grid { grid-template-columns: 1fr; }
}

/* ======= トレンド ======= */
.trend-grid {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; grid-template-columns: repeat(5, 1fr);
    gap: 16px;
}
.trend-card {
    padding: 20px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r3);
    text-decoration: none;
    color: var(--t1);
    transition: all var(--t-base);
}
.trend-card:hover { border-color: var(--pink); box-shadow: var(--s2); }
.trend-rank {
    font-family: var(--font-mont); font-weight: 700;
    font-size: 11px; color: var(--t3); margin-bottom: 4px;
}
.trend-tag {
    font-weight: 400; font-size: 16px;
    color: var(--t1); margin-bottom: 6px;
}
.trend-change {
    font-family: var(--font-inter); font-weight: 700;
    font-size: 11px; color: #c42e62;
    margin-bottom: 6px;
}
.trend-works { font-size: 11px; color: var(--t3); }
@media (max-width: 960px) { .trend-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .trend-grid { grid-template-columns: repeat(2, 1fr); } }

/* ======= コラム ======= */
.column-section { background: var(--bg-cream); }
.column-grid {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.column-card {
    display: block;
    text-decoration: none;
    color: var(--t1);
    transition: transform var(--t-base);
}
.column-card:hover { transform: translateY(-3px); }
.column-img {
    aspect-ratio: 16 / 10;
    background: linear-gradient(135deg, var(--rainbow-1), var(--rainbow-3));
    border-radius: var(--r3);
    margin-bottom: 12px;
    position: relative;
}
.column-img-label {
    position: absolute; top: 12px; left: 12px;
    padding: 4px 12px;
    background: rgba(255,255,255,0.95);
    border-radius: var(--r-full);
    font-size: 11px; font-weight: 700;
    color: var(--pink-dark);
}
.column-cat {
    font-family: var(--font-mont); font-weight: 700;
    font-size: 10px; color: var(--pink-dark);
    letter-spacing: 0.1em; margin-bottom: 4px;
}
.column-title {
    font-family: var(--font-sans); font-weight: 400;
    font-size: 16px; line-height: 1.4;
    color: var(--t1); margin-bottom: 8px;
}
.column-excerpt {
    font-size: 13px; color: var(--t2);
    line-height: 1.7; margin-bottom: 8px;
}
.column-meta { font-size: 11px; color: var(--t3); }
@media (max-width: 768px) { .column-grid { grid-template-columns: 1fr; } }

/* ======= ランキング ======= */
.ranking-grid {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.ranking-card {
    display: block;
    padding: 20px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r3);
    text-decoration: none;
    color: var(--t1);
    position: relative;
    transition: all var(--t-base);
}
.ranking-card:hover { transform: translateY(-2px); box-shadow: var(--s2); }
.ranking-card.top-1 {
    background: linear-gradient(135deg, #fef3c7 0%, #fce7ee 100%);
    border-color: #e8a521;
}
.ranking-card.top-2 {
    background: linear-gradient(135deg, #f3f4f6 0%, #e7e9fd 100%);
    border-color: #c0c6d1;
}
.ranking-card.top-3 {
    background: linear-gradient(135deg, #fff1e7 0%, #fce7ee 100%);
    border-color: #d4a574;
}
.ranking-crown {
    position: absolute; top: -10px; right: 16px;
    padding: 4px 12px;
    background: #fff;
    border: 2px solid #e8a521;
    border-radius: var(--r-full);
    font-size: 12px; font-weight: 700;
    color: #b88716;
}
.ranking-num-big {
    font-family: var(--font-inter); font-weight: 700;
    font-size: 32px; color: var(--t3);
    margin-bottom: 12px; line-height: 1;
}
.ranking-thumb-big {
    aspect-ratio: 16 / 10;
    background: linear-gradient(135deg, var(--rainbow-1), var(--rainbow-3));
    border-radius: var(--r2);
    margin-bottom: 12px;
}
.ranking-type {
    font-family: var(--font-inter); font-weight: 500;
    font-size: 10px; color: var(--pink-dark);
    margin-bottom: 4px;
}
.ranking-title-big {
    font-family: var(--font-sans); font-weight: 400;
    font-size: 15px; line-height: 1.4;
    color: var(--t1); margin-bottom: 6px;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.ranking-circle-name { font-size: 12px; color: var(--t3); margin-bottom: 8px; }
.ranking-bottom {
    display: flex; justify-content: space-between;
    align-items: center; font-size: 12px;
}
.ranking-price-big {
    font-family: var(--font-inter); font-weight: 700;
    color: var(--pink-dark);
}
.ranking-rating-big { color: var(--t3); }
@media (max-width: 768px) { .ranking-grid { grid-template-columns: 1fr; } }

/* ======= 二次/オリジナル ======= */
.origin-section { background: #fff; }
.origin-tabs {
    display: flex; gap: 8px; justify-content: center;
    margin-bottom: 24px;
}
.origin-tab {
    padding: 10px 28px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r-full);
    color: var(--t2);
    text-decoration: none;
    font-size: 13px;
    transition: all var(--t-base);
}
.origin-tab.active {
    background: linear-gradient(135deg, var(--pink-soft) 0%, var(--rainbow-3) 100%);
    border-color: var(--pink);
    color: var(--pink-dark);
    font-weight: 700;
}
.origin-grid {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
@media (max-width: 768px) { .origin-grid { grid-template-columns: repeat(2, 1fr); } }

/* ======= 3カラム（セール・新人・殿堂） ======= */
.triple-section { background: var(--bg-cream); }
.triple-grid {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.triple-col {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r3);
    padding: 24px;
}
.triple-col-head { margin-bottom: 16px; }
.triple-col-kicker {
    font-family: var(--font-mont); font-weight: 700;
    font-size: 11px; color: var(--pink-dark);
    margin-bottom: 4px; letter-spacing: 0.1em;
}
.triple-col-title {
    font-family: var(--font-sans); font-weight: 400;
    font-size: 18px; color: var(--t1);
    margin-bottom: 4px;
}
.triple-col-desc { font-size: 12px; color: var(--t3); }
.triple-list { display: flex; flex-direction: column; gap: 14px; }
.triple-item {
    display: flex; gap: 12px;
    padding: 10px;
    border-radius: var(--r2);
    text-decoration: none;
    transition: background var(--t-base);
}
.triple-item:hover { background: var(--bg-soft); }
.triple-item-thumb {
    width: 60px; height: 85px;
    background: linear-gradient(135deg, var(--rainbow-1), var(--rainbow-3));
    border-radius: var(--r2);
    flex-shrink: 0;
}
.triple-item-body { flex: 1; min-width: 0; }
.triple-item-type {
    font-family: var(--font-inter); font-size: 10px;
    color: var(--pink-dark); margin-bottom: 2px;
}
.triple-item-title {
    font-weight: 500; font-size: 13px;
    color: var(--t1); line-height: 1.4;
    margin-bottom: 4px;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.triple-item-meta {
    display: flex; gap: 6px;
    font-size: 11px; color: var(--t3);
}
.triple-item-price {
    font-family: var(--font-inter); font-weight: 700;
    color: var(--pink-dark);
}
@media (max-width: 960px) { .triple-grid { grid-template-columns: 1fr; } }

/* ======= ガイドCTA ======= */
.guide-cta-section { padding: 80px var(--pad-x); }
.guide-cta {
    max-width: var(--max-w); margin: 0 auto;
    padding: 56px 48px;
    background: linear-gradient(135deg, var(--rainbow-1) 0%, var(--rainbow-3) 50%, var(--rainbow-4) 100%);
    border-radius: var(--r4);
    text-align: center;
    position: relative; overflow: hidden;
}
.guide-cta-inner { position: relative; z-index: 1; }
.guide-cta-kicker {
    font-family: var(--font-mont); font-weight: 700;
    font-size: 12px; color: var(--pink-dark);
    letter-spacing: 0.1em; margin-bottom: 12px;
}
.guide-cta-title {
    font-family: var(--font-sans); font-weight: 400;
    font-size: clamp(22px, 3vw, 28px);
    color: var(--t1); line-height: 1.3;
    margin-bottom: 12px;
}
.guide-cta-desc {
    font-size: 14px; color: var(--t2);
    line-height: 1.8; margin-bottom: 28px;
    max-width: 640px; margin-left: auto; margin-right: auto;
}
.guide-cta-list {
    display: flex; flex-wrap: wrap; justify-content: center;
    gap: 10px;
}
.guide-cta-item {
    padding: 10px 20px;
    background: rgba(255,255,255,0.85);
    border: 1px solid var(--pink);
    border-radius: var(--r-full);
    color: var(--pink-dark);
    text-decoration: none;
    font-size: 13px; font-weight: 500;
    transition: all var(--t-base);
}
.guide-cta-item:hover {
    background: var(--pink-deep); color: #fff;
    transform: translateY(-1px);
}

/* ======= フッター ======= */
.site-footer {
    background: var(--bg-cream);
    border-top: 1px solid var(--line);
    padding: 64px var(--pad-x) 40px;
    margin-top: 80px;
}
.footer-inner {
    max-width: var(--max-w); margin: 0 auto;
    display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
    gap: 48px;
    padding-bottom: 32px;
    border-bottom: 1px solid var(--line);
}
.footer-logo {
    display: flex; align-items: center; gap: 8px;
    font-family: var(--font-kiwi); font-weight: 500;
    font-size: 18px; color: var(--t1);
    text-decoration: none;
    margin-bottom: 12px;
}
.footer-desc {
    font-size: 12px; color: var(--t3);
    line-height: 1.8;
}
.footer-col h4 {
    font-size: 12px; font-weight: 400;
    color: var(--t1); margin-bottom: 14px;
    letter-spacing: 0.02em;
}
.footer-col ul {
    list-style: none;
    display: flex; flex-direction: column; gap: 8px;
    padding: 0; margin: 0;
}
.footer-col a {
    font-size: 12px; color: var(--t2);
    text-decoration: none;
    transition: color var(--t-base);
}
.footer-col a:hover { color: var(--pink-dark); }
.footer-bottom {
    max-width: var(--max-w); margin: 0 auto;
    padding-top: 24px;
    display: flex; justify-content: space-between;
    font-size: 11px; color: var(--t3);
    flex-wrap: wrap; gap: 16px;
}
.adult-notice { color: var(--pink-dark); font-weight: 500; }
@media (max-width: 960px) {
    .footer-inner { grid-template-columns: 1fr 1fr; gap: 32px; }
}

/* ======= 作品ページ（記事型） ======= */
.work-page {
    max-width: var(--max-w); margin: 0 auto;
    padding: 24px var(--pad-x);
}
.work-breadcrumb {
    display: flex; align-items: center; gap: 8px;
    font-size: 12px; color: var(--t3);
    margin-bottom: 24px;
}
.work-breadcrumb a {
    color: var(--t2); text-decoration: none;
}
.work-breadcrumb a:hover { color: var(--pink-dark); }
.work-breadcrumb-sep { color: var(--t4); }

.work-article-layout {
    display: grid; grid-template-columns: 1fr 320px;
    gap: 48px;
}
@media (max-width: 960px) {
    .work-article-layout { grid-template-columns: 1fr; }
}

.work-article-main { min-width: 0; }
.article-header { padding: 20px 0 24px; }
.article-type {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 4px 12px;
    background: var(--pink-soft);
    border-radius: var(--r-full);
    font-family: var(--font-mont); font-weight: 500;
    font-size: 11px; color: var(--pink-dark);
    margin-bottom: 14px;
}
.article-type-dot {
    width: 5px; height: 5px; border-radius: 50%;
    background: var(--pink-deep);
}
.article-title {
    font-family: var(--font-sans); font-weight: 400;
    font-size: clamp(24px, 4vw, 36px);
    line-height: 1.3;
    color: var(--t1); margin-bottom: 12px;
}
.article-sub {
    font-size: 15px; color: var(--t2);
    line-height: 1.8; margin-bottom: 14px;
}
.article-meta {
    display: flex; flex-wrap: wrap; gap: 8px;
    font-size: 12px; color: var(--t3);
    padding-bottom: 20px;
    border-bottom: 1px solid var(--line-soft);
}
.article-meta-sep { color: var(--t4); }

.article-visual {
    aspect-ratio: 16 / 10;
    background: linear-gradient(135deg, var(--rainbow-1), var(--rainbow-3));
    border-radius: var(--r3);
    margin: 24px 0;
}

.sample-gallery {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 8px; margin: 24px 0;
}
.sample-img {
    aspect-ratio: 4 / 3;
    background: linear-gradient(135deg, var(--rainbow-1), var(--rainbow-3));
    border-radius: var(--r2);
}
@media (max-width: 560px) { .sample-gallery { grid-template-columns: repeat(2, 1fr); } }

.cta-inline {
    display: flex; align-items: center; gap: 16px;
    padding: 20px 24px;
    background: linear-gradient(135deg, var(--rainbow-1) 0%, var(--rainbow-3) 100%);
    border-radius: var(--r3);
    margin: 32px 0;
    flex-wrap: wrap;
}
.cta-inline-text {
    flex: 1; min-width: 260px;
    font-size: 13px; color: var(--t2);
    line-height: 1.7;
}
.cta-inline-text strong { color: var(--t1); font-weight: 700; }
.cta-inline-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 12px 24px;
    background: var(--fanza);
    color: #fff; text-decoration: none;
    border-radius: var(--r-full);
    font-weight: 700; font-size: 13px;
    flex-shrink: 0;
    transition: all var(--t-base);
}
.cta-inline-btn:hover { transform: translateY(-1px); box-shadow: var(--s2); }

.article-body {
    font-family: var(--font-sans); font-weight: 400;
    font-size: 15px; line-height: 1.95;
    color: var(--t1);
}
.article-body p { margin-bottom: 20px; }
.article-body .lead {
    font-size: 17px; color: var(--t1);
    line-height: 1.9; font-weight: 500;
    padding: 16px 0;
}
.article-h2 {
    font-family: var(--font-sans); font-weight: 400;
    font-size: 22px; line-height: 1.4;
    color: var(--t1);
    margin: 48px 0 20px;
    padding-left: 14px;
    border-left: 4px solid var(--pink);
}
.article-body h3 {
    font-size: 17px; font-weight: 700;
    color: var(--t1); margin: 32px 0 12px;
}

.spec-table {
    background: var(--bg-cream);
    border: 1px solid var(--line);
    border-radius: var(--r3);
    padding: 8px 20px;
    margin: 24px 0;
}
.spec-row {
    display: grid; grid-template-columns: 140px 1fr;
    gap: 16px; padding: 12px 0;
    border-bottom: 1px solid var(--line-soft);
    font-size: 13px;
}
.spec-row:last-child { border-bottom: none; }
.spec-label { color: var(--t3); font-weight: 500; }
.spec-value { color: var(--t1); }

.cta-final {
    background: linear-gradient(135deg, var(--rainbow-1) 0%, var(--rainbow-3) 50%, var(--rainbow-4) 100%);
    padding: 40px 32px;
    border-radius: var(--r4);
    margin: 48px 0 24px;
    text-align: center;
}
.cta-final-kicker {
    font-family: var(--font-mont); font-weight: 700;
    font-size: 11px; color: var(--pink-dark);
    letter-spacing: 0.1em; margin-bottom: 8px;
}
.cta-final-title {
    font-family: var(--font-sans); font-weight: 400;
    font-size: 22px; line-height: 1.3;
    color: var(--t1); margin-bottom: 8px;
}
.cta-final-desc {
    font-size: 13px; color: var(--t2);
    margin-bottom: 24px;
}
.cta-stack-final {
    display: flex; flex-direction: column; gap: 10px;
    max-width: 480px; margin: 0 auto;
}
.cta-final-btn {
    display: flex; align-items: center; justify-content: space-between;
    padding: 18px 24px;
    border-radius: var(--r3);
    text-decoration: none;
    color: #fff;
    transition: transform var(--t-base);
}
.cta-final-btn:hover { transform: translateY(-1px); }
.cta-final-btn-fanza { background: var(--fanza); }
.cta-final-btn-dlsite { background: var(--dlsite); }
.cta-btn-service {
    font-family: var(--font-inter); font-weight: 700;
    font-size: 11px; opacity: 0.85;
    margin-bottom: 2px;
}
.cta-btn-label {
    font-size: 15px; font-weight: 700;
}
.cta-btn-arrow { flex-shrink: 0; }

.article-tags {
    padding: 24px 0;
    border-top: 1px solid var(--line-soft);
    margin-top: 32px;
}
.article-tags-label {
    font-family: var(--font-mont); font-weight: 700;
    font-size: 11px; color: var(--t3);
    letter-spacing: 0.1em; margin-bottom: 12px;
}
.article-tags-list { display: flex; flex-wrap: wrap; gap: 6px; }
.article-tag {
    padding: 5px 12px;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: var(--r-full);
    color: var(--t2);
    text-decoration: none;
    font-size: 12px;
}
.article-tag:hover {
    background: var(--pink-soft); color: var(--pink-dark);
    border-color: var(--pink);
}

/* ======= 作品ページ サイドバー ======= */
.work-sidebar {
    display: flex; flex-direction: column; gap: 20px;
    position: sticky; top: 80px;
    align-self: start;
}
.sidebar-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r3);
    padding: 20px;
    box-shadow: var(--s1);
}
.sidebar-product-img {
    aspect-ratio: 210 / 297;
    background: linear-gradient(135deg, var(--rainbow-1), var(--rainbow-3));
    border-radius: var(--r2);
    margin-bottom: 16px;
}
.sidebar-price {
    font-family: var(--font-inter); font-weight: 700;
    font-size: 28px; color: var(--pink-dark);
    margin-bottom: 2px;
}
.sidebar-price-label {
    font-size: 11px; color: var(--t3);
    margin-bottom: 16px;
}
.sidebar-stats {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    padding: 14px 0;
    border-top: 1px solid var(--line-soft);
    border-bottom: 1px solid var(--line-soft);
    margin-bottom: 16px;
}
.sidebar-stat { text-align: center; }
.sidebar-stat-val {
    font-family: var(--font-inter); font-weight: 700;
    font-size: 14px; color: var(--t1);
}
.sidebar-stat-label {
    font-size: 10px; color: var(--t3);
}
.sidebar-cta-stack {
    display: flex; flex-direction: column; gap: 8px;
}
.sidebar-cta {
    display: flex; align-items: center; justify-content: space-between;
    padding: 14px 18px;
    border-radius: var(--r2);
    text-decoration: none;
    color: #fff;
    font-weight: 700; font-size: 13px;
    transition: transform var(--t-base);
}
.sidebar-cta:hover { transform: translateY(-1px); }
.sidebar-cta-fanza { background: var(--fanza); }
.sidebar-cta-dlsite { background: var(--dlsite); }
.sidebar-title {
    font-family: var(--font-mont); font-weight: 700;
    font-size: 11px; color: var(--pink-dark);
    letter-spacing: 0.1em; margin-bottom: 12px;
}
.sidebar-circle {
    display: flex; align-items: center; gap: 12px;
    margin-bottom: 12px;
}
.sidebar-circle-avatar {
    width: 44px; height: 44px; border-radius: 50%;
    background: linear-gradient(135deg, var(--rainbow-1), var(--rainbow-4));
    flex-shrink: 0;
}
.sidebar-circle-name { font-weight: 700; font-size: 13px; }
.sidebar-circle-count { font-size: 11px; color: var(--t3); }
.sidebar-circle-link {
    display: block; padding: 10px;
    background: var(--bg-soft);
    border-radius: var(--r2);
    text-align: center;
    color: var(--pink-dark);
    text-decoration: none;
    font-size: 12px; font-weight: 500;
}

/* ======= ページネーション ======= */
.pagination { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.pagination .page-numbers {
    padding: 10px 16px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r-full);
    color: var(--t2);
    text-decoration: none;
    font-family: var(--font-inter); font-weight: 500;
    font-size: 13px;
    transition: all var(--t-base);
}
.pagination .page-numbers.current {
    background: var(--pink-deep); color: #fff; border-color: var(--pink-deep);
}
.pagination .page-numbers:hover:not(.current) {
    border-color: var(--pink); color: var(--pink-dark);
}

/* ======= Toast（ダレコレv5教訓：CSS完備） ======= */
.toast {
    position: fixed; bottom: 32px; left: 50%;
    transform: translateX(-50%) translateY(20px);
    padding: 12px 24px;
    background: var(--t1); color: #fff;
    border-radius: var(--r-full);
    font-size: 13px; font-weight: 500;
    box-shadow: var(--s3);
    opacity: 0; pointer-events: none;
    transition: all 0.3s ease;
    z-index: 1000;
    max-width: 90%;
}
.toast.toast-show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.toast-success { background: var(--pink-deep); }
.toast.toast-error { background: #c0392b; }
@media (max-width: 560px) {
    .toast { bottom: 16px; padding: 10px 20px; font-size: 12px; }
}

/* ======= ユーティリティ ======= */
.accent {
    background: linear-gradient(135deg, var(--pink-deep) 0%, var(--pink-dark) 100%);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* ============================================================
   ヌキドコ v3.1 ブランド調整（2026-04-21）
   - 日本語見出し weight 700 → 400（柔らかく）
   - 英語キッカー → Montserrat + 紫→ピンクグラデ
   ============================================================ */

/* ----- 日本語見出し：weight を 400 に ----- */
.section-title,
.article-title,
.featured-title,
.genre-feature-title,
.column-title,
.ranking-title-big,
.modal-title,
.triple-col-title,
.cta-final-title,
.guide-cta-title,
.article-h2,
.triple-col-desc + * .triple-col-title {
    font-weight: 400;
}

/* ----- 作品タイプ表示（漫画/CG/音声等）— 日本語なので sans に ----- */
.article-type {
    font-family: var(--font-sans);
    font-weight: 500;
    color: transparent;
    background: linear-gradient(135deg, #9d5cd9 0%, #c83e8a 55%, #e04f7a 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* ----- 英語キッカー共通：Montserrat + 紫→ピンクグラデ ----- */
.section-kicker,
.featured-kicker,
.featured-label,
.genre-feature-kicker,
.column-cat,
.triple-col-kicker,
.guide-cta-kicker,
.cta-final-kicker,
.article-tags-label,
.sidebar-title {
    font-family: var(--font-mont);
    font-weight: 600;
    letter-spacing: 0.12em;
    background: linear-gradient(135deg, #9d5cd9 0%, #c83e8a 55%, #e04f7a 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

/* .featured-label は白バッジに乗るので背景も配慮 */
.featured-label {
    background-color: rgba(255,255,255,0.95);
    padding: 6px 14px;
    border-radius: var(--r-full);
}
.featured-label span.label-text {
    background: linear-gradient(135deg, #9d5cd9 0%, #c83e8a 55%, #e04f7a 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* ----- アイコン（SVG）用の共通スタイル ----- */
.icon-inline {
    display: inline-block;
    width: 1em;
    height: 1em;
    vertical-align: -0.125em;
    fill: currentColor;
    stroke: currentColor;
}

/* ランキング王冠の SVG (gold) */
.ranking-crown .icon-crown {
    width: 14px;
    height: 14px;
    vertical-align: -2px;
    margin-right: 4px;
    color: #e8a521;
}

/* 熱量メーター炎 (ピンク) */
.circle-heat .icon-flame {
    width: 10px;
    height: 10px;
    vertical-align: -1px;
    margin-right: 3px;
    color: var(--pink-deep);
}

/* 星評価 */
.icon-star {
    width: 12px;
    height: 12px;
    vertical-align: -2px;
    margin-right: 3px;
    color: #e8a521;
}

/* ガイドCTAアイコン */
.guide-cta-item .icon {
    width: 14px;
    height: 14px;
    vertical-align: -2px;
    margin-right: 6px;
    color: var(--pink-dark);
}

/* ============================================================
   作品リクエスト・掲載依頼ページ（page-work-request.php）
   ============================================================ */
.request-article {
    max-width: 840px;
    margin: 0 auto;
    padding: 24px 0;
}

.request-info {
    margin: 40px 0;
}
.request-info-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}
.request-info-card {
    padding: 28px;
    background: var(--bg-cream);
    border: 1px solid var(--line);
    border-radius: var(--r3);
}
.request-info-card .section-kicker {
    margin-bottom: 8px;
    font-size: 11px;
}
.request-info-title {
    font-family: var(--font-sans);
    font-weight: 400;
    font-size: 18px;
    color: var(--t1);
    margin-bottom: 12px;
}
.request-info-card p {
    font-size: 13px;
    line-height: 1.8;
    color: var(--t2);
    margin-bottom: 12px;
}
.request-info-card strong {
    color: var(--t1);
    font-weight: 500;
}
.request-info-list {
    list-style: none;
    padding: 0;
    margin: 0;
    border-top: 1px solid var(--line-soft);
    padding-top: 12px;
}
.request-info-list li {
    font-size: 12px;
    color: var(--t3);
    padding: 6px 0 6px 18px;
    position: relative;
    line-height: 1.6;
}
.request-info-list li::before {
    content: "";
    position: absolute;
    left: 4px;
    top: 14px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--pink);
}

.request-form-section {
    margin: 48px 0;
}
.request-form-intro {
    font-size: 13px;
    color: var(--t2);
    line-height: 1.8;
    margin-bottom: 20px;
}

.cf7-wrap {
    padding: 24px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r3);
}
.cf7-wrap .wpcf7-form p {
    margin-bottom: 16px;
}
.cf7-wrap label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--t1);
    margin-bottom: 6px;
}
.cf7-wrap .required {
    color: var(--pink-dark);
    font-size: 11px;
    margin-left: 4px;
}
.cf7-wrap input[type="text"],
.cf7-wrap input[type="email"],
.cf7-wrap input[type="url"],
.cf7-wrap input[type="tel"],
.cf7-wrap select,
.cf7-wrap textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--line);
    border-radius: var(--r2);
    font-family: inherit;
    font-size: 14px;
    color: var(--t1);
    background: #fff;
    transition: border-color var(--t-base);
}
.cf7-wrap input:focus,
.cf7-wrap select:focus,
.cf7-wrap textarea:focus {
    outline: none;
    border-color: var(--pink);
    box-shadow: 0 0 0 3px var(--pink-glow);
}
.cf7-wrap textarea { resize: vertical; min-height: 120px; }
.cf7-wrap .wpcf7-submit,
.cf7-wrap input[type="submit"] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 12px 32px;
    background: linear-gradient(135deg, var(--pink) 0%, var(--pink-deep) 100%);
    color: #fff;
    border: none;
    border-radius: var(--r-full);
    font-family: inherit;
    font-weight: 700;
    font-size: 13px;
    cursor: pointer;
    transition: all var(--t-base);
}
.cf7-wrap .wpcf7-submit:hover,
.cf7-wrap input[type="submit"]:hover {
    transform: translateY(-1px);
    box-shadow: var(--s-pink);
}

.request-notice {
    padding: 32px;
    background: var(--bg-cream);
    border: 1px dashed var(--line);
    border-radius: var(--r3);
    text-align: center;
    color: var(--t3);
    font-size: 13px;
    line-height: 1.8;
}
.request-notice strong {
    color: var(--pink-dark);
    font-weight: 700;
}
.request-notice code {
    padding: 2px 6px;
    background: #fff;
    border-radius: 3px;
    font-family: var(--font-inter);
    font-size: 12px;
    color: var(--pink-dark);
}

.request-alt {
    margin-top: 32px;
    padding-top: 20px;
    border-top: 1px solid var(--line-soft);
    text-align: center;
}
.request-alt-text {
    font-size: 12px;
    color: var(--t3);
    line-height: 1.7;
}
.request-alt-text a {
    color: var(--pink-dark);
    text-decoration: none;
    font-weight: 500;
}
.request-alt-text a:hover { text-decoration: underline; }

@media (max-width: 768px) {
    .request-info-grid { grid-template-columns: 1fr; }
    .cf7-wrap { padding: 18px; }
}

/* ============================================================
   ヌキドコ v3.2 一覧ページ共通コンポーネント
   page-genres / search / tag / page-favorites 他
   ============================================================ */

/* ----- ページヘッダー（記事型の簡易版） ----- */
.page-header-article {
    max-width: var(--max-w);
    margin: 0 auto 32px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--line-soft);
}
.page-header-article .section-kicker { margin-bottom: 8px; }
.page-header-article .article-title { margin-bottom: 8px; }
.page-header-article .article-sub {
    display: flex; align-items: baseline; gap: 12px;
    flex-wrap: wrap;
}
.page-header-count {
    font-family: var(--font-inter); font-weight: 500;
    color: var(--t3); font-size: 13px;
}

/* ----- フィルターバー（検索＋ソート） ----- */
.filter-bar {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 32px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--line-soft);
}
.filter-search {
    display: flex; gap: 8px; align-items: center;
    flex: 1; min-width: 260px; max-width: 520px;
    padding: 4px 4px 4px 18px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r-full);
    transition: border-color var(--t-base);
}
.filter-search:focus-within { border-color: var(--pink); }
.filter-search svg { color: var(--t3); flex-shrink: 0; }
.filter-search input {
    flex: 1; border: none; outline: none;
    padding: 10px 4px;
    font-family: inherit; font-size: 14px;
    background: transparent; color: var(--t1);
    min-width: 0;
}
.filter-search button {
    padding: 10px 20px;
    background: linear-gradient(135deg, var(--pink) 0%, var(--pink-deep) 100%);
    color: #fff;
    border: none; border-radius: var(--r-full);
    font-family: inherit; font-weight: 700;
    font-size: 13px; cursor: pointer;
    flex-shrink: 0;
    transition: all var(--t-base);
}
.filter-search button:hover { transform: translateY(-1px); box-shadow: var(--s-pink); }
.filter-clear {
    padding: 10px 16px; border: 1px solid var(--line);
    border-radius: var(--r-full); color: var(--t3);
    font-size: 12px; text-decoration: none;
    flex-shrink: 0;
}
.filter-sort {
    display: flex; align-items: center; gap: 10px;
    flex-shrink: 0;
}
.filter-sort-label {
    font-size: 12px; color: var(--t3);
}
.filter-sort select {
    padding: 9px 34px 9px 14px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r2);
    font-family: inherit; font-size: 13px;
    color: var(--t1);
    cursor: pointer;
    appearance: none; -webkit-appearance: none;
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a8a96' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
}

/* ----- 空状態 ----- */
.empty-state {
    max-width: var(--max-w);
    margin: 40px auto;
    padding: 80px 24px;
    text-align: center;
    background: var(--bg-cream);
    border: 1px dashed var(--line);
    border-radius: var(--r3);
}
.empty-state-icon {
    display: inline-flex;
    width: 72px; height: 72px;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--line);
    align-items: center; justify-content: center;
    color: var(--pink);
    margin-bottom: 16px;
}
.empty-state-text {
    font-size: 14px; color: var(--t2);
    line-height: 1.8;
    max-width: 440px; margin: 0 auto;
}

/* ----- ジャンル一覧（カード型） ----- */
.genre-list-grid {
    max-width: var(--max-w);
    margin: 0 auto 32px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 14px;
}
.genre-list-card {
    display: flex; flex-direction: column;
    align-items: center;
    padding: 24px 16px 20px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--r3);
    text-decoration: none;
    color: var(--t1);
    transition: all var(--t-base);
}
.genre-list-card:hover {
    transform: translateY(-2px);
    border-color: var(--pink);
    box-shadow: var(--s2);
}
.genre-list-icon {
    width: 52px; height: 52px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--rainbow-1) 0%, var(--rainbow-3) 100%);
    display: flex; align-items: center; justify-content: center;
    color: var(--pink-dark);
    margin-bottom: 12px;
}
.genre-list-name {
    font-weight: 500; font-size: 14px;
    color: var(--t1); margin-bottom: 4px;
    text-align: center;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}
.genre-list-count {
    font-family: var(--font-inter); font-weight: 500;
    font-size: 11px;
    color: var(--pink-dark);
}

/* ----- 固定ページ既定テンプレート（page.php） ----- */
.page-article {
    max-width: 760px;
    margin: 0 auto;
    padding: 24px 0 48px;
}
.page-content {
    font-size: 15px;
    line-height: 1.95;
    color: var(--t1);
}
.page-content h2 {
    font-family: var(--font-sans);
    font-weight: 400;
    font-size: 22px;
    margin: 40px 0 16px;
    padding-left: 14px;
    border-left: 4px solid var(--pink);
}
.page-content h3 {
    font-size: 17px; font-weight: 700;
    margin: 28px 0 12px;
}
.page-content p { margin-bottom: 16px; }
.page-content ul, .page-content ol {
    margin: 16px 0 20px 24px;
}
.page-content li { margin-bottom: 6px; }
.page-content a {
    color: var(--pink-dark); text-decoration: underline;
}
.page-content strong { color: var(--t1); font-weight: 700; }
.page-content blockquote {
    margin: 20px 0; padding: 16px 20px;
    background: var(--bg-cream);
    border-left: 3px solid var(--pink);
    border-radius: var(--r2);
    color: var(--t2); font-size: 14px;
}

@media (max-width: 768px) {
    .filter-bar { gap: 12px; }
    .filter-search { min-width: 0; }
    .page-header-article { margin-bottom: 24px; padding-bottom: 20px; }
    .genre-list-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px; }
    .empty-state { padding: 48px 16px; }
}
