/*
Theme Name: PotatoKenya
Theme URI: https://potatokenya.com
Author: PotatoKenya
Author URI: https://potatokenya.com
Description: A premium, fast, SEO-engineered agri-news magazine theme built for PotatoKenya.com. Features a built-in SEO toolkit (meta titles/descriptions, Open Graph, Twitter Cards, JSON-LD schema, breadcrumbs), a market-price ticker, smart related articles, inline contextual linking, reading-progress and table-of-contents tools, and a light, editorial design system. No page builder bloat, no dark mode — built for speed and rankings.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: potatokenya
Tags: blog, news, custom-colors, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, theme-options, full-width-template, sticky-post

PotatoKenya is a custom theme. The design tokens below are intentional choices,
not framework defaults: a warm "tuber cream" surface tone, vine-green primary,
harvest-gold accent, and a serif/sans/mono type system that gives the site an
editorial, data-aware "agri-news" identity instead of a generic blog look.
*/

/* =========================================================
   1. DESIGN TOKENS
   ========================================================= */
:root{
  /* Color: backgrounds */
  --color-bg:            #FFFFFF;
  --color-bg-cream:      #FBFAF6;
  --color-surface:       #F4ECD8;   /* tuber-cream surface for cards/sections */
  --color-surface-soft:  #F8F4EA;

  /* Color: text */
  --color-ink:           #261F1A;   /* soil-dark, warmer than pure black */
  --color-ink-soft:      #5C5247;
  --color-ink-faint:     #8A8074;

  /* Color: brand */
  --color-primary:       #2F8F46;   /* vine green */
  --color-primary-dark:  #1F6B33;
  --color-primary-light: #E6F4E9;
  --color-gold:          #C8932A;   /* harvest gold */
  --color-gold-dark:     #A6761E;
  --color-gold-light:    #FBF1DC;

  /* Color: category tags */
  --color-tag-farming:   #2F8F46;
  --color-tag-market:    #C8932A;
  --color-tag-disease:   #B5512B;
  --color-tag-variety:   #6B7A35;
  --color-tag-recipe:    #8C5A33;
  --color-tag-news:      #44607A;

  /* Color: utility */
  --color-border:        #E7E1D3;
  --color-border-strong: #D8CFB9;
  --color-success:       #2F8F46;
  --color-up:            #2F8F46;
  --color-down:          #B5512B;
  --color-focus:         #1F6B33;

  /* Typography */
  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body:    'Public Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:    'IBM Plex Mono', 'SFMono-Regular', Consolas, monospace;

  --fs-display-xl: clamp(2.5rem, 4vw + 1rem, 4.25rem);
  --fs-display-lg: clamp(2rem, 3vw + 1rem, 3rem);
  --fs-display-md: clamp(1.5rem, 1.6vw + 1rem, 2.1rem);
  --fs-display-sm: clamp(1.25rem, 1vw + 1rem, 1.5rem);
  --fs-body-lg:    1.1875rem;
  --fs-body:       1rem;
  --fs-body-sm:    0.9375rem;
  --fs-caption:    0.8125rem;
  --fs-eyebrow:    0.75rem;

  --lh-tight: 1.15;
  --lh-snug:  1.35;
  --lh-body:  1.7;

  /* Layout */
  --container-max: 1240px;
  --container-narrow: 760px;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 14px;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-7: 3rem;
  --space-8: 4.5rem;

  /* Shadow */
  --shadow-sm: 0 1px 2px rgba(38, 31, 26, 0.06);
  --shadow-md: 0 6px 20px rgba(38, 31, 26, 0.08);
  --shadow-lg: 0 16px 40px rgba(38, 31, 26, 0.12);

  --transition: 180ms ease;
}

/* =========================================================
   2. RESET & BASE
   ========================================================= */
*, *::before, *::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  *, *::before, *::after{ animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
}
body{
  margin: 0;
  background: var(--color-bg);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  -webkit-font-smoothing: antialiased;
}
img, svg, video{ max-width: 100%; height: auto; display: block; }
a{ color: var(--color-primary-dark); text-decoration: none; }
a:hover{ color: var(--color-gold-dark); }
ul, ol{ padding-left: 1.25em; }
button, input, select, textarea{ font-family: inherit; font-size: inherit; }
table{ border-collapse: collapse; width: 100%; }

:focus-visible{
  outline: 3px solid var(--color-focus);
  outline-offset: 2px;
  border-radius: 2px;
}

.screen-reader-text{
  position: absolute !important;
  clip: rect(1px,1px,1px,1px);
  width: 1px; height: 1px; overflow: hidden;
  word-wrap: normal !important;
}
.screen-reader-text:focus{
  position: fixed; top: 8px; left: 8px;
  width: auto; height: auto;
  background: var(--color-ink); color: #fff;
  padding: 12px 18px; z-index: 100000;
  border-radius: var(--radius-sm);
  clip: auto;
}
.skip-link{ z-index: 100000; }

/* =========================================================
   3. TYPOGRAPHY
   ========================================================= */
h1, h2, h3, h4, .font-display{
  font-family: var(--font-display);
  color: var(--color-ink);
  line-height: var(--lh-tight);
  font-weight: 600;
  margin: 0 0 0.5em;
}
h1{ font-size: var(--fs-display-lg); }
h2{ font-size: var(--fs-display-md); }
h3{ font-size: var(--fs-display-sm); }
h4{ font-size: 1.125rem; }
p{ margin: 0 0 1.25em; }

.eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-family: var(--font-mono);
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
}
.eyebrow::before{
  content: "";
  width: 7px; height: 7px;
  background: currentColor;
  border-radius: 50%;
  display: inline-block;
}

.text-muted{ color: var(--color-ink-soft); }
.text-faint{ color: var(--color-ink-faint); }

/* Category tag colors */
.tag-farming{ color: var(--color-tag-farming); }
.tag-market{ color: var(--color-tag-market); }
.tag-disease{ color: var(--color-tag-disease); }
.tag-variety{ color: var(--color-tag-variety); }
.tag-recipe{ color: var(--color-tag-recipe); }
.tag-news{ color: var(--color-tag-news); }

.bg-tag-farming{ background: var(--color-tag-farming); }
.bg-tag-market{ background: var(--color-tag-market); }
.bg-tag-disease{ background: var(--color-tag-disease); }
.bg-tag-variety{ background: var(--color-tag-variety); }
.bg-tag-recipe{ background: var(--color-tag-recipe); }
.bg-tag-news{ background: var(--color-tag-news); }

/* =========================================================
   4. LAYOUT
   ========================================================= */
.container{
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-5);
}
.container-narrow{
  max-width: var(--container-narrow);
  margin: 0 auto;
  padding: 0 var(--space-5);
}
.section{ padding: var(--space-7) 0; }
.section-tight{ padding: var(--space-6) 0; }

.section-head{
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
  border-bottom: 2px solid var(--color-ink);
  padding-bottom: var(--space-3);
}
.section-head h2{ margin: 0; }
.section-head .view-all{
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
  white-space: nowrap;
  color: var(--color-primary-dark);
}
.section-head .view-all:hover{ color: var(--color-gold-dark); }

.grid{ display: grid; gap: var(--space-5); }
.grid-2{ grid-template-columns: repeat(2, 1fr); }
.grid-3{ grid-template-columns: repeat(3, 1fr); }
.grid-4{ grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px){
  .grid-3, .grid-4{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px){
  .grid-2, .grid-3, .grid-4{ grid-template-columns: 1fr; }
}

.layout-with-sidebar{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: var(--space-7);
  align-items: start;
}
@media (max-width: 980px){
  .layout-with-sidebar{ grid-template-columns: 1fr; }
}

.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  padding: 0.85em 1.5em;
  border-radius: 999px;
  font-weight: 600;
  font-size: var(--fs-body-sm);
  border: 2px solid transparent;
  cursor: pointer;
  transition: var(--transition);
}
.btn-primary{ background: var(--color-primary); color: #fff; }
.btn-primary:hover{ background: var(--color-primary-dark); color: #fff; }
.btn-outline{ border-color: var(--color-ink); color: var(--color-ink); background: transparent; }
.btn-outline:hover{ background: var(--color-ink); color: #fff; }
.btn-gold{ background: var(--color-gold); color: #fff; }
.btn-gold:hover{ background: var(--color-gold-dark); color: #fff; }

/* =========================================================
   5. TOP UTILITY BAR + HEADER
   ========================================================= */
.topbar{
  background: var(--color-ink);
  color: #EDE8DF;
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
}
.topbar .container{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  gap: var(--space-4);
}
.topbar a{ color: #EDE8DF; }
.topbar a:hover{ color: var(--color-gold); }
.topbar-date{ opacity: 0.8; }
.topbar-social{ display: flex; gap: var(--space-4); list-style: none; margin: 0; padding: 0; }
.topbar-social a{ display: flex; }

.site-header{
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  z-index: 500;
}
.site-header .container{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
  padding-top: var(--space-4);
  padding-bottom: var(--space-4);
}
.site-branding{ display: flex; align-items: center; gap: 0.65rem; }
.site-branding img{ max-height: 48px; width: auto; }
.site-title{
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 700;
  margin: 0;
  letter-spacing: -0.01em;
}
.site-title a{ color: var(--color-ink); }
.site-title .accent{ color: var(--color-primary); }
.site-description{
  display: block;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-ink-faint);
}

.primary-nav{ display: flex; align-items: center; gap: var(--space-6); }
.primary-nav ul{
  display: flex;
  list-style: none;
  margin: 0; padding: 0;
  gap: var(--space-5);
}
.primary-nav li{ position: relative; }
.primary-nav a{
  color: var(--color-ink);
  font-weight: 600;
  font-size: 0.95rem;
  padding: 0.5em 0;
  display: inline-block;
  border-bottom: 2px solid transparent;
}
.primary-nav a:hover,
.primary-nav .current-menu-item > a{
  color: var(--color-primary-dark);
  border-bottom-color: var(--color-gold);
}

/* Submenus */
.primary-nav ul ul{
  position: absolute;
  top: 100%; left: 0;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  flex-direction: column;
  min-width: 220px;
  padding: 0.5rem;
  gap: 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  transition: var(--transition);
}
.primary-nav li:hover > ul,
.primary-nav li:focus-within > ul{
  opacity: 1; visibility: visible; transform: translateY(0);
}
.primary-nav ul ul a{ padding: 0.5em 0.75em; border-radius: var(--radius-sm); border: none; }
.primary-nav ul ul a:hover{ background: var(--color-primary-light); }

.header-actions{ display: flex; align-items: center; gap: var(--space-3); }
.header-search-toggle, .menu-toggle{
  background: var(--color-ink);
  color: #fff;
  border: none;
  width: 42px; height: 42px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: var(--transition);
}
.header-search-toggle:hover, .menu-toggle:hover{ background: var(--color-primary-dark); }
.menu-toggle{ display: none; border-radius: var(--radius-sm); }

.header-search-panel{
  display: none;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface-soft);
}
.header-search-panel.is-open{ display: block; }
.header-search-panel .container{ padding-top: var(--space-4); padding-bottom: var(--space-4); }
.header-search-panel form{ display: flex; gap: var(--space-3); }
.header-search-panel input[type="search"]{
  flex: 1;
  padding: 0.85em 1.1em;
  border: 2px solid var(--color-ink);
  border-radius: 999px;
  background: var(--color-bg);
}

@media (max-width: 980px){
  .primary-nav{ display: none; }
  .menu-toggle{ display: inline-flex; }
  .primary-nav.is-open{
    display: block;
    position: fixed;
    inset: 0 0 0 auto;
    width: min(86vw, 360px);
    background: var(--color-bg);
    padding: var(--space-6) var(--space-5);
    box-shadow: var(--shadow-lg);
    overflow-y: auto;
    z-index: 600;
  }
  .primary-nav.is-open ul{ flex-direction: column; gap: 0; }
  .primary-nav.is-open ul ul{
    position: static; opacity: 1; visibility: visible; transform: none;
    box-shadow: none; border: none; padding-left: var(--space-4);
  }
}

/* =========================================================
   6. MARKET TICKER (signature element)
   ========================================================= */
.market-ticker{
  background: var(--color-primary-dark);
  color: #fff;
  overflow: hidden;
  position: relative;
}
.market-ticker .ticker-label{
  position: absolute; left: 0; top: 0; bottom: 0;
  display: flex; align-items: center;
  gap: 0.4em;
  background: var(--color-gold);
  color: var(--color-ink);
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0 var(--space-4);
  z-index: 2;
}
.market-ticker .ticker-track-wrap{
  padding-left: 168px;
  overflow: hidden;
}
.market-ticker .ticker-track{
  display: flex;
  width: max-content;
  gap: var(--space-7);
  padding: 0.55rem 0;
  animation: ticker-scroll 32s linear infinite;
}
.market-ticker:hover .ticker-track{ animation-play-state: paused; }
@keyframes ticker-scroll{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}
.ticker-item{
  display: flex;
  align-items: center;
  gap: 0.5em;
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  white-space: nowrap;
}
.ticker-item .region{ font-weight: 700; }
.ticker-item .price{ color: var(--color-gold-light); }
.ticker-item .delta-up{ color: #A9E6B8; }
.ticker-item .delta-down{ color: #F3B7A0; }
@media (max-width: 600px){
  .market-ticker .ticker-label{ position: static; padding: 0.4rem var(--space-4) 0; }
  .market-ticker .ticker-track-wrap{ padding-left: 0; }
}

/* =========================================================
   7. HERO / FEATURED
   ========================================================= */
.hero{ padding: var(--space-6) 0 var(--space-7); }
.hero-grid{
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: var(--space-6);
}
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
}
.hero-main{
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-ink);
  min-height: 420px;
  display: flex;
  align-items: flex-end;
}
.hero-main img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.78;
}
.hero-main .hero-content{
  position: relative;
  z-index: 2;
  padding: var(--space-6);
  color: #fff;
}
.hero-main .eyebrow{ color: var(--color-gold-light); }
.hero-main h1, .hero-main h2{ color: #fff; font-size: var(--fs-display-lg); margin: 0.4em 0; }
.hero-main p{ color: #EDE8DF; max-width: 56ch; }
.hero-side{ display: flex; flex-direction: column; gap: var(--space-4); }
.hero-side-item{
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.hero-side-item:last-child{ border-bottom: none; padding-bottom: 0; }
.hero-side-item .thumb{
  width: 96px; height: 96px;
  flex-shrink: 0;
  border-radius: var(--radius-md);
  overflow: hidden;
}
.hero-side-item .thumb img{ width: 100%; height: 100%; object-fit: cover; }
.hero-side-item h3{ font-size: 1.05rem; margin: 0.25em 0; }
.hero-side-item .eyebrow{ font-size: 0.68rem; }

/* =========================================================
   8. ARTICLE CARDS
   ========================================================= */
.article-card{
  display: flex;
  flex-direction: column;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: var(--transition);
  height: 100%;
}
.article-card:hover{ box-shadow: var(--shadow-md); transform: translateY(-2px); border-color: var(--color-border-strong); }
.article-card .card-thumb{ aspect-ratio: 16/10; overflow: hidden; background: var(--color-surface); }
.article-card .card-thumb img{ width: 100%; height: 100%; object-fit: cover; transition: transform 400ms ease; }
.article-card:hover .card-thumb img{ transform: scale(1.05); }
.article-card .card-body{ padding: var(--space-4); display: flex; flex-direction: column; gap: 0.5rem; flex: 1; }
.article-card h3{ font-size: 1.1rem; margin: 0; line-height: var(--lh-snug); }
.article-card h3 a{ color: var(--color-ink); }
.article-card h3 a:hover{ color: var(--color-primary-dark); }
.article-card .card-excerpt{ color: var(--color-ink-soft); font-size: var(--fs-body-sm); margin: 0; }
.article-card .card-meta{
  margin-top: auto;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  color: var(--color-ink-faint);
}

.article-row{
  display: flex;
  gap: var(--space-4);
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--color-border);
}
.article-row:last-child{ border-bottom: none; }
.article-row .thumb{ width: 130px; flex-shrink: 0; border-radius: var(--radius-md); overflow: hidden; aspect-ratio: 4/3; }
.article-row .thumb img{ width: 100%; height: 100%; object-fit: cover; }
.article-row h3{ font-size: 1rem; margin: 0.2em 0; }

.numbered-list{ list-style: none; margin: 0; padding: 0; counter-reset: rank; }
.numbered-list li{ counter-increment: rank; display: flex; gap: var(--space-3); padding: var(--space-3) 0; border-bottom: 1px solid var(--color-border); }
.numbered-list li:last-child{ border-bottom: none; }
.numbered-list li::before{
  content: counter(rank, decimal-leading-zero);
  font-family: var(--font-mono);
  font-weight: 700;
  color: var(--color-gold-dark);
  font-size: 1.1rem;
  flex-shrink: 0;
}

.article-card .card-thumb .thumb-placeholder,
.thumb-placeholder{
  width: 100%; height: 100%;
  background: linear-gradient(135deg, var(--color-surface) 0%, var(--color-primary-light) 100%);
  position: relative;
}
.thumb-placeholder::after{
  content: "";
  position: absolute; inset: 0;
  background-image: radial-gradient(circle at 30% 30%, rgba(47,143,70,0.18) 0%, transparent 55%);
}

/* =========================================================
   9. NEWSLETTER CTA
   ========================================================= */
.newsletter-cta{
  background: var(--color-gold-light);
  border: 1px solid var(--color-gold);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
  flex-wrap: wrap;
}
.newsletter-cta h2{ margin: 0 0 0.25em; }
.newsletter-cta p{ margin: 0; color: var(--color-ink-soft); }
.newsletter-form{ display: flex; gap: 0.6rem; flex-wrap: wrap; }
.newsletter-form input[type="email"]{
  padding: 0.85em 1.1em;
  border: 2px solid var(--color-ink);
  border-radius: 999px;
  min-width: 240px;
}

/* =========================================================
   10. BREADCRUMBS
   ========================================================= */
.breadcrumbs{
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  color: var(--color-ink-faint);
  margin-bottom: var(--space-4);
}
.breadcrumbs a{ color: var(--color-ink-soft); }
.breadcrumbs a:hover{ color: var(--color-primary-dark); }
.breadcrumbs .sep{ margin: 0 0.4em; }

/* =========================================================
   11. SINGLE ARTICLE
   ========================================================= */
.article-header{ padding: var(--space-6) 0 var(--space-5); }
.article-header .eyebrow{ margin-bottom: 0.75rem; }
.article-header h1{ font-size: var(--fs-display-lg); margin-bottom: 0.5rem; }
.article-excerpt{ font-size: var(--fs-body-lg); color: var(--color-ink-soft); max-width: 70ch; }

.article-meta-row{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-5);
  padding: var(--space-4) 0;
  margin: var(--space-4) 0;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}
.article-author{ display: flex; align-items: center; gap: 0.6rem; }
.article-author img{ width: 40px; height: 40px; border-radius: 50%; object-fit: cover; }
.article-author .name{ font-weight: 700; font-size: 0.9rem; }
.article-author .role{ font-size: 0.78rem; color: var(--color-ink-faint); }
.article-meta-stats{ display: flex; gap: var(--space-4); font-family: var(--font-mono); font-size: var(--fs-caption); color: var(--color-ink-faint); }
.article-share{ display: flex; gap: 0.5rem; margin-left: auto; }
.article-share a{
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--color-border-strong);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-ink);
}
.article-share a:hover{ background: var(--color-ink); color: #fff; border-color: var(--color-ink); }

.article-featured-image{ border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 0.5rem; }
.article-featured-image img{ width: 100%; }
.article-image-caption{
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  color: var(--color-ink-faint);
  text-align: center;
  margin-bottom: var(--space-6);
}

.article-layout{
  display: grid;
  grid-template-columns: 240px minmax(0,1fr);
  gap: var(--space-7);
  align-items: start;
}
@media (max-width: 980px){
  .article-layout{ grid-template-columns: 1fr; }
}

.toc-box{
  position: sticky;
  top: 96px;
  background: var(--color-surface-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
}
.toc-box .toc-title{
  font-family: var(--font-mono);
  text-transform: uppercase;
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.06em;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin-bottom: 0.5rem;
}
.toc-box ol{ list-style: none; margin: 0; padding: 0; counter-reset: toc; }
.toc-box li{ counter-increment: toc; margin-bottom: 0.5rem; }
.toc-box li::before{ content: counter(toc) "."; color: var(--color-gold-dark); font-weight: 700; margin-right: 0.4em; font-family: var(--font-mono); }
.toc-box a{ font-size: 0.85rem; color: var(--color-ink-soft); line-height: 1.4; }
.toc-box a:hover, .toc-box a.is-active{ color: var(--color-primary-dark); }
.toc-box li ol{ margin-top: 0.4rem; margin-left: 0.6rem; }

@media (max-width: 980px){
  .toc-box{ position: static; margin-bottom: var(--space-5); }
}

.article-body-solo{
  max-width: var(--container-narrow);
  margin: 0 auto;
}

.reading-progress{
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  background: var(--color-gold);
  width: 0%;
  z-index: 700;
  transition: width 80ms linear;
}

/* Article body / entry-content typography */
.entry-content{ font-size: var(--fs-body-lg); max-width: 72ch; }
.entry-content > *:first-child::first-letter{
  float: left;
  font-family: var(--font-display);
  font-size: 4.2rem;
  line-height: 0.8;
  font-weight: 700;
  padding: 0.08em 0.08em 0 0;
  color: var(--color-primary-dark);
}
.entry-content h2{ margin-top: 1.6em; scroll-margin-top: 100px; }
.entry-content h3{ margin-top: 1.4em; scroll-margin-top: 100px; }
.entry-content a{ text-decoration: underline; text-decoration-color: var(--color-gold); text-underline-offset: 3px; }
.entry-content ul, .entry-content ol{ margin: 0 0 1.25em; padding-left: 1.4em; }
.entry-content li{ margin-bottom: 0.4em; }
.entry-content img{ border-radius: var(--radius-md); margin: 0.5em 0; }
.entry-content figure{ margin: var(--space-5) 0; }
.entry-content figcaption{ font-family: var(--font-mono); font-size: var(--fs-caption); color: var(--color-ink-faint); margin-top: 0.5em; }
.entry-content blockquote{
  margin: var(--space-6) 0;
  padding: var(--space-2) 0 var(--space-2) var(--space-5);
  border-left: 4px solid var(--color-gold);
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-style: italic;
  color: var(--color-ink);
}
.entry-content table{ margin: var(--space-5) 0; font-size: var(--fs-body-sm); }
.entry-content th, .entry-content td{ padding: 0.6em 0.9em; border: 1px solid var(--color-border); text-align: left; }
.entry-content th{ background: var(--color-surface); font-family: var(--font-mono); text-transform: uppercase; font-size: 0.75rem; letter-spacing: 0.04em; }
.entry-content code{ background: var(--color-surface); padding: 0.15em 0.4em; border-radius: 4px; font-size: 0.9em; }
.entry-content hr{ border: none; border-top: 1px solid var(--color-border); margin: var(--space-6) 0; }

/* Inline related box, inserted mid-article */
.inline-related{
  background: var(--color-primary-light);
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-6) 0;
  display: flex;
  gap: var(--space-4);
  align-items: center;
}
.inline-related .icon{ flex-shrink: 0; color: var(--color-primary-dark); }
.inline-related .label{
  font-family: var(--font-mono);
  font-size: var(--fs-eyebrow);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-primary-dark);
  font-weight: 700;
  display: block;
  margin-bottom: 0.2em;
}
.inline-related a{ font-family: var(--font-display); font-size: 1.05rem; font-weight: 600; color: var(--color-ink); text-decoration: none; }
.inline-related a:hover{ color: var(--color-primary-dark); }

/* Read-more card, inserted mid-article / end of excerpt-style loops */
.read-more-card{
  display: flex;
  gap: var(--space-4);
  align-items: center;
  background: var(--color-bg);
  border: 1px solid var(--color-border-strong);
  border-left: 4px solid var(--color-gold);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin: var(--space-6) 0;
}
.read-more-card .thumb{ width: 84px; height: 84px; flex-shrink: 0; border-radius: var(--radius-sm); overflow: hidden; }
.read-more-card .thumb img{ width: 100%; height: 100%; object-fit: cover; }
.read-more-card .label{ font-family: var(--font-mono); font-size: var(--fs-eyebrow); text-transform: uppercase; color: var(--color-gold-dark); font-weight: 700; }
.read-more-card a.title{ font-family: var(--font-display); font-weight: 600; color: var(--color-ink); font-size: 1.05rem; }

/* Tags */
.entry-tags{ display: flex; flex-wrap: wrap; gap: 0.5rem; margin: var(--space-6) 0; }
.entry-tags a{
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  border: 1px solid var(--color-border-strong);
  border-radius: 999px;
  padding: 0.35em 0.9em;
  color: var(--color-ink-soft);
}
.entry-tags a:hover{ background: var(--color-ink); color: #fff; border-color: var(--color-ink); }

/* Author box */
.author-box{
  display: flex;
  gap: var(--space-4);
  background: var(--color-surface-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  margin: var(--space-7) 0;
}
.author-box img{ width: 72px; height: 72px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.author-box h3{ margin: 0 0 0.3em; font-size: 1.05rem; }
.author-box p{ margin: 0; color: var(--color-ink-soft); font-size: var(--fs-body-sm); }
.author-box .author-links{ margin-top: 0.5rem; display: flex; gap: 0.6rem; }

/* Related posts grid at article end */
.related-posts{ margin-top: var(--space-8); }

/* =========================================================
   12. SIDEBAR WIDGETS
   ========================================================= */
.widget{
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  margin-bottom: var(--space-5);
}
.widget-title{
  font-family: var(--font-mono);
  text-transform: uppercase;
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.06em;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-ink);
}
.widget ul{ list-style: none; margin: 0; padding: 0; }
.widget_categories li, .widget_archive li{
  display: flex; justify-content: space-between;
  padding: 0.5rem 0; border-bottom: 1px solid var(--color-border);
  font-size: var(--fs-body-sm);
}
.widget_categories li:last-child, .widget_archive li:last-child{ border-bottom: none; }
.widget .tagcloud a{
  display: inline-block; margin: 0 0.4em 0.4em 0;
  font-family: var(--font-mono) !important;
  font-size: 0.78rem !important;
  border: 1px solid var(--color-border-strong);
  border-radius: 999px; padding: 0.3em 0.8em;
}
.widget-newsletter{ background: var(--color-gold-light); border-color: var(--color-gold); }

/* =========================================================
   13. FOOTER
   ========================================================= */
.site-footer{
  background: var(--color-ink);
  color: #D9D2C5;
  margin-top: var(--space-8);
}
.footer-top{ padding: var(--space-7) 0; }
.footer-grid{ display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: var(--space-6); }
@media (max-width: 980px){ .footer-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px){ .footer-grid{ grid-template-columns: 1fr; } }
.site-footer h2, .site-footer h3, .footer-col-title{
  color: #fff;
  font-family: var(--font-mono);
  text-transform: uppercase;
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.06em;
  margin-bottom: var(--space-4);
}
.site-footer a{ color: #D9D2C5; }
.site-footer a:hover{ color: var(--color-gold); }
.footer-about .site-title{ color: #fff; }
.footer-about p{ color: #B7AF9F; font-size: var(--fs-body-sm); max-width: 36ch; }
.footer-social{ display: flex; gap: 0.6rem; margin-top: var(--space-4); }
.footer-social a{
  width: 38px; height: 38px; border-radius: 50%;
  border: 1px solid #4A4239;
  display: flex; align-items: center; justify-content: center;
}
.footer-social a:hover{ background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.footer-col ul{ list-style: none; margin: 0; padding: 0; }
.footer-col li{ margin-bottom: 0.6rem; font-size: var(--fs-body-sm); }
.footer-bottom{
  border-top: 1px solid #3A332B;
  padding: var(--space-4) 0;
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 0.5rem;
  color: #9C9382;
}

/* =========================================================
   14. ARCHIVE / CATEGORY / SEARCH
   ========================================================= */
.archive-header{
  padding: var(--space-6) 0;
  border-bottom: 3px solid var(--color-ink);
  margin-bottom: var(--space-6);
}
.archive-header .eyebrow{ color: var(--color-primary-dark); }
.archive-header h1{ margin: 0.2em 0 0.3em; }
.archive-header .archive-description{ color: var(--color-ink-soft); max-width: 70ch; }

.pagination{
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  margin-top: var(--space-7);
  flex-wrap: wrap;
}
.pagination a, .pagination span{
  min-width: 42px; height: 42px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: var(--fs-body-sm);
  padding: 0 0.8em;
}
.pagination .current{ background: var(--color-ink); color: #fff; border-color: var(--color-ink); }
.pagination a:hover{ border-color: var(--color-ink); }

/* =========================================================
   15. 404 / SEARCH NO RESULTS
   ========================================================= */
.error-404{ text-align: center; padding: var(--space-8) 0; }
.error-404 .code{
  font-family: var(--font-display);
  font-size: clamp(4rem, 12vw, 9rem);
  color: var(--color-surface);
  -webkit-text-stroke: 2px var(--color-primary);
  line-height: 1;
  margin-bottom: 0;
}
.error-404 h1{ margin-top: 0.3em; }
.error-404 .error-search{ max-width: 480px; margin: var(--space-5) auto; }

/* =========================================================
   16. COMMENTS
   ========================================================= */
.comments-area{ margin-top: var(--space-8); }
.comment-list{ list-style: none; margin: 0; padding: 0; }
.comment-list .children{ list-style: none; margin: 0 0 0 var(--space-6); padding: 0; }
.comment-body{ display: flex; gap: var(--space-4); padding: var(--space-4) 0; border-bottom: 1px solid var(--color-border); }
.comment-author img{ border-radius: 50%; }
.comment-meta{ font-family: var(--font-mono); font-size: var(--fs-caption); color: var(--color-ink-faint); }
.comment-content p:last-child{ margin-bottom: 0; }
.comment-respond{ background: var(--color-surface-soft); border-radius: var(--radius-lg); padding: var(--space-5); margin-top: var(--space-5); }
.comment-form p{ margin-bottom: var(--space-4); }
.comment-form input[type="text"], .comment-form input[type="email"], .comment-form input[type="url"], .comment-form textarea{
  width: 100%;
  padding: 0.75em 1em;
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
}
.comment-form textarea{ min-height: 140px; }

/* =========================================================
   17. PAGE / FULL WIDTH
   ========================================================= */
.page-content{ max-width: 72ch; margin: 0 auto; padding: var(--space-7) 0; }
.page-content .entry-content{ max-width: none; }

/* =========================================================
   18. RESPONSIVE FINE-TUNING
   ========================================================= */
@media (max-width: 600px){
  .section{ padding: var(--space-6) 0; }
  .article-meta-row{ gap: var(--space-3); }
  .article-share{ margin-left: 0; width: 100%; justify-content: flex-start; }
  h1{ font-size: var(--fs-display-md); }
}

/* Print */
@media print{
  .site-header, .market-ticker, .site-footer, .article-share, .toc-box, .inline-related, .newsletter-cta, .comments-area{ display: none; }
}
