/* ============================================================
   TRIMMER PICKS — Heritage Editorial
   Shared stylesheet (powers HTML previews + WordPress theme)
   Built on CSS variables so the WP Customizer can override them.
   ============================================================ */

/* ---------- Design tokens (overridable by Customizer) ---------- */
:root{
  --tp-cream:#F6F2EA;
  --tp-paper:#FCFAF5;
  --tp-ink:#1C1A17;
  --tp-ink-soft:#4A453E;
  --tp-line:#E2DAcc;
  --tp-line-soft:#EBE4D6;
  --tp-accent:#A9794B;
  --tp-accent-dk:#8A5F38;
  --tp-heading-font:'Playfair Display', Georgia, serif;
  --tp-body-font:'Work Sans', system-ui, sans-serif;
  --tp-base-size:17px;
  --tp-h1:60px;
  --tp-maxw:1280px;
  --tp-radius:0px;
  --tp-space:1;
}

/* ---------- Reset / base ---------- */
*{box-sizing:border-box;}
body{margin:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--tp-body-font);
  color:var(--tp-ink);
  background:var(--tp-paper);
  font-size:var(--tp-base-size);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;height:auto;}
h1,h2,h3,h4,h5,h6{font-family:var(--tp-heading-font);font-weight:700;line-height:1.1;letter-spacing:-.01em;margin:0;}
p{margin:0 0 1.1em;}
ul,ol{margin:0;padding:0;}
button{font-family:inherit;}

.tp-wrap{max-width:var(--tp-maxw);margin:0 auto;padding:0 32px;width:100%;}
.tp-screenreader{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;}

/* skip link */
.tp-skip{position:absolute;left:-9999px;top:0;background:var(--tp-ink);color:#fff;padding:10px 16px;z-index:200;}
.tp-skip:focus{left:8px;top:8px;}

/* ---------- Placeholder ---------- */
.ph{position:relative;background:linear-gradient(135deg,#E8E0D2,#D8CDB8);overflow:hidden;}
.ph::after{content:attr(data-label);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:12px;font-family:var(--tp-body-font);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#9A8B6F;}

/* ---------- Buttons ---------- */
.btn{display:inline-block;font-family:var(--tp-body-font);font-size:12.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;padding:15px 32px;background:var(--tp-ink);color:var(--tp-cream);transition:.2s;border:none;cursor:pointer;border-radius:var(--tp-radius);}
.btn:hover{background:var(--tp-accent-dk);color:#fff;}
.btn.ghost{background:transparent;color:var(--tp-ink);border:1px solid var(--tp-ink);}
.btn.ghost:hover{background:var(--tp-ink);color:var(--tp-cream);}
.btn.accent{background:var(--tp-accent);}
.btn.accent:hover{background:var(--tp-accent-dk);}

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar{background:var(--tp-ink);color:#E8E1D4;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;}
.topbar .tp-wrap{display:flex;align-items:center;justify-content:space-between;min-height:42px;gap:16px;}
.topbar a.tb-link{color:#C9A36A;border-bottom:1px solid #5a4f3d;padding-bottom:1px;}
.topbar .tb-social{display:flex;gap:18px;font-size:11px;}
.topbar .tb-social a:hover{color:#fff;}

/* ============================================================
   HEADER
   ============================================================ */
header.site{background:var(--tp-paper);border-bottom:1px solid var(--tp-line);position:relative;z-index:60;}
header.site.sticky{position:sticky;top:0;}
.hd{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;min-height:96px;gap:20px;}

/* branding */
.brand{text-align:center;white-space:nowrap;display:inline-flex;flex-direction:column;align-items:center;gap:3px;line-height:1;}
.brand .brand-logo{max-height:52px;width:auto;}
.brand .brand-name{font-family:var(--tp-heading-font);font-weight:800;font-size:30px;letter-spacing:.02em;color:var(--tp-ink);}
.brand .brand-tag{font-family:var(--tp-body-font);font-weight:500;font-size:9.5px;letter-spacing:.42em;text-transform:uppercase;color:var(--tp-accent);}

/* nav */
nav.main ul{display:flex;gap:30px;font-size:13.5px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;list-style:none;align-items:center;}
nav.main a{display:inline-block;padding:4px 0;border-bottom:2px solid transparent;transition:.2s;}
nav.main a:hover,nav.main .current-menu-item>a{border-color:var(--tp-accent);}
nav.main ul ul{display:none;}/* submenu simplified for preview */

.hd-r{display:flex;justify-content:flex-end;gap:20px;align-items:center;}
.hd-l{display:flex;align-items:center;gap:30px;}
.icn{width:20px;height:20px;stroke:var(--tp-ink);stroke-width:1.6;fill:none;cursor:pointer;background:none;border:none;padding:0;}

/* header layout variants */
header.site[data-layout="logo-center"] .hd{grid-template-columns:1fr auto 1fr;}
header.site[data-layout="logo-left"] .hd{grid-template-columns:auto 1fr auto;}
header.site[data-layout="logo-left"] .brand{text-align:left;align-items:flex-start;}
header.site[data-layout="logo-left"] nav.main ul{justify-content:flex-end;}

/* hamburger */
.tp-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;background:none;border:none;cursor:pointer;padding:9px;}
.tp-burger span{display:block;height:2px;width:100%;background:var(--tp-ink);transition:.25s;}
.tp-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.tp-burger[aria-expanded="true"] span:nth-child(2){opacity:0;}
.tp-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* mobile drawer */
.tp-mobile-nav{position:fixed;inset:0 0 0 auto;width:min(82vw,360px);background:var(--tp-paper);z-index:120;transform:translateX(100%);transition:transform .3s ease;box-shadow:-8px 0 40px rgba(0,0,0,.15);display:flex;flex-direction:column;padding:26px 28px;overflow-y:auto;}
.tp-mobile-nav.open{transform:translateX(0);}
.tp-mobile-overlay{position:fixed;inset:0;background:rgba(20,18,15,.5);z-index:110;opacity:0;visibility:hidden;transition:.3s;}
.tp-mobile-overlay.open{opacity:1;visibility:visible;}
.tp-mobile-nav .mclose{align-self:flex-end;background:none;border:none;font-size:30px;line-height:1;cursor:pointer;color:var(--tp-ink);}
.tp-mobile-nav ul{list-style:none;margin-top:14px;}
.tp-mobile-nav li{border-bottom:1px solid var(--tp-line-soft);}
.tp-mobile-nav a{display:block;padding:16px 2px;font-size:16px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;}
.tp-mobile-nav .m-social{display:flex;gap:18px;margin-top:24px;}
.tp-mobile-nav .m-social svg{width:20px;height:20px;stroke:var(--tp-ink);fill:none;stroke-width:1.6;}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding:54px 0 60px;}
.hero-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:46px;align-items:center;}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--tp-accent-dk);display:flex;align-items:center;gap:12px;margin-bottom:22px;}
.eyebrow::after{content:"";flex:1;height:1px;background:var(--tp-line);}
.hero h1{font-size:var(--tp-h1);font-weight:800;margin-bottom:20px;}
.hero p.lead{font-size:1.06rem;color:var(--tp-ink-soft);max-width:90%;margin-bottom:26px;}
.meta{font-size:13px;letter-spacing:.04em;color:var(--tp-ink-soft);text-transform:uppercase;margin-bottom:26px;}
.meta b{color:var(--tp-ink);font-weight:600;}
.hero .ph{aspect-ratio:4/5;border:1px solid var(--tp-line);}

/* ============================================================
   SECTIONS
   ============================================================ */
.sec{padding:calc(56px * var(--tp-space)) 0;}
.sec.alt{background:var(--tp-cream);}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:34px;border-bottom:1px solid var(--tp-line);padding-bottom:18px;gap:20px;}
.sec-head h2{font-size:34px;}
.sec-head .kick{font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--tp-accent-dk);margin-bottom:8px;}
.seemore{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--tp-ink);border-bottom:1.5px solid var(--tp-accent);padding-bottom:3px;white-space:nowrap;}

/* article grid */
.grid{display:grid;gap:30px;}
.grid.cols-2{grid-template-columns:repeat(2,1fr);}
.grid.cols-3{grid-template-columns:repeat(3,1fr);}
.grid.cols-4{grid-template-columns:repeat(4,1fr);}
.card .ph{aspect-ratio:3/4;margin-bottom:16px;border:1px solid var(--tp-line);}
.card .cat{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--tp-accent-dk);margin-bottom:9px;display:inline-block;}
.card h3{font-size:19px;font-weight:700;line-height:1.22;margin-bottom:10px;}
.card:hover h3{color:var(--tp-accent-dk);}
.card .by{font-size:12px;letter-spacing:.04em;color:var(--tp-ink-soft);text-transform:uppercase;}
.card .excerpt{font-size:14px;color:var(--tp-ink-soft);margin-top:8px;}

/* category split */
.catrow{display:grid;grid-template-columns:1fr 1fr;gap:46px;}
.catfeat .ph{aspect-ratio:16/11;margin-bottom:18px;border:1px solid var(--tp-line);}
.catfeat .kick{font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--tp-accent-dk);margin-bottom:10px;}
.catfeat h3{font-size:26px;margin-bottom:12px;}
.catfeat p{color:var(--tp-ink-soft);margin-bottom:14px;}
.catlist{display:flex;flex-direction:column;gap:18px;}
.li{display:grid;grid-template-columns:108px 1fr;gap:18px;align-items:center;padding-bottom:18px;border-bottom:1px solid var(--tp-line-soft);}
.li .ph{aspect-ratio:1;border:1px solid var(--tp-line);}
.li h4{font-family:var(--tp-heading-font);font-size:17px;font-weight:700;line-height:1.2;margin-bottom:6px;}
.li .by{font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--tp-ink-soft);}

/* author strip */
.author{background:var(--tp-ink);color:var(--tp-cream);}
.author .tp-wrap{display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:center;padding:60px 32px;}
.author .ph{width:170px;height:170px;border-radius:50%;border:3px solid var(--tp-accent);flex:none;}
.author .kick{color:var(--tp-accent);font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;margin-bottom:14px;}
.author h2{color:var(--tp-cream);font-size:32px;margin-bottom:14px;}
.author p{color:#D8CFBE;max-width:640px;margin-bottom:20px;}

/* newsletter */
.nl{background:var(--tp-accent);color:#fff;text-align:center;}
.nl .tp-wrap{padding:64px 32px;}
.nl .kick{font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;margin-bottom:14px;opacity:.85;}
.nl h2{color:#fff;font-size:38px;margin-bottom:16px;}
.nl p{max-width:520px;margin:0 auto 26px;opacity:.92;}
.nlform{display:flex;gap:0;max-width:480px;margin:0 auto;}
.nlform input{flex:1;border:none;padding:16px 18px;font-family:var(--tp-body-font);font-size:14px;min-width:0;border-radius:var(--tp-radius);}
.nlform button{background:var(--tp-ink);color:#fff;border:none;padding:0 28px;font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;border-radius:var(--tp-radius);}

/* ============================================================
   FOOTER
   ============================================================ */
footer.site{background:var(--tp-ink);color:#CFC6B5;padding:64px 0 0;}
.fcols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid #34302a;}
.fcols.cols-1{grid-template-columns:1fr;}
.fcols.cols-2{grid-template-columns:1fr 1fr;}
.fcols.cols-3{grid-template-columns:1.6fr 1fr 1fr;}
footer .brand{text-align:left;align-items:flex-start;margin-bottom:16px;}
footer .brand .brand-name{color:var(--tp-cream);}
footer .brand .brand-tag{color:var(--tp-accent);}
.fcol h4{font-family:var(--tp-body-font);font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--tp-accent);margin-bottom:18px;}
.fcol a{display:block;font-size:14px;margin-bottom:11px;color:#CFC6B5;}
.fcol a:hover{color:#fff;}
.fcol ul{list-style:none;}
.fabout{font-size:14px;line-height:1.7;max-width:300px;color:#CFC6B5;}
.fbot{display:flex;justify-content:space-between;align-items:center;padding:24px 0;font-size:12.5px;letter-spacing:.04em;color:#857d6e;gap:18px;flex-wrap:wrap;}
.fsoc{display:flex;gap:14px;}
.fsoc a{width:34px;height:34px;border:1px solid #443f37;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.fsoc a:hover{border-color:var(--tp-accent);}
.fsoc svg{width:15px;height:15px;stroke:#CFC6B5;fill:none;stroke-width:1.6;}

/* ============================================================
   PAGE HEADER (archives / static pages)
   ============================================================ */
.page-head{background:var(--tp-cream);border-bottom:1px solid var(--tp-line);padding:52px 0;text-align:center;}
.page-head .crumbs{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--tp-ink-soft);margin-bottom:16px;}
.page-head .crumbs a:hover{color:var(--tp-accent-dk);}
.page-head h1{font-size:46px;margin-bottom:14px;}
.page-head p{color:var(--tp-ink-soft);max-width:640px;margin:0 auto;}
.filterbar{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:24px;}
.filterbar a{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:9px 18px;border:1px solid var(--tp-line);border-radius:999px;color:var(--tp-ink-soft);transition:.2s;}
.filterbar a:hover,.filterbar a.on{background:var(--tp-ink);color:var(--tp-cream);border-color:var(--tp-ink);}

/* pagination */
.pagination{display:flex;gap:8px;justify-content:center;align-items:center;margin-top:50px;}
.pagination a,.pagination span{min-width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;border:1px solid var(--tp-line);font-size:14px;font-weight:600;color:var(--tp-ink);transition:.2s;}
.pagination a:hover,.pagination .current{background:var(--tp-ink);color:var(--tp-cream);border-color:var(--tp-ink);}

/* ============================================================
   SINGLE POST  (article + TOC + sidebar)
   ============================================================ */
.single-hero{background:var(--tp-cream);border-bottom:1px solid var(--tp-line);padding:48px 0 44px;}
.single-hero .crumbs{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--tp-ink-soft);margin-bottom:18px;}
.single-hero .cat{font-size:11.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--tp-accent-dk);margin-bottom:14px;display:inline-block;}
.single-hero h1{font-size:48px;max-width:900px;margin-bottom:18px;}
.single-hero .pmeta{display:flex;align-items:center;gap:16px;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--tp-ink-soft);}
.single-hero .pmeta .av{width:40px;height:40px;border-radius:50%;border:1px solid var(--tp-line);}
.single-hero .pmeta b{color:var(--tp-ink);font-weight:600;}

.single-feat{margin:0 auto;}
.single-feat .ph{aspect-ratio:21/9;border-bottom:1px solid var(--tp-line);}

.post-layout{display:grid;grid-template-columns:1fr 340px;gap:56px;padding:56px 0;}
.post-layout.no-sidebar{grid-template-columns:minmax(0,760px);just-content:center;}

.entry{font-size:1.06rem;line-height:1.8;color:var(--tp-ink-soft);max-width:760px;}
.entry h2{font-family:var(--tp-heading-font);font-size:30px;color:var(--tp-ink);margin:42px 0 16px;scroll-margin-top:110px;}
.entry h3{font-family:var(--tp-heading-font);font-size:23px;color:var(--tp-ink);margin:32px 0 12px;scroll-margin-top:110px;}
.entry p{margin-bottom:1.3em;}
.entry a{color:var(--tp-accent-dk);border-bottom:1px solid var(--tp-line);}
.entry a:hover{border-color:var(--tp-accent-dk);}
.entry ul,.entry ol{margin:0 0 1.3em 1.2em;}
.entry li{margin-bottom:.5em;}
.entry blockquote{margin:30px 0;padding:8px 0 8px 28px;border-left:3px solid var(--tp-accent);font-family:var(--tp-heading-font);font-style:italic;font-size:24px;line-height:1.4;color:var(--tp-ink);}
.entry img,.entry .ph{border:1px solid var(--tp-line);margin:28px 0;}
.entry figure{margin:28px 0;}
.entry figcaption{font-size:13px;color:var(--tp-ink-soft);text-align:center;margin-top:10px;text-transform:uppercase;letter-spacing:.06em;}

/* TOC box */
.toc{border:1px solid var(--tp-line);background:var(--tp-paper);padding:22px 24px;margin-bottom:34px;}
.toc .toc-head{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--tp-accent-dk);margin-bottom:14px;}
.toc ol{list-style:none;counter-reset:toc;}
.toc li{counter-increment:toc;margin-bottom:10px;font-size:14.5px;}
.toc li a{color:var(--tp-ink-soft);}
.toc li a::before{content:counter(toc,decimal-leading-zero) ".";color:var(--tp-accent);font-weight:600;margin-right:8px;}
.toc li a:hover,.toc li.active a{color:var(--tp-ink);}

/* sidebar */
.sidebar{display:flex;flex-direction:column;gap:36px;align-self:start;position:sticky;top:110px;}
.widget h4{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--tp-accent-dk);margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--tp-line);}
.widget-author{border:1px solid var(--tp-line);padding:28px 24px;text-align:center;}
.widget-author .ph{width:96px;height:96px;border-radius:50%;margin:0 auto 16px;border:2px solid var(--tp-accent);}
.widget-author h5{font-family:var(--tp-heading-font);font-size:20px;margin-bottom:10px;}
.widget-author p{font-size:14px;color:var(--tp-ink-soft);margin-bottom:16px;}
.widget-list .li-sm{display:grid;grid-template-columns:64px 1fr;gap:14px;align-items:center;margin-bottom:16px;}
.widget-list .li-sm .ph{aspect-ratio:1;border:1px solid var(--tp-line);}
.widget-list .li-sm h5{font-family:var(--tp-heading-font);font-size:15px;line-height:1.25;}
.widget-list .li-sm .by{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--tp-ink-soft);margin-top:4px;}
.widget-nl{background:var(--tp-accent);color:#fff;padding:28px 24px;}
.widget-nl h4{color:#fff;border-color:rgba(255,255,255,.3);}
.widget-nl p{font-size:14px;margin-bottom:14px;}
.widget-nl input{width:100%;border:none;padding:12px 14px;margin-bottom:10px;font-family:var(--tp-body-font);font-size:14px;border-radius:var(--tp-radius);}
.widget-nl button{width:100%;background:var(--tp-ink);color:#fff;border:none;padding:13px;font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border-radius:var(--tp-radius);}
.widget-search{display:flex;}
.widget-search input{flex:1;border:1px solid var(--tp-line);border-right:none;padding:12px 14px;font-family:var(--tp-body-font);font-size:14px;min-width:0;}
.widget-search button{background:var(--tp-ink);color:#fff;border:none;padding:0 16px;cursor:pointer;}

/* tags + share */
.post-foot{max-width:760px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;border-top:1px solid var(--tp-line);border-bottom:1px solid var(--tp-line);padding:22px 0;margin-top:40px;}
.tags{display:flex;gap:8px;flex-wrap:wrap;}
.tags a{font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:7px 14px;border:1px solid var(--tp-line);color:var(--tp-ink-soft);}
.tags a:hover{background:var(--tp-ink);color:var(--tp-cream);border-color:var(--tp-ink);}
.share{display:flex;gap:10px;align-items:center;}
.share span{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--tp-ink-soft);}
.share a{width:34px;height:34px;border:1px solid var(--tp-line);border-radius:50%;display:flex;align-items:center;justify-content:center;}
.share svg{width:15px;height:15px;stroke:var(--tp-ink);fill:none;stroke-width:1.6;}

/* author box */
.authorbox{max-width:760px;display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:center;background:var(--tp-cream);border:1px solid var(--tp-line);padding:30px;margin-top:40px;}
.authorbox .ph{width:110px;height:110px;border-radius:50%;border:2px solid var(--tp-accent);flex:none;}
.authorbox .kick{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--tp-accent-dk);margin-bottom:8px;}
.authorbox h4{font-family:var(--tp-heading-font);font-size:22px;margin-bottom:10px;}
.authorbox p{font-size:14.5px;color:var(--tp-ink-soft);margin-bottom:0;}

/* related */
.related{background:var(--tp-cream);border-top:1px solid var(--tp-line);padding:56px 0;}
.related h2{font-size:30px;margin-bottom:28px;text-align:center;}

/* ============================================================
   COMMENTS
   ============================================================ */
.comments{max-width:760px;margin-top:46px;}
.comments h3{font-size:24px;margin-bottom:24px;}
.comment{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:22px 0;border-bottom:1px solid var(--tp-line-soft);}
.comment .ph{width:52px;height:52px;border-radius:50%;flex:none;}
.comment .cm-meta{font-size:13px;color:var(--tp-ink-soft);margin-bottom:6px;}
.comment .cm-meta b{color:var(--tp-ink);}
.commentform{margin-top:30px;display:grid;gap:16px;max-width:760px;}
.commentform .row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.commentform input,.commentform textarea{border:1px solid var(--tp-line);padding:14px 16px;font-family:var(--tp-body-font);font-size:15px;width:100%;background:var(--tp-paper);}
.commentform textarea{min-height:140px;resize:vertical;}

/* ============================================================
   STATIC PAGE / ABOUT / CONTACT
   ============================================================ */
.page-body{padding:56px 0;}
.prose{max-width:760px;margin:0 auto;font-size:1.06rem;line-height:1.8;color:var(--tp-ink-soft);}
.prose h2{font-size:30px;color:var(--tp-ink);margin:38px 0 14px;}
.prose p{margin-bottom:1.3em;}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start;}
.contactform{display:grid;gap:16px;}
.contactform label{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--tp-ink-soft);margin-bottom:-8px;}
.contactform input,.contactform textarea{border:1px solid var(--tp-line);padding:14px 16px;font-family:var(--tp-body-font);font-size:15px;background:var(--tp-paper);width:100%;}
.contactform textarea{min-height:160px;resize:vertical;}
.contact-info .ci{display:flex;gap:14px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--tp-line-soft);}
.contact-info .ci svg{width:22px;height:22px;stroke:var(--tp-accent-dk);fill:none;stroke-width:1.6;flex:none;margin-top:2px;}
.contact-info .ci h5{font-family:var(--tp-heading-font);font-size:17px;margin-bottom:4px;}
.contact-info .ci p{font-size:14px;color:var(--tp-ink-soft);margin:0;}

/* ============================================================
   404 / SEARCH-NONE
   ============================================================ */
.notfound{text-align:center;padding:90px 0;}
.notfound .big{font-family:var(--tp-heading-font);font-size:130px;font-weight:800;line-height:1;color:var(--tp-accent);opacity:.35;}
.notfound h1{font-size:40px;margin:10px 0 16px;}
.notfound p{color:var(--tp-ink-soft);max-width:480px;margin:0 auto 26px;}
.notfound .searchwrap{max-width:420px;margin:0 auto;display:flex;}
.notfound .searchwrap input{flex:1;border:1px solid var(--tp-line);border-right:none;padding:14px 16px;font-family:var(--tp-body-font);font-size:15px;min-width:0;}
.notfound .searchwrap button{background:var(--tp-ink);color:#fff;border:none;padding:0 24px;font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;}

/* ============================================================
   RESPONSIVE — TABLET
   ============================================================ */
@media(max-width:1024px){
  :root{--tp-h1:48px;--tp-maxw:100%;}
  .tp-wrap{padding:0 28px;}
  .grid.cols-4{grid-template-columns:repeat(3,1fr);}
  .post-layout{grid-template-columns:1fr 300px;gap:40px;}
  .single-hero h1{font-size:40px;}
  .hero h1{font-size:48px;}
}

/* ============================================================
   RESPONSIVE — BELOW 900 (stack hero / split / sidebar)
   ============================================================ */
@media(max-width:900px){
  .hero-grid,.catrow{grid-template-columns:1fr;gap:32px;}
  .hero .ph{aspect-ratio:16/10;}
  .grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,1fr);}
  .author .tp-wrap{grid-template-columns:1fr;text-align:center;justify-items:center;padding:48px 28px;}
  .author p{margin-left:auto;margin-right:auto;}
  .post-layout{grid-template-columns:1fr;gap:0;}
  .sidebar{position:static;margin-top:48px;border-top:1px solid var(--tp-line);padding-top:40px;}
  .contact-grid{grid-template-columns:1fr;gap:36px;}
  .fcols{grid-template-columns:1fr 1fr;gap:32px;}
  .fcols.cols-3,.fcols.cols-4{grid-template-columns:1fr 1fr;}
  /* show hamburger, hide desktop nav */
  nav.main,.hd-l nav.main{display:none;}
  .tp-burger{display:flex;}
  .hd{grid-template-columns:auto 1fr auto;}
  header.site[data-layout="logo-center"] .hd{grid-template-columns:auto 1fr auto;}
  .brand{text-align:left;align-items:flex-start;}
  .hd-l{order:1;}
  .brand{order:2;justify-self:center;}
  .hd-r{order:3;}
}

/* ============================================================
   RESPONSIVE — MOBILE
   ============================================================ */
@media(max-width:640px){
  :root{--tp-h1:36px;--tp-base-size:16px;}
  .tp-wrap{padding:0 20px;}
  .topbar{font-size:11px;}
  .topbar .tb-social{display:none;}
  .topbar .tp-wrap{justify-content:center;text-align:center;min-height:38px;}
  .hd{min-height:74px;gap:8px;}
  .brand .brand-name{font-size:23px;}
  .brand .brand-tag{font-size:8px;letter-spacing:.34em;}
  .brand .brand-logo{max-height:40px;}
  .hero{padding:36px 0 40px;}
  .hero h1{font-size:34px;}
  .hero p.lead{max-width:100%;}
  .sec{padding:40px 0;}
  .sec-head{flex-direction:column;align-items:flex-start;gap:10px;}
  .sec-head h2{font-size:27px;}
  .grid{gap:24px;}
  .grid.cols-2,.grid.cols-3,.grid.cols-4{grid-template-columns:1fr;}
  .card .ph{aspect-ratio:16/10;}
  .li{grid-template-columns:84px 1fr;gap:14px;}
  .author h2{font-size:27px;}
  .author .ph{width:130px;height:130px;}
  .nl .tp-wrap{padding:46px 20px;}
  .nl h2{font-size:29px;}
  .nlform{flex-direction:column;gap:10px;}
  .nlform button{padding:14px;}
  .page-head{padding:38px 0;}
  .page-head h1{font-size:33px;}
  .single-hero{padding:34px 0 30px;}
  .single-hero h1{font-size:30px;}
  .single-hero .pmeta{flex-wrap:wrap;gap:10px;font-size:12px;}
  .single-feat .ph{aspect-ratio:16/10;}
  .post-layout{padding:38px 0;}
  .entry h2{font-size:25px;}
  .entry h3{font-size:20px;}
  .entry blockquote{font-size:20px;}
  .authorbox{grid-template-columns:1fr;text-align:center;justify-items:center;padding:26px 22px;}
  .post-foot{flex-direction:column;align-items:flex-start;}
  .comment{grid-template-columns:1fr;}
  .comment .ph{display:none;}
  .commentform .row{grid-template-columns:1fr;}
  .fcols{grid-template-columns:1fr;gap:30px;}
  .fcols.cols-2,.fcols.cols-3,.fcols.cols-4{grid-template-columns:1fr;}
  .fbot{flex-direction:column;align-items:flex-start;}
  .notfound .big{font-size:90px;}
  .notfound h1{font-size:30px;}
}

/* ============================================================
   ASPECT RATIO UTILITIES
   Override .card .thumb / .card .ph default 3:4 by adding a ratio-* class.
   ============================================================ */
.ratio-3-4  { aspect-ratio: 3/4; }
.ratio-4-3  { aspect-ratio: 4/3; }
.ratio-1-1  { aspect-ratio: 1/1; }
.ratio-16-9 { aspect-ratio: 16/9; }
.ratio-21-9 { aspect-ratio: 21/9; }
.ratio-2-1  { aspect-ratio: 2/1; }

/* card/ph already sets aspect-ratio; ratio-* overrides with same specificity via .thumb.ratio-* */
.thumb.ratio-3-4,  .ph.ratio-3-4  { aspect-ratio: 3/4; }
.thumb.ratio-4-3,  .ph.ratio-4-3  { aspect-ratio: 4/3; }
.thumb.ratio-1-1,  .ph.ratio-1-1  { aspect-ratio: 1/1; }
.thumb.ratio-16-9, .ph.ratio-16-9 { aspect-ratio: 16/9; }
.thumb.ratio-21-9, .ph.ratio-21-9 { aspect-ratio: 21/9; }

/* ============================================================
   REVISED CARD STRUCTURE — fixes nested-<a> layout bug.
   Old:  <a class="card"> ... <a class="cat"> ... </a> </a>   ← invalid HTML
   New:  <article class="card">
            <a class="card-img" href="..."><span class="thumb ratio-*"></span></a>
            <div class="card-body">
              <span class="cat">…</span>
              <h3><a href="...">Title</a></h3>
              <div class="by">…</div>
            </div>
         </article>
   ============================================================ */
.card { display: flex; flex-direction: column; }
.card-img { display: block; overflow: hidden; }
.card-img .thumb,
.card-img .ph { margin-bottom: 0; display: block; width: 100%; }
.card-body { flex: 1; padding-top: 14px; }
.card-body .cat { display: inline-block; margin-bottom: 8px; }
.card-body h3 { margin-bottom: 8px; }
.card-body h3 a { color: inherit; text-decoration: none; }
.card:hover .card-body h3 a { color: var(--tp-accent-dk); }
.card-body .by { font-size: 12px; letter-spacing: .04em; color: var(--tp-ink-soft); text-transform: uppercase; }
.card-body .by a { color: inherit; text-decoration: none; }
.card-body .excerpt { font-size: 14px; color: var(--tp-ink-soft); margin-top: 6px; margin-bottom: 0; }

/* grid still applies */
.grid .card { }

/* ============================================================
   REVISED LIST ITEM — .li (catlist in homepage sections)
   <div class="li">
     <a class="li-img" href="..."><span class="thumb ratio-1-1"></span></a>
     <div class="li-body">
       <h4><a href="...">Title</a></h4>
       <div class="by">Category · Time</div>
     </div>
   </div>
   ============================================================ */
.li { display: grid; grid-template-columns: 108px 1fr; gap: 18px; align-items: center; padding-bottom: 18px; border-bottom: 1px solid var(--tp-line-soft); }
.li .li-img { display: block; }
.li .li-img .thumb,
.li .li-img .ph { aspect-ratio: 1; border: 1px solid var(--tp-line); }
.li .li-body h4 { font-family: var(--tp-heading-font); font-size: 16px; font-weight: 700; line-height: 1.25; margin-bottom: 6px; }
.li .li-body h4 a { color: inherit; text-decoration: none; }
.li:hover .li-body h4 a { color: var(--tp-accent-dk); }
.li .li-body .by { font-size: 12px; text-transform: uppercase; letter-spacing: .05em; color: var(--tp-ink-soft); }

/* ============================================================
   RELATED / SIMILAR STORIES — clean 2–3 column grid
   ============================================================ */
.related { background: var(--tp-cream); border-top: 1px solid var(--tp-line); padding: 56px 0; }
.related h2 { font-size: 30px; text-align: center; margin-bottom: 32px; }
.related .grid .card-img .thumb,
.related .grid .card-img .ph { aspect-ratio: 4/3; }

/* ============================================================
   SIDEBAR WIDGET RECENT POSTS — proper compact layout
   ============================================================ */
.widget-list .li-sm { display: grid; grid-template-columns: 72px 1fr; gap: 12px; align-items: start; margin-bottom: 16px; border-bottom: 1px solid var(--tp-line-soft); padding-bottom: 14px; }
.widget-list .li-sm:last-child { border-bottom: none; }
.widget-list .li-sm .li-img { display: block; }
.widget-list .li-sm .li-img .thumb,
.widget-list .li-sm .li-img .ph { aspect-ratio: 1; border: 1px solid var(--tp-line); display: block; }
.widget-list .li-sm .li-body h5 { font-family: var(--tp-heading-font); font-size: 14px; font-weight: 700; line-height: 1.25; margin-bottom: 4px; }
.widget-list .li-sm .li-body h5 a { color: inherit; text-decoration: none; }
.widget-list .li-sm .li-body h5 a:hover { color: var(--tp-accent-dk); }
.widget-list .li-sm .li-body .by { font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--tp-ink-soft); }

/* ============================================================
   BLOG LIST LAYOUT — fix multi-column broken appearance
   ============================================================ */
.blog-list { display: flex; flex-direction: column; gap: 32px; }
.blog-list .card { display: grid; grid-template-columns: 280px 1fr; gap: 28px; align-items: start; border-bottom: 1px solid var(--tp-line-soft); padding-bottom: 28px; }
.blog-list .card-img { display: block; }
.blog-list .card-img .thumb,
.blog-list .card-img .ph { aspect-ratio: 4/3; margin-bottom: 0; }
.blog-list .card-body { padding-top: 0; }
.blog-list .card-body h3 { font-size: 22px; }
@media(max-width: 640px) {
  .blog-list .card { grid-template-columns: 1fr; }
  .blog-list .card-img .thumb,
  .blog-list .card-img .ph { aspect-ratio: 16/9; }
}

/* ============================================================
   WORDPRESS CORE COMPATIBILITY
   ============================================================ */
/* dropdown submenus */
nav.main ul li{position:relative;}
nav.main ul ul{display:none;position:absolute;top:100%;left:0;background:var(--tp-paper);border:1px solid var(--tp-line);min-width:210px;padding:8px 0;box-shadow:0 14px 34px rgba(20,18,15,.12);z-index:80;flex-direction:column;gap:0;}
nav.main ul li:hover>ul,nav.main ul li:focus-within>ul{display:flex;}
nav.main ul ul li a{display:block;padding:9px 18px;border:none;font-size:12.5px;white-space:nowrap;}
nav.main ul ul li a:hover{background:var(--tp-cream);border:none;}
nav.main .menu-item-has-children>a::after{content:"";display:inline-block;width:5px;height:5px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);margin-left:7px;vertical-align:middle;opacity:.6;}
.tp-mobile-nav .sub-menu{margin:0 0 0 14px;}
.tp-mobile-nav .sub-menu a{padding:11px 2px;font-size:13.5px;}

/* alignment + media */
.alignleft{float:left;margin:6px 28px 18px 0;}
.alignright{float:right;margin:6px 0 18px 28px;}
.aligncenter{display:block;margin:18px auto;}
.alignwide{margin-left:-60px;margin-right:-60px;max-width:calc(100% + 120px);}
.alignfull{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:100vw;width:100vw;}
.wp-caption{max-width:100%;}
.wp-caption-text,.wp-element-caption{font-size:13px;color:var(--tp-ink-soft);text-align:center;margin-top:8px;text-transform:uppercase;letter-spacing:.06em;}
.entry .wp-block-image img{border:1px solid var(--tp-line);}
.sticky .card,.entry .sticky-badge{position:relative;}
.post-password-form input{border:1px solid var(--tp-line);padding:12px 14px;font-family:var(--tp-body-font);}
.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;word-wrap:normal!important;}

/* WP widgets in sidebar / footer */
.widget ul{list-style:none;}
.widget select{width:100%;padding:11px 12px;border:1px solid var(--tp-line);font-family:var(--tp-body-font);background:var(--tp-paper);}
.widget_recent_entries li,.widget_categories li,.widget_archive li,.widget_pages li,.widget_meta li,.widget_recent_comments li,.widget_nav_menu li{font-size:14px;padding:8px 0;border-bottom:1px solid var(--tp-line-soft);}
.widget_recent_entries a,.widget_categories a,.widget_archive a,.widget_pages a{color:var(--tp-ink);}
.widget_recent_entries a:hover,.widget_categories a:hover,.widget_archive a:hover{color:var(--tp-accent-dk);}
.fcol .widget{margin-bottom:28px;}
.fcol .widget h4,.fcol .widgettitle{font-family:var(--tp-body-font);font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--tp-accent);margin-bottom:16px;}
.fcol .widget li{border-color:#34302a;color:#CFC6B5;}
.fcol .widget a{color:#CFC6B5;}
.fcol .widget a:hover{color:#fff;}
.fcol .widget select{background:#34302a;border-color:#443f37;color:#CFC6B5;}

/* tag cloud */
.tagcloud a{display:inline-block;font-size:12px!important;letter-spacing:.05em;text-transform:uppercase;padding:6px 12px;border:1px solid var(--tp-line);margin:0 6px 6px 0;color:var(--tp-ink-soft);}
.tagcloud a:hover{background:var(--tp-ink);color:var(--tp-cream);border-color:var(--tp-ink);}

/* comments list (WP) */
.commentlist{list-style:none;}
.commentlist .children{list-style:none;margin-left:40px;}
.comment-body{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:22px 0;border-bottom:1px solid var(--tp-line-soft);}
.comment-body .avatar{width:52px;height:52px;border-radius:50%;}
.comment-author{font-size:14px;}
.comment-author .fn{font-style:normal;font-weight:600;color:var(--tp-ink);}
.comment-meta{font-size:12px;color:var(--tp-ink-soft);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;}
.comment-meta a{color:var(--tp-ink-soft);}
.reply a{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--tp-accent-dk);}
.comment-respond .comment-reply-title{font-family:var(--tp-heading-font);font-size:24px;margin-bottom:18px;}
.comment-form label{display:block;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--tp-ink-soft);margin-bottom:6px;}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{width:100%;border:1px solid var(--tp-line);padding:13px 15px;font-family:var(--tp-body-font);font-size:15px;background:var(--tp-paper);margin-bottom:16px;}
.comment-form textarea{min-height:140px;resize:vertical;}

/* search form */
.search-form{display:flex;}
.search-form .search-field{flex:1;border:1px solid var(--tp-line);border-right:none;padding:12px 14px;font-family:var(--tp-body-font);font-size:14px;min-width:0;background:var(--tp-paper);}
.search-form .search-submit{background:var(--tp-ink);color:#fff;border:none;padding:0 18px;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;}

/* admin bar offset for sticky header */
body.admin-bar header.site.sticky{top:32px;}
@media(max-width:782px){body.admin-bar header.site.sticky{top:46px;}}

/* list blog layout */
.blog-list .card{display:grid;grid-template-columns:300px 1fr;gap:30px;align-items:center;border-bottom:1px solid var(--tp-line-soft);padding-bottom:30px;}
.blog-list .card .ph,.blog-list .card .thumb{aspect-ratio:4/3;margin-bottom:0;}
.blog-list .card h3{font-size:24px;}
@media(max-width:640px){.blog-list .card{grid-template-columns:1fr;gap:16px;}}

/* featured image as background helper */
.thumb{display:block;background-size:cover;background-position:center;border:1px solid var(--tp-line);}
.card .thumb{aspect-ratio:3/4;margin-bottom:16px;}
.li .thumb{aspect-ratio:1;}
.single-feat .thumb{aspect-ratio:21/9;}
.hero .thumb{aspect-ratio:4/5;border:1px solid var(--tp-line);}
.catfeat .thumb{aspect-ratio:16/11;margin-bottom:18px;}
.li-sm .thumb{aspect-ratio:1;}
.widget-author .thumb,.authorbox .thumb,.author .thumb{border-radius:50%;}
