.lo-blog-detail .detail-hero-inner { max-width: 920px; margin: 0 auto; padding: 56px 24px 60px; position: relative; text-align: center; }
.lo-blog-detail .lo-eyebrow { justify-content: center; }
.lo-blog-detail .lo-eyebrow::after { content: ""; width: 28px; height: 2px; background: var(--orange); }
.lo-blog-detail .lo-hero h1 { margin: 0 auto 18px; font-size: 52px; line-height: 1.12; max-width: 820px; }
.lo-blog-detail .lede { color: #bdbdbd; max-width: 680px; margin: 0 auto; font-size: 16px; line-height: 1.65; }
.lo-blog-detail .lo-meta-row { justify-content: center; margin-top: 24px; color: #bdbdbd; }
.lo-blog-detail .lo-meta-row b { color: #fff; }

.lo-cover { max-width: 1100px; margin: -40px auto 0; padding: 0 24px; position: relative; z-index: 2; }
.lo-cover img { width: 100%; aspect-ratio: 21 / 9; object-fit: cover; border-radius: 18px; box-shadow: 0 30px 60px -30px rgba(0,0,0,.4); }
.detail-wrap { max-width: 1180px; padding-top: 56px; }
.detail-layout { display: grid; grid-template-columns: 120px 1fr 240px; gap: 48px; align-items: flex-start; }

.share { position: sticky; top: 96px; display: flex; flex-direction: column; gap: 10px; align-items: center; }
.share small { font-size: 11px; color: var(--muted); text-transform: uppercase; writing-mode: vertical-rl; transform: rotate(180deg); margin-bottom: 8px; }
.share a { width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--line); background: #fff; color: #333; display: inline-flex; align-items: center; justify-content: center; transition: all .2s; font-weight: 700; }
.share a:hover { background: #111; color: #fff; border-color: #111; transform: translateY(-2px); }

.article { max-width: 720px; }
.tags-top { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 24px; }
.tags-top a { font-size: 11px; color: var(--orange); text-transform: uppercase; font-weight: 700; background: #fff4e9; border: 1px solid #ffe0c2; padding: 5px 10px; border-radius: 6px; }
.article p { font-size: 17px; line-height: 1.85; color: #2a2a2a; margin: 0 0 22px; }
.article > p:first-of-type::first-letter { font-size: 64px; float: left; line-height: .9; font-weight: 900; margin: 6px 12px 0 0; color: var(--orange); }
.article h2 { font-size: 30px; margin: 44px 0 18px; color: #111; position: relative; padding-left: 18px; letter-spacing: 0; }
.article h2::before { content: ""; position: absolute; left: 0; top: 8px; bottom: 8px; width: 4px; background: var(--orange); border-radius: 2px; }
.article h3 { font-size: 22px; margin: 32px 0 14px; color: #111; }
.article h2, .article h3 { scroll-margin-top: 120px; }
.article a { color: var(--orange); font-weight: 600; border-bottom: 1px solid #ffd9b8; }
.article blockquote { margin: 32px 0; padding: 24px 28px; background: var(--bg-soft); border-left: 4px solid var(--orange); border-radius: 0 12px 12px 0; font-size: 19px; line-height: 1.6; color: #222; font-style: italic; }
.article blockquote footer { margin-top: 12px; font-size: 13px; font-style: normal; color: var(--muted); }
.article ul { margin: 0 0 22px; padding-left: 22px; font-size: 17px; line-height: 1.85; color: #2a2a2a; }
.article ul li { margin-bottom: 8px; }
.article ul li::marker { color: var(--orange); }
.article figure { margin: 32px 0; }
.article figure img { border-radius: 14px; }
.article figcaption { margin-top: 10px; font-size: 13px; color: var(--muted); text-align: center; font-style: italic; }

.author { margin-top: 48px; padding: 24px; border: 1px solid var(--line); border-radius: 14px; background: var(--bg-soft); display: flex; gap: 18px; align-items: center; }
.author .av { width: 64px; height: 64px; border-radius: 50%; background: #ddd; display: inline-flex; align-items: center; justify-content: center; font-weight: 800; color: #666; flex: 0 0 64px; }
.author h4 { margin: 0 0 6px; font-size: 16px; }
.author p { margin: 0; font-size: 13px; color: var(--muted); line-height: 1.6; }
.pn { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 32px; }
.pn a { display: block; padding: 20px; border: 1px solid var(--line); border-radius: 12px; background: #fff; transition: all .2s; }
.pn a:hover { border-color: #111; transform: translateY(-2px); }
.pn small { font-size: 11px; color: var(--muted); text-transform: uppercase; display: block; margin-bottom: 6px; }
.pn b { font-size: 15px; line-height: 1.4; color: #111; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.pn .next { text-align: right; }

.toc { position: sticky; top: 96px; }
.toc-title { font-size: 11px; text-transform: uppercase; color: #111; font-weight: 700; margin: 0 0 14px; }
.toc-link { display: block; padding: 8px 14px; font-size: 13px; line-height: 1.35; color: var(--muted); border-left: 2px solid var(--orange); }
.toc-link.depth-3 { padding-left: 26px; font-size: 12px; border-left-color: var(--line); }
.toc-link:hover { color: var(--orange); }
.promo-prod { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 18px; margin-top: 20px; }
.promo-prod small { font-size: 11px; color: var(--orange); font-weight: 700; text-transform: uppercase; }
.promo-prod h4 { margin: 6px 0 12px; font-size: 15px; line-height: 1.4; }
.promo-prod .btn { display: block; text-align: center; border-radius: 999px; background: #111; color: #fff; padding: 11px 16px; font-weight: 700; }

.lo-section { max-width: 1180px; margin: 0 auto; padding: 48px 24px; }
.lo-section h2.sec { font-size: 26px; margin: 0 0 24px; letter-spacing: 0; }
.rel-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.rel .ph { aspect-ratio: 16 / 10; border-radius: 12px; background: linear-gradient(135deg,#ededea,#f7f7f3); display: flex; align-items: center; justify-content: center; color: #bbb; font-weight: 800; margin-bottom: 14px; overflow: hidden; }
.rel .ph img { width: 100%; height: 100%; object-fit: cover; }
.rel small { font-size: 11px; color: var(--orange); font-weight: 700; text-transform: uppercase; }
.rel h4 { font-size: 16px; line-height: 1.4; margin: 6px 0; color: #111; }
.rel:hover h4 { color: var(--orange); }
.comments { background: var(--bg-soft); border-top: 1px solid var(--line); }
.comments .inner { max-width: 780px; margin: 0 auto; padding: 48px 24px 64px; }

@media (max-width: 1100px) {
  .detail-layout { grid-template-columns: 1fr; gap: 36px; }
  .share { position: static; flex-direction: row; justify-content: center; }
  .share small { writing-mode: initial; transform: none; margin: 0; }
  .toc { position: static; }
}

@media (max-width: 700px) {
  .lo-blog-detail .lo-hero h1 { font-size: 34px; }
  .rel-grid, .pn { grid-template-columns: 1fr; }
  .author { flex-direction: column; text-align: center; }
}
