.sc-placeholder { background: color-mix(in srgb, currentcolor 8%, transparent); border: 1px solid color-mix(in srgb, currentcolor, transparent); border-radius: 2px; box-sizing: border-box; overflow: hidden; }
@keyframes sc-shine { 
  0% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
html.sc-dc-streaming .sc-placeholder, html.sc-dc-streaming .sc-interp.sc-missing { position: relative; background: color-mix(in srgb, currentcolor 5%, transparent); border-color: transparent; }
html.sc-dc-streaming .sc-placeholder::before, html.sc-dc-streaming .sc-interp.sc-missing::before { content: ""; position: absolute; inset: 0px; pointer-events: none; background: linear-gradient(90deg, rgba(217, 119, 87, 0) 25%, rgba(247, 225, 211, 0.95) 37%, rgba(217, 119, 87, 0) 63%) 0% 0% / 400% 100%; animation: 1.4s ease 0s infinite normal none running sc-shine; }
html.sc-dc-streaming .sc-placeholder:nth-child(n+9 of .sc-placeholder)::before, html.sc-dc-streaming .sc-interp.sc-missing:nth-child(n+9 of .sc-interp.sc-missing)::before { animation: auto ease 0s 1 normal none running none; background: color-mix(in srgb, currentcolor 8%, transparent); }
.sc-placeholder-error { padding: 4px 8px; font: 11px / 1.4 ui-monospace, monospace; color: color-mix(in srgb, currentcolor 70%, transparent); word-break: break-word; }
.sc-interp.sc-missing { display: inline-block; width: 2em; height: 1em; overflow: hidden; vertical-align: text-bottom; background: rgba(255, 255, 255, 0.3); border: 1px solid rgba(0, 0, 0, 0.5); border-radius: 2px; box-sizing: border-box; color: transparent; user-select: none; }
.sc-interp.sc-unresolved { font-family: ui-monospace, monospace; font-size: 0.85em; color: color-mix(in srgb, currentcolor, transparent); background: color-mix(in srgb, currentcolor 10%, transparent); border-radius: 3px; padding: 0px 3px; }
.sc-host.sc-has-error { position: relative; }
.sc-logic-error { position: absolute; top: 8px; left: 8px; z-index: 2147483647; max-width: 60ch; padding: 6px 10px; background: rgb(176, 0, 32); color: rgb(255, 255, 255); font: 12px / 1.4 ui-monospace, monospace; border-radius: 4px; white-space: pre-wrap; pointer-events: none; }
@media print {
  @page { margin: 0.5cm; }
  figure, table { break-inside: avoid; }
  #dc-root, #dc-root > .sc-host { height: auto; }
  *, ::before, ::after { print-color-adjust: exact; backdrop-filter: none !important; animation-delay: -99s !important; animation-duration: 0.001s !important; animation-iteration-count: 1 !important; animation-fill-mode: both !important; animation-play-state: running !important; transition-duration: 0s !important; }
}
x-dc { display: none !important; }
.fx { display: flex; }
.col { display: flex; flex-direction: column; }
.grid { display: grid; }
.ac { align-items: center; }
.jc { justify-content: center; }
.jb { justify-content: space-between; }
.f1 { flex: 1 1 0%; }
.noshrink { flex-shrink: 0; }
.wrap { flex-wrap: wrap; }
.fw5 { font-weight: 500; }
.fw6 { font-weight: 600; }
.fw7 { font-weight: 700; }
.fw8 { font-weight: 800; }
.fs11 { font-size: 11px; }
.fs12 { font-size: 12px; }
.fs13 { font-size: 13px; }
.fs14 { font-size: 14px; }
.fs15 { font-size: 15px; }
.fs16 { font-size: 16px; }
.fs20 { font-size: 20px; }
.fs22 { font-size: 22px; }
.upper { text-transform: uppercase; }
.tc { text-align: center; }
.nowrap { white-space: nowrap; }
.gap8 { gap: 8px; }
.gap10 { gap: 10px; }
.gap12 { gap: 12px; }
.gap16 { gap: 16px; }
.gap24 { gap: 24px; }
.m0 { margin: 0px; }
.mt8 { margin-top: 8px; }
.mt12 { margin-top: 12px; }
.mt16 { margin-top: 16px; }
.mb8 { margin-bottom: 8px; }
.mb12 { margin-bottom: 12px; }
.mb16 { margin-bottom: 16px; }
.posrel { position: relative; }
.posabs { position: absolute; }
.round { border-radius: 50%; }
.ohide { overflow: hidden; }
.bbox { box-sizing: border-box; }
.pointer { cursor: pointer; }
.w100 { width: 100%; }
.b0 { border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; }
.site-eroterest { --maxw: 1120px; --gap: 20px; --radius: 10px; --radius-sm: 6px; --pad: clamp(16px, 4vw, 34px); --head-h: 58px; --bd: 2px; --ff: "Zen Maru Gothic", system-ui, sans-serif; --ff-display: "Kaisei Decol", "Zen Maru Gothic", serif; --ls: .02em; }
.site-eroterest[data-mode="dark"] { --c-page: #1a1510; --c-surface: #241d15; --c-surface-2: #2f2619; --c-ink: #f3e7cf; --c-ink-2: #b8a888; --c-ink-3: #8a795d; --c-line: rgba(243,231,207,.20); --c-line-2: rgba(243,231,207,.10); --shadow: 4px 4px 0 rgba(0,0,0,.45); --thumb-bg: #332818; }
.site-eroterest[data-mode="light"] { --c-page: #efe3c6; --c-surface: #f8efd7; --c-surface-2: #ecdfbe; --c-ink: #3a2c1a; --c-ink-2: #7a6647; --c-ink-3: #a5926c; --c-line: rgba(58,44,26,.28); --c-line-2: rgba(58,44,26,.13); --shadow: 4px 4px 0 rgba(58,44,26,.20); --thumb-bg: #e2d4ac; }
.site-eroterest[data-theme="theme-red"] { --c-accent: oklch(0.56 0.14 38); --c-accent-2: oklch(0.48 0.14 38); --c-accent-ink: #fbf1dc; }
.site-eroterest[data-theme="theme-purple"] { --c-accent: oklch(0.52 0.11 340); --c-accent-2: oklch(0.45 0.11 340); --c-accent-ink: #fbf1dc; }
.site-eroterest[data-theme="theme-mono-gold"] { --c-accent: oklch(0.66 0.12 74); --c-accent-2: oklch(0.57 0.12 74); --c-accent-ink: #2a1e0a; }
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
.site-eroterest { font-family: var(--ff); background: var(--c-page); color: var(--c-ink); letter-spacing: var(--ls); line-height: 1.75; -webkit-font-smoothing: antialiased; min-height: 100vh; font-weight: 400; }
.site-eroterest img { max-width: 100%; display: block; }
.site-eroterest a { color: inherit; text-decoration: none; }
.site-eroterest button { font-family: inherit; cursor: pointer; }
.container { max-width: var(--maxw); margin: 0px auto; padding-left: var(--pad); padding-right: var(--pad); }
.layout { max-width: var(--maxw); margin: 0px auto; padding: 0 var(--pad); display: grid; grid-template-columns: minmax(0px, 1fr) 320px; gap: 44px; align-items: start; }
.content-main { min-width: 0px; }
@media (max-width: 900px) {
  .layout { grid-template-columns: 1fr; gap: 38px; }
}
.c-header { position: sticky; top: 0px; z-index: 40; background: color-mix(in srgb, var(--c-page) 82%, transparent); backdrop-filter: saturate(1.2) blur(14px); border-bottom: 1px solid var(--c-line-2); }
.c-header__row { max-width: var(--maxw); margin: 0px auto; height: var(--head-h); padding: 0 var(--pad); display: flex; align-items: center; gap: 14px; }
.brand { font-weight: 500; font-size: 15px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-ink); }
.brand b { color: var(--c-accent); font-weight: 700; }
.c-header__spacer { flex: 1 1 0%; }
.c-tool { width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--c-line); background: transparent; color: var(--c-ink); display: grid; place-items: center; transition: background 0.2s, border-color 0.2s; }
.c-tool:hover { background: var(--c-surface-2); border-color: var(--c-accent); }
.c-tool svg { width: 17px; height: 17px; stroke: currentcolor; fill: none; stroke-width: 1.7; }
.header-search { overflow: hidden; max-height: 0px; transition: max-height 0.28s; border-bottom: 1px solid var(--c-line-2); }
.header-search.is-open { max-height: 80px; }
.header-search__inner { max-width: var(--maxw); margin: 0px auto; padding: 12px var(--pad); }
.header-search form { display: flex; gap: 8px; }
.header-search input { flex: 1 1 0%; height: 42px; border-radius: 999px; border: 1px solid var(--c-line); background: var(--c-surface); color: var(--c-ink); padding: 0px 18px; font-size: 14px; font-family: inherit; }
.header-search input:focus { outline: none; border-color: var(--c-accent); }
.header-search button { height: 42px; padding: 0px 20px; border-radius: 999px; border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; background: var(--c-accent); color: var(--c-accent-ink); font-weight: 500; font-size: 13px; }
.genre-nav { border-bottom: 1px solid var(--c-line-2); background: var(--c-page); }
.genre-nav .container { overflow: visible; }
.genre-nav ul { list-style: none; margin: 0px; padding: 12px var(--pad); display: flex; gap: 9px; overflow-x: auto; scrollbar-width: none; }
.genre-nav ul::-webkit-scrollbar { display: none; }
.genre-nav li { flex: 0 0 auto; }
.genre-nav a { display: inline-block; padding: 7px 15px; border-radius: 999px; font-size: 12.5px; white-space: nowrap; color: var(--c-ink-2); border: 1px solid var(--c-line); transition: color 0.2s, border-color 0.2s, background 0.2s; }
.genre-nav a:hover { color: var(--c-ink); border-color: var(--c-accent); }
.genre-nav a.is-active { color: var(--c-accent-ink); background: var(--c-accent); border-color: var(--c-accent); }
.drawer-scrim { position: fixed; inset: 0px; z-index: 60; background: rgba(0, 0, 0, 0.55); animation: 0.2s ease 0s 1 normal none running fade; }
.drawer { position: fixed; top: 0px; right: 0px; bottom: 0px; z-index: 61; width: min(84vw, 320px); background: var(--c-surface); border-left: 1px solid var(--c-line); padding: 22px; display: flex; flex-direction: column; gap: 6px; animation: 0.26s ease 0s 1 normal none running slideL; }
.drawer__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.drawer__head span { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--c-ink-3); }
.drawer a { padding: 13px 8px; border-bottom: 1px solid var(--c-line-2); font-size: 15px; color: var(--c-ink); transition: color 0.18s; }
.drawer a:hover { color: var(--c-accent); }
@keyframes slideL { 
  0% { transform: translateX(100%); }
  100% { transform: translateX(0px); }
}
@keyframes fade { 
  0% { opacity: 0; }
  100% { opacity: 1; }
}
@keyframes rise { 
  0% { opacity: 0; transform: translateY(10px); }
  100% { opacity: 1; transform: translateY(0px); }
}
.hero { max-width: var(--maxw); margin: 0px auto; padding: 52px var(--pad) 30px; }
.hero h1 { font-size: clamp(24px, 4.4vw, 38px); font-weight: 500; letter-spacing: 0.02em; line-height: 1.4; margin: 0px 0px 12px; }
.hero .lead { color: var(--c-ink-2); font-size: 15px; max-width: 60ch; margin: 0px; font-weight: 300; }
.hero__kicker { font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--c-accent); margin: 0px 0px 16px; }
.block { max-width: var(--maxw); margin: 0px auto; padding: 14px var(--pad) 30px; }
.section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin: 26px 0px 20px; }
.section-head h2 { font-size: 17px; font-weight: 500; letter-spacing: 0.08em; margin: 0px; display: flex; align-items: center; gap: 11px; }
.section-head h2::before { content: ""; width: 8px; height: 8px; border-radius: 2px; background: var(--c-accent); transform: rotate(45deg); }
.section-head .more { font-size: 12px; color: var(--c-ink-2); border-bottom: 1px solid transparent; transition: color 0.2s, border-color 0.2s; }
.section-head .more:hover { color: var(--c-accent); border-color: var(--c-accent); }
.card-grid { display: grid; grid-template-columns: repeat(2, minmax(0px, 1fr)); gap: var(--gap); }
@media (max-width: 600px) {
  .card-grid { grid-template-columns: 1fr; gap: 16px; }
}
.card { display: flex; flex-direction: column; background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); transition: border-color 0.25s, transform 0.25s, background 0.25s; }
.card:hover { border-color: var(--c-accent); background: var(--c-surface-2); }
.card .thumb { position: relative; aspect-ratio: 4 / 3; background: var(--thumb-bg); overflow: hidden; }
.card .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.card:hover .thumb img { transform: scale(1.035); }
.card .thumb__cat { position: absolute; top: 11px; left: 11px; font-size: 10.5px; letter-spacing: 0.08em; padding: 4px 9px; border-radius: 999px; background: color-mix(in srgb, var(--c-page) 62%, transparent); color: var(--c-ink); backdrop-filter: blur(4px); border: 1px solid var(--c-line-2); }
.card .thumb__dur { position: absolute; bottom: 11px; right: 11px; font-size: 11px; font-variant-numeric: tabular-nums; padding: 3px 8px; border-radius: 6px; background: rgba(0, 0, 0, 0.62); color: rgb(255, 255, 255); }
.card-body { padding: 15px 17px 17px; display: flex; flex-direction: column; gap: 10px; flex: 1 1 0%; }
.card-title { font-size: 14.5px; font-weight: 400; line-height: 1.6; color: var(--c-ink); margin: 0px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card-meta { display: flex; align-items: center; gap: 12px; font-size: 11.5px; color: var(--c-ink-3); margin-top: auto; }
.card-meta .star { color: var(--c-accent); font-variant-numeric: tabular-nums; }
.genre-tiles { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 12px; }
.genre-tile { padding: 20px 16px; border: 1px solid var(--c-line); border-radius: var(--radius-sm); background: var(--c-surface); font-size: 13.5px; color: var(--c-ink); display: flex; flex-direction: column; gap: 5px; transition: border-color 0.2s, background 0.2s; }
.genre-tile:hover { border-color: var(--c-accent); background: var(--c-surface-2); }
.genre-tile small { color: var(--c-ink-3); font-size: 11px; }
.ero-part, .c-adslot { border: 1px dashed var(--c-line); border-radius: var(--radius-sm); min-height: 64px; margin: 22px 0px; display: grid; place-items: center; color: var(--c-ink-3); font-size: 11px; letter-spacing: 0.12em; background: var(--c-line-2); }
.ero-part::before, .c-adslot::before { content: attr(data-slot); }
.article { max-width: 760px; }
.breadcrumb { font-size: 11.5px; color: var(--c-ink-3); margin: 6px 0px 20px; display: flex; gap: 8px; flex-wrap: wrap; }
.breadcrumb a:hover { color: var(--c-accent); }
.a-title { font-size: clamp(21px, 3.6vw, 29px); font-weight: 500; line-height: 1.5; letter-spacing: 0.01em; margin: 0px 0px 14px; }
.metaline { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; font-size: 12px; color: var(--c-ink-2); margin-bottom: 26px; }
.pr-badge { font-size: 10px; font-weight: 700; letter-spacing: 0.1em; padding: 3px 8px; border-radius: 5px; background: var(--c-accent); color: var(--c-accent-ink); }
.metaline .ero-site { color: var(--c-ink-3); }
.metaline .ero-site::before { content: "配信元 "; color: var(--c-ink-3); }
.ero-play { margin: 0px 0px 16px; }
.ero-play-btn { display: flex; align-items: center; justify-content: center; gap: 12px; width: 100%; padding: 19px; border-radius: var(--radius-sm); background: var(--c-accent); color: var(--c-accent-ink); font-size: 16px; font-weight: 700; letter-spacing: 0.04em; transition: filter 0.2s, transform 0.1s; }
.ero-play-btn:hover { filter: brightness(1.06); }
.ero-play-btn:active { transform: translateY(1px); }
.ero-play-btn svg { width: 20px; height: 20px; fill: currentcolor; }
.ero-thumb { margin: 0px 0px 4px; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--c-line); }
.ero-thumb .thumb { aspect-ratio: 4 / 3; background: var(--thumb-bg); position: relative; }
.ero-thumb img { width: 100%; height: 100%; object-fit: cover; }
.ero-thumb .thumb::after { content: ""; position: absolute; inset: 0px; display: grid; place-items: center; background: radial-gradient(circle, rgba(0, 0, 0, 0.15), transparent 60%); }
.ero-part-fzgrid { min-height: auto; padding: 16px; display: block; border-style: solid; }
.fzgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 10px; }
.fzgrid a { border: 1px solid var(--c-line); border-radius: 8px; overflow: hidden; aspect-ratio: 1 / 1.4; background: var(--thumb-bg); }
.fzgrid img { width: 100%; height: 100%; object-fit: cover; }
.fzgrid__cap { font-size: 10.5px; letter-spacing: 0.1em; color: var(--c-ink-3); text-transform: uppercase; }
.article-body { font-size: 15px; line-height: 2; color: var(--c-ink); margin: 26px 0px; }
.article-body p { margin: 0px 0px 20px; }
.article-body h3 { font-size: 17px; font-weight: 500; margin: 34px 0px 14px; letter-spacing: 0.03em; }
.ero-tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 26px 0px; }
.ero-tag { font-size: 12px; padding: 6px 13px; border-radius: 999px; border: 1px solid var(--c-line); color: var(--c-ink-2); transition: color 0.2s, border-color 0.2s; }
.ero-tag:hover { color: var(--c-accent); border-color: var(--c-accent); }
.ero-tag::before { content: "#"; color: var(--c-ink-3); margin-right: 2px; }
.related { margin: 44px 0px 10px; }
.share { display: flex; gap: 12px; margin: 30px 0px 10px; }
.share a { flex: 1 1 0%; text-align: center; padding: 13px; border-radius: var(--radius-sm); border: 1px solid var(--c-line); font-size: 13px; font-weight: 500; color: var(--c-ink); transition: border-color 0.2s, color 0.2s; }
.share a:hover { border-color: var(--c-accent); color: var(--c-accent); }
.archive-head { max-width: var(--maxw); margin: 0px auto; padding: 44px var(--pad) 8px; }
.archive-head h1 { font-size: clamp(20px, 3.4vw, 28px); font-weight: 500; margin: 0px; }
.archive-head p { color: var(--c-ink-3); font-size: 12.5px; margin: 8px 0px 0px; letter-spacing: 0.06em; }
.pager { display: flex; justify-content: center; gap: 12px; margin: 38px 0px 10px; }
.pager a { padding: 11px 22px; border-radius: 999px; border: 1px solid var(--c-line); font-size: 13px; color: var(--c-ink); transition: border-color 0.2s, color 0.2s; }
.pager a:hover { border-color: var(--c-accent); color: var(--c-accent); }
.pager span { padding: 11px 6px; font-size: 12.5px; color: var(--c-ink-3); }
.sidebar { display: flex; flex-direction: column; gap: 26px; position: sticky; top: calc(var(--head-h) + 16px); }
@media (max-width: 900px) {
  .sidebar { position: static; }
}
.widget__title { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--c-ink-3); margin: 0px 0px 14px; }
.widget { border: 1px solid var(--c-line); border-radius: var(--radius); padding: 20px; background: var(--c-surface); }
.widget form { display: flex; gap: 8px; }
.widget input[type="search"] { flex: 1 1 0%; height: 40px; border-radius: 999px; border: 1px solid var(--c-line); background: var(--c-page); color: var(--c-ink); padding: 0px 15px; font-size: 13px; font-family: inherit; }
.widget input:focus { outline: none; border-color: var(--c-accent); }
.widget button { height: 40px; width: 40px; border-radius: 50%; border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; background: var(--c-accent); color: var(--c-accent-ink); display: grid; place-items: center; }
.widget button svg { width: 15px; height: 15px; stroke: currentcolor; fill: none; stroke-width: 2; }
.tagcloud-wrap { display: flex; flex-wrap: wrap; gap: 7px; }
.tagcloud-wrap a { font-size: 12px; padding: 5px 11px; border-radius: 999px; border: 1px solid var(--c-line); color: var(--c-ink-2); transition: color 0.2s, border-color 0.2s; }
.tagcloud-wrap a:hover { color: var(--c-accent); border-color: var(--c-accent); }
.contact { max-width: 640px; margin: 0px auto; padding: 48px var(--pad) 60px; }
.contact h1 { font-size: clamp(22px, 3.6vw, 30px); font-weight: 500; margin: 0px 0px 8px; }
.contact p.lead { color: var(--c-ink-2); font-size: 14px; margin: 0px 0px 30px; font-weight: 300; }
.field { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.field label { font-size: 12px; letter-spacing: 0.08em; color: var(--c-ink-2); }
.field input, .field textarea { border: 1px solid var(--c-line); border-radius: var(--radius-sm); background: var(--c-surface); color: var(--c-ink); padding: 13px 15px; font-size: 14px; font-family: inherit; }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--c-accent); }
.field textarea { min-height: 150px; resize: vertical; line-height: 1.8; }
.btn-submit { width: 100%; padding: 15px; border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; border-radius: var(--radius-sm); background: var(--c-accent); color: var(--c-accent-ink); font-weight: 700; font-size: 15px; letter-spacing: 0.04em; transition: filter 0.2s; }
.btn-submit:hover { filter: brightness(1.06); }
.c-footer { border-top: 1px solid var(--c-line-2); margin-top: 50px; background: var(--c-surface); }
.c-footer__inner { max-width: var(--maxw); margin: 0px auto; padding: 38px var(--pad); }
.c-footer .note { font-size: 11.5px; color: var(--c-ink-3); line-height: 1.9; max-width: 70ch; margin: 0px 0px 16px; }
.c-footer .cr { font-size: 11px; color: var(--c-ink-3); letter-spacing: 0.1em; }
.c-footer .flinks { display: flex; gap: 18px; flex-wrap: wrap; margin: 0px 0px 20px; }
.c-footer .flinks a { font-size: 12.5px; color: var(--c-ink-2); }
.c-footer .flinks a:hover { color: var(--c-accent); }
.sp-cta { position: fixed; left: 0px; right: 0px; bottom: 0px; z-index: 45; padding: 12px var(--pad) calc(12px + env(safe-area-inset-bottom)); background: color-mix(in srgb,var(--c-page) 88%,transparent); backdrop-filter: blur(12px); border-top: 1px solid var(--c-line); animation: 0.24s ease 0s 1 normal none running rise; }
.btn-cta { display: flex; align-items: center; justify-content: center; gap: 10px; max-width: var(--maxw); margin: 0px auto; padding: 15px; border-radius: var(--radius-sm); background: var(--c-accent); color: var(--c-accent-ink); font-weight: 700; font-size: 15px; }
.btn-cta svg { width: 18px; height: 18px; fill: currentcolor; }
.pagetop { position: fixed; right: 18px; bottom: 78px; z-index: 44; width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--c-line); background: var(--c-surface); color: var(--c-ink); display: grid; place-items: center; box-shadow: rgba(0, 0, 0, 0.25) 0px 4px 16px; animation: 0.2s ease 0s 1 normal none running fade; }
.pagetop svg { width: 18px; height: 18px; stroke: currentcolor; fill: none; stroke-width: 2; }
.age-overlay { position: fixed; inset: 0px; z-index: 100; background: color-mix(in srgb,var(--c-page) 92%,#000); backdrop-filter: blur(6px); display: grid; place-items: center; padding: 24px; animation: 0.25s ease 0s 1 normal none running fade; }
.age-box { max-width: 420px; text-align: center; background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--radius); padding: 40px 32px; animation: 0.3s ease 0s 1 normal none running rise; }
.age-box .mark { font-size: 11px; letter-spacing: 0.28em; color: var(--c-accent); text-transform: uppercase; margin: 0px 0px 18px; }
.age-box h2 { font-size: 21px; font-weight: 500; margin: 0px 0px 12px; }
.age-box p { font-size: 13px; color: var(--c-ink-2); line-height: 1.9; margin: 0px 0px 26px; }
.age-actions { display: flex; flex-direction: column; gap: 11px; }
.age-enter { padding: 15px; border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; border-radius: var(--radius-sm); background: var(--c-accent); color: var(--c-accent-ink); font-weight: 700; font-size: 15px; }
.age-leave { padding: 14px; border: 1px solid var(--c-line); border-radius: var(--radius-sm); background: transparent; color: var(--c-ink-2); font-size: 13px; }
.demo-bar { position: fixed; z-index: 120; left: 50%; bottom: 16px; transform: translateX(-50%); display: flex; gap: 8px; align-items: center; padding: 8px 10px; border-radius: 999px; background: rgb(16, 16, 20); border: 1px solid rgba(255, 255, 255, 0.14); box-shadow: rgba(0, 0, 0, 0.5) 0px 10px 40px; font-family: var(--ff); font-size: 12px; }
.demo-bar select { background: rgb(28, 28, 34); color: rgb(238, 238, 238); border: 1px solid rgba(255, 255, 255, 0.14); border-radius: 999px; padding: 6px 10px; font-size: 12px; font-family: inherit; }
.demo-bar .seg { display: flex; gap: 3px; background: rgb(28, 28, 34); border-radius: 999px; padding: 3px; border: 1px solid rgba(255, 255, 255, 0.12); }
.demo-bar .seg button { border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; background: transparent; color: rgb(187, 187, 187); padding: 5px 11px; border-radius: 999px; font-size: 11.5px; }
.demo-bar .seg button.on { background: rgb(58, 58, 68); color: rgb(255, 255, 255); }
.demo-bar .lbl { color: rgb(106, 106, 114); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; padding-left: 4px; }
@media (max-width: 600px) {
  .demo-bar { flex-wrap: wrap; max-width: 94vw; justify-content: center; bottom: 76px; }
}
.site-eroterest { position: relative; }
.site-eroterest::before { content: ""; position: fixed; inset: 0px; z-index: 0; pointer-events: none; opacity: 0.5; background-image: radial-gradient(currentcolor 0.6px, transparent 0.6px); background-size: 5px 5px; color: var(--c-ink-3); mix-blend-mode: overlay; }
.site-eroterest > * { position: relative; z-index: 1; }
.brand, .hero h1, .a-title, .section-head h2, .age-box h2, .contact h1, .archive-head h1 { font-family: var(--ff-display); font-weight: 700; letter-spacing: 0.06em; }
.brand { letter-spacing: 0.2em; }
.hero__kicker, .widget__title, .hero .lead, .card-title { letter-spacing: 0.04em; }
.c-header { background: var(--c-page); backdrop-filter: none; border-bottom: var(--bd) solid var(--c-ink); }
.c-header::after { content: ""; display: block; height: 2px; background: var(--c-accent); }
.c-tool { border: var(--bd) solid var(--c-ink); border-radius: 6px; }
.c-tool:hover { background: var(--c-accent); color: var(--c-accent-ink); border-color: var(--c-ink); }
.genre-nav { border-bottom: var(--bd) solid var(--c-ink); }
.genre-nav a { border-radius: 6px; border: var(--bd) solid var(--c-line); font-weight: 500; background: var(--c-surface); box-shadow: 2px 2px 0 var(--c-line-2); }
.genre-nav a:hover { border-color: var(--c-ink); box-shadow: 2px 2px 0 var(--c-accent); }
.genre-nav a.is-active { border-color: var(--c-ink); box-shadow: 2px 2px 0 var(--c-ink); }
.section-head h2::before { content: "★"; width: auto; height: auto; background: none; transform: none; color: var(--c-accent); font-size: 15px; line-height: 1; }
.card { border: var(--bd) solid var(--c-ink); border-radius: var(--radius); box-shadow: var(--shadow); transition: transform 0.12s, box-shadow 0.12s, background 0.2s; }
.card:hover { background: var(--c-surface); transform: translate(2px, 2px); box-shadow: 1px 1px 0 var(--c-ink); }
.card .thumb { border-bottom: var(--bd) solid var(--c-ink); }
.card .thumb__cat { border-radius: 4px; border: 1.5px solid var(--c-ink); background: var(--c-accent); color: var(--c-accent-ink); backdrop-filter: none; font-weight: 700; }
.card .thumb__dur { border-radius: 4px; font-family: var(--ff-display); }
.genre-tile { border: var(--bd) solid var(--c-ink); box-shadow: var(--shadow); }
.genre-tile:hover { transform: translate(2px, 2px); box-shadow: 1px 1px 0 var(--c-ink); }
.ero-play-btn, .btn-cta, .btn-submit, .age-enter, .header-search button { border: var(--bd) solid var(--c-ink); border-radius: var(--radius-sm); box-shadow: 4px 4px 0 var(--c-ink); font-family: var(--ff-display); transition: transform 0.1s, box-shadow 0.1s, filter 0.2s; }
.ero-play-btn:hover, .btn-cta:hover, .btn-submit:hover, .age-enter:hover { transform: translate(2px, 2px); box-shadow: 2px 2px 0 var(--c-ink); filter: none; }
.ero-play-btn:active, .btn-submit:active { transform: translate(4px, 4px); box-shadow: 0 0 0 var(--c-ink); }
.ero-thumb { border: var(--bd) solid var(--c-ink); box-shadow: var(--shadow); }
.ero-thumb .thumb { border-width: medium; border-style: none; border-color: currentcolor; border-image: initial; }
.ero-part, .c-adslot { border: 2px dashed var(--c-ink); border-radius: var(--radius-sm); background: repeating-linear-gradient(45deg, var(--c-line-2) 0 8px, transparent 8px 16px); }
.ero-part-fzgrid { border-style: solid; background: var(--c-surface); }
.fzgrid a { border: var(--bd) solid var(--c-ink); }
.widget { border: var(--bd) solid var(--c-ink); box-shadow: var(--shadow); }
.widget input, .header-search input, .field input, .field textarea, .pager a, .ero-tag, .tagcloud-wrap a, .share a, .age-box { border-width: var(--bd); }
.age-box { border: var(--bd) solid var(--c-ink); box-shadow: 6px 6px 0 var(--c-accent); }
.age-leave { border: var(--bd) solid var(--c-ink); border-radius: var(--radius-sm); }
.metaline .pr-badge { border: 1.5px solid var(--c-ink); border-radius: 4px; }
.field input:focus, .field textarea:focus, .widget input:focus, .header-search input:focus { border-color: var(--c-accent); }
.c-footer { border-top: var(--bd) solid var(--c-ink); }
.pagetop { border: var(--bd) solid var(--c-ink); border-radius: 8px; box-shadow: 3px 3px 0 var(--c-ink); }
.sp-cta { background: var(--c-page); backdrop-filter: none; border-top: var(--bd) solid var(--c-ink); }

/* ===== WP実サイト向け調整（JS連動・engine互換） ===== */
.drawer[hidden],.drawer-scrim[hidden]{display:none!important;} /* ドロワーは既定非表示・theme.jsで開閉 */
.pagetop{display:none;} .pagetop.show{display:grid;}          /* スクロールで出現 */
.sp-cta{display:none;} .sp-cta.show{display:block;}           /* single・スクロールで出現 */
html.age-ok .age-overlay{display:none!important;}             /* Cookie済みは年齢確認を即時非表示 */
/* engine(enmedia_card/media/primary_cat)の出力をCのカードに整合 */
.card .thumb .media{position:absolute;inset:0;width:100%;height:100%;}
.card .thumb .media img,.card .thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.card .thumb .badge{position:absolute;left:8px;top:8px;z-index:2;font-size:11px;line-height:1;padding:4px 8px;border-radius:6px;background:var(--c-accent);color:var(--c-accent-ink);}
.card .card-title{font-weight:500;}
.card .card-meta .date{color:var(--c-ink-2);}
/* FANZAおすすめ作品グリッド（管理画面が注入する .ero-fz-*・ダーク/ミニマル） */
.ero-fz-block{margin:16px 0;}
.ero-fz-block .section-head,.ero-fz-head,.fzgrid__cap{font-weight:500;margin:0 0 10px;color:var(--c-ink);display:block;}
.ero-fz-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.ero-fz-item{display:block;text-decoration:none;color:var(--c-ink);}
.ero-fz-item img{width:100%;height:auto;aspect-ratio:3/4;object-fit:cover;border-radius:10px;display:block;background:var(--c-surface-2);}
.ero-fz-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:12px;line-height:1.35;margin-top:5px;color:var(--c-ink-2);}
@media(max-width:600px){.ero-fz-grid{grid-template-columns:repeat(2,1fr);gap:8px;}.ero-fz-grid .ero-fz-item:nth-child(n+7){display:none;}}

.age-overlay[hidden]{display:none!important;} /* 「はい」押下時 theme.js が付与する hidden を効かせる */
/* ===== FANZA審査記事(single-fanza)＆FANZA用サイドバー：テーマAと同構造・B/Cトークンで装飾 ===== */
.article-head .cat{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;}
.article-head .cat .badge{font-size:11px;line-height:1;padding:4px 9px;border-radius:999px;background:var(--c-accent);color:var(--c-accent-ink);}
.article-head .a-title{font-size:clamp(20px,4vw,28px);font-weight:600;line-height:1.5;}
.article-head .metaline{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:12px;padding-bottom:14px;color:var(--c-ink-2);font-size:12.5px;}
.article-head .metaline .dot{width:3px;height:3px;border-radius:50%;background:var(--c-line);}
.eyecatch{margin:6px 0 14px;}
.eyecatch .media,.eyecatch .ph{border-radius:10px;aspect-ratio:16/9;overflow:hidden;background:var(--c-surface-2);display:block;}
.eyecatch .media img{width:100%;height:100%;object-fit:contain;border-radius:10px;display:block;}
.sample-movie{position:relative;width:100%;aspect-ratio:16/9;margin:0 0 16px;border-radius:10px;overflow:hidden;background:#000;}
.sample-movie iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.toc{margin:18px 0;border:1px solid var(--c-line);border-radius:10px;background:var(--c-surface-2);overflow:hidden;}
.toc-toggle{display:flex;align-items:center;gap:9px;width:100%;padding:13px 15px;font-size:13.5px;font-weight:500;color:var(--c-ink);background:none;border:0;cursor:pointer;}
.toc-toggle .ic{color:var(--c-accent);display:grid;}.toc-toggle .chev{margin-left:auto;transition:transform .22s;color:var(--c-ink-2);display:grid;}
.toc[data-open="false"] .chev{transform:rotate(-90deg);}
.toc-body{padding:0 15px;max-height:800px;overflow:hidden;transition:max-height .3s,padding .3s;}
.toc[data-open="false"] .toc-body{max-height:0;}.toc[data-open="true"] .toc-body{padding-bottom:12px;}
.toc ol{counter-reset:toc;list-style:none;margin:0;padding:0;}.toc li{position:relative;}
.toc li a{display:block;padding:8px 0 8px 26px;font-size:13px;color:var(--c-ink-2);line-height:1.5;text-decoration:none;}
.toc li a:hover{color:var(--c-accent);}.toc li.lv3 a{padding-left:40px;font-size:12px;}
.toc li a::before{counter-increment:toc;content:counter(toc,decimal-leading-zero);position:absolute;left:0;top:8px;font-size:10px;color:var(--c-ink-2);}
.toc li.lv3 a::before{content:"";}
.points{margin:18px 0;padding:16px;border:1px solid var(--c-line);border-radius:10px;background:var(--c-surface-2);}
.points h3{display:flex;align-items:center;gap:7px;margin:0 0 10px;font-size:15px;font-weight:600;}
.points h3 .icon{width:18px;height:18px;fill:var(--c-accent);}
.points ul{margin:0;padding-left:20px;}.points li{margin:5px 0;line-height:1.6;}
.spec{margin:22px 0;}
.spec-table{width:100%;border-collapse:collapse;font-size:13px;}
.spec-table th,.spec-table td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--c-line);vertical-align:top;}
.spec-table th{width:6.5em;white-space:nowrap;color:var(--c-ink-2);font-weight:500;background:var(--c-surface-2);}
.spec-table td{color:var(--c-ink);}.spec-table a{color:var(--c-accent);text-decoration:none;}.spec-table a:hover{text-decoration:underline;}
.spec-table tr:last-child th,.spec-table tr:last-child td{border-bottom:none;}
.cta-block{display:grid;grid-template-columns:1fr;gap:14px;margin:22px 0;padding:18px;border:1px solid var(--c-line);border-radius:12px;background:var(--c-surface-2);}
@media(min-width:640px){.cta-block{grid-template-columns:220px 1fr;align-items:center;}}
.cta-sample{position:relative;border-radius:10px;overflow:hidden;background:var(--c-surface);}
.cta-sample .badge{position:absolute;left:8px;top:8px;z-index:2;font-size:11px;padding:4px 8px;border-radius:999px;background:var(--c-accent);color:var(--c-accent-ink);}
.cta-sample .media img{width:100%;height:auto;display:block;}
.cta-info h3{margin:0 0 10px;font-size:16px;font-weight:600;line-height:1.5;}
.cta-meta{display:flex;flex-direction:column;gap:5px;margin-bottom:12px;font-size:12.5px;}
.cta-meta .r{display:flex;gap:8px;}.cta-meta .k{color:var(--c-ink-2);min-width:5em;}.cta-meta .v{color:var(--c-ink);}
.cta-note{margin:8px 0 0;font-size:11px;color:var(--c-ink-2);}
.related-works{margin:24px 0;}
.rw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.rw-card{display:block;border-radius:8px;overflow:hidden;background:var(--c-surface-2);border:1px solid var(--c-line);text-decoration:none;color:var(--c-ink);transition:border-color .2s;}
.rw-card:hover{border-color:var(--c-accent);}
.rw-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--c-surface);}.rw-thumb img{width:100%;height:100%;object-fit:contain;display:block;}
.rw-title{padding:7px 9px;font-size:12px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
@media(max-width:600px){.rw-grid{gap:8px;}}
/* FANZA用サイドバー（新着/人気/ジャンル） */
.side-list,.pop-list{display:flex;flex-direction:column;gap:10px;}
.side-item,.pop-item{display:flex;gap:10px;align-items:center;text-decoration:none;color:var(--c-ink);}
.side-item .thumb,.pop-item .thumb{flex:0 0 72px;width:72px;aspect-ratio:16/10;border-radius:6px;overflow:hidden;background:var(--c-surface-2);}
.side-item .thumb img,.pop-item .thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.side-item .pt,.pop-item .pt{font-size:12.5px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:0;}
.si-date{font-size:11px;color:var(--c-ink-2);}
.pop-item{position:relative;}.pop-item .pno{flex:0 0 auto;width:20px;font-weight:700;color:var(--c-accent);font-size:14px;text-align:center;}
.genre-chips{display:flex;flex-wrap:wrap;gap:6px;}
.genre-chips a{font-size:12px;padding:5px 10px;border-radius:999px;border:1px solid var(--c-line);color:var(--c-ink-2);text-decoration:none;}
.genre-chips a:hover{border-color:var(--c-accent);color:var(--c-accent);}
.widget-title{display:flex;align-items:center;gap:7px;margin:0 0 10px;font-size:13px;font-weight:600;color:var(--c-ink);}
.widget-title .mark{width:8px;height:8px;border-radius:2px;background:var(--c-accent);transform:rotate(45deg);}
/* ===== FANZA投稿のサムネは画像全体表示(contain)。エロタレ(video)は cover のまま ===== */
.card[data-type="fanza"] .thumb .media img,
.card[data-type="fanza"] .thumb img{object-fit:contain;background:var(--c-surface-2);}
/* フッター: FANZA Webサービス クレジット */
.footer-powered{margin:6px 0 0;font-size:11px;color:var(--c-ink-2);text-align:center;}
.footer-powered a{color:var(--c-ink-2);text-decoration:underline;}
.footer-powered a:hover{color:var(--c-accent);}

/* 年齢確認: .site-eroterest > * の position:relative/z-index:1 に負けないよう固定オーバーレイを担保 */
.site-eroterest > .age-overlay{position:fixed;inset:0;z-index:9999;}

/* 固定/追従UIの重なり修正: デモの .site-eroterest>*{position:relative;z-index:1}＋::before{z-index:0} が
   main内の固定sp-ctaを閉じ込め、後続footerが被る問題を解消。背景ドットを最背面へ回して z-index:1 を解除。 */
.site-eroterest::before{z-index:-1;}
.site-eroterest > *{z-index:auto;}
.site-eroterest > .c-header{position:sticky;}
.site-eroterest > .pagetop{position:fixed;z-index:60;}
.site-eroterest > .drawer{position:fixed;z-index:61;}
.site-eroterest > .drawer-scrim{position:fixed;z-index:60;}
