/* doujin.css — 同人・インディーズページ専用（style.css を継承） */
.site-nav{display:flex;gap:4px}
.site-nav a{color:var(--muted,#a49fb8);text-decoration:none;font-weight:700;font-size:.9rem;padding:6px 12px;border-radius:999px;white-space:nowrap}
.site-nav a.on,.site-nav a:hover{color:#fff;background:rgba(255,45,120,.16)}

.d-genrebar{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 26px}
.g-chip{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;font-weight:600;color:#cfc8e0;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:999px;padding:3px 9px}
.g-chip-lg{font-size:.82rem;padding:6px 13px}
.g-chip-lg i{font-style:normal;color:#ff2d78;font-weight:800}

.d-circle{margin:0 0 40px}
.d-circle-head{display:flex;align-items:baseline;gap:12px;margin:0 0 16px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08)}
.d-circle-name{font-size:1.3rem;font-weight:900;color:#fff;margin:0}
.d-circle-count{font-size:.82rem;color:#a49fb8;font-weight:600}

.d-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px}
.d-card{display:flex;flex-direction:column;background:#181421;border:1px solid #241d33;border-radius:14px;overflow:hidden;text-decoration:none;color:inherit;transition:transform .15s,border-color .15s}
.d-card:hover{transform:translateY(-3px);border-color:#ff2d78}
.d-thumb{position:relative;aspect-ratio:3/4;background:#0d0b14;overflow:hidden}
.d-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.d-noimg{position:absolute;inset:0;display:grid;place-items:center;color:#4a4360;font-size:.8rem;letter-spacing:.1em}
.d-buy{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(255,45,120,.92));color:#fff;font-weight:800;font-size:.82rem;text-align:center;padding:18px 8px 9px;opacity:0;transition:opacity .15s}
.d-card:hover .d-buy{opacity:1}
.d-body{display:flex;flex-direction:column;gap:7px;padding:11px 12px 13px}
.d-title{font-size:.84rem;font-weight:700;line-height:1.4;color:#f5f3fa;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.3em}
.d-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.d-price{font-size:.95rem;font-weight:900;color:#ffcf5c}
.d-date{font-size:.7rem;color:#8c86a0}
.d-genres{display:flex;flex-wrap:wrap;gap:4px}
.d-genres .g-chip{font-size:.66rem;padding:2px 7px}

@media(max-width:540px){.d-grid{grid-template-columns:repeat(2,1fr);gap:11px}.d-circle-name{font-size:1.1rem}}

/* ===== ジャンルチップ（クリック可能なボタン） ===== */
.g-chip-lg{cursor:pointer;font-family:inherit;-webkit-appearance:none;appearance:none;transition:background .12s,color .12s,border-color .12s}
.g-chip-lg:hover{color:#fff;border-color:rgba(255,45,120,.5)}
.g-chip-lg.on{background:#ff2d78;border-color:#ff2d78;color:#fff}
.g-chip-lg.on i{color:#fff}

/* ===== 一覧：単一グリッド（見出し＋カード）。フィルタ時はフラット ===== */
.d-all{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px;align-items:start}
.d-head{grid-column:1/-1;display:flex;align-items:baseline;gap:12px;margin:24px 0 2px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08)}
.d-head:first-child{margin-top:0}
.d-head-name{font-size:1.3rem;font-weight:900;color:#fff}
.d-head-count{font-size:.82rem;color:#a49fb8;font-weight:600}
.d-all.is-flat{gap:16px}
.d-empty{color:#a49fb8;text-align:center;padding:40px 0;font-weight:600}

/* ===== 作品詳細ページ ===== */
.dd{max-width:980px}
.dd-crumb{font-size:.8rem;color:#a49fb8;margin:0 0 18px}
.dd-crumb a{color:#cfc8e0;text-decoration:none}
.dd-crumb a:hover{color:#ff2d78}
.dd-top{display:grid;grid-template-columns:300px 1fr;gap:28px;margin:0 0 26px}
.dd-cover{aspect-ratio:3/4;background:#0d0b14;border:1px solid #241d33;border-radius:14px;overflow:hidden;display:grid;place-items:center}
.dd-cover img{width:100%;height:100%;object-fit:cover;display:block}
.dd-info{display:flex;flex-direction:column;gap:14px;min-width:0}
.dd-title{font-size:1.5rem;font-weight:900;line-height:1.35;color:#fff;margin:0}
.dd-metarow{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.dd-circle{font-size:.85rem;color:#cfc8e0;font-weight:700}
.dd-genres{display:flex;flex-wrap:wrap;gap:6px}
.dd-genres .g-chip{text-decoration:none;cursor:pointer}
.dd-genres .g-chip:hover{color:#fff;border-color:rgba(255,45,120,.5)}
.dd-desc{font-size:.92rem;line-height:1.8;color:#cfc8e0;margin:4px 0 0;white-space:pre-wrap}
.dd-cta{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(90deg,#ff2d78,#ff5fa0);color:#fff;font-weight:900;font-size:1.05rem;text-decoration:none;padding:15px 24px;border-radius:12px;box-shadow:0 6px 22px rgba(255,45,120,.35);transition:transform .12s,box-shadow .12s}
.dd-cta:hover{transform:translateY(-2px);box-shadow:0 9px 28px rgba(255,45,120,.5)}
.dd-cta-wrap{margin:30px 0;text-align:center}
.dd-cta-wrap .dd-cta{min-width:min(420px,80%)}
.dd-samples{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin:8px 0 0}
.dd-sample{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:10px;background:#0d0b14;cursor:zoom-in;border:1px solid #241d33}
.dd-related{margin:44px 0 0}
.dd-rel-h{font-size:1.1rem;font-weight:800;color:#fff;margin:0 0 16px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08)}
@media(max-width:640px){.dd-top{grid-template-columns:1fr;gap:18px}.dd-cover{max-width:240px;margin:0 auto}.dd-title{font-size:1.2rem}.dd-samples{grid-template-columns:repeat(2,1fr)}}

/* サンプル写真ライトボックス・ギャラリー（女優ページと同仕様: ←→/スワイプ/スライドショー） */
.wd-lightbox[hidden]{display:none}
.wd-lightbox{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(0,0,0,.92)}
.wd-lb-img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px}
.wd-lb-x{position:absolute;top:14px;right:16px;width:42px;height:42px;border-radius:11px;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.5);color:#fff;font-size:1.1rem;cursor:pointer;z-index:2}
.wd-lb-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:54px;height:54px;border-radius:50%;border:1px solid rgba(255,255,255,.28);background:rgba(0,0,0,.5);color:#fff;font-size:2.1rem;line-height:0;cursor:pointer;display:flex;align-items:center;justify-content:center;padding-bottom:4px}
.wd-lb-nav:hover{background:rgba(255,45,120,.65);border-color:#ff2d78}
.wd-lb-prev{left:16px}.wd-lb-next{right:16px}
.wd-lb-count{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:2;color:#fff;font-size:.85rem;background:rgba(0,0,0,.55);padding:5px 14px;border-radius:999px}
.wd-lb-slideshow{position:absolute;top:14px;left:16px;z-index:2;height:42px;min-width:42px;padding:0 14px;border-radius:11px;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.5);color:#fff;font-size:.95rem;cursor:pointer;display:flex;align-items:center;gap:5px}
.wd-lb-slideshow:hover{background:rgba(255,45,120,.6);border-color:#ff2d78}
.wd-lb-slideshow.on{background:#ff2d78;border-color:#ff2d78}
@media(max-width:520px){.wd-lb-nav{width:46px;height:46px;font-size:1.8rem}.wd-lb-prev{left:8px}.wd-lb-next{right:8px}}
