body { font-family: system-ui, sans-serif; margin: 0; background: #f8fafc; color: #0f172a; }
.container { max-width: 1040px; margin: 0 auto; padding: 32px 20px 56px; }
a { color: #2563eb; text-decoration: none; }
:root { --site-accent: #2563eb; }
.site-header { position: sticky; top: 0; z-index: 20; backdrop-filter: blur(10px); background: rgba(248,250,252,0.86); border-bottom: 1px solid #dbe3ee; }
.site-header-inner { max-width: 1040px; margin: 0 auto; padding: 14px 20px; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.site-brand { display: grid; gap: 4px; color: #0f172a; }
.site-intro-strip { display: flex; gap: 8px; flex-wrap: wrap; color: #64748b; font-size: 13px; }
.site-nav { display: flex; gap: 16px; flex-wrap: wrap; }
.site-nav a { color: #475569; font-weight: 600; }
.site-footer { border-top: 1px solid #dbe3ee; background: #ffffff; margin-top: 40px; }
.site-footer-inner { max-width: 1040px; margin: 0 auto; padding: 22px 20px 36px; display: grid; gap: 12px; color: #475569; }
.site-footer-note { max-width: 720px; line-height: 1.6; }
.hero-card { background: white; border: 1px solid #dbe3ee; border-radius: 20px; padding: 28px; box-shadow: 0 12px 24px rgba(15,23,42,0.06); margin-bottom: 24px; }
.site-pulse-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; margin-bottom: 24px; }
.pulse-card { background: #ffffff; border: 1px solid #dbe3ee; border-radius: 16px; padding: 16px; display: grid; gap: 6px; box-shadow: 0 8px 20px rgba(15,23,42,0.04); }
.pulse-card strong { font-size: 24px; color: #0f172a; }
.pulse-card span { color: #64748b; font-size: 13px; font-weight: 600; }
.eyebrow { display: inline-flex; padding: 4px 10px; border-radius: 999px; background: #dbeafe; color: var(--site-accent); font-size: 12px; font-weight: 700; margin-bottom: 10px; }
.mission-copy { color: #334155; font-weight: 600; margin-top: 8px; }
.tone-copy { color: #64748b; margin-top: 10px; }
.hero-pills { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 16px; }
.hero-pill { display: inline-flex; padding: 6px 10px; border-radius: 999px; background: #f1f5f9; color: #334155; font-size: 13px; font-weight: 600; }
.trust-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; margin-bottom: 24px; }
.trust-item { background: white; border: 1px solid #dbe3ee; border-radius: 16px; padding: 14px; color: #475569; box-shadow: 0 8px 20px rgba(15,23,42,0.04); }
.section-rail { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 24px; }
.section-rail-item { background: #ffffff; border: 1px dashed #cbd5e1; border-radius: 14px; padding: 10px 14px; color: #475569; font-weight: 600; }
.editorial-method { margin-bottom: 28px; }
.section-head { display: grid; gap: 8px; margin-bottom: 16px; }
.browse-section { margin-top: 8px; }
.browse-grid-shell { background: #ffffff; border: 1px solid #dbe3ee; border-radius: 20px; padding: 20px; box-shadow: 0 8px 20px rgba(15,23,42,0.04); }
.browse-grid-head { display: grid; gap: 6px; margin-bottom: 16px; }
.method-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; }
.method-card { background: white; border: 1px solid #dbe3ee; border-radius: 18px; padding: 18px; display: grid; gap: 8px; box-shadow: 0 8px 20px rgba(15,23,42,0.04); }
.method-card span { color: #64748b; line-height: 1.5; }
.featured-shell { background: linear-gradient(135deg, #eff6ff 0%, #ffffff 100%); border: 1px solid #dbe3ee; border-radius: 20px; padding: 24px; margin-bottom: 24px; box-shadow: 0 12px 24px rgba(15,23,42,0.05); }
.featured-copy { display: grid; gap: 12px; }
.guide-shell { background: #ffffff; border: 1px solid #dbe3ee; border-radius: 20px; padding: 24px; margin-bottom: 24px; box-shadow: 0 10px 20px rgba(15,23,42,0.04); display: grid; gap: 12px; }
.freshness-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; margin-bottom: 24px; }
.freshness-item { background: #ffffff; border: 1px solid #dbe3ee; border-radius: 16px; padding: 14px; color: #475569; box-shadow: 0 8px 20px rgba(15,23,42,0.04); }
.meta-chip-row { display: flex; gap: 10px; flex-wrap: wrap; }
.meta-chip { display: inline-flex; padding: 6px 10px; border-radius: 999px; background: white; border: 1px solid #dbe3ee; color: #475569; font-size: 12px; font-weight: 600; }
.post-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.post-card { display: grid; gap: 8px; background: white; border: 1px solid #dbe3ee; border-radius: 18px; padding: 18px; box-shadow: 0 8px 20px rgba(15,23,42,0.05); }
.post-card-meta { font-size: 12px; font-weight: 700; color: #64748b; text-transform: uppercase; letter-spacing: 0.04em; }
.post-card span { color: #64748b; font-size: 14px; line-height: 1.45; }
.post-layout { display: grid; grid-template-columns: minmax(0, 1fr) 260px; gap: 20px; align-items: start; }
.post-shell { background: white; padding: 28px; border-radius: 20px; border: 1px solid #dbe3ee; box-shadow: 0 12px 24px rgba(15,23,42,0.06); }
.post-meta { font-size: 12px; font-weight: 700; color: var(--site-accent); background: #dbeafe; display: inline-flex; padding: 4px 10px; border-radius: 999px; margin-bottom: 12px; }
.post-summary-box { background: #f8fafc; border: 1px solid #dbe3ee; border-radius: 16px; padding: 16px; margin: 18px 0; color: #334155; }
.reader-checklist { background: #ffffff; border: 1px solid #dbe3ee; border-radius: 16px; padding: 16px; margin: 0 0 20px; color: #334155; }
.reader-checklist ul { margin: 10px 0 0; padding-left: 18px; display: grid; gap: 8px; }
.section-head.compact { margin-bottom: 12px; }
.guide-map { background: #ffffff; border: 1px solid #dbe3ee; border-radius: 16px; padding: 16px; margin: 0 0 20px; display: grid; gap: 12px; }
.guide-map-list { display: grid; gap: 10px; }
.guide-map-item { display: grid; grid-template-columns: auto minmax(0, 1fr) auto; align-items: start; gap: 12px; padding: 12px; border: 1px solid #e2e8f0; border-radius: 14px; background: #f8fafc; color: #0f172a; }
.guide-map-order { width: 28px; height: 28px; border-radius: 999px; background: #dbeafe; color: var(--site-accent); display: inline-flex; align-items: center; justify-content: center; font-weight: 800; font-size: 13px; }
.guide-map-copy { display: grid; gap: 4px; }
.guide-map-copy span { color: #64748b; font-size: 13px; line-height: 1.5; }
.guide-map-tag { display: inline-flex; padding: 5px 10px; border-radius: 999px; background: #ffffff; border: 1px solid #dbe3ee; color: #475569; font-size: 12px; font-weight: 700; }
.post-cta-row { display: flex; gap: 12px; flex-wrap: wrap; margin: 18px 0 24px; }
.next-step-card { background: #ffffff; border: 1px solid #dbe3ee; border-radius: 16px; padding: 16px; margin: 0 0 24px; color: #334155; display: grid; gap: 8px; }
.trust-callout { background: linear-gradient(135deg, #eff6ff 0%, #ffffff 100%); border: 1px solid #dbe3ee; border-radius: 16px; padding: 16px; margin: 0 0 24px; color: #334155; display: grid; gap: 8px; }
.quick-compare { margin: 0 0 24px; display: grid; gap: 12px; }
.compare-table-wrap { overflow-x: auto; background: #ffffff; border: 1px solid #dbe3ee; border-radius: 16px; padding: 8px; }
.compare-table { width: 100%; border-collapse: collapse; }
.compare-table th, .compare-table td { border-bottom: 1px solid #e2e8f0; padding: 12px 10px; text-align: left; }
.compare-table th { color: #475569; font-size: 13px; }
.cta-button { display: inline-flex; align-items: center; justify-content: center; padding: 10px 16px; border-radius: 12px; background: var(--site-accent); color: white; font-weight: 700; }
.cta-button.secondary { background: #e2e8f0; color: #0f172a; }
.post-content { line-height: 1.75; color: #1e293b; }
.post-content h2, .post-content h3 { margin-top: 1.8em; }
.post-content table { width: 100%; border-collapse: collapse; margin: 20px 0; }
.post-content table th, .post-content table td { border: 1px solid #dbe3ee; padding: 10px 12px; text-align: left; }
.post-sidebar { display: grid; gap: 16px; position: sticky; top: 24px; }
.sidebar-card { background: white; border: 1px solid #dbe3ee; border-radius: 16px; padding: 16px; box-shadow: 0 8px 20px rgba(15,23,42,0.04); display: grid; gap: 10px; }
.sidebar-link { color: var(--site-accent); font-weight: 600; }
.mission-stack { gap: 10px; }
.chip-link-row { display: flex; gap: 8px; flex-wrap: wrap; }
.chip-link { display: inline-flex; padding: 6px 10px; border-radius: 999px; background: #f1f5f9; color: #475569; font-size: 12px; font-weight: 600; }
.info-stack { gap: 12px; }
.info-row { display: flex; justify-content: space-between; gap: 12px; align-items: center; color: #475569; }
.info-row strong { color: #0f172a; text-align: right; }
.recommendation-stack { gap: 12px; }
.recommendation-card { border: 1px solid #dbe3ee; border-radius: 14px; padding: 12px; background: #f8fafc; display: grid; gap: 6px; }
.comparison-stack { gap: 12px; }
.comparison-card { border: 1px solid #dbe3ee; border-radius: 14px; padding: 12px; background: #ffffff; display: grid; gap: 4px; }
.related-posts { margin-top: 24px; background: white; border: 1px solid #dbe3ee; border-radius: 20px; padding: 24px; box-shadow: 0 12px 24px rgba(15,23,42,0.05); }
/* Trustworthy Korean info-blog readability overrides */
body { background: #f4f6f8; color: #20242b; }
.container { max-width: 1200px; padding: 28px 20px 72px; }
.site-header { position: static; backdrop-filter: none; background: #ffffff; border-bottom: 1px solid #e8edf2; }
.site-header-inner { max-width: 1200px; padding: 14px 20px; align-items: center; }
.site-intro-strip { display: none; }
.site-nav a { color: #6b7280; font-size: 14px; }
.hero-card, .featured-shell, .guide-shell, .browse-grid-shell, .related-posts { border-radius: 16px; box-shadow: 0 8px 22px rgba(15,23,42,0.04); }
.site-pulse-strip, .freshness-strip, .section-rail, .editorial-method { display: none; }
.post-layout { grid-template-columns: 1fr; max-width: 780px; margin: 0 auto; }
.post-sidebar { display: none; }
.post-shell { background: #ffffff; padding: 36px 34px 40px; border: 1px solid #e5e7eb; box-shadow: 0 8px 24px rgba(15,23,42,0.04); border-radius: 18px; }
.post-shell h1 { font-size: 36px; line-height: 1.42; margin: 0 0 14px; letter-spacing: -0.025em; color: #111827; }
.post-meta { padding: 0; background: transparent; color: #2f855a; margin-bottom: 8px; }
.post-byline { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 24px; color: #6b7280; font-size: 13px; }
.post-byline span { position: relative; padding-right: 10px; }
.post-byline span:not(:last-child)::after { content: '·'; position: absolute; right: 0; color: #c0c7d1; }
.post-byline .post-updated { color: #5f6b7a; font-weight: 500; }
.post-summary-box { background: #faf7ef; border: 1px solid #ece5d7; border-radius: 14px; padding: 18px 20px; margin: 0 0 20px; color: #3b3f45; }
.reader-checklist, .guide-map, .trust-callout, .quick-compare, .related-posts { background: #ffffff; border: 1px solid #e7ebf0; border-radius: 14px; box-shadow: none; padding: 18px 20px; }
.next-step-card { display: none; }
.guide-map-item { grid-template-columns: auto minmax(0, 1fr); gap: 10px; background: transparent; border: none; border-bottom: 1px solid #eef2f7; border-radius: 0; padding: 12px 0; }
.guide-map-item:last-child { border-bottom: none; }
.guide-map-tag { display: none; }
.guide-map-order { background: rgba(47, 133, 90, 0.12); color: #2f855a; }
.meta-chip { background: #f6f7f9; border-color: #e5e7eb; }
.cta-button { background: #2f855a; border-radius: 999px; padding: 10px 18px; }
.cta-button.secondary { background: #f3f4f6; color: #475569; }
.post-content { font-size: 18px; line-height: 1.95; color: #20242b; word-break: keep-all; }
.post-content h2 { font-size: 25px; margin-top: 44px; margin-bottom: 14px; padding-left: 12px; border-left: 4px solid #2f855a; }
.post-content h3 { font-size: 20px; margin-top: 30px; margin-bottom: 10px; color: #1f2937; }
.post-content p { margin: 1.05em 0; }
.compare-table-wrap { border-color: #e5e7eb; border-radius: 12px; }
.compare-table th { background: #f8fafb; color: #4b5563; }
.trust-callout { background: #f7fbf8; border-color: #d8e8dc; }
.post-grid { grid-template-columns: 1fr; }
.post-card { border: none; border-bottom: 1px solid #eef2f7; border-radius: 0; box-shadow: none; padding: 14px 0; background: transparent; }
.post-card:last-child { border-bottom: none; }
/* final modest info-blog overrides */
.site-header-inner { justify-content: space-between; }
.site-brand { gap: 2px; }
.site-nav { gap: 14px; }
.hero-card, .featured-shell, .guide-shell, .browse-grid-shell, .site-pulse-strip, .freshness-strip, .section-rail, .editorial-method { display: none !important; }
.blog-home-intro { box-shadow: none; border-radius: 14px; padding: 22px 24px; }
.blog-home-intro h1 { font-size: 30px; }
.featured-post-article, .home-post-list { box-shadow: none; border-radius: 14px; }
.home-feature-grid { display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(280px, 0.85fr); gap: 16px; margin-top: 8px; }
.home-feature-lead { position: relative; min-height: 360px; border-radius: 20px; overflow: hidden; display: grid; align-items: end; color: inherit; border: 1px solid #e3e9f0; background: #f8fafc; }
.home-feature-image { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.home-feature-overlay { position: relative; z-index: 1; display: grid; gap: 10px; padding: 22px; background: linear-gradient(180deg, rgba(15,23,42,0.04) 0%, rgba(15,23,42,0.72) 100%); color: #ffffff; }
.home-feature-overlay .home-entry-meta,
.home-feature-overlay .home-entry-label,
.home-feature-overlay .home-entry-date,
.home-feature-overlay .home-entry-sep { color: rgba(255,255,255,0.82); }
.home-feature-overlay strong { font-size: 34px; line-height: 1.28; color: #ffffff; }
.home-feature-overlay > span { color: rgba(255,255,255,0.88); line-height: 1.7; }
.home-feature-overlay .meta-chip { background: rgba(255,255,255,0.14); border-color: rgba(255,255,255,0.18); color: #ffffff; backdrop-filter: blur(10px); }
.home-feature-side { display: grid; gap: 14px; }
.home-spotlight-card { display: grid; grid-template-columns: 112px minmax(0, 1fr); gap: 12px; padding: 12px; border-radius: 18px; border: 1px solid #e3e9f0; background: #ffffff; color: inherit; }
.home-spotlight-image { width: 112px; height: 112px; border-radius: 14px; object-fit: cover; border: 1px solid #e3e9f0; background: #f8fafc; }
.home-spotlight-copy { min-width: 0; display: grid; gap: 8px; align-content: start; }
.home-spotlight-copy strong { font-size: 18px; line-height: 1.45; color: #1f2937; }
.home-archive-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin-top: 10px; }
.home-archive-card { display: grid; gap: 12px; padding: 14px; border-radius: 18px; border: 1px solid #e3e9f0; background: #ffffff; color: inherit; }
.home-archive-image { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; border-radius: 14px; border: 1px solid #e3e9f0; background: #f8fafc; }
.home-archive-copy { min-width: 0; display: grid; gap: 10px; }
.home-archive-copy strong { font-size: 24px; line-height: 1.4; color: #1f2937; }
.featured-post-link, .home-post-item { display: grid; grid-template-columns: 168px minmax(0, 1fr); gap: 16px; align-items: start; color: inherit; padding: 14px 0; border-top: 1px solid #edf1f5; }
.featured-post-article > .section-head, .home-post-list > .section-head { margin-bottom: 0; }
.featured-post-link strong, .home-post-item strong { font-size: 24px; }
.featured-post-link { border-bottom: 1px solid #edf1f5; }
.home-post-item:first-of-type { border-top: none; }
.home-post-thumb { display: block; width: 100%; aspect-ratio: 16 / 10; border-radius: 12px; border: 1px solid #e3e9f0; background: linear-gradient(135deg, #eef3f7 0%, #f8fafc 100%); box-shadow: inset 0 1px 0 rgba(255,255,255,0.6); }
.home-post-thumb-image { display: block; width: 100%; aspect-ratio: 16 / 10; object-fit: cover; border-radius: 12px; border: 1px solid #e3e9f0; background: #f8fafc; }
.featured-post-link .home-post-thumb,
.home-post-item:nth-of-type(3n+1) .home-post-thumb { background: linear-gradient(135deg, #e5f0ea 0%, #f8fbf9 100%); }
.home-post-item:nth-of-type(3n+2) .home-post-thumb { background: linear-gradient(135deg, #eef1f7 0%, #f8f9fc 100%); }
.home-post-item:nth-of-type(3n+3) .home-post-thumb { background: linear-gradient(135deg, #f3efe5 0%, #fbf9f4 100%); }
.home-post-copy { min-width: 0; display: grid; gap: 8px; }
.home-entry-meta { display: flex; align-items: center; gap: 6px; color: #7b8794; font-size: 12px; font-weight: 600; letter-spacing: 0.02em; }
.home-entry-label { color: #6d7b88; }
.home-entry-sep { color: #c0c8d2; }
.home-entry-date { color: #6f7a86; font-weight: 500; }
.home-entry-keyword { color: #6b7280; font-weight: 500; }
.home-post-copy > span { color: #5f6b7a; line-height: 1.65; }
.home-title-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.top-count-badge { display: inline-flex; align-items: center; justify-content: center; padding: 4px 9px; border-radius: 999px; background: #f3f6f8; border: 1px solid #e1e7ee; color: #5f6b7a; font-size: 11px; font-weight: 800; letter-spacing: 0.04em; white-space: nowrap; }
.product-strip { display: grid; gap: 14px; margin: 0 0 18px; }
.guide-archetype-shell { display: grid; gap: 14px; margin: 8px 0 20px; }
.guide-quick-compare-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.guide-quick-compare-card { display: grid; gap: 6px; padding: 14px; border-radius: 16px; border: 1px solid #e6ebf1; background: #ffffff; box-shadow: 0 4px 14px rgba(15,23,42,0.03); }
.guide-quick-compare-card strong { font-size: 15px; line-height: 1.45; color: #111827; }
.guide-quick-compare-card span { color: #2563eb; font-size: 12px; font-weight: 700; }
.guide-quick-compare-card p { margin: 0; color: #5f6b7a; font-size: 13px; line-height: 1.65; }
.guide-step-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 10px; }
.guide-step-card { display: grid; gap: 8px; padding: 14px; border-radius: 16px; border: 1px solid #e6ebf1; background: #ffffff; box-shadow: 0 4px 14px rgba(15,23,42,0.03); color: inherit; }
.guide-step-label { display: inline-flex; align-self: start; padding: 4px 8px; border-radius: 999px; background: #eef6ff; color: #2563eb; font-size: 11px; font-weight: 800; letter-spacing: 0.03em; }
.guide-step-card strong { font-size: 15px; line-height: 1.5; color: #1f2937; }
.guide-product-strip { margin-top: 6px; }
.post-hero-stack + .product-strip { margin-top: -2px; }
.guide-density-shell { display: grid; gap: 16px; margin: 10px 0 24px; }
.guide-decision-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.guide-decision-card { display: grid; gap: 10px; padding: 16px; border-radius: 16px; border: 1px solid #e6ebf1; background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%); box-shadow: 0 4px 14px rgba(15,23,42,0.03); }
.guide-decision-label { display: inline-flex; align-self: start; padding: 4px 8px; border-radius: 999px; background: #eef6f1; color: #2f855a; font-size: 11px; font-weight: 800; letter-spacing: 0.03em; }
.guide-decision-card strong { font-size: 16px; line-height: 1.45; color: #111827; }
.guide-decision-card p { margin: 0; color: #5f6b7a; font-size: 14px; line-height: 1.7; }
.guide-decision-fit { color: #2563eb; font-size: 12px; font-weight: 700; }
.guide-check-card { padding: 18px; border-radius: 16px; background: #f8fafc; border: 1px solid #e6ebf1; }
.guide-check-card strong { display: block; margin-bottom: 10px; color: #111827; font-size: 15px; }
.guide-check-card ul { margin: 0; padding-left: 18px; display: grid; gap: 10px; color: #4b5563; line-height: 1.7; }
.faq-archetype-shell { display: grid; gap: 12px; margin: 10px 0 22px; }
.faq-question-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.faq-question-card { display: grid; gap: 8px; padding: 16px; border-radius: 16px; border: 1px solid #e6ebf1; background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%); box-shadow: 0 4px 14px rgba(15,23,42,0.03); }
.faq-question-order { display: inline-flex; align-self: start; padding: 4px 10px; border-radius: 999px; background: #eef6ff; color: #2563eb; font-size: 12px; font-weight: 800; letter-spacing: 0.03em; }
.faq-question-card strong { font-size: 16px; line-height: 1.45; color: #111827; }
.faq-question-card p { margin: 0; color: #5f6b7a; font-size: 14px; line-height: 1.7; }
.comparison-archetype-shell { display: grid; gap: 12px; margin: 10px 0 22px; }
.comparison-card-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.comparison-card-tile { display: grid; gap: 8px; padding: 16px; border-radius: 16px; border: 1px solid #e6ebf1; background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%); box-shadow: 0 4px 14px rgba(15,23,42,0.03); }
.comparison-card-tile strong { font-size: 16px; line-height: 1.45; color: #111827; }
.comparison-card-tile span { color: #2563eb; font-size: 12px; font-weight: 700; }
.comparison-card-tile p { margin: 0; color: #5f6b7a; font-size: 14px; line-height: 1.7; }
.body-summary-shell,
.guide-body-highlight-shell { display: grid; gap: 12px; margin: 10px 0 24px; }
.body-summary-grid,
.guide-body-highlight-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.body-summary-card,
.guide-body-highlight-card { display: grid; gap: 8px; padding: 16px; border-radius: 16px; border: 1px solid #e6ebf1; background: #ffffff; box-shadow: 0 4px 14px rgba(15,23,42,0.03); }
.body-summary-order,
.guide-body-highlight-order { width: 30px; height: 30px; border-radius: 999px; background: #eef6ff; color: #2563eb; display: inline-flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 800; }
.body-summary-card strong,
.guide-body-highlight-card strong { font-size: 16px; line-height: 1.45; color: #111827; }
.body-summary-card p,
.guide-body-highlight-card p { margin: 0; color: #5f6b7a; font-size: 14px; line-height: 1.7; }
.reading-flow-shell { display: grid; gap: 12px; margin: 10px 0 24px; }
.reading-flow-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.reading-flow-card { display: grid; gap: 8px; padding: 16px; border-radius: 16px; border: 1px solid #e6ebf1; background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%); box-shadow: 0 4px 14px rgba(15,23,42,0.03); }
.reading-flow-order { width: 30px; height: 30px; border-radius: 999px; background: #eef6ff; color: #2563eb; display: inline-flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 800; }
.reading-flow-card strong { font-size: 16px; line-height: 1.45; color: #111827; }
.reading-flow-card p { margin: 0; color: #5f6b7a; font-size: 14px; line-height: 1.7; }
.post-trust-strip { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin: 10px 0 24px; }
.post-trust-card { display: grid; gap: 6px; padding: 16px; border-radius: 16px; border: 1px solid #e6ebf1; background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%); box-shadow: 0 4px 14px rgba(15,23,42,0.03); }
.post-trust-card span { color: #7b8794; font-size: 12px; font-weight: 700; letter-spacing: 0.03em; }
.post-trust-card strong { color: #111827; font-size: 16px; line-height: 1.45; }
.product-section-head { margin-bottom: 2px; }
.section-kicker { display: inline-flex; margin-bottom: 8px; padding: 5px 10px; border-radius: 999px; background: #eef6f1; color: #2f855a; font-size: 11px; font-weight: 800; letter-spacing: 0.04em; }
.section-intro { margin: 8px 0 0; color: #5f6b7a; font-size: 14px; line-height: 1.7; }
.product-card { position: relative; overflow: hidden; display: grid; grid-template-columns: 220px minmax(0, 1fr); gap: 24px; padding: 24px; border: 1px solid #e2e8f0; border-radius: 18px; background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%); color: inherit; align-items: start; box-shadow: 0 10px 24px rgba(15,23,42,0.05); }
.product-card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: linear-gradient(90deg, #2f855a 0%, #60a5fa 100%); opacity: 0.95; }
.product-card-grid { display: grid; grid-template-columns: 1fr; gap: 14px; }
.product-visual-column { display: grid; gap: 12px; align-self: stretch; }
.product-thumb-wrap { width: 220px; min-height: 188px; border-radius: 18px; background: linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%); display: flex; align-items: center; justify-content: center; overflow: hidden; border: 1px solid #e7ebf0; }
.product-thumb { width: 100%; height: 100%; object-fit: cover; }
.product-thumb-fallback { display: block; width: 60px; height: 60px; border-radius: 8px; background: linear-gradient(135deg, #dfe6f2 0%, #f4f7fb 100%); }
.product-visual-meta { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.product-visual-chip { display: inline-flex; align-items: center; justify-content: center; min-height: 38px; padding: 8px 10px; border-radius: 12px; background: #f8fafc; border: 1px solid #e7ebf0; color: #475569; font-size: 12px; font-weight: 700; text-align: center; }
.product-card-copy { min-width: 0; display: grid; gap: 14px; }
.product-card-topline { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; }
.product-rank-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.product-rank-chip { display: inline-flex; align-items: center; justify-content: center; padding: 4px 10px; border-radius: 999px; background: #eef6f1; color: #2f855a; font-size: 11px; font-weight: 800; letter-spacing: 0.04em; }
.product-fit-chip { display: inline-flex; align-items: center; justify-content: center; padding: 4px 10px; border-radius: 999px; background: #f6f7fb; color: #556070; font-size: 11px; font-weight: 700; letter-spacing: 0.02em; }
.product-score-row { display: inline-flex; align-items: center; gap: 8px; }
.product-stars { color: #f59e0b; font-size: 14px; letter-spacing: 0.08em; }
.product-score { color: #0f172a; font-size: 14px; font-weight: 800; }
.product-card-copy strong { font-size: 22px; line-height: 1.42; color: #111827; }
.product-price-row { display: flex; align-items: end; gap: 10px; flex-wrap: wrap; }
.product-price { font-size: 24px; font-weight: 900; color: #0f172a; letter-spacing: -0.02em; }
.product-price-hint { color: #7b8794; font-size: 12px; font-weight: 600; }
.product-badges { display: flex; gap: 6px; flex-wrap: wrap; }
.product-badge { display: inline-flex; padding: 4px 8px; border-radius: 999px; font-size: 11px; font-weight: 700; }
.product-badge.rocket { background: #eef6ff; color: #1d4ed8; }
.product-badge.shipping { background: #edfdf3; color: #047857; }
.product-badge.neutral { background: #f3f4f6; color: #6b7280; }
.product-meta-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 8px; }
.product-meta-item { display: grid; gap: 3px; padding: 10px 12px; border-radius: 12px; background: #f8fafc; border: 1px solid #e7ebf0; min-width: 0; }
.product-meta-item span { color: #7b8794; font-size: 11px; font-weight: 700; letter-spacing: 0.03em; }
.product-meta-item strong { font-size: 14px; line-height: 1.35; color: #1f2937; }
.product-note { margin: 0; padding: 12px 14px; border-radius: 14px; background: #fbfcfd; border: 1px solid #e7ebf0; border-left: 4px solid #2f855a; color: #5f6b7a; font-size: 14px; line-height: 1.75; overflow: visible; }
.product-note-label { display: block; margin-bottom: 5px; color: #2f855a; font-size: 11px; font-weight: 800; letter-spacing: 0.03em; }
.product-cta-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.product-card-cta { display: inline-flex; align-items: center; justify-content: center; min-width: 164px; padding: 14px 22px; border-radius: 999px; font-size: 14px; font-weight: 800; letter-spacing: 0.01em; }
.product-card-cta.primary { flex: 1 1 220px; background: #ffffff; color: #1d4ed8; border: 2px solid #3b82f6; box-shadow: 0 8px 18px rgba(59,130,246,0.14); }
.product-card-cta.primary::after { content: "↗"; margin-left: 6px; font-size: 12px; }
.product-card-cta.primary.muted { color: #64748b; border-color: #cbd5e1; box-shadow: none; background: #f8fafc; }
.product-card-cta.primary.muted::after { content: ""; margin-left: 0; }
.product-card-cta.secondary { min-width: auto; padding: 6px 4px; background: transparent; color: #64748b; border: none; }
.product-card-cta.secondary::after { content: "›"; margin-left: 6px; color: #94a3b8; font-size: 13px; }
.product-card-disabled { cursor: default; }
.post-layout { max-width: 1200px; grid-template-columns: minmax(0, 1fr) 270px; align-items: start; gap: 34px; }
.post-shell { border-radius: 16px; padding: 36px 38px 44px; }
.post-shell h1 { font-size: 34px; line-height: 1.34; letter-spacing: -0.035em; }
.post-hero-grid { display: grid; grid-template-columns: 1fr; gap: 22px; margin-bottom: 18px; align-items: start; }
.post-hero-stack { display: grid; gap: 18px; margin-bottom: 20px; }
.post-hero-stack .post-cover { max-width: 100%; }
.post-hero-main { min-width: 0; }
.post-hero-side { display: grid; gap: 14px; padding: 18px; border-radius: 18px; border: 1px solid #e5eaf1; background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%); box-shadow: 0 6px 18px rgba(15,23,42,0.04); }
.post-hero-figure { margin: 0; display: grid; justify-items: center; gap: 10px; }
.post-hero-image { width: min(760px, 100%); aspect-ratio: 16 / 9; object-fit: cover; border-radius: 18px; border: 1px solid #e5eaf1; background: #f3f4f6; display: block; box-shadow: 0 8px 24px rgba(15,23,42,0.06); }
.hero-side-badge-row { display: flex; justify-content: flex-start; }
.hero-side-badge { display: inline-flex; align-items: center; justify-content: center; padding: 6px 12px; border-radius: 999px; background: #eef6f1; color: #2f855a; font-size: 12px; font-weight: 800; letter-spacing: 0.03em; }
.hero-stat-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.hero-stat-card { display: grid; gap: 5px; padding: 12px; border-radius: 14px; background: #ffffff; border: 1px solid #e6ebf1; }
.hero-stat-card span { color: #7b8794; font-size: 11px; font-weight: 700; letter-spacing: 0.03em; }
.hero-stat-card strong { color: #1f2937; font-size: 15px; line-height: 1.35; }
.hero-checklist { margin: 0; padding-left: 18px; display: grid; gap: 10px; color: #4b5563; line-height: 1.7; }
.hero-checklist li::marker { color: #2f855a; font-weight: 700; }
.post-intro-block { display: grid; gap: 10px; }
.post-lead { margin: 0; font-size: 19px; line-height: 1.72; color: #1f2937; font-weight: 700; }
.post-sublead { margin: 0; font-size: 16px; line-height: 1.85; color: #5f6b7a; }
.method-shell { display: grid; gap: 12px; margin: 10px 0 22px; }
.article-method-card { box-shadow: 0 4px 14px rgba(15,23,42,0.03); border-radius: 16px; border: 1px solid #e6ebf1; background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%); }
.article-method-card span { color: #7b8794; font-size: 12px; font-weight: 700; letter-spacing: 0.03em; }
.article-method-card strong { font-size: 16px; line-height: 1.5; color: #111827; }
.post-summary-box, .reader-checklist, .trust-callout { display: none !important; }
.guide-map.plain, .quick-compare.plain, .related-posts { padding: 0; border: none; background: transparent; }
.section-head.compact h2, .quick-compare .section-head h2, .related-posts h2 { font-size: 19px; margin: 0 0 10px; padding: 0; border: none; }
.guide-map-list { gap: 0; }
.guide-map-item { padding: 10px 0; }
.guide-map-link { display: grid; grid-template-columns: auto minmax(0, 1fr); gap: 10px; align-items: start; color: inherit; text-decoration: none; }
.guide-map-link:hover strong { color: #2f855a; }
.guide-map-copy strong { font-size: 15px; }
.post-content { font-size: 17px; line-height: 1.98; }
.post-content h2 + p { margin-top: 12px; font-size: 18px; line-height: 1.9; color: #4b5563; }
.post-content h2 + p strong { color: #1f2937; }
.post-content ul,
.post-content ol { padding-left: 22px; display: grid; gap: 10px; margin: 16px 0; color: #4b5563; }
.post-content li::marker { color: #2f855a; font-weight: 700; }
.post-content table { border-collapse: separate; border-spacing: 0; background: #ffffff; border: 1px solid #e5eaf1; border-radius: 16px; overflow: hidden; box-shadow: 0 6px 18px rgba(15,23,42,0.04); }
.post-content table th { background: linear-gradient(180deg, #f4f8fc 0%, #fbfdff 100%); color: #334155; font-weight: 700; }
.post-content table tbody tr:nth-child(even) td { background: #fcfdfd; }
.guide-post-content h2:first-child { margin-top: 18px; }
.guide-post-content p + table,
.guide-post-content table + p { margin-top: 14px; }
.guide-post-content h2 { display: block; padding: 14px 16px; border-left: none; border-radius: 16px; background: linear-gradient(180deg, #ffffff 0%, #f7fafc 100%); border: 1px solid #e6ebf1; box-shadow: 0 4px 14px rgba(15,23,42,0.03); }
.guide-post-content h2 + p { padding: 0 4px; }
.guide-post-content h3 { margin-top: 24px; }
.guide-post-content ul,
.guide-post-content ol { padding-left: 22px; display: grid; gap: 10px; color: #4b5563; }
.guide-post-content li::marker { color: #2563eb; font-weight: 700; }
.guide-post-content table { border-collapse: separate; border-spacing: 0; background: #ffffff; border: 1px solid #e5eaf1; border-radius: 16px; overflow: hidden; box-shadow: 0 6px 18px rgba(15,23,42,0.04); }
.guide-post-content table th { background: linear-gradient(180deg, #f4f8fc 0%, #fbfdff 100%); color: #334155; font-weight: 700; }
.guide-post-content table tbody tr:nth-child(even) td { background: #fcfdfd; }
.post-content a { color: #2155a2; overflow-wrap: anywhere; word-break: break-word; text-decoration-color: rgba(33,85,162,0.25); text-underline-offset: 3px; }
.post-content h2 { font-size: 23px; border-left-width: 3px; margin-top: 36px; }
.post-content h3 { font-size: 18px; }
.compare-table-wrap { padding: 0; border: none; }
.compare-table th, .compare-table td { padding: 11px 8px; }
.post-card { padding: 12px 0; }
.modest-side-rail { display: grid; gap: 16px; position: sticky; top: 20px; }
.side-card { background: #ffffff; border: 1px solid #e6ebf1; border-radius: 12px; padding: 14px; box-shadow: 0 4px 14px rgba(15,23,42,0.03); }
.side-card strong { display: block; font-size: 14px; margin-bottom: 10px; color: #111827; }
.side-card-list { display: grid; gap: 8px; color: #667085; font-size: 13px; line-height: 1.6; }
.side-rail-posts { display: grid; gap: 10px; }
.side-rail-posts.compact { gap: 8px; }
.side-rail-post { display: grid; grid-template-columns: 72px minmax(0, 1fr); gap: 12px; align-items: start; color: #334155; font-size: 14px; line-height: 1.55; padding-bottom: 10px; border-bottom: 1px solid #eef2f7; }
.side-rail-post.compact { grid-template-columns: 56px minmax(0, 1fr); gap: 10px; }
.side-rail-thumb { width: 72px; aspect-ratio: 1 / 1; border-radius: 12px; background: linear-gradient(135deg, #eef3f7 0%, #f8fafc 100%); border: 1px solid #e4eaf1; display: block; }
.side-rail-post.compact .side-rail-thumb { width: 56px; border-radius: 10px; }
.side-rail-thumb-image { width: 72px; height: 72px; object-fit: cover; border-radius: 12px; border: 1px solid #e4eaf1; display: block; }
.side-rail-post.compact .side-rail-thumb-image { width: 56px; height: 56px; border-radius: 10px; }
.side-rail-copy { min-width: 0; display: grid; gap: 4px; }
.side-rail-copy strong { color: #1f2937; font-size: 14px; line-height: 1.45; font-weight: 700; }
.side-rail-copy span { color: #7b8794; font-size: 12px; line-height: 1.5; }
.side-rail-post:last-child { border-bottom: none; padding-bottom: 0; }
.side-tag-list { display: flex; gap: 8px; flex-wrap: wrap; }
.side-tag { display: inline-flex; padding: 6px 10px; border-radius: 999px; background: #f5f7fa; color: #667085; font-size: 12px; }
@media (max-width: 1180px) { .post-layout { grid-template-columns: 1fr; max-width: 900px; } .modest-side-rail { position: static; } .post-hero-grid { grid-template-columns: 1fr; } }
@media (max-width: 960px) { .home-feature-grid, .home-archive-grid, .featured-post-link, .home-post-item, .post-layout, .product-card-grid, .product-card, .guide-quick-compare-grid, .comparison-card-grid, .faq-question-grid, .guide-body-highlight-grid, .body-summary-grid, .reading-flow-grid, .post-trust-strip, .hero-stat-grid { grid-template-columns: 1fr; } .home-feature-lead { min-height: 300px; } .home-feature-overlay strong { font-size: 28px; } .home-spotlight-card { grid-template-columns: 88px minmax(0, 1fr); } .home-spotlight-image { width: 88px; height: 88px; } .home-post-thumb { aspect-ratio: 16 / 9; } .post-sidebar { position: static; } .site-header-inner { grid-template-columns: 1fr; display: grid; } .site-intro-strip { display: none; } .product-thumb-wrap { width: 100%; aspect-ratio: 16 / 10; min-height: auto; } .product-meta-grid, .product-visual-meta { grid-template-columns: repeat(2, minmax(0, 1fr)); } .post-shell { padding: 28px 22px 34px; } .post-shell h1 { font-size: 34px; } .post-lead { font-size: 20px; } .post-sublead { font-size: 17px; } }

.generated-content-body h2:nth-last-of-type(1),
.generated-content-body h2:nth-last-of-type(2) { }
.generated-content-body h2 + p:empty { display: none; }

.inline-visual-block { margin: 42px 0; display: grid; justify-items: center; gap: 10px; }
.inline-visual-block img { width: min(720px, 100%); aspect-ratio: 16 / 8.5; object-fit: cover; border-radius: 18px; border: 1px solid #e5eaf1; box-shadow: 0 10px 26px rgba(15,23,42,0.06); background: #f3f4f6; }
.inline-visual-block.compact img { width: min(660px, 100%); }
.inline-visual-block figcaption { color: #7b8794; font-size: 13px; line-height: 1.6; }

.inline-visual-block.late { margin-top: 56px; }
.generated-content-body h2:nth-last-of-type(1), .generated-content-body h2:nth-last-of-type(2) { display: none; }
.generated-content-body h2:nth-last-of-type(1) + p, .generated-content-body h2:nth-last-of-type(2) + p { display: none; }

.guide-editor-note { margin: 42px 0 28px; padding: 24px 26px; border: 1px solid #dce8df; border-left: 4px solid #2f855a; border-radius: 16px; background: linear-gradient(180deg, #fbfffd 0%, #f5fbf7 100%); }
.guide-editor-note h2 { margin: 0 0 10px; border: none; padding: 0; background: transparent; box-shadow: none; font-size: 24px; }
.guide-editor-note p { margin: 0; color: #3f4b5b; line-height: 1.9; font-size: 17px; }
.seo-answer-note { margin-top: 26px; }
.guide-fit-block { margin: 22px 0 34px; padding: 22px 24px; border: 1px solid #e5ebf6; border-radius: 18px; background: #fafcff; }
.guide-fit-list { margin: 14px 0 0; padding-left: 20px; display: grid; gap: 10px; color: #334155; line-height: 1.75; }
.guide-deep-dive { margin: 18px 0 30px; }
.guide-deep-dive-list { display: grid; gap: 16px; }
.guide-detail-card { padding: 22px 24px; border: 1px solid #e5eaf1; border-radius: 18px; background: #fff; box-shadow: 0 4px 14px rgba(15,23,42,0.03); }
.guide-detail-head { display: grid; gap: 8px; margin-bottom: 10px; }
.guide-detail-head h3 { margin: 0; font-size: 24px; line-height: 1.45; color: #172033; }
.guide-detail-summary { margin: 0 0 10px; color: #526072; font-size: 15px; line-height: 1.8; }
.guide-detail-card p { margin: 0; color: #334155; line-height: 1.9; font-size: 17px; }
.guide-detail-points { margin: 14px 0 0; padding-left: 20px; display: grid; gap: 8px; color: #475569; line-height: 1.75; }
.inline-visual-block.after-products { margin: 38px 0 28px; }
.generated-content-body h2:nth-of-type(1), .generated-content-body h2:nth-of-type(2), .generated-content-body h2:nth-of-type(3), .generated-content-body h2:nth-of-type(4), .generated-content-body h2:nth-of-type(5) { display: none; }
.generated-content-body h2:nth-of-type(1) + p, .generated-content-body h2:nth-of-type(2) + p, .generated-content-body h2:nth-of-type(3) + p, .generated-content-body h2:nth-of-type(4) + p, .generated-content-body h2:nth-of-type(5) + p { display: none; }

.generated-content-archive { display: none; }
.inline-visual-block.mid-flow { margin: 34px 0 34px; }
.guide-final-note { margin-top: 32px; }

.guide-info-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; margin: 28px 0 34px; }
.guide-info-grid article { padding: 18px; border: 1px solid #dfe8e2; border-radius: 16px; background: #fbfffd; }
.guide-info-grid strong { display: block; margin-bottom: 8px; color: #1f2937; font-size: 17px; }
.guide-info-grid p { margin: 0; line-height: 1.75; color: #4b5563; font-size: 15px; }
.guide-final-note ul { margin: 14px 0 0; padding-left: 20px; display: grid; gap: 8px; color: #3f4b5b; line-height: 1.75; }
.guide-faq-block { margin: 36px 0 16px; }
.faq-list { display: grid; gap: 14px; }
.faq-item { padding: 18px 20px; border: 1px solid #e3eaf2; border-radius: 16px; background: #fbfdff; }
.faq-item h3 { margin: 0 0 10px; font-size: 20px; line-height: 1.4; color: #172033; }
.faq-item p { margin: 0; color: #4b5563; line-height: 1.8; }
@media (max-width: 960px) { .guide-info-grid { grid-template-columns: 1fr; } }

.persona-product-section { margin: 42px 0 36px; }
.persona-head { margin-bottom: 16px; }
.persona-head h2 { margin-bottom: 8px; }
.persona-head p { max-width: 66ch; color: #4f5f72; line-height: 1.8; font-size: 16px; }
.persona-product-list { display: grid; gap: 14px; }
.persona-product-card { display: grid; grid-template-columns: 132px minmax(0, 1fr); column-gap: 18px; row-gap: 12px; align-items: start; padding: 16px; border: 1px solid #dfe7ef; border-radius: 12px; background: #ffffff; }
.persona-product-card.featured { border-color: #b9d9c7; background: #fbfefc; }
.persona-product-media { position: relative; align-self: start; }
.persona-product-media img { width: 132px; height: 132px; object-fit: cover; border-radius: 10px; border: 1px solid #dfe7ef; background: #f8fafc; display: block; }
.persona-product-media span { position: absolute; top: 8px; left: 8px; padding: 4px 7px; border-radius: 7px; background: rgba(255,255,255,0.94); border: 1px solid rgba(226,232,240,0.9); color: #176b43; font-size: 11px; font-weight: 800; }
.persona-product-copy { min-width: 0; display: grid; gap: 8px; }
.persona-product-details { grid-column: 1 / -1; display: grid; gap: 10px; padding-top: 2px; }
.persona-row { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.persona-type, .persona-mbti { display: inline-flex; align-items: center; border-radius: 7px; padding: 5px 8px; font-size: 12px; font-weight: 800; line-height: 1; }
.persona-type { color: #176b43; background: #edf7f1; border: 1px solid #d0eadb; }
.persona-mbti { color: #475569; background: #f7f8fa; border: 1px solid #e2e8f0; }
.persona-product-copy h3 { margin: 0; color: #172033; font-size: 20px; line-height: 1.42; letter-spacing: -0.02em; }
.persona-product-copy p { margin: 0; color: #405065; font-size: 15px; line-height: 1.72; }
.persona-product-name { display: block; color: #111827; font-size: 15px; line-height: 1.5; }
.persona-product-meta { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 1px; }
.persona-product-meta span { display: inline-flex; padding: 6px 8px; border-radius: 8px; background: #f8fafc; border: 1px solid #e4eaf1; color: #334155; font-size: 12.5px; font-weight: 700; }
.persona-fit-list { margin: 0; padding-left: 18px; display: grid; gap: 4px; color: #465568; line-height: 1.65; font-size: 14.5px; }
.persona-fit-list li::marker { color: #2f855a; }
.persona-caution { margin-top: 2px !important; padding: 0 0 0 10px; border-left: 3px solid #e8c981; color: #6a4a10 !important; background: transparent; border-radius: 0; font-size: 14px !important; line-height: 1.65 !important; }
.persona-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 2px; }
.persona-actions a, .persona-actions span { display: inline-flex; align-items: center; justify-content: center; min-height: 36px; padding: 0 13px; border-radius: 8px; border: 1px solid #2f855a; background: #2f855a; color: #ffffff; font-weight: 800; font-size: 14px; text-decoration: none; }
.persona-actions span { border-color: #d6dee8; background: #f5f7fa; color: #7b8794; }
@media (max-width: 720px) {
  .persona-product-card { grid-template-columns: 96px minmax(0, 1fr); gap: 12px; padding: 13px; }
  .persona-product-media img { width: 96px; height: 96px; }
  .persona-product-copy h3 { font-size: 18px; }
  .persona-product-copy p { font-size: 14px; }
}

.article-author-line { display: inline-flex; align-items: center; gap: 8px; margin-top: 14px; color: #334155; text-decoration: none; font-size: 15px; }
.article-author-line:hover strong { text-decoration: underline; text-underline-offset: 3px; }
.author-avatar { width: 46px; height: 46px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; background: #e8f5ee; color: #167447; border: 1px solid #bfe8d0; font-weight: 800; }
.author-avatar.small { width: 28px; height: 28px; font-size: 13px; }
.author-avatar.large { width: 72px; height: 72px; font-size: 26px; }
.article-author-box { display: flex; gap: 16px; margin: 44px 0 10px; padding: 22px; border: 1px solid #dce8df; border-radius: 16px; background: #fbfefc; }
.article-author-box h2 { margin: 2px 0 8px; padding: 0; border: 0; background: none; box-shadow: none; font-size: 22px; }
.article-author-box p { margin: 0; color: #475569; line-height: 1.75; font-size: 15px; }
.author-box-topline { color: #2f855a; font-size: 13px; font-weight: 800; }
.author-tag-row { display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 0; }
.author-tag-row span { padding: 5px 8px; border-radius: 8px; background: #effaf3; border: 1px solid #d6f0df; color: #166534; font-size: 12px; font-weight: 700; }
.article-author-box .author-disclosure { margin-top: 10px; color: #64748b; font-size: 13px; }
.author-profile-link, .back-link a { display: inline-flex; margin-top: 12px; color: #166534; font-weight: 800; text-decoration: none; }
.author-profile-link:hover, .back-link a:hover { text-decoration: underline; text-underline-offset: 3px; }
.about-page, .author-profile-page { display: grid; gap: 26px; }
.about-hero, .author-profile-hero { display: grid; gap: 12px; }
.about-hero h1, .author-profile-hero h1 { margin: 0; font-size: clamp(32px, 5vw, 48px); line-height: 1.18; letter-spacing: -0.04em; }
.about-hero p, .author-profile-hero p { margin: 0; color: #475569; font-size: 18px; line-height: 1.8; }
.author-profile-hero { display: flex; align-items: center; }
.editorial-policy-card, .author-note-box { padding: 24px; border: 1px solid #dce8df; border-radius: 16px; background: #fbfefc; }
.editorial-policy-card h2 { margin: 0 0 12px; font-size: 24px; }
.editorial-policy-card ul { margin: 0; padding-left: 20px; display: grid; gap: 9px; color: #475569; line-height: 1.75; }
.editorial-policy-card p, .author-note-box p { color: #475569; line-height: 1.8; }
.author-directory { display: grid; gap: 18px; }
.author-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.author-card { display: flex; gap: 13px; padding: 16px; border: 1px solid #e1e8ef; border-radius: 14px; background: #fff; color: inherit; text-decoration: none; }
.author-card:hover { border-color: #b7dfc7; }
.author-card strong { display: block; margin-bottom: 3px; color: #111827; }
.author-card p { margin: 0 0 4px; color: #334155; font-weight: 700; }
.author-card small { color: #64748b; line-height: 1.55; }
.author-note-box strong { display: block; margin-bottom: 6px; color: #166534; }
@media (max-width: 720px) {
  .article-author-box, .author-profile-hero { align-items: flex-start; }
  .author-grid { grid-template-columns: 1fr; }
}

/* Maily-inspired editor channel pages */
.author-channel-page {
  max-width: 900px;
  margin: 0 auto;
  padding: 16px 0 56px;
}
.author-channel-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 26px 32px;
  padding: 22px 0 28px;
  border-bottom: 1px solid #dfe5ec;
}
.author-channel-topline {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 12px;
  color: #475569;
  font-weight: 700;
}
.site-wave-mark {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #1f7a4b;
  font-size: 30px;
  line-height: 1;
  text-decoration: none;
}
.author-channel-identity {
  display: flex;
  align-items: center;
  gap: 26px;
  min-width: 0;
}
.author-channel-avatar {
  width: 104px;
  height: 104px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  background: #e6f5ec;
  border: 1px solid #b9e2ca;
  color: #136a3f;
  font-size: 42px;
  font-weight: 900;
}
.author-channel-copy {
  min-width: 0;
}
.author-channel-from {
  margin: 0 0 4px;
  color: #1f7a4b;
  font-size: 14px;
  font-weight: 800;
}
.author-channel-copy h1 {
  margin: 0;
  color: #111827;
  font-size: clamp(38px, 6vw, 56px);
  line-height: 1.12;
  letter-spacing: -0.05em;
}
.author-channel-handle {
  margin: 5px 0 0;
  color: #64748b;
  font-size: 18px;
}
.author-channel-tagline {
  margin: 22px 0 0;
  color: #172033;
  font-size: 20px;
  line-height: 1.7;
  word-break: keep-all;
}
.author-channel-actions {
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  gap: 12px;
  padding-bottom: 6px;
}
.author-channel-link {
  min-height: 42px;
  padding: 0 16px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #d7dee8;
  background: #ffffff;
  color: #334155;
  font-weight: 800;
  text-decoration: none;
}
.author-channel-link.primary {
  border-color: #1f7a4b;
  background: #146c43;
  color: #ffffff;
}
.author-channel-stats {
  grid-column: 1 / -1;
  display: flex;
  gap: 30px;
  margin: 6px 0 0;
  padding: 0;
}
.author-channel-stats div {
  display: grid;
  gap: 4px;
}
.author-channel-stats dt {
  color: #64748b;
  font-size: 15px;
}
.author-channel-stats dd {
  margin: 0;
  color: #111827;
  font-size: 25px;
  line-height: 1.1;
}
.author-channel-tabs {
  display: flex;
  gap: 34px;
  border-bottom: 1px solid #dfe5ec;
  margin: 24px 0 18px;
}
.author-channel-tabs a {
  padding: 0 0 14px;
  color: #475569;
  font-size: 18px;
  font-weight: 700;
  text-decoration: none;
  border-bottom: 2px solid transparent;
}
.author-channel-tabs a.active {
  color: #111827;
  border-bottom-color: #111827;
}
.author-post-list {
  display: grid;
  gap: 14px;
}
.author-post-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 260px;
  gap: 22px;
  align-items: stretch;
  min-height: 160px;
  padding: 16px 0;
  border-bottom: 1px solid #e6ebf1;
  color: inherit;
  text-decoration: none;
}
.author-post-card:first-child {
  padding-top: 0;
}
.author-post-card:hover h2 {
  text-decoration: underline;
  text-underline-offset: 4px;
}
.author-post-card-copy {
  display: grid;
  align-content: start;
  gap: 8px;
}
.author-post-category {
  margin: 0;
  color: #64748b;
  font-size: 14px;
}
.author-post-card h2 {
  margin: 0;
  color: #111827;
  font-size: 24px;
  line-height: 1.35;
  letter-spacing: -0.025em;
}
.author-post-card p:not(.author-post-category) {
  margin: 0;
  color: #475569;
  line-height: 1.65;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.author-post-card span {
  color: #64748b;
  font-size: 13px;
}
.author-post-card img {
  width: 100%;
  height: 100%;
  min-height: 150px;
  object-fit: cover;
  border: 1px solid #dfe5ec;
  background: #f8fafc;
}
.author-editor-note,
.author-empty-state {
  margin-top: 30px;
  padding: 22px 0 0;
  border-top: 1px solid #dfe5ec;
}
.author-editor-note h2,
.author-empty-state h2 {
  margin: 0 0 12px;
  color: #111827;
  font-size: 24px;
}
.author-editor-note p,
.author-empty-state p {
  color: #475569;
  line-height: 1.75;
}
.author-editor-note ul {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 16px 0;
  padding: 0;
  list-style: none;
}
.author-editor-note li {
  padding: 6px 10px;
  border: 1px solid #d6e9dd;
  border-radius: 8px;
  background: #f2faf5;
  color: #166534;
  font-size: 13px;
  font-weight: 800;
}
.author-editor-disclosure {
  color: #64748b !important;
  font-size: 14px;
}
@media (max-width: 760px) {
  .author-channel-page { padding: 4px 0 40px; }
  .author-channel-hero { grid-template-columns: 1fr; gap: 20px; }
  .author-channel-identity { align-items: flex-start; gap: 16px; }
  .author-channel-avatar { width: 72px; height: 72px; font-size: 28px; }
  .author-channel-copy h1 { font-size: 36px; }
  .author-channel-actions { justify-content: flex-start; }
  .author-channel-stats { gap: 18px; flex-wrap: wrap; }
  .author-post-card { grid-template-columns: 1fr; }
  .author-post-card img { aspect-ratio: 16 / 9; height: auto; }
}
.author-avatar.image,
.author-channel-avatar.image {
  object-fit: cover;
  object-position: center;
  padding: 0;
  color: transparent;
}
.author-channel-avatar.image {
  display: block;
  box-shadow: none;
}
.author-post-card {
  margin: 0 -12px;
  padding: 16px 12px;
  border-radius: 12px;
  border-bottom: 1px solid #e6ebf1;
  transition: background-color 150ms ease, border-color 150ms ease;
}
.author-post-card:hover {
  background: #ffffff;
  border-color: #d8e0ea;
}
.author-post-card:hover h2 {
  text-decoration: none;
}
.author-post-card:hover img {
  border-color: #cbd5e1;
}
/* Stable block hover for author post rows: no text-only hover and no size shift */
.author-post-list { gap: 8px; }
.author-post-card {
  margin: 0;
  padding: 16px;
  border: 0;
  border-radius: 12px;
  box-sizing: border-box;
  box-shadow: inset 0 -1px 0 #e6ebf1;
  background: transparent;
}
.author-post-card:hover {
  background: #ffffff;
  box-shadow: inset 0 0 0 1px #d8e0ea;
}
.author-post-card:first-child { padding-top: 16px; }
/* Author profile typography and footer alignment polish */
.author-channel-tagline {
  max-width: 620px;
  font-size: 16px;
  line-height: 1.7;
  color: #334155;
}
.author-editor-note p {
  max-width: 760px;
  font-size: 15px;
  line-height: 1.85;
}
.site-footer {
  margin-top: 0;
}
.site-footer-inner {
  max-width: 900px;
  padding: 26px 20px 36px;
}
.site-footer-note {
  max-width: 620px;
}
@media (min-width: 761px) {
  .author-channel-page + .site-footer,
  .site-footer {
    text-align: left;
  }
}
.author-channel-tabs button {
  appearance: none;
  border: 0;
  background: transparent;
  padding: 0 0 14px;
  color: #475569;
  font: inherit;
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  border-bottom: 2px solid transparent;
}
.author-channel-tabs button.active {
  color: #111827;
  border-bottom-color: #111827;
}
.author-channel-tabs a { display: none; }
.author-editor-note[hidden], .author-post-list[hidden] { display: none; }
.author-editor-note {
  margin-top: 0;
  padding: 22px 0 0;
  border-top: 0;
}
.author-editor-note h2 {
  margin-bottom: 18px;
}
.author-editor-note p {
  max-width: 680px;
  font-size: 17px;
  line-height: 1.9;
}
.author-channel-handle {
  word-spacing: 0.18em;
}
.author-channel-stats dd {
  font-size: 22px;
  letter-spacing: -0.02em;
}
.author-channel-stats dt {
  white-space: nowrap;
}
/* Cleaner post-bottom author strip inspired by newsletter bylines */
.article-author-strip {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 34px 0 4px;
  padding: 16px 0 0;
  border-top: 1px solid #e5eaf0;
}
.article-author-strip .author-avatar {
  width: 38px;
  height: 38px;
  font-size: 13px;
}
.article-author-strip-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.article-author-strip-copy span {
  color: #1f7a4b;
  font-size: 13px;
  font-weight: 800;
}
.article-author-strip-copy strong {
  color: #111827;
  font-size: 15px;
}
.article-author-strip .author-profile-link {
  margin: 0 0 0 auto;
  color: #166534;
  font-size: 14px;
}
@media (max-width: 560px) {
  .article-author-strip { align-items: flex-start; }
  .article-author-strip .author-profile-link { margin-left: 0; }
}
/* Bottom related posts carousel */
.bottom-related-carousel {
  margin: 26px 0 0;
  padding: 22px 0 0;
  border-top: 1px solid #e5eaf0;
}
.bottom-related-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}
.bottom-related-head h2 {
  margin: 0;
  padding: 0;
  border: 0;
  color: #111827;
  font-size: 20px;
  line-height: 1.4;
}
.bottom-related-controls {
  display: flex;
  gap: 8px;
}
.bottom-related-controls button {
  width: 34px;
  height: 34px;
  border: 1px solid #d9e1ea;
  border-radius: 8px;
  background: #ffffff;
  color: #334155;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}
.bottom-related-controls button:hover {
  border-color: #b7c4d3;
  background: #f8fafc;
}
.bottom-related-track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(260px, 320px);
  gap: 14px;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
  padding: 2px 2px 10px;
}
.bottom-related-card {
  scroll-snap-align: start;
  display: grid;
  grid-template-rows: 130px minmax(0, 1fr);
  border: 1px solid #e1e8ef;
  border-radius: 12px;
  overflow: hidden;
  background: #ffffff;
  color: inherit;
  text-decoration: none;
}
.bottom-related-card:hover {
  border-color: #c8d4e0;
}
.bottom-related-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: #f8fafc;
}
.bottom-related-card div {
  display: grid;
  gap: 6px;
  padding: 12px;
}
.bottom-related-card span {
  color: #1f7a4b;
  font-size: 12px;
  font-weight: 800;
}
.bottom-related-card strong {
  color: #111827;
  font-size: 16px;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.bottom-related-card p {
  margin: 0;
  color: #64748b;
  font-size: 13px;
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
@media (max-width: 560px) {
  .bottom-related-track { grid-auto-columns: minmax(230px, 82vw); }
}
