*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;line-height:1.7;color:#111;background:#fff}
.astro-gIjOOvXg{max-width:900px;margin:0 auto;padding:0 28px}
.astro-C3icY7aw{background:#111;color:#fff;padding:64px 0;margin-bottom:48px}
.astro-C3icY7aw h1{font-size:42px;font-weight:800;letter-spacing:-1px;margin-bottom:8px}
.astro-C3icY7aw p{font-size:18px;opacity:.7}
.astro-C3icY7aw a{color:#fff;text-decoration:none;font-size:22px;font-weight:800}
.astro-cGIM9GNZ{padding:0}
.astro-ncxI7NGf{padding:32px 0;border-left:4px solid #111;padding-left:24px;margin-bottom:28px}
.astro-ncxI7NGf h2{font-size:24px;font-weight:700;margin-bottom:6px}
.astro-ncxI7NGf h2 a{color:#111;text-decoration:none}
.astro-ncxI7NGf h2 a:hover{text-decoration:underline}
.astro-ncxI7NGf .astro-BDPiOr8q{font-size:12px;font-weight:600;text-transform:uppercase;color:#888;letter-spacing:1px;margin-bottom:8px}
.astro-ncxI7NGf p{font-size:15px;color:#444;margin-bottom:10px}
.astro-BuhCwHKe{display:inline-block;background:#111;color:#fff;padding:8px 20px;font-size:13px;font-weight:700;text-decoration:none;text-transform:uppercase;letter-spacing:1px}
.astro-BuhCwHKe:hover{background:#333}
.astro-LAuTFRmM{padding-bottom:60px}
.astro-LAuTFRmM h1{font-size:38px;font-weight:800;letter-spacing:-1px;margin-bottom:10px}
.astro-LAuTFRmM time{font-size:12px;font-weight:600;text-transform:uppercase;color:#888;letter-spacing:1px;display:block;margin-bottom:28px}
.astro-LAuTFRmM h2{font-size:26px;font-weight:700;margin:40px 0 14px}
.astro-LAuTFRmM h3{font-size:20px;font-weight:700;margin:32px 0 10px}
.astro-LAuTFRmM p{margin-bottom:18px;font-size:17px}
.astro-LAuTFRmM ul,.astro-LAuTFRmM ol{margin:0 0 18px 24px}
.astro-LAuTFRmM a{color:#111;font-weight:600;text-decoration:underline}
.astro-LAuTFRmM img{max-width:100%;height:auto;margin:20px 0}
.astro-m0YYbBYV{background:#111;color:#888;padding:28px 0;margin-top:48px;text-align:center;font-size:12px}
.astro-m0YYbBYV a{color:#888;text-decoration:none}
.astro-AJ1wdwEp{background:#222;color:#aaa;padding:14px 20px;margin-bottom:24px;font-size:13px;font-style:italic}
.astro-6Crv0yn2{background:#1a1a1a;color:#888;padding:14px 20px;margin-top:32px;font-size:12px;border-top:3px solid #444}
.astro-rpUcTn3o{margin:0 0 24px}
.astro-7sASGbDB{width:100%;height:auto;border-radius:0}
.astro-lVPJofpA{border-left:4px solid #111;padding-left:24px;margin-top:48px}
.astro-lVPJofpA h3{font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.astro-lVPJofpA ul{list-style:none;padding:0}
.astro-lVPJofpA li{padding:6px 0}
.astro-lVPJofpA a{color:#111;text-decoration:underline;font-weight:600}
/* === Theme === */
:root{--primary:#1C3D47;--accent:#B23A29;--secondary:#2F6B4A;--bg:#F6E7D4;--bg-alt:#EFDEC5;--surface:#FDF8EE;--fg:#1A1F1D;--fg-muted:#6A5A4A;--border:#D4C5A8;--success:#2F6B4A;--warning:#8B5A00;--danger:#A8371E;--r:2px;--r-card:2px;--r-btn:2px;--r-img:2px;--fb:'Source Sans 3',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;--fh:'Source Serif 4',Georgia,'Times New Roman',serif;--fm:ui-monospace,'SF Mono',Menlo,Consolas,monospace;--max:1160px;--read:64ch;--ease:cubic-bezier(.2,.7,.2,1);--shadow-sm:0 1px 2px rgba(28,61,71,.06);--shadow-md:0 4px 12px rgba(28,61,71,.08)}
/* === Custom === */
/* ==========================================================================
   CleanBurn Daily — FT-inspired Editorial-Financial
   Paper-pink palette · 2px radii · Serif headings · Zero consumer softness
   Template: bold (.bld-* whitelist only)
   ========================================================================== */

/* === Fonts: 2 families (mono uses system fonts via CSS var fallback) === */
@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:opsz,wght@8..60,400;8..60,600;8..60,700&family=Source+Sans+3:wght@400;500;600&display=swap');

/* === Base reset (custom > theme > base, element selectors are safe) === */
*, *::before, *::after { box-sizing: border-box; }

body {
  margin: 0;
  font-family: var(--fb);
  font-size: 17px;
  line-height: 1.7;
  color: var(--fg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* === Global typography === */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--fh);
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.18;
  color: var(--primary);
  text-wrap: balance;
  margin: 0;
}

p { text-wrap: pretty; }

a {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
  transition: color 180ms var(--ease);
}
a:hover { color: var(--primary); }

img { max-width: 100%; height: auto; display: block; }

::selection { background: var(--primary); color: var(--bg); }

/* Focus ring — accessibility hard requirement, never remove */
:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 3px;
}

/* === .astro-gIjOOvXg: page-width container (also used inside .astro-C3icY7aw) === */
.astro-gIjOOvXg {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 28px;
}

/* === .astro-C3icY7aw: masthead (homepage + article pages) === */
.astro-C3icY7aw {
  background: var(--primary);
  color: var(--bg);
  padding: 56px 0 48px;
  margin: 0 0 0;
  border-bottom: 4px double var(--accent);  /* FT signature: double rule */
}

.astro-C3icY7aw h1 {
  color: var(--bg);
  font-family: var(--fh);
  font-weight: 700;
  font-size: clamp(38px, 5.5vw, 64px);
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0;
}

.astro-C3icY7aw p {
  color: rgba(246, 231, 212, 0.82);
  font-size: clamp(16px, 1.4vw, 19px);
  font-family: var(--fb);
  font-weight: 400;
  margin: 14px 0 0;
  max-width: 58ch;
  letter-spacing: 0.01em;
}

/* Article-page hero is just the title as a back-to-home link */
.astro-C3icY7aw a {
  color: var(--bg);
  font-family: var(--fh);
  font-weight: 700;
  font-size: clamp(22px, 2.5vw, 32px);
  letter-spacing: -0.015em;
  text-decoration: none;
  display: inline-block;
  transition: opacity 180ms var(--ease);
}
.astro-C3icY7aw a:hover {
  color: var(--bg);
  opacity: 0.82;
}

/* === .astro-cGIM9GNZ: homepage feed container === */
.astro-cGIM9GNZ {
  padding: 48px 0 64px;
}

/* === .astro-ncxI7NGf: article card (homepage) + article body wrapper === */
.astro-ncxI7NGf {
  padding: 28px 0;
  border-top: 1px solid var(--border);
  border-left: none;                    /* ← 此次修改：override base_css 的 4px #111 黑線 */
  padding-left: 0;                      /* ← 此次修改：回歸無縮排 */
  margin: 0;
}
.astro-ncxI7NGf:first-child {
  border-top: none;
  padding-top: 8px;
}

.astro-ncxI7NGf h2 {
  font-size: clamp(22px, 2.3vw, 28px);
  line-height: 1.22;
  margin: 0 0 8px;
  letter-spacing: -0.015em;
}
.astro-ncxI7NGf h2 a {
  color: var(--primary);
  text-decoration: none;
  background-image: linear-gradient(var(--accent), var(--accent));
  background-size: 0 1px;
  background-repeat: no-repeat;
  background-position: 0 100%;
  transition: background-size 240ms var(--ease), color 180ms var(--ease);
}
.astro-ncxI7NGf h2 a:hover {
  background-size: 100% 1px;
  color: var(--accent);
  text-decoration: none;                /* ← 此次修改：阻止 base_css hover 時的 underline 壞我的 gradient 掃線 */
}

.astro-ncxI7NGf p {
  color: var(--fg-muted);
  font-size: 16px;
  line-height: 1.55;
  margin: 8px 0 10px;
  max-width: 64ch;
}

/* === .astro-BDPiOr8q: date eyebrow === */
.astro-ncxI7NGf .astro-BDPiOr8q,                    /* ← 此次修改：提高 specificity 勝過 base_css 的 .astro-ncxI7NGf .astro-BDPiOr8q #888 灰 */
.astro-BDPiOr8q {
  display: inline-block;
  font-family: var(--fb);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0 0 10px;
}

/* === .astro-LAuTFRmM: article body container === */
.astro-LAuTFRmM {
  max-width: var(--read);
  margin: 0 auto;
  padding: 56px 0 64px;
  font-size: 18px;
  line-height: 1.78;
  color: var(--fg);
}

.astro-LAuTFRmM h1 {
  font-size: clamp(32px, 4.2vw, 48px);
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--fg);  /* Article titles use ink, not primary — more editorial */
  margin: 0 0 18px;
}

.astro-LAuTFRmM h2 {
  font-size: clamp(24px, 2.6vw, 30px);
  line-height: 1.2;
  margin: 48px 0 14px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
  color: var(--primary);
}

.astro-LAuTFRmM h3 {
  font-size: 21px;
  line-height: 1.3;
  margin: 32px 0 10px;
  color: var(--primary);
}

.astro-LAuTFRmM p { margin: 0 0 22px; }

.astro-LAuTFRmM a {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color 180ms var(--ease), text-decoration-thickness 180ms var(--ease);
}
.astro-LAuTFRmM a:hover {
  color: var(--primary);
  text-decoration-thickness: 2px;
}

.astro-LAuTFRmM img {
  border-radius: var(--r-img);
  margin: 32px 0;
  width: 100%;
  border: 1px solid var(--border);
}

.astro-LAuTFRmM blockquote {
  font-family: var(--fh);
  font-style: italic;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.45;
  color: var(--primary);
  border-left: 3px solid var(--accent);
  padding: 4px 0 4px 22px;
  margin: 32px 0;
  letter-spacing: -0.005em;
}

.astro-LAuTFRmM ul,
.astro-LAuTFRmM ol {
  margin: 0 0 22px;
  padding-left: 22px;
}
.astro-LAuTFRmM li { margin-bottom: 8px; }

.astro-LAuTFRmM hr {
  border: 0;
  height: 1px;
  background: var(--border);
  margin: 44px auto;
  max-width: 120px;
}

/* Inline mono — for cost-per-serving math, ingredient doses, etc. */
.astro-LAuTFRmM code {
  font-family: var(--fm);
  font-size: 0.9em;
  background: var(--bg-alt);
  padding: 2px 6px;
  border-radius: var(--r);
  border: 1px solid var(--border);
  color: var(--primary);
}

/* Article date line (rendered via <hgroup> by bold template) */
.astro-LAuTFRmM hgroup {
  margin: 0 0 32px;
}
.astro-LAuTFRmM hgroup > *:not(h1):not(h2):not(h3) {
  font-family: var(--fb);
  font-size: 13px;
  color: var(--fg-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-top: 8px;
  display: block;
}

/* === .astro-BuhCwHKe: CTA button (rare — mostly used on 404 page) === */
.astro-BuhCwHKe {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 13px 22px;
  background: var(--accent);
  color: var(--bg);
  font-family: var(--fb);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: var(--r-btn);
  border: 1px solid var(--accent);
  transition: background 180ms var(--ease), border-color 180ms var(--ease), transform 120ms var(--ease);
}
.astro-BuhCwHKe:hover {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--bg);
}
.astro-BuhCwHKe:active { transform: translateY(1px); }

/* === .astro-lVPJofpA: related articles block (end of each article) === */
.astro-lVPJofpA {
  margin: 64px 0 0;
  padding: 28px 0 0;
  border-top: 2px solid var(--primary);
  border-left: none;                    /* ← 此次修改：override base_css 的 4px #111 黑線 */
  padding-left: 0;                      /* ← 此次修改：回歸無縮排 */
}
.astro-lVPJofpA h3 {
  font-family: var(--fb);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--primary);
  margin: 0 0 18px;
}
.astro-lVPJofpA ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.astro-lVPJofpA li {
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  margin: 0;
}
.astro-lVPJofpA li:last-child { border-bottom: none; }
.astro-lVPJofpA a {
  color: var(--primary);
  font-family: var(--fh);
  font-size: 17px;
  font-weight: 500;
  text-decoration: none;
  transition: color 180ms var(--ease);
}
.astro-lVPJofpA a:hover { color: var(--accent); }

/* === .astro-m0YYbBYV: footer === */
.astro-m0YYbBYV {
  background: var(--primary);
  color: rgba(246, 231, 212, 0.7);
  padding: 32px 0;
  margin-top: 80px;
  font-size: 14px;
  text-align: center;
}
.astro-m0YYbBYV p { margin: 0; }
.astro-m0YYbBYV a {
  color: var(--bg);
  text-decoration: none;
  border-bottom: 1px solid rgba(246, 231, 212, 0.3);
  transition: border-color 180ms var(--ease);
  padding-bottom: 1px;
}
.astro-m0YYbBYV a:hover { border-bottom-color: var(--bg); }

/* === .astro-AJ1wdwEp: affiliate disclosure (FTC compliance) === */
.astro-AJ1wdwEp {
  background: var(--bg-alt);
  border-left: 3px solid var(--accent);
  border-radius: 0;
  padding: 14px 18px;
  margin: 28px 0;
  font-size: 14px;
  line-height: 1.55;
  color: var(--fg-muted);
}
.astro-AJ1wdwEp strong {
  display: block;
  font-family: var(--fh);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--primary);
  margin: 0 0 4px;
}

/* === .astro-6Crv0yn2: YMYL disclaimer — visually distinct from .astro-AJ1wdwEp === */
.astro-6Crv0yn2 {
  background: transparent;
  border: 1px solid var(--border);
  border-top: 2px solid var(--primary);
  border-radius: 0;
  padding: 16px 20px;
  margin: 36px 0 24px;
  font-size: 13px;
  line-height: 1.6;
  color: var(--fg-muted);
  font-style: italic;
}
.astro-6Crv0yn2 strong {
  display: block;
  font-family: var(--fh);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--primary);
  margin: 0 0 6px;
  font-style: normal;
}

/* === .astro-rpUcTn3o / .astro-7sASGbDB: article hero image === */
.astro-rpUcTn3o {
  margin: 0 0 32px;
  overflow: hidden;
  border-radius: var(--r-img);
  border: 1px solid var(--border);
}
.astro-7sASGbDB {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16/9;
  object-fit: cover;
}

/* === Responsive === */
@media (max-width: 720px) {
  .astro-gIjOOvXg { padding: 0 20px; }
  .astro-C3icY7aw { padding: 40px 0 32px; }
  .astro-LAuTFRmM {
    padding: 32px 0 48px;
    font-size: 17px;
  }
  .astro-LAuTFRmM h2 {
    margin-top: 36px;
    padding-top: 16px;
  }
}

@media (max-width: 480px) {
  body { font-size: 16px; }
  .astro-LAuTFRmM {
    font-size: 16px;
    line-height: 1.72;
  }
  .astro-C3icY7aw { padding: 32px 0 28px; }
}

/* === Print: let readers save/print clean articles === */
@media print {
  .astro-C3icY7aw,
  .astro-m0YYbBYV,
  .astro-lVPJofpA { display: none; }
  .astro-LAuTFRmM {
    max-width: 100%;
    padding: 0;
    color: #000;
  }
  a {
    color: #000;
    text-decoration: underline;
  }
  body { background: #fff; }
}
