:root {
  --bg: #ecebe4;
  --ink: #191b1f;
  --muted: #697076;
  --line: #c9c8bf;
  --paper: #fffefa;
  --rail: #24272b;
  --rail-ink: #f8f5ec;
  --rail-muted: #c6c0b4;
  --accent: #b0183a;
  --accent-2: #006e72;
  --gold: #a86812;
  --blue: #245784;
}
* { box-sizing: border-box; }
html { background: var(--bg); color: var(--ink); font-family: "Yu Gothic", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif; line-height: 1.58; }
body { margin: 0; }
a { color: var(--accent-2); text-decoration-thickness: 1px; text-underline-offset: 3px; }
.app-frame { min-height: 100vh; display: grid; grid-template-columns: 252px minmax(0, 1fr); }
.side-rail { position: sticky; top: 0; height: 100vh; overflow: auto; padding: 16px 0 28px; background: var(--rail); color: var(--rail-ink); border-right: 1px solid #16181b; }
.rail-brand { display: block; padding: 14px 18px 18px; color: var(--rail-ink); font-size: 1.18rem; font-weight: 850; text-decoration: none; }
.rail-group { border-top: 1px solid rgba(255,255,255,.12); }
.rail-group h2 { margin: 0; padding: 10px 18px 7px; background: #c8c8c2; color: #202124; font-size: 1.08rem; line-height: 1.25; }
.rail-group a { display: block; padding: 12px 22px; color: var(--rail-ink); border-bottom: 1px solid rgba(143,183,212,.38); text-decoration: none; font-size: 1.06rem; }
.rail-group a:hover { background: #30343a; }
.rail-group a.active { background: var(--accent); color: white; font-weight: 800; }
.content-shell { min-width: 0; }
.site-header { position: sticky; top: 0; z-index: 5; display: flex; justify-content: space-between; align-items: center; gap: 24px; padding: 11px clamp(16px, 3vw, 34px); border-bottom: 1px solid var(--line); background: rgba(255,254,250,.96); backdrop-filter: blur(8px); }
.brand { color: var(--ink); font-weight: 850; text-decoration: none; }
.top-nav { display: flex; gap: 6px; flex-wrap: wrap; }
.top-nav a { padding: 6px 9px; border: 1px solid var(--line); color: var(--ink); background: #f6f4ed; text-decoration: none; font-size: .9rem; }
.top-nav a.active { background: var(--ink); color: white; border-color: var(--ink); }
main { max-width: 1180px; margin: 0 auto; padding: 22px clamp(14px, 3vw, 36px) 64px; }
.search-band, .page-hero, .band { margin: 0 0 16px; padding: 18px; border: 1px solid var(--line); background: var(--paper); box-shadow: 0 1px 0 rgba(0,0,0,.04); }
.feature-band { border-top: 4px solid var(--accent); }
.page-hero { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 18px; align-items: start; }
.human-hero { align-items: center; }
.profile-photo { width: clamp(108px, 15vw, 164px); aspect-ratio: 3 / 4; overflow: hidden; border: 1px solid var(--line); background: #e6e4db; justify-self: end; }
.profile-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.eyebrow { margin: 0 0 5px; color: var(--accent); font-size: .72rem; font-weight: 850; text-transform: uppercase; letter-spacing: 0; }
h1 { margin: 0; font-size: 2rem; line-height: 1.22; letter-spacing: 0; }
h2 { margin: 0 0 12px; padding-bottom: 7px; border-bottom: 2px solid var(--ink); font-size: 1.16rem; letter-spacing: 0; }
h3 { margin: 0 0 8px; font-size: 1rem; line-height: 1.35; letter-spacing: 0; }
.lead { max-width: 820px; color: var(--muted); margin: 9px 0 0; }
.badge-row { display: flex; gap: 8px; flex-wrap: wrap; align-items: flex-start; }
.badge { display: inline-flex; align-items: center; min-height: 25px; padding: 3px 7px; background: #efeee6; border: 1px solid var(--line); color: var(--ink); font-size: .8rem; font-weight: 700; }
.badge.strong { background: #e2f2ef; border-color: #94c9c3; color: #005f63; }
.badge.warn { background: #fbefd8; border-color: #dfb866; color: #6b4300; }
.badge.route { background: #f7e0e6; border-color: #d893a6; color: var(--accent); }
.badge.log { background: #e5edf5; border-color: #aec4d8; color: var(--blue); }
#site-search { width: min(820px, 100%); margin-top: 16px; padding: 12px 13px; border: 2px solid #202124; background: white; color: var(--ink); font: inherit; font-size: 1.02rem; }
.search-results { display: grid; gap: 8px; margin-top: 12px; max-width: 860px; }
.search-hit { display: block; padding: 10px 12px; border: 1px solid var(--line); background: white; text-decoration: none; }
.subline { display: block; color: var(--muted); font-size: .88rem; margin-top: 2px; }
.meta-grid { display: grid; grid-template-columns: minmax(105px, 165px) minmax(0, 1fr); gap: 7px 16px; margin: 0; }
.meta-grid dt { color: var(--muted); }
.meta-grid dd { margin: 0; min-width: 0; overflow-wrap: anywhere; }
.split { display: grid; grid-template-columns: minmax(160px, 246px) minmax(0, 1fr); gap: 18px; align-items: start; }
.cover { width: 100%; max-width: 246px; border: 1px solid var(--line); background: #e9e9e1; }
.primary-link { display: inline-flex; margin-top: 14px; padding: 9px 12px; background: var(--accent-2); color: white; text-decoration: none; font-weight: 800; }
.link-list, .rank-list { margin: 0; padding-left: 22px; }
.link-list li, .rank-list li { margin: 7px 0; padding-right: 8px; }
.log-list { margin: 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.log-list li { padding: 10px 12px; border-left: 4px solid var(--blue); background: #f7f8f6; }
.log-title { font-weight: 800; overflow-wrap: anywhere; }
.log-summary { margin: 5px 0 7px; }
.log-summary strong { color: var(--muted); font-size: .86rem; }
.log-excerpt { margin: 8px 0 7px; padding: 8px 10px; border-left: 3px solid var(--accent); background: #fff; color: #26282b; font-size: .96rem; line-height: 1.55; overflow-wrap: anywhere; }
.log-tags { display: flex; flex-wrap: wrap; gap: 5px; margin: 0 0 4px; }
.log-tag { display: inline-flex; align-items: center; min-height: 22px; padding: 2px 6px; border: 1px solid #b9c8d6; background: #eef4f8; color: var(--blue); font-size: .78rem; font-weight: 750; }
.conversation-overview { margin-bottom: 12px; padding: 12px; border: 1px solid #d8d7cf; background: #fbfaf5; }
.metric-strip { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 9px; }
.metric-chip { display: inline-grid; grid-template-columns: minmax(0, 1fr) auto; gap: 8px; align-items: center; min-height: 30px; padding: 4px 8px; border: 1px solid #9dbfc0; background: #e7f2f1; color: #005f63; font-size: .82rem; }
.metric-chip.soft { border-color: #d6c196; background: #fbf1da; color: #6b4300; }
.metric-chip strong { min-width: 0; overflow-wrap: anywhere; }
.metric-chip em { font-style: normal; font-weight: 850; }
.log-signal { display: inline-flex; margin: 0 0 5px; padding: 2px 7px; background: var(--ink); color: white; font-size: .78rem; font-weight: 800; }
.nav-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; }
.nav-grid a { display: block; min-height: 72px; padding: 12px; border: 1px solid var(--line); background: #f7f6f0; color: var(--ink); text-decoration: none; }
.nav-grid strong { display: block; }
.nav-grid span { display: block; color: var(--muted); font-size: .88rem; margin-top: 4px; }
.qa-block { border-left: 5px solid var(--accent-2); padding-left: 14px; }
.question { margin: 0 0 6px; color: var(--muted); font-weight: 700; }
.answer { font-size: 1.2rem; font-weight: 750; margin: 0 0 12px; }
.source-note { color: var(--muted); font-size: .86rem; margin: 12px 0 0; }
.work-card-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin: 0; padding: 0; list-style: none; }
.work-card { display: grid; grid-template-columns: 88px minmax(0, 1fr); gap: 11px; padding: 11px; border: 1px solid var(--line); background: white; }
.thumb { width: 88px; aspect-ratio: 3 / 4; object-fit: cover; border: 1px solid var(--line); background: #e9e9e1; }
.media-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.media-tile { min-width: 0; border: 1px solid var(--line); background: #fff; }
.tile-image { display: block; aspect-ratio: 3 / 4; background: #deddd4; overflow: hidden; }
.tile-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.tile-copy { padding: 9px; }
.tile-status { display: inline-block; margin-bottom: 5px; padding: 2px 6px; background: var(--accent); color: #fff; font-size: .72rem; font-weight: 800; }
.tile-title { display: block; color: var(--ink); font-weight: 800; text-decoration: none; line-height: 1.36; overflow-wrap: anywhere; }
.tile-meta { display: block; color: var(--muted); font-size: .82rem; margin-top: 5px; }
.panel-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.compact-panel { border: 1px solid var(--line); background: #f8f7f1; padding: 12px; }
.compact-panel h3 { border-bottom: 1px solid var(--line); padding-bottom: 6px; }
.compact-panel ul { list-style: none; margin: 0; padding: 0; }
.compact-panel li { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 10px; padding: 7px 0; border-bottom: 1px solid #e1e0d8; }
.compact-panel li:last-child { border-bottom: 0; }
.compact-panel a { min-width: 0; overflow-wrap: anywhere; font-weight: 700; }
.compact-panel span { color: var(--muted); font-size: .78rem; }
.detail-list { margin: 0; padding: 0; list-style: none; display: grid; gap: 8px; }
.detail-list li { display: grid; grid-template-columns: minmax(120px, 190px) minmax(0, 1fr); gap: 12px; padding: 9px 0; border-bottom: 1px solid #e3e1d8; }
.detail-list li:last-child { border-bottom: 0; }
.detail-list strong { color: var(--muted); font-size: .9rem; }
.detail-list span { min-width: 0; overflow-wrap: anywhere; }
.affiliate-work-list { margin: 0; padding: 0; list-style: none; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.affiliate-work { min-width: 0; border: 1px solid var(--line); background: #fff; }
.affiliate-work-main { display: grid; grid-template-columns: 112px minmax(0, 1fr); gap: 12px; min-height: 156px; padding: 10px; color: var(--ink); text-decoration: none; }
.affiliate-cover { display: block; width: 112px; aspect-ratio: 3 / 4; overflow: hidden; border: 1px solid var(--line); background: #e6e4db; color: var(--muted); font-size: .76rem; }
.affiliate-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.affiliate-cover.no-image { display: grid; place-items: center; text-align: center; }
.affiliate-copy { display: flex; min-width: 0; flex-direction: column; gap: 6px; }
.affiliate-copy strong, .affiliate-copy span, .affiliate-copy em { display: block; min-width: 0; overflow-wrap: anywhere; }
.affiliate-copy strong { color: var(--accent-2); font-size: 1.05rem; line-height: 1.25; text-decoration: underline; text-underline-offset: 3px; }
.affiliate-copy span { font-size: .92rem; line-height: 1.45; }
.affiliate-copy em { color: var(--muted); font-size: .78rem; font-style: normal; }
.affiliate-copy b { margin-top: auto; align-self: flex-start; padding: 5px 8px; background: var(--accent-2); color: #fff; font-size: .82rem; line-height: 1.2; }
.site-detail-link { display: inline-flex; margin: 0 10px 10px 134px; color: var(--muted); font-size: .78rem; }
.empty { color: var(--muted); margin: 0; }
@media (max-width: 760px) {
  .app-frame { display: block; }
  .side-rail { position: static; height: auto; padding-bottom: 8px; }
  .rail-group { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .rail-group h2 { grid-column: 1 / -1; }
  .rail-group a { padding: 10px 14px; font-size: .96rem; }
  .site-header { align-items: flex-start; flex-direction: column; gap: 8px; }
  .page-hero, .split { grid-template-columns: 1fr; }
  .profile-photo { justify-self: start; width: 118px; }
  .nav-grid, .work-card-list, .media-grid, .panel-grid, .affiliate-work-list { grid-template-columns: 1fr; }
  .affiliate-work-main { grid-template-columns: 96px minmax(0, 1fr); min-height: 132px; }
  .affiliate-cover { width: 96px; }
  .site-detail-link { margin-left: 118px; }
  .detail-list li { grid-template-columns: 1fr; gap: 3px; }
  .meta-grid { grid-template-columns: 1fr; gap: 2px 0; }
  .cover { max-width: 210px; }
}

.rail-brand,
.brand {
  display: grid;
  gap: 2px;
  line-height: 1.18;
}

.rail-brand {
  width: 100%;
  justify-items: center;
  text-align: center;
}

.rail-brand-name,
.brand-name {
  display: block;
  overflow-wrap: anywhere;
}

.rail-brand-subtitle,
.brand-subtitle {
  display: block;
  color: #d7d1c6;
  font-size: .72rem;
  font-weight: 750;
  overflow-wrap: anywhere;
}

.rail-brand-hint,
.brand-hint {
  display: block;
  color: rgba(215, 209, 198, .85);
  font-size: .68rem;
  font-weight: 650;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.rail-brand-hint {
  margin-top: 10px;
}

.brand-subtitle {
  color: var(--muted);
}

.alias-badge {
  display: inline;
  margin-left: .35em;
  color: var(--accent);
  font-size: .78em;
  font-weight: 850;
}

.alias-fanza-link {
  color: var(--accent-2);
  font-weight: 850;
}

.cover-affiliate-link {
  display: block;
  color: inherit;
}

.fanza-genre-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
}

.fanza-genre-list a {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 4px 8px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--accent-2);
  font-size: .84rem;
  font-weight: 850;
  text-decoration: none;
}

.affiliate-rail-group h2 {
  background: #d7d1c6;
}

.side-rail .disabled {
  display: block;
  padding: 13px 18px;
  border-top: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.42);
  cursor: not-allowed;
}

.side-rail {
  display: flex;
  flex-direction: column;
}

.rail-free-plan {
  display: block;
  margin: auto 14px 0;
  padding: 12px 14px;
  border: 1px solid #f0c45b;
  background: #f4d06f;
  color: #202124;
  font-weight: 900;
  line-height: 1.35;
  text-align: center;
  text-decoration: none;
}

.rail-free-plan:hover {
  background: #ffe08b;
}

.affiliate-disclosure {
  border-left: 5px solid var(--gold);
}

.mutual-link-footer {
  margin: 24px 0 0;
  padding: 18px 0 0;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: .84rem;
  text-align: center;
}

.mutual-link-footer a {
  color: var(--muted);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.mutual-link-footer a:hover {
  color: var(--accent-2);
}

.affiliate-route-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.affiliate-route {
  display: block;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  text-decoration: none;
}

.affiliate-route strong,
.affiliate-route span {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
}

.affiliate-route strong {
  color: var(--accent-2);
  font-size: 1.02rem;
  line-height: 1.32;
}

.affiliate-route span {
  margin-top: 5px;
  color: var(--muted);
  font-size: .88rem;
}

.affiliate-cta-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.affiliate-cta-list a {
  display: grid;
  gap: 5px;
  min-height: 86px;
  padding: 12px;
  border: 1px solid #9dbfc0;
  background: #fff;
  color: var(--ink);
  text-decoration: none;
}

.affiliate-cta-list strong,
.affiliate-cta-list span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.affiliate-cta-list strong {
  color: var(--accent-2);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.affiliate-cta-list span {
  color: var(--muted);
  font-size: .88rem;
}

.dti-banner {
  display: grid;
  place-items: center start;
  width: min(100%, 344px);
  min-height: 292px;
  padding: 20px;
  border: 1px solid var(--line);
  background: #f7f6f0;
}

.dti-banner iframe {
  max-width: 100%;
  border: 0;
  background: #fff;
}

.free-plan-band {
  border-top: 4px solid var(--accent);
  background: #fffefa;
}

.free-plan-kicker {
  display: inline-flex;
  margin: 0 0 8px;
  padding: 3px 8px;
  background: var(--accent);
  color: #fff;
  font-size: .78rem;
  font-weight: 850;
}

.free-plan-band h2 {
  border-bottom-color: var(--accent);
}

.free-plan-wide-stack {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}

.free-plan-compact .free-plan-wide-stack {
  justify-items: center;
}

.free-plan-compact .free-plan-banner {
  width: min(100%, var(--banner-width, 728px));
}

.free-plan-banner {
  display: grid;
  place-items: center;
  min-width: 0;
  border: 1px solid #d893a6;
  background: #fff;
  text-decoration: none;
  overflow: hidden;
}

.free-plan-banner img {
  display: block;
  width: 100%;
  max-width: var(--banner-width, 900px);
  height: auto;
}

.free-plan-banner:hover,
.free-plan-card-banner:hover {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.free-plan-banner-caption {
  display: block;
  width: 100%;
  padding: 8px 10px;
  background: #fff;
  color: var(--ink);
  font-size: .86rem;
  font-weight: 850;
  line-height: 1.35;
  text-align: left;
}

.free-plan-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.free-plan-card-banner {
  display: grid;
  min-width: 0;
  border: 1px solid #9dbfc0;
  background: #fff;
  color: var(--ink);
  text-decoration: none;
  overflow: hidden;
}

.free-plan-card-banner img {
  display: block;
  width: 100%;
  height: auto;
  background: #f6f4ed;
}

.free-plan-text-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.free-plan-text-links a {
  display: inline-flex;
  min-height: 34px;
  align-items: center;
  padding: 6px 9px;
  border: 1px solid var(--line);
  background: #f6f4ed;
  color: var(--ink);
  font-size: .86rem;
  font-weight: 800;
  text-decoration: none;
}

.free-plan-more {
  display: inline-flex;
  margin-top: 12px;
  padding: 8px 11px;
  border: 1px solid var(--line);
  background: #f6f4ed;
  color: var(--ink);
  font-weight: 800;
  text-decoration: none;
}

.free-plan-sandwich {
  border-left: 5px solid var(--accent-2);
  background: #fff;
}

.free-plan-sandwich h2 {
  margin-bottom: 10px;
  border-bottom: 1px solid var(--line);
  color: var(--accent-2);
  font-size: 1.02rem;
}

.free-plan-inline-banner {
  display: grid;
  place-items: center;
  min-width: 0;
  border: 1px solid #9dbfc0;
  background: #fff;
  text-decoration: none;
  overflow: hidden;
}

.free-plan-inline-banner img {
  display: block;
  width: 100%;
  max-width: var(--banner-width, 728px);
  height: auto;
}

.unresolved-link {
  color: var(--muted);
  font-weight: 700;
}

.work-list {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.work-row {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  min-width: 0;
  padding: 10px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  text-decoration: none;
}

.work-row-thumb {
  display: block;
  width: 96px;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  border: 1px solid var(--line);
  background: #e6e4db;
}

.work-row-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.thumb,
.tile-image img,
.affiliate-cover img {
  object-fit: contain;
  background: #f3f2ec;
}

.work-row-thumb > span {
  display: grid;
  width: 100%;
  height: 100%;
  place-items: center;
  padding: 6px;
  color: var(--muted);
  font-size: .76rem;
  text-align: center;
}

.work-row-copy {
  display: grid;
  align-content: start;
  gap: 5px;
  min-width: 0;
}

.work-row-title,
.portrait-name {
  color: var(--accent-2);
  font-weight: 850;
  line-height: 1.32;
  overflow-wrap: anywhere;
}

.work-row-meta,
.portrait-meta {
  color: var(--muted);
  font-size: .84rem;
  overflow-wrap: anywhere;
}

.inline-actress-link {
  color: var(--accent-2);
  font-weight: 850;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.ranking-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ranking-card {
  display: grid;
  gap: 7px;
  min-width: 0;
  padding: 10px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  text-align: center;
  text-decoration: none;
}

.ranking-card-rank {
  color: #111;
  font-size: 1.05rem;
  font-weight: 900;
  line-height: 1.1;
}

.rank-move {
  margin-left: 3px;
  font-size: .9rem;
  font-weight: 900;
}

.rank-move.up {
  color: #00c928;
}

.rank-move.down {
  color: #e11d1d;
}

.ranking-card-image {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #e6e4db;
}

.ranking-card-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ranking-card-name {
  color: #1436d8;
  font-weight: 800;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.generated-profile-grid {
  display: grid;
  grid-template-columns: minmax(120px, 170px) minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

.generated-profile-grid .profile-photo {
  width: 100%;
  max-width: 280px;
  aspect-ratio: 1;
}

.generated-profile-grid .profile-photo img {
  object-fit: contain;
}

.monthly-ranking-note {
  margin: 0 0 14px;
  color: var(--muted);
}

.kana-jump {
  display: grid;
  gap: 14px;
}

.kana-grid {
  display: grid;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  gap: 4px;
}

.kana-grid a,
.kana-grid span {
  display: grid;
  min-height: 44px;
  place-items: center;
  border: 2px solid #15d5df;
  background: #fff;
  color: #08bfc8;
  font-size: 1.25rem;
  font-weight: 750;
  text-decoration: none;
}

.kana-grid span {
  border-color: transparent;
  color: transparent;
}

.kana-grid a:hover {
  background: #e9feff;
}

.kana-section {
  scroll-margin-top: 16px;
}

.kana-section h3 {
  margin: 18px 0 10px;
  padding: 8px 11px;
  background: #68d3e6;
  color: #fff;
  font-size: 1.3rem;
}

.kana-actress-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.kana-actress-list a {
  min-width: 0;
}

.kana-actress-list .portrait-row {
  grid-template-columns: 68px minmax(0, 1fr);
  min-height: 92px;
}

.kana-actress-list .portrait-row img,
.kana-actress-list .portrait-fallback {
  width: 68px;
}

.kana-actress-list .portrait-name,
.kana-actress-list .portrait-meta {
  display: block;
}

.pager {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.pager a,
.pager span {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  padding: 5px 9px;
  border: 1px solid var(--line);
  background: #f6f4ed;
  color: var(--ink);
  text-decoration: none;
  font-weight: 800;
}

.pager span {
  background: var(--ink);
  color: white;
}

.portrait-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.portrait-row {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 10px;
  min-width: 0;
  min-height: 76px;
  padding: 8px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  text-decoration: none;
}

.portrait-row img,
.portrait-fallback {
  width: 58px;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border: 1px solid var(--line);
  background: #e6e4db;
}

.feature-actress-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.feature-actress-card {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 11px;
  min-width: 0;
  min-height: 96px;
  padding: 9px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  text-decoration: none;
}

.feature-actress-card img,
.feature-actress-card .portrait-fallback {
  width: 72px;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border: 1px solid var(--line);
  background: #e6e4db;
}

.feature-actress-card-copy {
  display: grid;
  align-content: center;
  gap: 3px;
  min-width: 0;
}

.feature-actress-card-copy strong {
  color: var(--accent-2);
  font-size: 1.02rem;
  overflow-wrap: anywhere;
}

.feature-actress-card-copy span {
  color: var(--muted);
  font-size: .82rem;
  overflow-wrap: anywhere;
}

.portrait-fallback {
  display: grid;
  place-items: center;
  color: var(--muted);
  font-size: .72rem;
}

.topic-list {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.topic-list li {
  padding: 10px 12px;
  border-left: 4px solid var(--blue);
  background: #fff;
}

.topic-list a {
  font-weight: 850;
}

.topic-alt-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
  font-size: .82rem;
}

.topic-alt-links a {
  color: var(--muted);
  font-weight: 800;
}

.genre-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.genre-tile {
  display: block;
  min-width: 0;
  min-height: 84px;
  padding: 11px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  text-decoration: none;
}

.genre-tile strong,
.genre-tile span {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
}

.genre-tile strong {
  color: var(--accent-2);
}

.kana-entry-panel {
  display: grid;
  grid-template-columns: minmax(160px, 240px) minmax(0, 1fr);
  align-items: start;
  gap: 18px;
  min-width: 0;
  padding: 16px 18px;
  border: 3px solid #00d4d8;
  background: #fff;
  color: var(--ink);
}

.kana-entry-panel strong,
.kana-entry-panel span {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
}

.kana-entry-panel strong {
  color: var(--accent-2);
  font-size: 1.35rem;
  line-height: 1.35;
}

.kana-entry-panel span {
  color: var(--muted);
  font-size: .92rem;
  line-height: 1.55;
}

.kana-entry-panel .kana-grid a,
.kana-entry-panel .kana-grid span {
  min-height: 34px;
  font-size: 1rem;
}

.compare-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
}

.compare-table th,
.compare-table td {
  padding: 9px;
  border: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
}

.compare-table th {
  background: #efeee6;
}

@media (max-width: 760px) {
  .affiliate-route-grid,
  .affiliate-cta-list,
  .free-plan-card-grid,
  .portrait-list,
  .genre-grid,
  .kana-actress-list,
  .feature-actress-grid {
    grid-template-columns: 1fr;
  }

  .generated-profile-grid {
    grid-template-columns: 1fr;
  }

  .kana-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .kana-entry-panel {
    grid-template-columns: 1fr;
  }

  .work-row {
    grid-template-columns: 76px minmax(0, 1fr);
  }

  .work-row-thumb {
    width: 76px;
  }
}
