/*
Theme Name: Handeen — Editorial
Theme URI: https://bjornhandeen.com
Author: Built for Bjorn Handeen
Description: A broadsheet-editorial theme for a political strategist. Newsprint cream, ink, and a single oxblood accent; Libre Caslon display, Libre Franklin labels, Newsreader body; documentary duotone photography. Classic theme — no page builder required.
Version: 1.0.5
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: handeen
*/

/* ============================================================
   PALETTE — change the accent in ONE place.
   Oxblood is the default. To switch to the North Idaho "pine"
   variant, comment the oxblood line and uncomment the pine line.
   ============================================================ */
:root{
  --paper:#F3EFE5;        /* newsprint cream (page)        */
  --paper-2:#ECE7D9;      /* slightly darker paper (bands) */
  --ink:#1A1714;          /* warm near-black (text)        */
  --ink-soft:rgba(26,23,20,.70);
  --ink-faint:rgba(26,23,20,.50);
  --hair:rgba(26,23,20,.16);
  --hair-strong:rgba(26,23,20,.85);

  --accent:#7E2B26;       /* OXBLOOD  (default)            */
  /* --accent:#2C4636; */ /* PINE     (uncomment to swap)  */

  --cas:'Libre Caslon Display',Georgia,'Times New Roman',serif;
  --news:'Newsreader',Georgia,serif;
  --fr:'Libre Franklin',system-ui,-apple-system,Segoe UI,sans-serif;

  --wrap:1180px;
  --rule:1px;
}

/* ---------- reset / base ---------- */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--news);font-size:18px;line-height:1.7;
  font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--cas);font-weight:400;line-height:1.06;margin:0 0 .5em;letter-spacing:.005em}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:12px;z-index:200;background:var(--ink);color:var(--paper);padding:10px 16px;font-family:var(--fr);font-size:13px}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}

/* ---------- shared editorial bits ---------- */
.eyebrow{
  font-family:var(--fr);text-transform:uppercase;letter-spacing:.18em;
  font-size:12px;font-weight:500;color:var(--accent);margin:0 0 16px;
}
.eyebrow.muted{color:var(--ink-faint)}
.rule{height:1px;background:var(--hair);border:0;margin:0}
.rule-accent{height:3px;width:60px;background:var(--accent);border:0;margin:14px 0 0}
.cap{
  font-family:var(--fr);text-transform:uppercase;letter-spacing:.12em;
  font-size:11.5px;color:var(--ink-faint);margin-top:10px;line-height:1.4;
}
.figure{position:relative;margin:0;border:1px solid var(--hair);background:var(--paper-2)}
.figure img{width:100%}

.btn{
  display:inline-block;font-family:var(--fr);text-transform:uppercase;
  letter-spacing:.14em;font-size:12px;font-weight:500;
  background:var(--ink);color:var(--paper);padding:14px 26px;border:1px solid var(--ink);
  border-radius:0;transition:background .15s ease,color .15s ease;
}
.btn:hover{background:transparent;color:var(--ink)}
.btn-ghost{background:transparent;color:var(--ink)}
.link-arrow{display:inline-flex;align-items:center;gap:7px;font-family:var(--fr);font-size:14px;font-weight:500;color:var(--ink);border-bottom:1px solid var(--accent);padding-bottom:2px;transition:color .15s ease}
.link-arrow:hover{color:var(--accent)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* ---------- masthead ---------- */
.site-head{
  position:sticky;top:0;z-index:100;background:var(--paper);
  border-bottom:1px solid var(--hair);transition:box-shadow .2s ease;
}
.site-head.scrolled{box-shadow:0 1px 0 var(--hair),0 8px 24px rgba(26,23,20,.06)}
.head-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 28px}
.nameplate{font-family:var(--cas);font-size:24px;letter-spacing:.01em;line-height:1;color:var(--ink)}
.nameplate small{display:block;font-family:var(--fr);text-transform:uppercase;letter-spacing:.2em;font-size:9.5px;color:var(--accent);margin-top:5px;font-weight:500}
.nav ul{display:flex;gap:26px;list-style:none;margin:0;padding:0;align-items:center}
.nav a{font-family:var(--fr);text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-weight:500;color:var(--ink-soft);padding:6px 0;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}
.nav a:hover,.nav .current-menu-item>a{color:var(--ink);border-color:var(--accent)}
.nav-toggle{display:none;background:none;border:0;font-family:var(--fr);text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:var(--ink);cursor:pointer}

/* ---------- hero ---------- */
.hero{padding:58px 0 54px;border-bottom:1px solid var(--hair)}
.hero-grid{display:grid;grid-template-columns:1.25fr .9fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.7rem,6.2vw,4.7rem);margin:0 0 24px}
.hero h1 em{font-family:var(--news);font-style:italic;font-weight:400}
.standfirst{font-size:1.3rem;line-height:1.5;color:var(--ink);max-width:48ch;margin:0 0 30px}
.hero-actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin-bottom:28px}
.hero-creds{margin-top:6px;border-top:1px solid var(--hair);padding-top:20px}
.hero-creds-head{font-family:var(--fr);text-transform:uppercase;letter-spacing:.07em;font-size:11.5px;font-weight:500;color:var(--accent);margin:0 0 12px}
.hero-creds ul{list-style:none;margin:0;padding:0}
.hero-creds li{font-family:var(--fr);font-size:13px;letter-spacing:.02em;color:var(--ink-soft);line-height:1.4;padding:6px 0 6px 26px;position:relative}
.hero-creds li::before{content:"\2713";position:absolute;left:0;top:5px;color:var(--accent);font-size:13px;font-weight:700}
.hero-figure{position:relative}

/* ---------- full-bleed documentary band ---------- */
.band{position:relative;background:var(--ink)}
.band img{width:100%;max-height:560px;object-fit:cover;opacity:.96}
.band .band-cap{position:absolute;left:0;bottom:0;right:0;padding:18px 28px;background:linear-gradient(to top,rgba(26,23,20,.72),transparent);color:var(--paper)}
.band .band-cap span{font-family:var(--fr);text-transform:uppercase;letter-spacing:.14em;font-size:11.5px}

/* ---------- section scaffolding ---------- */
.section{padding:62px 0}
.section + .section{border-top:1px solid var(--hair)}
.section-head{margin-bottom:36px;max-width:62ch}
.section-head h2{font-size:clamp(1.9rem,3.6vw,2.7rem)}
.section-head p{color:var(--ink-soft);font-size:1.15rem;margin:.4em 0 0}

/* ---------- offerings ---------- */
.offer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--hair)}
.offer{padding:34px 30px 34px 0;border-right:1px solid var(--hair)}
.offer:last-child{border-right:0;padding-right:0}
.offer:not(:first-child){padding-left:30px}
.offer h3{font-size:1.45rem;margin:0 0 12px}
.offer .lede{font-family:var(--fr);text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--accent);font-weight:500;margin:0 0 16px;display:block}
.offer p{color:var(--ink-soft);font-size:1.02rem;margin:0}

/* ---------- writing / dispatches ---------- */
.dispatch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px}
.dispatch{border-top:2px solid var(--ink);padding-top:18px}
.dispatch .date{font-family:var(--fr);text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--ink-faint);margin-bottom:10px}
.dispatch h3{font-size:1.4rem;margin:0 0 10px}
.dispatch h3 a:hover{color:var(--accent)}
.dispatch p{color:var(--ink-soft);font-size:1.02rem;margin:0 0 14px}
.read-on{font-family:var(--fr);text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:500;color:var(--accent)}
.section-foot{margin-top:46px;border-top:1px solid var(--hair);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}

/* ---------- about strip ---------- */
.about{background:var(--paper-2)}
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:start}
.about-figure .sketch{margin-top:18px;display:flex;align-items:center;gap:16px}
.about-figure .sketch img{width:78px;height:78px;border-radius:50%;border:1px solid var(--hair);object-fit:cover}
.about-figure .sketch span{font-family:var(--fr);text-transform:uppercase;letter-spacing:.1em;font-size:11px;color:var(--ink-faint);line-height:1.5}
.about-copy p{color:var(--ink-soft);font-size:1.12rem}
.about-copy p:first-of-type{margin-top:0}
.creds{list-style:none;margin:26px 0 0;padding:0}
.creds li{padding:13px 0;border-bottom:1px solid var(--hair)}
.creds .org{display:block;font-family:var(--fr);text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:500;color:var(--accent);margin-bottom:3px}
.creds .role{font-family:var(--news);font-size:1.05rem;color:var(--ink)}

/* ---------- pull quote ---------- */
.pull{text-align:center;padding:92px 0}
.pull blockquote{margin:0 auto;max-width:18ch;font-family:var(--cas);font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.08}
.pull blockquote em{font-family:var(--news);font-style:italic}
.pull .by{font-family:var(--fr);text-transform:uppercase;letter-spacing:.16em;font-size:11.5px;color:var(--ink-faint);margin-top:26px}

/* ---------- contact CTA ---------- */
.cta{background:var(--ink);color:var(--paper);text-align:center;padding:84px 0}
.cta h2{color:var(--paper);font-size:clamp(2rem,4vw,3rem)}
.cta p{color:rgba(243,239,229,.78);font-size:1.2rem;max-width:46ch;margin:0 auto 30px}
.cta .btn{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.cta .btn:hover{background:transparent;color:var(--paper)}
.cta .eyebrow{color:rgba(243,239,229,.6)}

/* ---------- post / page content ---------- */
.page-hero{padding:62px 0 34px;border-bottom:1px solid var(--hair)}
.page-hero .eyebrow{margin-bottom:18px}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.4rem);max-width:18ch}
.entry-meta{font-family:var(--fr);text-transform:uppercase;letter-spacing:.12em;font-size:11.5px;color:var(--ink-faint);margin-top:18px}
.prose{max-width:none}
.entry-content{max-width:68ch;margin:0 auto;padding:54px 0}
.entry-content p{margin:0 0 1.3em}
.entry-content > p:first-of-type::first-letter{font-family:var(--cas);font-size:3.1em;line-height:.8;float:left;padding:6px 12px 0 0;color:var(--accent)}
.entry-content h2{font-size:1.9rem;margin:1.6em 0 .5em}
.entry-content h3{font-size:1.4rem;margin:1.4em 0 .4em}
.entry-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.entry-content blockquote{border-left:3px solid var(--accent);margin:1.6em 0;padding:.2em 0 .2em 28px;font-family:var(--cas);font-size:1.5rem;line-height:1.25}
.entry-content img{margin:1.6em 0;border:1px solid var(--hair)}
.entry-content ul,.entry-content ol{padding-left:1.2em}
.entry-content code{font-family:ui-monospace,Menlo,monospace;font-size:.9em;background:var(--paper-2);padding:2px 6px}
.entry-footer{max-width:68ch;margin:0 auto;border-top:1px solid var(--hair);padding:22px 0;font-family:var(--fr);font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint)}

/* ---------- archive list ---------- */
.archive-list{max-width:760px;margin:0 auto}
.archive-row{padding:30px 0;border-bottom:1px solid var(--hair);display:grid;grid-template-columns:140px 1fr;gap:28px;align-items:baseline}
.archive-row .date{font-family:var(--fr);text-transform:uppercase;letter-spacing:.1em;font-size:11.5px;color:var(--ink-faint);padding-top:6px}
.archive-row h2{font-size:1.7rem;margin:0 0 8px}
.archive-row h2 a:hover{color:var(--accent)}
.archive-row p{color:var(--ink-soft);font-size:1.05rem;margin:0}

/* ---------- footer ---------- */
.site-foot{background:var(--paper-2);border-top:1px solid var(--hair);padding:54px 0 40px;margin-top:0}
.foot-top{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-start}
.foot-name{font-family:var(--cas);font-size:26px}
.foot-name small{display:block;font-family:var(--fr);text-transform:uppercase;letter-spacing:.16em;font-size:10px;color:var(--accent);margin-top:6px;font-weight:500}
.foot-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:22px}
.foot-nav a{font-family:var(--fr);text-transform:uppercase;letter-spacing:.1em;font-size:11.5px;color:var(--ink-soft)}
.foot-nav a:hover{color:var(--accent)}
.foot-bottom{margin-top:38px;border-top:1px solid var(--hair);padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-family:var(--fr);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint)}

/* ---------- pagination ---------- */
.pagination{max-width:760px;margin:40px auto 0;display:flex;justify-content:center;gap:10px;font-family:var(--fr);font-size:12px;text-transform:uppercase;letter-spacing:.1em}
.pagination .page-numbers{padding:9px 14px;border:1px solid var(--hair);color:var(--ink-soft)}
.pagination .current{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ---------- reveal motion ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:38px}
  .hero-figure{order:-1;max-width:360px}
  .offer-grid{grid-template-columns:1fr}
  .offer{border-right:0;border-bottom:1px solid var(--hair);padding:26px 0!important}
  .offer:last-child{border-bottom:0}
  .dispatch-grid{grid-template-columns:1fr;gap:0}
  .dispatch{border-top:1px solid var(--hair);padding:24px 0}
  .dispatch:first-child{border-top:2px solid var(--ink)}
  .about-grid{grid-template-columns:1fr;gap:34px}
  .archive-row{grid-template-columns:1fr;gap:8px}
}
@media (max-width:680px){
  body{font-size:16px;line-height:1.55}
  .nameplate{font-size:19px}
  .section-head{margin-bottom:28px}
  .nav{position:fixed;inset:64px 0 auto 0;background:var(--paper);border-bottom:1px solid var(--hair);transform:translateY(-130%);transition:transform .25s ease;padding:8px 0}
  .nav.open{transform:none;box-shadow:0 16px 30px rgba(26,23,20,.1)}
  .nav ul{flex-direction:column;gap:0;align-items:stretch}
  .nav a{display:block;padding:14px 28px;border-bottom:1px solid var(--hair)}
  .nav-toggle{display:block}
  .hero{padding:30px 0 34px}
  .hero h1{font-size:2.2rem;line-height:1.07;margin:0 0 16px}
  .standfirst{font-size:1.1rem;line-height:1.45;margin:0 0 22px}
  .hero-grid{gap:32px}
  .hero-figure{max-width:none}
  .hero-figure img{width:100%;height:46vh;object-fit:cover;object-position:50% 18%}
  .hero-actions{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:24px}
  .section{padding:44px 0}
  .pull{padding:64px 0}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{scroll-behavior:auto!important}
}
