.lr-rd-hero {
  background: var(--warm); position: relative; overflow: hidden;
  border-bottom: 1px solid var(--hair);
}
.lr-rd-hero__inner {
  max-width: 1100px; margin: 0 auto;
  padding: 64px 24px 72px; position: relative;
  display: grid; grid-template-columns: 1fr; gap: 38px; align-items: center;
}
.lr-rd-hero__body {
  max-width: 660px;
}
.lr-rd-hero__kicker {
  font-family: var(--italic); font-style: italic;
  font-size: 12px; color: var(--accent); letter-spacing: 2px;
  margin-bottom: 24px; padding-left: 44px;
  position: relative; display: inline-block; white-space: nowrap;
}
.lr-rd-hero__kicker::before {
  content: ''; position: absolute; left: 0; top: 50%;
  width: 32px; height: 1px; background: var(--accent);
}
.lr-rd-hero h1 {
  font-family: var(--serif);
  font-size: clamp(32px, 5.2vw, 56px);
  line-height: 1.4; font-weight: 500; margin: 0 0 28px;
  letter-spacing: 0.05em; text-wrap: balance;
}
.lr-rd-hero h1 em {
  font-family: var(--italic); font-style: italic; color: var(--accent);
  font-weight: 400;
}
.lr-rd-hero__line {
  display: inline;
}
.lr-rd-hero__lead {
  font-family: var(--serif); font-size: 15.5px;
  line-height: 2.15; color: var(--fg);
  letter-spacing: 0.04em; max-width: 560px; margin: 0 0 36px;
}
.lr-rd-hero__lead em {
  font-family: var(--italic); font-style: italic; color: var(--accent);
}
.lr-rd-hero__cta {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 16px 28px; background: var(--accent); color: var(--bg);
  font-family: var(--sans); font-size: 14px; font-weight: 500;
  letter-spacing: 0.06em; text-decoration: none;
  border-radius: 999px;
  transition: transform 0.15s, box-shadow 0.2s;
}
.lr-rd-hero__cta:hover { transform: translateY(-1px); box-shadow: 0 14px 28px -10px rgba(16,32,58,0.4); }

.lr-rd-hero__visual {
  background: var(--card);
  border: 1px solid var(--hair);
  box-shadow: 0 24px 60px -36px rgba(16,32,58,0.28);
  overflow: hidden;
}
.lr-rd-hero__visual img {
  display: block;
  width: 100%;
  height: auto;
}

@media (min-width: 768px) {
  .lr-rd-hero__inner { padding: 96px 40px 110px; grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.8fr); }
}
@media (min-width: 1100px) {
  .lr-rd-hero__inner { padding: 128px 48px 140px; gap: 72px; }
  .lr-rd-hero__line { display: block; }
}
@media (max-width: 767px) {
  .lr-rd-hero__line { display: block; }
}
@media (max-width: 560px) {
  .lr-rd-hero__visual { margin-top: 4px; }
}

/* 共通 */
.lr-rd-sec { padding: 80px 24px; }
.lr-rd-sec.alt { background: var(--accent-soft); }
.lr-rd-sec.warm { background: var(--warm); }
.lr-rd-sec__inner { max-width: 1100px; margin: 0 auto; }
@media (min-width: 900px) { .lr-rd-sec { padding: 110px 48px; } }

.lr-rd-h2 {
  font-family: var(--serif);
  font-size: clamp(24px, 3.2vw, 34px);
  font-weight: 500; line-height: 1.55; letter-spacing: 0.06em;
  margin: 0 0 28px; text-wrap: balance;
}
.lr-rd-lead {
  font-family: var(--serif); font-size: 15px;
  line-height: 2.1; color: var(--fg);
  letter-spacing: 0.04em; max-width: 620px; margin: 0 0 40px;
}
.lr-rd-lead em {
  font-family: var(--italic); font-style: italic; color: var(--accent);
}

/* 埋め込みエピソード */
.lr-rd-embeds {
  display: grid; grid-template-columns: 1fr; gap: 28px;
  margin: 42px 0 0;
}
.lr-rd-embed {
  display: grid; grid-template-columns: 1fr; gap: 0;
  width: 100%; margin: 0;
  background: var(--card); border: 1px solid var(--hair);
  box-shadow: 0 24px 60px -42px rgba(16,32,58,0.24);
}
.lr-rd-embed__frame {
  position: relative; aspect-ratio: 16 / 9;
  background:
    radial-gradient(circle at 28% 35%, rgba(209,172,128,0.18), transparent 58%),
    linear-gradient(135deg, #10203A 0%, #1a3457 100%);
  overflow: hidden;
}
.lr-rd-embed__frame iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%; border: 0;
}
.lr-rd-embed__body {
  padding: 24px;
  display: flex; flex-direction: column; gap: 14px;
}
.lr-rd-embed__meta {
  display: flex; flex-wrap: wrap; gap: 10px 14px;
  font-family: var(--italic); font-style: italic;
  font-size: 11px; color: var(--accent); letter-spacing: 1.6px;
}
.lr-rd-embed h3 {
  font-family: var(--serif); font-size: clamp(19px, 2vw, 23px);
  font-weight: 500; letter-spacing: 0.04em; line-height: 1.55;
  color: var(--fg); margin: 0;
}
.lr-rd-embed p {
  font-family: var(--serif); font-size: 14.5px; line-height: 2;
  color: var(--sub); letter-spacing: 0.04em; margin: 0;
}
.lr-rd-embed__foot {
  display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  padding-top: 6px;
  font-family: var(--italic); font-style: italic;
  font-size: 12px; color: var(--sub); letter-spacing: 1px;
}
.lr-rd-embed__foot a {
  color: var(--accent); text-decoration: none;
}
.lr-rd-embed__foot a:hover {
  text-decoration: underline;
  text-underline-offset: 4px;
}
@media (min-width: 1080px) {
  .lr-rd-embeds { grid-template-columns: 1fr; gap: 28px; }
  .lr-rd-embed {
    grid-template-columns: minmax(430px, 0.98fr) minmax(300px, 1fr);
    align-items: stretch;
  }
  .lr-rd-embed__frame {
    align-self: start;
  }
  .lr-rd-embed__body {
    padding: 30px 34px 32px;
  }
}

/* どこで聴ける */
.lr-rd-where {
  display: grid; grid-template-columns: 1fr; gap: 16px; margin: 36px 0 0;
}
.lr-rd-where__card {
  padding: 28px 28px; background: var(--card);
  border: 1px solid var(--hair); text-decoration: none; color: inherit;
  display: grid; grid-template-columns: 48px 1fr auto; gap: 18px; align-items: center;
  transition: border-color 0.2s, transform 0.15s;
}
.lr-rd-where__card:hover { border-color: var(--accent); transform: translateX(4px); }
.lr-rd-where__icn {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--accent-soft);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
}
.lr-rd-where__name {
  font-family: var(--serif); font-size: 17px; font-weight: 500;
  letter-spacing: 0.04em; line-height: 1.5; color: var(--fg);
}
.lr-rd-where__name small {
  display: block; font-family: var(--italic); font-style: italic;
  font-size: 12px; color: var(--sub); margin-top: 4px; letter-spacing: 1px;
}
.lr-rd-where__arrow {
  font-family: var(--italic); font-style: italic;
  font-size: 12px; color: var(--accent); letter-spacing: 1px;
}
@media (min-width: 768px) { .lr-rd-where { grid-template-columns: 1fr 1fr; } }

/* community 誘導 */
.lr-rd-suggest {
  background: var(--fg); color: var(--bg);
  padding: 48px 32px; margin: 36px 0 0;
  display: grid; grid-template-columns: 1fr; gap: 24px;
  position: relative; overflow: hidden;
}
.lr-rd-suggest__label {
  font-family: var(--italic); font-style: italic;
  font-size: 11px; color: var(--bg); opacity: 0.6; letter-spacing: 2px;
  margin-bottom: 6px;
}
.lr-rd-suggest h3 {
  font-family: var(--serif); font-size: clamp(20px, 2.6vw, 26px);
  font-weight: 500; line-height: 1.55; letter-spacing: 0.06em;
  color: var(--bg); margin: 0 0 14px;
}
.lr-rd-suggest p {
  font-family: var(--sans); font-size: 13.5px; line-height: 2;
  color: var(--bg); opacity: 0.75; letter-spacing: 0.02em;
  margin: 0; max-width: 480px;
}
.lr-rd-suggest__cta {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 24px; background: var(--accent); color: var(--bg);
  font-family: var(--sans); font-size: 13.5px; font-weight: 500;
  letter-spacing: 0.06em; text-decoration: none;
  border-radius: 999px; align-self: start;
  transition: transform 0.15s;
}
.lr-rd-suggest__cta:hover { transform: translateY(-1px); }
@media (min-width: 768px) {
  .lr-rd-suggest { grid-template-columns: 1.5fr 1fr; align-items: center; padding: 56px 48px; }
}
