/*
Theme Name: Commodities Stock Letter
Theme URI: https://example.com
Author: Keegan Igneri
Description: A minimal, markets-terminal newsletter theme. Centered masthead, a running quote ticker, monospace data, and a clean editorial post layout. Built for a weekly commodities briefing.
Version: 1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: commodities-stock-letter
*/

:root{
  --ink:#0E0E0E;--paper:#FFFFFF;--paper-2:#F6F5F2;--line:#E4E2DC;--muted:#6B6B68;
  --up:#1F7A4D;--down:#B23B2E;
  --serif:'Newsreader',Georgia,serif;--sans:'Inter',system-ui,-apple-system,sans-serif;--mono:'IBM Plex Mono',ui-monospace,Menlo,monospace;
  --wrap:1120px;--narrow:720px;
}
*{box-sizing:border-box;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased;}
a{color:inherit;}
img{max-width:100%;height:auto;display:block;}
:focus-visible{outline:2px solid var(--ink);outline-offset:3px;}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px;}
.narrow{max-width:var(--narrow);margin:0 auto;padding:0 28px;}
.rule{height:1px;background:var(--line);border:0;margin:0;}
.eyebrow{font-family:var(--mono);font-size:11.5px;letter-spacing:.34em;text-transform:uppercase;color:var(--muted);margin:0;}

/* Ticker */
.ticker{background:var(--ink);color:var(--paper);overflow:hidden;font-family:var(--mono);font-size:12.5px;letter-spacing:.02em;}
.ticker__track{display:flex;width:max-content;animation:scroll 38s linear infinite;}
.ticker:hover .ticker__track{animation-play-state:paused;}
.quote{padding:9px 22px;white-space:nowrap;border-right:1px solid rgba(255,255,255,.14);display:inline-flex;gap:10px;align-items:baseline;}
.quote .sym{color:rgba(255,255,255,.62);}
.quote .chg.up{color:#5BD08A;}
.quote .chg.down{color:#E8867A;}
@keyframes scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media (prefers-reduced-motion:reduce){.ticker__track{animation:none;flex-wrap:wrap;width:auto;}}

/* Top bar (inner pages) */
.topbar{border-bottom:1px solid var(--line);}
.topbar__in{max-width:var(--wrap);margin:0 auto;padding:18px 28px;display:flex;justify-content:space-between;align-items:center;gap:16px;}
.brand{font-family:var(--serif);font-weight:600;font-size:19px;letter-spacing:-.01em;text-decoration:none;}
.topbar nav{display:flex;gap:22px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;}
.topbar nav a{text-decoration:none;color:var(--muted);}
.topbar nav a:hover{color:var(--ink);}

/* Masthead hero (home) */
.masthead{text-align:center;padding:64px 28px 54px;}
.masthead .eyebrow{margin-bottom:22px;}
.wordmark{font-family:var(--serif);font-weight:500;font-size:clamp(38px,7vw,68px);line-height:1.02;letter-spacing:-.015em;margin:0;}
.wordmark a{text-decoration:none;}
.tagline{max-width:560px;margin:20px auto 0;color:var(--muted);font-size:18px;}

/* Subscribe */
.subscribe{display:flex;gap:8px;max-width:440px;margin:32px auto 0;}
.subscribe input[type=email]{flex:1;min-width:0;font-family:var(--sans);font-size:15px;padding:13px 16px;border:1px solid var(--ink);background:var(--paper);color:var(--ink);}
.subscribe input::placeholder{color:#9b9b97;}
.subscribe button{font-family:var(--mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;padding:13px 24px;border:1px solid var(--ink);background:var(--ink);color:var(--paper);cursor:pointer;transition:background .15s,color .15s;}
.subscribe button:hover{background:var(--paper);color:var(--ink);}
.consent{font-family:var(--mono);font-size:11px;color:var(--muted);margin:14px auto 0;max-width:440px;}
.form-note{font-family:var(--mono);font-size:12.5px;color:var(--up);margin:14px 0 0;min-height:1em;}

/* Sections */
.section{padding:56px 0;}
.section--alt{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.section-head{display:flex;align-items:center;gap:18px;margin:0 0 36px;}
.section-head .line{flex:1;height:1px;background:var(--line);}

/* Lead post */
.lead{display:grid;grid-template-columns:1.05fr 1fr;gap:44px;align-items:center;}
.lead__art{border:1px solid var(--line);background:var(--paper);aspect-ratio:16/11;width:100%;overflow:hidden;}
.lead__art img{width:100%;height:100%;object-fit:cover;}
.post-cat{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--down);margin:0 0 16px;}
.lead h2{font-family:var(--serif);font-weight:500;font-size:clamp(28px,4vw,42px);line-height:1.08;letter-spacing:-.015em;margin:0;}
.lead h2 a{text-decoration:none;}
.lead h2 a:hover{text-decoration:underline;text-underline-offset:4px;}
.deck{color:var(--muted);font-size:17px;margin:16px 0 0;max-width:46ch;}

/* Byline */
.byline{display:flex;align-items:center;gap:12px;margin:26px 0 0;}
.avatar{width:40px;height:40px;border-radius:50%;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-family:var(--mono);font-size:13px;font-weight:500;flex:none;}
.byline .who{font-size:14px;font-weight:500;line-height:1.2;}
.byline .meta{font-family:var(--mono);font-size:11.5px;color:var(--muted);letter-spacing:.02em;}

/* Card grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.card{background:var(--paper);padding:28px 26px 30px;display:flex;flex-direction:column;}
.card .post-cat{color:var(--ink);}
.card h3{font-family:var(--serif);font-weight:500;font-size:23px;line-height:1.14;letter-spacing:-.01em;margin:0;}
.card h3 a{text-decoration:none;}
.card h3 a:hover{text-decoration:underline;text-underline-offset:3px;}
.card .deck{font-size:15px;margin-top:12px;}
.card .cmeta{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-top:auto;padding-top:22px;}

/* Single article */
.article{max-width:var(--narrow);margin:0 auto;padding:52px 28px 24px;}
.article h1{font-family:var(--serif);font-weight:600;font-size:clamp(34px,6vw,52px);line-height:1.05;letter-spacing:-.02em;margin:0;}
.article .standfirst{font-family:var(--serif);font-size:21px;color:var(--muted);margin:18px 0 0;line-height:1.4;}
.article .byline{margin-top:30px;padding-bottom:30px;border-bottom:1px solid var(--line);}
.article-body{font-size:18px;}
.article-body h2{font-family:var(--serif);font-weight:600;font-size:28px;letter-spacing:-.01em;margin:44px 0 4px;}
.article-body h3{font-family:var(--serif);font-weight:600;font-size:22px;margin:32px 0 4px;}
.article-body p{margin:16px 0;}
.article-body strong{font-weight:600;}
.article-body ul{margin:16px 0;padding-left:1.2em;}
.article-body li{margin:8px 0;}
.article-body img{margin:28px 0;border:1px solid var(--line);}
.article-body blockquote{margin:24px 0;padding:4px 0 4px 20px;border-left:2px solid var(--ink);font-family:var(--serif);font-size:20px;color:var(--muted);}
.article-body hr{border:0;height:1px;background:var(--line);margin:36px 0;}

/* CTA */
.cta{background:var(--ink);color:var(--paper);text-align:center;padding:54px 28px;margin-top:48px;}
.cta h2{font-family:var(--serif);font-weight:500;font-size:28px;margin:0 0 8px;}
.cta p{color:rgba(255,255,255,.6);margin:0 0 24px;}
.cta .subscribe input[type=email]{border-color:var(--paper);background:transparent;color:var(--paper);}
.cta .subscribe input::placeholder{color:rgba(255,255,255,.5);}
.cta .subscribe button{border-color:var(--paper);background:var(--paper);color:var(--ink);}
.cta .subscribe button:hover{background:transparent;color:var(--paper);}

/* Footer */
.foot{background:var(--ink);color:var(--paper);padding:60px 0 40px;}
.foot__bar{display:flex;justify-content:space-between;align-items:center;gap:20px;border-top:1px solid rgba(255,255,255,.16);padding-top:26px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:rgba(255,255,255,.6);}
.foot__bar nav{display:flex;gap:24px;}
.foot__bar a{text-decoration:none;}
.foot__bar a:hover{color:var(--paper);}

@media (max-width:860px){.lead{grid-template-columns:1fr;gap:26px;}.grid{grid-template-columns:1fr;}}
@media (max-width:560px){.masthead{padding:44px 22px 38px;}.subscribe{flex-direction:column;}.foot__bar{flex-direction:column;align-items:flex-start;gap:18px;}}
