/* ============================================================================
   Platepusher article kit: shared design system for rich editorial pages
   (roundups, vs/comparison pages, glossary). Tokens derived from
   Workflow/assets/postdrome/brand.json. Component classes are namespaced
   `ak-` so they never collide with the per-page injected styles or styles.css.

   Rules honored: no em-dashes; accent #C7634A is punctuation-emphasis only
   (never a fill); severity scale is the only multi-hue data-viz palette.
   ============================================================================ */

:root {
  --ak-bg: #ffffff;
  --ak-surface: #fafafb;
  --ak-surface-2: #f4f4f5;
  --ak-text: #111827;
  --ak-text-2: #4b5563;
  --ak-text-3: #9ca3af;
  --ak-accent: #f25940;
  --ak-accent-deep: #111827;
  --ak-accent-soft: #fdece9;
  --ak-divider: #e5e7eb;
  --ak-punct: #f25940;
  --ak-calm: #3d7a5e;
  --ak-moderate: #d4a574;
  --ak-severe: #f25940;
  --ak-serif: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --ak-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --ak-radius: 16px;
  --ak-shadow: 0 12px 40px rgba(17, 24, 39, 0.10);
  --ak-shadow-sm: 0 4px 14px rgba(17, 24, 39, 0.08);
}

/* ---- layout ---- */
.ak-wrap { width: min(880px, calc(100% - 40px)); margin: 0 auto; }
.ak-wrap--wide { width: min(1040px, calc(100% - 40px)); }
.ak-section { padding: 30px 0; }
.ak-prose p { margin: 0 0 16px; font-family: var(--ak-sans); font-size: 1.06rem; line-height: 1.68; color: var(--ak-text); }
.ak-prose p:last-child { margin-bottom: 0; }
.ak-prose strong { color: var(--ak-accent-deep); font-weight: 700; }
.ak-prose a { color: var(--ak-accent); text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1px; }
.ak-h2 { margin: 40px 0 16px; font-family: var(--ak-serif); font-weight: 800; font-size: clamp(1.5rem, 3vw, 2rem); line-height: 1.2; letter-spacing: -0.015em; color: var(--ak-accent-deep); }
.ak-h3 { margin: 28px 0 12px; font-family: var(--ak-serif); font-size: 1.28rem; line-height: 1.25; color: var(--ak-accent-deep); }
.ak-kicker { font-family: var(--ak-sans); font-size: 0.8rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ak-accent); margin: 0 0 12px; }

/* ---- eyebrow / table of contents ---- */
.ak-toc { background: var(--ak-surface); border: 1px solid var(--ak-divider); border-radius: var(--ak-radius); padding: 20px 24px; margin: 26px 0; box-shadow: var(--ak-shadow-sm); }
.ak-toc h2 { margin: 0 0 10px; font-family: var(--ak-sans); font-size: 0.8rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ak-text-2); }
.ak-toc ol { margin: 0; padding-left: 20px; columns: 2; column-gap: 28px; }
.ak-toc li { margin: 0 0 7px; font-size: 0.96rem; line-height: 1.4; break-inside: avoid; }
.ak-toc a { color: var(--ak-accent); text-decoration: none; }
@media (max-width: 560px) { .ak-toc ol { columns: 1; } }

/* ---- figure + caption (charts live here) ---- */
.ak-figure { margin: 28px 0; }
.ak-figure svg { display: block; width: 100%; height: auto; background: var(--ak-surface); border: 1px solid var(--ak-divider); border-radius: var(--ak-radius); box-shadow: var(--ak-shadow-sm); }
.ak-figcaption { margin: 12px 4px 0; font-family: var(--ak-sans); font-size: 0.9rem; line-height: 1.5; color: var(--ak-text-2); }
.ak-figcaption b { color: var(--ak-accent-deep); }

/* ---- comparison / scorecard table ---- */
.ak-table-scroll { overflow-x: auto; margin: 24px 0; border-radius: var(--ak-radius); border: 1px solid var(--ak-divider); box-shadow: var(--ak-shadow-sm); }
.ak-table { width: 100%; border-collapse: collapse; background: var(--ak-surface); font-family: var(--ak-sans); font-size: 0.96rem; }
.ak-table caption { caption-side: bottom; padding: 12px 16px; font-size: 0.86rem; color: var(--ak-text-2); text-align: left; }
.ak-table th, .ak-table td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--ak-divider); vertical-align: top; }
.ak-table thead th { background: var(--ak-accent-deep); color: #fff; font-weight: 600; font-size: 0.84rem; letter-spacing: 0.02em; position: sticky; top: 0; }
.ak-table tbody th { font-weight: 700; color: var(--ak-accent-deep); }
.ak-table tr:last-child td, .ak-table tr:last-child th { border-bottom: none; }
.ak-table .ak-col-ours { background: var(--ak-accent-soft); }
.ak-table thead .ak-col-ours { background: var(--ak-accent); }
.ak-row-ours th, .ak-row-ours td { background: var(--ak-accent-soft); }
.ak-cell-num { font-variant-numeric: tabular-nums; font-weight: 700; color: var(--ak-accent-deep); }
.ak-yes { color: #3d7a5e; font-weight: 700; }
.ak-no { color: var(--ak-text-3); }
.ak-partial { color: var(--ak-moderate); font-weight: 600; }

/* ---- verdict / who-should-pick cards ---- */
.ak-verdict { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin: 26px 0; }
.ak-verdict__card { background: var(--ak-surface); border: 1px solid var(--ak-divider); border-radius: var(--ak-radius); padding: 22px 24px; box-shadow: var(--ak-shadow-sm); }
.ak-verdict__card--ours { border-color: var(--ak-accent); background: linear-gradient(180deg, var(--ak-accent-soft) 0%, var(--ak-surface) 60%); }
.ak-verdict__h { margin: 0 0 10px; font-family: var(--ak-sans); font-size: 0.78rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ak-accent); }
.ak-verdict__card p { margin: 0; font-size: 1.0rem; line-height: 1.6; color: var(--ak-text); }
@media (max-width: 620px) { .ak-verdict { grid-template-columns: 1fr; } }

/* ---- pros / cons ---- */
.ak-proscons { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin: 24px 0; }
.ak-proscons__col { background: var(--ak-surface); border: 1px solid var(--ak-divider); border-radius: var(--ak-radius); padding: 20px 22px; box-shadow: var(--ak-shadow-sm); }
.ak-proscons__h { margin: 0 0 12px; font-family: var(--ak-sans); font-size: 0.86rem; font-weight: 700; letter-spacing: 0.04em; }
.ak-proscons__h--pro { color: #3d7a5e; }
.ak-proscons__h--con { color: var(--ak-severe); }
.ak-proscons ul { margin: 0; padding-left: 18px; }
.ak-proscons li { margin: 0 0 9px; font-size: 0.98rem; line-height: 1.5; color: var(--ak-text); }
@media (max-width: 620px) { .ak-proscons { grid-template-columns: 1fr; } }

/* ---- stat row (big numbers) ---- */
.ak-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 26px 0; }
.ak-stat { background: var(--ak-surface); border: 1px solid var(--ak-divider); border-radius: var(--ak-radius); padding: 22px 20px; text-align: center; box-shadow: var(--ak-shadow-sm); }
.ak-stat__n { font-family: var(--ak-serif); font-size: clamp(1.8rem, 4vw, 2.5rem); line-height: 1; color: var(--ak-accent); }
.ak-stat__n sup { font-size: 0.5em; }
.ak-stat__l { margin: 10px 0 0; font-family: var(--ak-sans); font-size: 0.9rem; line-height: 1.4; color: var(--ak-text-2); }
.ak-stat__src { display: block; margin-top: 6px; font-size: 0.74rem; color: var(--ak-text-3); }
@media (max-width: 620px) { .ak-stats { grid-template-columns: 1fr; } }

/* ---- callout (note / warning / source) ---- */
.ak-callout { margin: 24px 0; padding: 18px 22px; border-radius: 12px; border-left: 4px solid var(--ak-accent); background: var(--ak-accent-soft); }
.ak-callout--warn { border-left-color: var(--ak-severe); background: #fbeee9; }
.ak-callout__h { margin: 0 0 6px; font-family: var(--ak-sans); font-size: 0.82rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ak-accent-deep); }
.ak-callout p { margin: 0; font-size: 0.98rem; line-height: 1.6; color: var(--ak-text); }

/* ---- pull quote ---- */
.ak-pull { margin: 30px 0; padding: 0 0 0 24px; border-left: 3px solid var(--ak-punct); }
.ak-pull p { margin: 0; font-family: var(--ak-serif); font-size: clamp(1.3rem, 3vw, 1.7rem); line-height: 1.35; color: var(--ak-accent-deep); }

/* ---- decision / bottleneck pick cards ---- */
.ak-picks { display: grid; gap: 14px; margin: 24px 0; }
.ak-pick { display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: start; background: var(--ak-surface); border: 1px solid var(--ak-divider); border-radius: 14px; padding: 18px 20px; box-shadow: var(--ak-shadow-sm); }
.ak-pick__tag { align-self: start; font-family: var(--ak-sans); font-size: 0.72rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: #fff; background: var(--ak-accent); border-radius: 999px; padding: 6px 12px; white-space: nowrap; }
.ak-pick p { margin: 0; font-size: 0.98rem; line-height: 1.55; color: var(--ak-text); }

/* ---- pills / badges ---- */
.ak-pill { display: inline-block; font-family: var(--ak-sans); font-size: 0.78rem; font-weight: 600; padding: 4px 10px; border-radius: 999px; background: var(--ak-surface-2); color: var(--ak-text-2); border: 1px solid var(--ak-divider); }
.ak-pill--ours { background: var(--ak-accent); color: #fff; border-color: var(--ak-accent); }

/* ---- FAQ accordion ---- */
.ak-faq { margin: 22px 0; }
.ak-faq details { background: var(--ak-surface); border: 1px solid var(--ak-divider); border-radius: 12px; margin: 0 0 10px; padding: 4px 20px; box-shadow: var(--ak-shadow-sm); }
.ak-faq summary { cursor: pointer; padding: 14px 0; font-family: var(--ak-sans); font-weight: 600; font-size: 1.02rem; color: var(--ak-accent-deep); list-style: none; }
.ak-faq summary::-webkit-details-marker { display: none; }
.ak-faq summary::after { content: "+"; float: right; color: var(--ak-accent); font-weight: 400; font-size: 1.3rem; line-height: 1; }
.ak-faq details[open] summary::after { content: "\2013"; }
.ak-faq details[open] summary { border-bottom: 1px solid var(--ak-divider); }
.ak-faq__a { padding: 14px 0 16px; font-size: 0.99rem; line-height: 1.6; color: var(--ak-text); }

/* ---- inline CTA strip ---- */
.ak-cta { margin: 34px 0; padding: 28px 30px; border-radius: 20px; background: linear-gradient(135deg, var(--ak-accent-deep) 0%, var(--ak-accent) 100%); color: #fff; box-shadow: var(--ak-shadow); }
.ak-cta__h { margin: 0 0 8px; font-family: var(--ak-serif); font-size: 1.4rem; line-height: 1.25; color: #fff; }
.ak-cta p { margin: 0 0 18px; font-size: 1.0rem; line-height: 1.55; color: rgba(255,255,255,0.86); }
.ak-cta a { display: inline-flex; align-items: center; gap: 8px; background: #fff; color: var(--ak-accent-deep); font-family: var(--ak-sans); font-weight: 600; border-radius: 999px; padding: 12px 22px; text-decoration: none; }

/* ---- site chrome (header / hero / footer), self-contained for kit pages ---- */
.ak-body { background: var(--ak-bg); color: var(--ak-text); font-family: var(--ak-sans); margin: 0; }
.ak-header { position: sticky; top: 0; z-index: 20; background: rgba(250,250,247,0.92); backdrop-filter: blur(18px); border-bottom: 1px solid var(--ak-divider); }
.ak-nav { width: min(1140px, calc(100% - 40px)); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 14px 0; }
.ak-brand img { height: 50px; width: auto; display: block; }
.ak-btn { display: inline-flex; align-items: center; gap: 8px; border-radius: 999px; padding: 11px 20px; font-family: var(--ak-sans); font-weight: 600; font-size: 0.95rem; text-decoration: none; cursor: pointer; border: 1px solid transparent; }
.ak-btn--primary { background: var(--ak-accent); color: #fff; box-shadow: 0 10px 22px rgba(74,107,122,0.22); }
.ak-btn--primary:hover { background: var(--ak-accent-deep); }
.ak-hero { padding: 48px 0 8px; }
.ak-hero .ak-h1 { margin: 0 0 16px; font-family: var(--ak-serif); font-weight: 800; font-size: clamp(2rem, 4.4vw, 3rem); line-height: 1.1; letter-spacing: -0.02em; color: var(--ak-accent-deep); }
.ak-hero__dek { margin: 0; max-width: 720px; font-family: var(--ak-sans); font-size: 1.14rem; line-height: 1.55; color: var(--ak-text-2); }
.ak-hero__meta { margin: 16px 0 0; font-size: 0.86rem; color: var(--ak-text-3); }
.ak-footer { margin-top: 56px; padding: 44px 0 36px; border-top: 1px solid var(--ak-divider); background: var(--ak-bg); }
.ak-footer__grid { width: min(1140px, calc(100% - 40px)); margin: 0 auto; display: grid; grid-template-columns: minmax(240px,1fr) repeat(2, minmax(140px,1fr)); gap: 32px; align-items: start; }
.ak-footer__grid img { height: 38px; }
.ak-footer__grid h3 { margin: 0 0 12px; font-size: 0.76rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ak-text-2); }
.ak-footer__grid ul { list-style: none; padding: 0; margin: 0; }
.ak-footer__grid li { margin: 0 0 8px; }
.ak-footer__grid a { color: var(--ak-accent); text-decoration: none; font-size: 0.95rem; }
.ak-footer__copy { margin: 12px 0 4px; color: var(--ak-text-2); font-size: 0.9rem; }
.ak-footer__us { margin: 0; color: var(--ak-text-3); font-size: 0.82rem; }
.ak-disclaimer { width: min(880px, calc(100% - 40px)); margin: 0 auto; padding: 8px 0 0; font-size: 0.82rem; line-height: 1.5; color: var(--ak-text-3); }
@media (max-width: 720px) { .ak-footer__grid { grid-template-columns: 1fr; } }

/* ---- glossary specific ---- */
.ak-gloss-nav { display: flex; flex-wrap: wrap; gap: 8px; margin: 22px 0; }
.ak-gloss-nav a { font-family: var(--ak-sans); font-weight: 700; font-size: 0.92rem; color: var(--ak-accent); background: var(--ak-surface); border: 1px solid var(--ak-divider); border-radius: 10px; width: 38px; height: 38px; display: inline-flex; align-items: center; justify-content: center; text-decoration: none; }
.ak-gloss-nav a:hover { background: var(--ak-accent); color: #fff; }
.ak-term { background: var(--ak-surface); border: 1px solid var(--ak-divider); border-radius: var(--ak-radius); padding: 22px 24px; margin: 0 0 16px; box-shadow: var(--ak-shadow-sm); scroll-margin-top: 90px; }
.ak-term h3 { margin: 0 0 4px; font-family: var(--ak-serif); font-size: 1.3rem; color: var(--ak-accent-deep); }
.ak-term__pron { font-family: var(--ak-sans); font-size: 0.86rem; font-style: italic; color: var(--ak-text-3); margin: 0 0 12px; }
.ak-term__also { margin: 12px 0 0; font-size: 0.9rem; color: var(--ak-text-2); }
.ak-term p { margin: 0 0 10px; font-size: 1.0rem; line-height: 1.62; color: var(--ak-text); font-family: var(--ak-sans); }
