.author-byline { display: flex; align-items: center; gap: 10px; padding: 10px 0; margin-bottom: 8px; }
.author-byline .author-avatar { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.author-byline .author-meta { font-size: 13px; line-height: 18px; color: rgba(255, 255, 255, 0.75); }
.author-byline .author-meta .author-name { font-weight: 600; color: #f0f0f0; }
.author-box { background-color: #1c1b20; padding: 20px; display: flex; gap: 16px; margin-top: 12px; border-radius: 4px; border: 1px solid rgba(255, 255, 255, 0.06); position: relative; }
.author-box .author-box-avatar { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.author-box .author-box-content .author-box-name { font-family: "Plus Jakarta Sans", sans-serif; font-size: 16px; font-weight: 700; color: #f0f0f0; margin-bottom: 2px; }
.author-box .author-box-content .author-box-title { font-size: 12px; font-weight: 600; color: #BE1E2D; margin-bottom: 8px; }
.author-box .author-box-content .author-box-bio { font-size: 14px; line-height: 22px; color: rgba(255, 255, 255, 0.75); margin: 0; }
.author-quote { display: flex; gap: 16px; padding: 24px; background-color: rgba(255, 255, 255, 0.03); border: 1px solid rgba(255, 255, 255, 0.06); border-left: 3px solid #BE1E2D; border-radius: 4px; margin-top: 16px; position: relative; }
.author-quote::before { content: "\201C"; position: absolute; top: 12px; left: 20px; font-family: "Plus Jakarta Sans", sans-serif; font-size: 48px; font-weight: 800; color: rgba(190, 30, 45, 0.2); line-height: 1; pointer-events: none; }
.author-quote .author-quote-avatar { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 2px solid rgba(190, 30, 45, 0.3); }
.author-quote .author-quote-text { font-family: "Plus Jakarta Sans", sans-serif; font-size: 15px; line-height: 24px; color: rgba(255, 255, 255, 0.85); font-style: italic; font-weight: 500; margin: 0; padding-top: 4px; }
.author-quote .author-quote-text .author-quote-name { display: flex; align-items: center; gap: 8px; font-style: normal; font-family: "Inter", sans-serif; font-size: 13px; font-weight: 700; color: #f0f0f0; margin-top: 12px; }
.author-quote .author-quote-text .author-quote-role { font-style: normal; font-size: 12px; font-weight: 600; color: #BE1E2D; }
.author-section { background-color: #1c1b20; padding: 28px; border-radius: 4px; border: 1px solid rgba(255, 255, 255, 0.06); }
.author-section .author-section-grid { display: grid; grid-template-columns: 1fr; gap: 24px; align-items: center; }
.author-section .author-section-photo { position: relative; border-radius: 4px; overflow: hidden; }
.author-section .author-section-photo img { width: 100%; aspect-ratio: 1; object-fit: cover; }
.author-section .author-section-photo .photo-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(190, 30, 45, 0.1), transparent); }
.author-section .author-section-photo .photo-label { position: absolute; bottom: 0; left: 0; right: 0; background-color: rgba(26, 26, 26, 0.85); padding: 8px 16px; font-family: "Plus Jakarta Sans", sans-serif; font-size: 13px; font-weight: 700; color: #ffffff; }
.author-section .author-section-info .author-label { font-size: 12px; font-weight: 700; color: #BE1E2D; margin-bottom: 8px; }
.author-section .author-section-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 16px; margin-bottom: 16px; }
.author-section .author-section-stats .stat-block .stat-val { font-family: "Plus Jakarta Sans", sans-serif; font-size: 28px; font-weight: 800; color: #f0f0f0; display: block; }
.author-section .author-section-stats .stat-block .stat-desc { font-size: 11px; font-weight: 600; color: rgba(255, 255, 255, 0.75); }
.author-section .author-cta { display: inline-block; background-color: #BE1E2D; color: #ffffff; font-family: "Plus Jakarta Sans", sans-serif; font-size: 14px; font-weight: 700; padding: 12px 24px; text-decoration: none; border-radius: 24px; transition: background-color 0.2s ease; }
.author-section .author-cta:hover { background-color: #BE1E2D; color: #ffffff; }
@media (min-width: 768px) {
  .author-section { padding: 36px; }
  .author-section .author-section-stats .stat-block .stat-val { font-size: 34px; }
}
@media (min-width: 1024px) {
  .author-section .author-section-grid { grid-template-columns: 5fr 7fr; gap: 40px; }
}
