.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; }
* { box-sizing: border-box; }
html, body { margin: 0px; padding: 0px; }
body { background: rgb(14, 14, 16); font-family: "Noto Sans JP", system-ui, sans-serif; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }
a { color: inherit; }
.site-eroterest { --sp: 16px; --maxw: 1180px; --demo-h: 52px; --r-card: 8px; --r-btn: 10px; --r-pill: 999px; --head-h: 60px; color: var(--c-ink); background: var(--c-page); font-family: "Noto Sans JP", system-ui, sans-serif; line-height: 1.6; min-height: 100vh; transition: background 0.25s, color 0.25s; }
.mono { font-family: "Roboto Mono", monospace; }
.site-eroterest[data-theme="theme-red"][data-mode="light"] { --c-page: #faf6f4; --c-surface: #ffffff; --c-surface-2: #f4ece9; --c-ink: #1c1512; --c-ink-2: #7a6d67; --c-line: #e9ddd8; --c-accent: #d81f36; --c-accent-2: #ff5a4d; --c-accent-ink: #ffffff; --shadow: 0 1px 2px rgba(30,10,10,.06); --shadow-lg: 0 14px 34px rgba(120,20,30,.14); }
.site-eroterest[data-theme="theme-red"][data-mode="dark"] { --c-page: #141010; --c-surface: #1f1817; --c-surface-2: #2b201e; --c-ink: #f6efec; --c-ink-2: #b3a49f; --c-line: #382b28; --c-accent: #ff3b52; --c-accent-2: #ff7a5c; --c-accent-ink: #1a0c0d; --shadow: 0 1px 2px rgba(0,0,0,.4); --shadow-lg: 0 16px 40px rgba(0,0,0,.55); }
.site-eroterest[data-theme="theme-purple"][data-mode="light"] { --c-page: #f7f5fb; --c-surface: #ffffff; --c-surface-2: #efeaf7; --c-ink: #191324; --c-ink-2: #6a6180; --c-line: #e5ddf1; --c-accent: #7c3aed; --c-accent-2: #c026d3; --c-accent-ink: #ffffff; --shadow: 0 1px 2px rgba(30,10,50,.06); --shadow-lg: 0 14px 34px rgba(70,20,140,.16); }
.site-eroterest[data-theme="theme-purple"][data-mode="dark"] { --c-page: #110d1a; --c-surface: #1b1527; --c-surface-2: #271d38; --c-ink: #f2ecfa; --c-ink-2: #a99fbf; --c-line: #312643; --c-accent: #a970ff; --c-accent-2: #e05be8; --c-accent-ink: #160a24; --shadow: 0 1px 2px rgba(0,0,0,.4); --shadow-lg: 0 16px 40px rgba(0,0,0,.6); }
.site-eroterest[data-theme="theme-mono-gold"][data-mode="light"] { --c-page: #f8f7f3; --c-surface: #ffffff; --c-surface-2: #efece4; --c-ink: #1b1813; --c-ink-2: #6c6558; --c-line: #e6e0d3; --c-accent: #b28522; --c-accent-2: #8a6a1c; --c-accent-ink: #ffffff; --shadow: 0 1px 2px rgba(30,25,10,.06); --shadow-lg: 0 14px 34px rgba(90,70,20,.14); }
.site-eroterest[data-theme="theme-mono-gold"][data-mode="dark"] { --c-page: #121110; --c-surface: #1c1a15; --c-surface-2: #26221a; --c-ink: #f4f1e7; --c-ink-2: #ada691; --c-line: #322d22; --c-accent: #d8b556; --c-accent-2: #b89235; --c-accent-ink: #171308; --shadow: 0 1px 2px rgba(0,0,0,.4); --shadow-lg: 0 16px 40px rgba(0,0,0,.55); }
.container { max-width: var(--maxw); margin: 0px auto; padding: 0px 16px; width: 100%; }
.site-main { padding: 22px 0px 60px; }
.page { display: none; }
.site-eroterest[data-page="top"] .page-top, .site-eroterest[data-page="single"] .page-single, .site-eroterest[data-page="archive"] .page-archive, .site-eroterest[data-page="contact"] .page-contact { display: block; }
.two-col { display: block; }
@media (min-width: 960px) {
  .two-col { display: grid; grid-template-columns: minmax(0px, 1fr) 300px; gap: 34px; align-items: start; }
}
.ero-part { margin: 0px; }
.slot-demo { border: 1px dashed var(--c-line); background: var(--c-surface-2); border-radius: 6px; color: var(--c-ink-2); font: 500 11px / 1.3 "Roboto Mono", monospace; letter-spacing: 0.02em; display: flex; align-items: center; justify-content: center; text-align: center; padding: 14px; min-height: 52px; gap: 8px; }
.slot-demo b { color: var(--c-ink); font-weight: 700; }
.ad-slot { width: 100%; background: var(--c-surface-2); border: 1px dashed var(--c-line); border-radius: 6px; min-height: 90px; display: flex; align-items: center; justify-content: center; color: var(--c-ink-2); font: 500 11px / 1.4 "Roboto Mono", monospace; text-align: center; }
.demo-bar { position: fixed; top: 0px; left: 0px; right: 0px; height: var(--demo-h); z-index: 200; background: rgb(17, 17, 20); border-bottom: 1px solid rgb(38, 38, 44); display: flex; align-items: center; gap: 14px; padding: 0px 14px; overflow-x: auto; white-space: nowrap; }
.demo-bar::-webkit-scrollbar { height: 0px; }
.demo-tag { font: 700 10px / 1 "Roboto Mono", monospace; letter-spacing: 0.12em; color: rgb(138, 138, 148); flex: 0 0 auto; }
.demo-grp { display: flex; align-items: center; gap: 6px; flex: 0 0 auto; }
.demo-lab { font: 600 10px / 1 "Roboto Mono", monospace; color: rgb(106, 106, 116); text-transform: uppercase; letter-spacing: 0.08em; }
.demo-pill { border: 1px solid rgb(51, 51, 60); background: rgb(27, 27, 32); color: rgb(201, 201, 210); border-radius: 999px; font: 600 12px / 1 "Noto Sans JP"; padding: 8px 13px; transition: 0.15s; }
.demo-pill:hover { border-color: rgb(74, 74, 85); color: rgb(255, 255, 255); }
.demo-pill[data-on="1"] { background: rgb(255, 255, 255); color: rgb(17, 17, 17); border-color: rgb(255, 255, 255); }
.demo-sw { width: 22px; height: 22px; border-radius: 50%; border: 2px solid rgb(51, 51, 60); padding: 0px; }
.demo-sw[data-on="1"] { border-color: rgb(255, 255, 255); box-shadow: rgb(17, 17, 17) 0px 0px 0px 2px, rgb(255, 255, 255) 0px 0px 0px 3px; }
.demo-div { width: 1px; height: 22px; background: rgb(42, 42, 49); flex: 0 0 auto; }
.wrap { margin-top: var(--demo-h); }
.site-header { position: sticky; top: var(--demo-h); z-index: 60; background: var(--c-surface); border-bottom: 1px solid var(--c-line); box-shadow: var(--shadow); }
.header-inner { display: flex; align-items: center; gap: 14px; height: var(--head-h); }
.brand { font-weight: 900; font-size: 22px; letter-spacing: -0.02em; text-decoration: none; color: var(--c-ink); flex: 0 0 auto; display: flex; align-items: center; gap: 2px; }
.brand .brand-x { color: var(--c-accent); }
.header-search { flex: 1 1 0%; display: none; }
@media (min-width: 760px) {
  .header-search { display: block; }
}
.search-form { display: flex; align-items: center; background: var(--c-surface-2); border: 1px solid var(--c-line); border-radius: var(--r-pill); overflow: hidden; max-width: 440px; }
.search-form input { flex: 1 1 0%; border: 0px; background: transparent; padding: 10px 16px; font-size: 14px; color: var(--c-ink); outline: none; min-width: 0px; }
.search-form input::placeholder { color: var(--c-ink-2); }
.search-form button { border: 0px; background: transparent; padding: 0px 14px; height: 40px; display: flex; align-items: center; color: var(--c-ink-2); }
.header-tools { display: flex; align-items: center; gap: 6px; margin-left: auto; flex: 0 0 auto; }
.icon-btn { width: 42px; height: 42px; border-radius: 10px; border: 1px solid var(--c-line); background: var(--c-surface); display: flex; align-items: center; justify-content: center; color: var(--c-ink); }
.icon-btn:hover { background: var(--c-surface-2); }
@media (min-width: 760px) {
  .js-search-toggle { display: none; }
}
.svgi { width: 20px; height: 20px; stroke: currentcolor; stroke-width: 2; fill: none; }
.genre-nav { background: var(--c-surface); border-bottom: 1px solid var(--c-line); }
.genre-nav ul { list-style: none; margin: 0px; padding: 0px; display: flex; gap: 2px; overflow-x: auto; scrollbar-width: none; }
.genre-nav ul::-webkit-scrollbar { height: 0px; }
.genre-nav li { flex: 0 0 auto; }
.genre-nav a { display: block; padding: 13px 15px; text-decoration: none; color: var(--c-ink-2); font-weight: 700; font-size: 13.5px; letter-spacing: -0.01em; white-space: nowrap; border-bottom: 3px solid transparent; transition: 0.15s; }
.genre-nav a:hover { color: var(--c-ink); }
.genre-nav a.on { color: var(--c-accent); border-bottom-color: var(--c-accent); }
.msearch { padding: 12px 0px; border-bottom: 1px solid var(--c-line); background: var(--c-surface); }
.mdrawer { background: var(--c-surface); border-bottom: 1px solid var(--c-line); }
.mdrawer ul { list-style: none; margin: 0px; padding: 6px 0px; }
.mdrawer a { display: block; padding: 12px 16px; text-decoration: none; color: var(--c-ink); font-weight: 700; border-bottom: 1px solid var(--c-line); }
.card-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
@media (min-width: 600px) {
  .card-grid { grid-template-columns: repeat(3, 1fr); gap: 16px; }
}
@media (min-width: 960px) {
  .card-grid { grid-template-columns: repeat(4, 1fr); }
}
.card { display: flex; flex-direction: column; background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--r-card); overflow: hidden; text-decoration: none; color: var(--c-ink); transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s; }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: transparent; }
.thumb { position: relative; aspect-ratio: 4 / 3; overflow: hidden; background: var(--c-surface-2); }
.ph { position: absolute; inset: 0px; background-image: repeating-linear-gradient(135deg, rgba(0, 0, 0, 0.035) 0px, rgba(0, 0, 0, 0.035) 1px, transparent 1px, transparent 9px); display: flex; align-items: center; justify-content: center; }
.ph::after { content: attr(data-l); font: 500 10px / 1 "Roboto Mono", monospace; color: var(--c-ink-2); opacity: 0.8; letter-spacing: 0.06em; }
.cat-chip { position: absolute; top: 7px; left: 7px; background: var(--c-accent); color: var(--c-accent-ink); font-weight: 700; font-size: 10.5px; padding: 3px 8px; border-radius: var(--r-pill); letter-spacing: 0.02em; }
.thumb-star { position: absolute; bottom: 7px; right: 7px; background: rgba(0, 0, 0, 0.62); color: rgb(255, 215, 94); font-weight: 700; font-size: 11px; padding: 2px 7px; border-radius: var(--r-pill); }
.card-body { padding: 9px 11px 11px; display: flex; flex-direction: column; gap: 7px; flex: 1 1 0%; }
.card-title { font-weight: 700; font-size: 13.5px; line-height: 1.4; letter-spacing: -0.01em; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card-meta { display: flex; align-items: center; gap: 8px; margin-top: auto; font-size: 11px; color: var(--c-ink-2); }
.card-meta .star { color: rgb(224, 165, 42); font-weight: 700; }
.section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin: 0px 0px 14px; padding-bottom: 10px; border-bottom: 2px solid var(--c-ink); }
.section-head h2 { margin: 0px; font-size: 19px; font-weight: 900; letter-spacing: -0.02em; display: flex; align-items: center; gap: 9px; }
.section-head h2::before { content: ""; width: 5px; height: 20px; background: var(--c-accent); border-radius: 2px; display: inline-block; }
.see-all { font-size: 12px; font-weight: 700; color: var(--c-accent); text-decoration: none; white-space: nowrap; }
.block { margin: 0px 0px 34px; }
.hero { margin: 0px 0px 30px; }
.hero-band { margin: 0px 0px 18px; }
.hero-band .eyebrow { font: 700 11px / 1 "Roboto Mono", monospace; letter-spacing: 0.18em; color: var(--c-accent); text-transform: uppercase; }
.hero-band h1 { margin: 9px 0px 8px; font-size: clamp(26px, 5vw, 42px); font-weight: 900; line-height: 1.12; letter-spacing: -0.03em; }
.hero-band .lead { margin: 0px; color: var(--c-ink-2); font-size: 14.5px; max-width: 640px; }
.hero-mosaic { display: grid; grid-template-columns: 1fr; gap: 12px; }
@media (min-width: 700px) {
  .hero-mosaic { grid-template-columns: 1.7fr 1fr; grid-template-rows: 1fr 1fr; }
  .hm-big { grid-row: 1 / 3; }
}
.hm-big .thumb { aspect-ratio: 16 / 10; }
.hm-big .card-title { font-size: 17px; -webkit-line-clamp: 2; }
.feat-tag { display: inline-block; background: var(--c-ink); color: var(--c-page); font-weight: 700; font-size: 10.5px; padding: 3px 9px; border-radius: var(--r-pill); margin-bottom: 7px; letter-spacing: 0.04em; width: fit-content; }
.genre-find { margin: 0px 0px 10px; }
.genre-tiles { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
@media (min-width: 600px) {
  .genre-tiles { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 960px) {
  .genre-tiles { grid-template-columns: repeat(6, 1fr); }
}
.genre-tile { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--r-card); padding: 16px 8px; text-decoration: none; color: var(--c-ink); font-weight: 700; font-size: 13px; transition: 0.16s; }
.genre-tile:hover { border-color: var(--c-accent); color: var(--c-accent); transform: translateY(-2px); }
.genre-tile .gt-count { font: 500 10px / 1 "Roboto Mono", monospace; color: var(--c-ink-2); }
.breadcrumbs { font-size: 12px; color: var(--c-ink-2); margin: 0px 0px 14px; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.breadcrumbs a { color: var(--c-ink-2); text-decoration: none; }
.breadcrumbs a:hover { color: var(--c-accent); }
.breadcrumbs .sep { opacity: 0.5; }
.a-title { font-size: clamp(21px, 3.6vw, 30px); font-weight: 900; line-height: 1.25; letter-spacing: -0.02em; margin: 0px 0px 12px; }
.metaline { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; margin: 0px 0px 18px; font-size: 12.5px; color: var(--c-ink-2); }
.pr-badge { background: var(--c-surface-2); color: var(--c-ink-2); border: 1px solid var(--c-line); font-weight: 700; font-size: 10.5px; padding: 2px 8px; border-radius: 4px; letter-spacing: 0.06em; }
.metaline time { font-weight: 500; }
.ero-site { display: inline-flex; align-items: center; gap: 5px; font-weight: 700; color: var(--c-ink); }
.ero-site::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--c-accent); }
.ero-play { margin: 0px 0px 14px; }
.ero-play-btn { display: flex; align-items: center; justify-content: center; gap: 12px; background: var(--c-accent); color: var(--c-accent-ink); font-weight: 900; font-size: 18px; letter-spacing: 0.01em; padding: 19px 20px; border-radius: var(--r-btn); text-decoration: none; box-shadow: var(--shadow-lg); transition: transform 0.15s, filter 0.15s; }
.ero-play-btn:hover { transform: translateY(-2px); filter: brightness(1.06); }
.play-ico { width: 22px; height: 22px; fill: currentcolor; }
.ero-thumb { margin: 0px 0px 18px; border-radius: var(--r-btn); overflow: hidden; box-shadow: var(--shadow); }
.ero-thumb a { display: block; position: relative; }
.ero-thumb .thumb { aspect-ratio: 16 / 9; border-radius: var(--r-btn); }
.ero-thumb .play-overlay { position: absolute; inset: 0px; display: flex; align-items: center; justify-content: center; }
.ero-thumb .play-overlay span { width: 64px; height: 64px; border-radius: 50%; background: rgba(0, 0, 0, 0.5); display: flex; align-items: center; justify-content: center; backdrop-filter: blur(2px); }
.ero-thumb .play-overlay svg { width: 26px; height: 26px; fill: rgb(255, 255, 255); margin-left: 3px; }
.ero-part-linked, .ero-part-fzgrid, .ero-part-after-linked, .ero-part-after-banner { margin: 0px 0px 18px; }
.fz-head { font-weight: 900; font-size: 15px; margin: 0px 0px 10px; display: flex; align-items: center; gap: 8px; }
.fz-head::before { content: ""; width: 4px; height: 16px; background: var(--c-accent); border-radius: 2px; }
.fz-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
@media (min-width: 600px) {
  .fz-grid { grid-template-columns: repeat(6, 1fr); }
}
.fz-item { text-decoration: none; color: var(--c-ink); }
.fz-item .thumb { aspect-ratio: 3 / 4; border-radius: 6px; }
.fz-item .fz-t { font-size: 11px; font-weight: 500; margin-top: 5px; line-height: 1.35; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.article-body { font-size: 15px; line-height: 1.85; color: var(--c-ink); margin: 22px 0px; }
.article-body p { margin: 0px 0px 16px; }
.article-body h2 { font-size: 19px; font-weight: 900; margin: 26px 0px 12px; letter-spacing: -0.01em; }
.ero-tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 20px 0px; }
.ero-tag { background: var(--c-surface-2); border: 1px solid var(--c-line); color: var(--c-ink-2); text-decoration: none; font-size: 12px; font-weight: 500; padding: 6px 12px; border-radius: var(--r-pill); transition: 0.15s; }
.ero-tag::before { content: "#"; opacity: 0.55; margin-right: 2px; }
.ero-tag:hover { border-color: var(--c-accent); color: var(--c-accent); }
.related { margin: 30px 0px 0px; }
.share { display: flex; align-items: center; gap: 10px; margin: 26px 0px 0px; flex-wrap: wrap; }
.share .share-lab { font-weight: 700; font-size: 13px; }
.share a { display: inline-flex; align-items: center; gap: 7px; text-decoration: none; font-weight: 700; font-size: 13px; padding: 9px 16px; border-radius: var(--r-btn); color: rgb(255, 255, 255); }
.share .x-btn { background: rgb(17, 17, 17); }
.share .line-btn { background: rgb(6, 199, 85); }
.site-eroterest[data-mode="dark"] .share .x-btn { background: rgb(51, 51, 51); }
.arch-head { margin: 0px 0px 20px; padding: 20px; background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--r-card); }
.arch-head .kicker { font: 700 11px / 1 "Roboto Mono", monospace; letter-spacing: 0.16em; color: var(--c-accent); text-transform: uppercase; }
.arch-head h1 { margin: 8px 0px 4px; font-size: 26px; font-weight: 900; letter-spacing: -0.02em; }
.arch-head p { margin: 0px; color: var(--c-ink-2); font-size: 13px; }
.pager { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 32px 0px 0px; flex-wrap: wrap; }
.pager a, .pager span { min-width: 42px; height: 42px; padding: 0px 14px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--c-line); background: var(--c-surface); border-radius: 9px; text-decoration: none; color: var(--c-ink); font-weight: 700; font-size: 14px; }
.pager a:hover { border-color: var(--c-accent); color: var(--c-accent); }
.pager .cur { background: var(--c-accent); color: var(--c-accent-ink); border-color: var(--c-accent); }
.pager .ell { border: 0px; background: transparent; }
.contact-wrap { max-width: 640px; margin: 0px auto; }
.contact-wrap .arch-head { margin-bottom: 22px; }
.form-card { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--r-card); padding: 24px; }
.field { margin: 0px 0px 18px; }
.field label { display: block; font-weight: 700; font-size: 13px; margin: 0px 0px 7px; }
.field label .req { color: var(--c-accent); margin-left: 4px; }
.field input, .field textarea { width: 100%; border: 1px solid var(--c-line); background: var(--c-page); border-radius: 8px; padding: 12px 14px; font-size: 14px; font-family: inherit; color: var(--c-ink); outline: none; transition: 0.15s; }
.field input:focus, .field textarea:focus { border-color: var(--c-accent); box-shadow: 0 0 0 3px color-mix(in srgb,var(--c-accent) 18%,transparent); }
.field textarea { resize: vertical; min-height: 140px; }
.btn-submit { width: 100%; background: var(--c-accent); color: var(--c-accent-ink); border: 0px; border-radius: var(--r-btn); padding: 15px; font-weight: 900; font-size: 15px; letter-spacing: 0.02em; }
.btn-submit:hover { filter: brightness(1.06); }
.sidebar { margin-top: 34px; }
@media (min-width: 960px) {
  .sidebar { margin-top: 0px; }
}
.widget { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: var(--r-card); padding: 16px; margin: 0px 0px 18px; }
.widget-title { font-weight: 900; font-size: 14px; margin: 0px 0px 12px; display: flex; align-items: center; gap: 7px; }
.widget-title::before { content: ""; width: 4px; height: 15px; background: var(--c-accent); border-radius: 2px; }
.tagcloud-wrap { display: flex; flex-wrap: wrap; gap: 7px; }
.tagcloud-wrap a { font-size: 12px; font-weight: 500; color: var(--c-ink-2); text-decoration: none; background: var(--c-surface-2); padding: 5px 10px; border-radius: var(--r-pill); transition: 0.15s; }
.tagcloud-wrap a:hover { color: var(--c-accent); }
.site-footer { background: var(--c-surface); border-top: 1px solid var(--c-line); margin-top: 20px; }
.footer-inner { padding: 30px 0px; }
.foot-brand { font-weight: 900; font-size: 20px; letter-spacing: -0.02em; margin: 0px 0px 10px; }
.foot-brand .brand-x { color: var(--c-accent); }
.foot-note { font-size: 11.5px; line-height: 1.8; color: var(--c-ink-2); max-width: 720px; margin: 0px 0px 16px; }
.foot-note .r18 { display: inline-block; border: 1px solid var(--c-accent); color: var(--c-accent); font-weight: 700; font-size: 10px; padding: 1px 6px; border-radius: 4px; margin-right: 6px; }
.foot-links { display: flex; flex-wrap: wrap; gap: 16px; margin: 0px 0px 16px; }
.foot-links a { font-size: 12px; font-weight: 700; color: var(--c-ink); text-decoration: none; }
.foot-links a:hover { color: var(--c-accent); }
.copyright { font-size: 11px; color: var(--c-ink-2); border-top: 1px solid var(--c-line); padding-top: 16px; }
.sp-cta { position: fixed; left: 0px; right: 0px; bottom: 0px; z-index: 80; padding: 10px 14px calc(10px + env(safe-area-inset-bottom)); background: linear-gradient(to top,var(--c-page) 60%,transparent); display: none; }
.site-eroterest[data-page="single"] .sp-cta, .site-eroterest[data-page="archive"] .sp-cta { display: block; }
@media (min-width: 760px) {
  .sp-cta { display: none !important; }
}
.btn-cta { display: flex; align-items: center; justify-content: center; gap: 10px; background: var(--c-accent); color: var(--c-accent-ink); font-weight: 900; font-size: 16px; padding: 15px; border-radius: var(--r-btn); text-decoration: none; box-shadow: var(--shadow-lg); }
.btn-cta svg { width: 20px; height: 20px; fill: currentcolor; }
.to-top { position: fixed; right: 16px; bottom: 80px; z-index: 70; width: 46px; height: 46px; border-radius: 50%; border: 1px solid var(--c-line); background: var(--c-surface); color: var(--c-ink); box-shadow: var(--shadow-lg); display: flex; align-items: center; justify-content: center; }
@media (min-width: 760px) {
  .to-top { bottom: 24px; }
}
.to-top:hover { color: var(--c-accent); }
.age-overlay { position: fixed; inset: 0px; z-index: 300; background: rgba(8, 6, 10, 0.82); backdrop-filter: blur(6px); display: flex; align-items: center; justify-content: center; padding: 20px; animation: 0.3s ease 0s 1 normal none running agefade; }
@keyframes agefade { 
  0% { opacity: 0; }
  100% { opacity: 1; }
}
.age-card { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 16px; max-width: 420px; width: 100%; padding: 32px 28px; text-align: center; box-shadow: rgba(0, 0, 0, 0.5) 0px 30px 80px; }
.age-r18 { display: inline-flex; align-items: center; justify-content: center; width: 60px; height: 60px; border-radius: 50%; background: var(--c-accent); color: var(--c-accent-ink); font-weight: 900; font-size: 17px; margin: 0px auto 16px; letter-spacing: 0.02em; }
.age-card h2 { margin: 0px 0px 10px; font-size: 20px; font-weight: 900; letter-spacing: -0.01em; }
.age-card p { margin: 0px 0px 22px; font-size: 13px; line-height: 1.7; color: var(--c-ink-2); }
.age-actions { display: flex; flex-direction: column; gap: 10px; }
.age-enter { background: var(--c-accent); color: var(--c-accent-ink); border: 0px; border-radius: var(--r-btn); padding: 15px; font-weight: 900; font-size: 15px; }
.age-enter:hover { filter: brightness(1.06); }
.age-leave { background: transparent; color: var(--c-ink-2); border: 1px solid var(--c-line); border-radius: var(--r-btn); padding: 13px; font-weight: 700; font-size: 13.5px; }
.age-leave:hover { background: var(--c-surface-2); }
.age-left { padding: 40px 24px; text-align: center; color: var(--c-ink-2); font-size: 14px; }

/* ===== engine互換（enmedia_card/enmedia_media/enmedia_primary_cat の出力をデザインのカードに整合） ===== */
.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:999px;background:var(--c-accent);color:var(--c-accent-ink);font-weight:500;}
.card .card-title{font-weight:500;}
.card .card-meta .date{color:var(--c-ink-2);}
/* FANZAおすすめ作品グリッド（管理画面が注入する .ero-fz-* を雑誌グリッド風に） */
.ero-fz-block{margin:14px 0;}
.ero-fz-block .section-head,.ero-fz-head{font-weight:500;margin:0 0 10px;color:var(--c-ink);}
.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:16/11;object-fit:cover;border-radius:var(--r-card,8px);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;}
.ero-fz-item:hover .ero-fz-title{color:var(--c-accent);}
@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;}}

/* ===== WP実サイト向け調整（デモ固有要素の無効化・JS連動） ===== */
.site-eroterest{--demo-h:0px;} /* デモの上部ツールバー高さを無効化（stickyヘッダをtop:0に） */
html.age-ok .age-overlay{display:none!important;} /* Cookie済みは年齢確認を即時非表示（フラッシュ防止） */
.to-top{display:none;} .to-top.show{display:flex;} /* ページトップはスクロールで出現（theme.js .show連動） */

.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);}
