:root{--bg:#14100f;--card:#1e1817;--line:#33292;--line:#33292b;--text:#f0e8e4;--dim:#a89890;--accent:#e0517a;--accent2:#ffb347}
*{box-sizing:border-box;margin:0}
body{background:var(--bg);color:var(--text);font-family:"Hiragino Sans","Meiryo",sans-serif;line-height:1.7}
a{color:var(--accent);text-decoration:none}

/* 年齢ゲート */
#age-gate{position:fixed;inset:0;background:#0c0a09;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}
.age-box{max-width:520px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:32px;text-align:center}
.age-box h1{font-size:22px;margin-bottom:16px;color:var(--accent2)}
.age-box p{margin-bottom:14px;font-size:14px}
.age-box .note{color:var(--dim);font-size:12px}
.age-btns{display:flex;gap:12px;justify-content:center;margin-top:20px}
.age-btns button{background:var(--accent);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:15px;cursor:pointer;font-weight:600}
.age-btns .leave{padding:12px 24px;color:var(--dim);border:1px solid var(--line);border-radius:8px}

/* ヘッダ */
.topbar{display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;flex-wrap:wrap}
.logo{font-weight:800;font-size:20px;color:var(--accent2);letter-spacing:.05em}
.search{display:flex;flex:1;min-width:200px;gap:6px}
.search input{flex:1;background:var(--bg);border:1px solid var(--line);color:var(--text);padding:9px 12px;border-radius:8px}
.search button{background:var(--accent);border:none;color:#fff;padding:9px 16px;border-radius:8px;cursor:pointer}
.badge{font-size:11px;border:1px solid var(--accent);color:var(--accent);padding:3px 8px;border-radius:99px}

.pr-banner{background:#2a1f1d;color:var(--dim);font-size:12px;padding:8px 20px;border-bottom:1px solid var(--line)}

.container{max-width:1100px;margin:0 auto;padding:20px;display:grid;grid-template-columns:1fr 260px;gap:24px}
@media(max-width:820px){.container{grid-template-columns:1fr}}
h2{font-size:16px;margin-bottom:14px;padding-left:10px;border-left:3px solid var(--accent)}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.card{background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:transform .15s}
.card:hover{transform:translateY(-3px)}
.card .thumb{aspect-ratio:3/4;background:linear-gradient(135deg,#2a2320,#3a2d29);display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:12px;text-align:center;padding:8px}
.card .meta{padding:8px 10px}
.card .t{font-size:13px;font-weight:600;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card .c{font-size:11px;color:var(--dim);margin-top:4px}

.genres{list-style:none}
.genres li{border-bottom:1px solid var(--line)}
.genres a{display:flex;justify-content:space-between;padding:8px 4px;font-size:13px;color:var(--text)}
.genres .cnt{color:var(--dim);font-size:11px}

footer{border-top:1px solid var(--line);padding:24px 20px;margin-top:40px;text-align:center}
.disclaimer{max-width:800px;margin:0 auto 16px;color:var(--dim);font-size:12px;background:#231a18;padding:12px;border-radius:8px}
.foot-links{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:12px;font-size:12px}
footer small{color:var(--dim);font-size:11px}

/* 作品記事ページ */
.article{max-width:820px;margin:0 auto;padding:20px}
.article h1{font-size:22px;line-height:1.4;margin-bottom:12px}
.crumb{font-size:12px;color:var(--dim);margin-bottom:12px}
.answer-box{background:#231a18;border:1px solid var(--accent);border-radius:10px;padding:16px;margin:16px 0}
.answer-box strong{color:var(--accent2)}
.samples{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin:16px 0}
.samples .s{aspect-ratio:3/4;background:linear-gradient(135deg,#2a2320,#3a2d29);border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:11px;text-align:center;padding:6px}
.cta{display:block;background:linear-gradient(135deg,var(--accent),#c23d63);color:#fff;text-align:center;padding:16px;border-radius:10px;font-weight:700;font-size:16px;margin:20px 0}
.cta small{display:block;font-weight:400;font-size:12px;opacity:.9;margin-top:4px}
.review{margin:16px 0}
.review h3{font-size:15px;margin:16px 0 8px;color:var(--accent2)}
.related{margin-top:24px}
