/*
Theme Name: YesEarth
Theme URI: https://www.yesearth.org/
Author: SLRD YesEarth
Author URI: https://www.yesearth.org/
Description: Ground-up classic theme for YesEarth. Presentation layer for the yesearth-core plugin: a structured-CMS site driven by a reusable section builder, with Programs, Missions, Events, Team, Partners, Resources, Testimonials, a Join Us module and a Jobs module. Biochar-and-leaf design language, bilingual-ready, responsive and accessible.
Version: 1.2.0
Requires at least: 6.0
Requires PHP: 7.4
Tested up to: 6.9
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: yesearth
Tags: custom-logo, custom-menu, featured-images, translation-ready, two-columns, right-sidebar, full-width-template
*/

/* ========== Tokens ========== */
:root{
  --char:#17150F;
  --char-2:#221E15;
  --canvas:#F2F5EA;
  --paper:#FBFCF6;
  --leaf:#2F6233;
  --sprout:#74A12F;
  --clay:#B5673A;
  --stone:#646857;
  --line:#D8DCC8;
  --line-strong:#C4C9B0;
  --radius:14px;
  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--canvas);color:var(--char);font-family:Inter,system-ui,sans-serif;font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;line-height:1.04;letter-spacing:-.02em;margin:0}
h4,h5,h6{font-family:"Bricolage Grotesque",sans-serif;font-weight:600;margin:0 0 .4em}
a{color:inherit}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:"Space Mono",monospace;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--leaf)}
.mono{font-family:"Space Mono",monospace}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:16px;background:#fff;color:#000;padding:12px;z-index:100000;width:auto;height:auto}
:focus-visible{outline:3px solid var(--sprout);outline-offset:2px}

/* ========== Buttons ========== */
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 24px;border-radius:999px;font-weight:600;font-size:.98rem;text-decoration:none;cursor:pointer;border:1px solid transparent;transition:transform .2s var(--ease),background .2s}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--leaf);color:#fff}
.btn-primary:hover{background:#26512a;color:#fff}
.btn-ghost{background:transparent;border-color:var(--char);color:var(--char)}
.btn-ghost:hover{background:var(--char);color:#fff}
.btn .arr{transition:transform .2s var(--ease)}
.btn:hover .arr{transform:translateX(3px)}

/* ========== Header ========== */
.top-bar{background:var(--char);color:#cdd0c0;font-size:.8rem;text-align:center;padding:7px 0;font-family:"Space Mono",monospace;letter-spacing:.04em}
.site-header{position:sticky;top:0;z-index:50;background:rgba(242,245,234,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;gap:18px;min-height:64px}
.brand{display:flex;align-items:center;gap:10px;font-family:"Bricolage Grotesque";font-weight:800;font-size:1.15rem;text-decoration:none;color:var(--char)}
.brand img{max-height:46px;width:auto}
.brand .mark{width:30px;height:30px;border-radius:50%;background:var(--leaf);display:grid;place-items:center;color:#fff;font-size:.9rem}
.brand small{display:block;font-family:Inter;font-weight:500;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);margin-top:1px}
.ye-nav{margin-left:auto}
.ye-menu{display:flex;gap:22px;align-items:center;list-style:none;margin:0;padding:0}
.ye-menu a{text-decoration:none;font-size:.92rem;font-weight:500;color:var(--char);opacity:.85}
.ye-menu a:hover,.ye-menu .current-menu-item>a{opacity:1;color:var(--leaf)}
.ye-menu .sub-menu{display:none}
.header-cta{margin-left:6px}
.lang{display:flex;border:1px solid var(--line-strong);border-radius:999px;overflow:hidden;font-size:.72rem;font-weight:600}
.lang button{border:0;background:transparent;padding:5px 11px;cursor:pointer;font:inherit;color:var(--stone)}
.lang button.on{background:var(--char);color:#fff}
.menu-btn{display:none;margin-left:auto;width:40px;height:40px;border:1px solid var(--line-strong);background:transparent;border-radius:10px;cursor:pointer;font-size:1.1rem}
@media(max-width:900px){
  .ye-nav{position:fixed;inset:64px 0 auto;background:var(--paper);border-bottom:1px solid var(--line);transform:translateY(-120%);transition:transform .25s var(--ease);margin:0}
  .ye-nav.open{transform:none}
  .ye-menu{flex-direction:column;align-items:flex-start;gap:0;padding:10px 24px}
  .ye-menu li{width:100%;border-bottom:1px solid var(--line)}
  .ye-menu a{display:block;padding:14px 0}
  .menu-btn{display:inline-grid;place-items:center}
  .header-cta{display:none}
}

/* ========== Hero ========== */
.hero{padding:88px 0 64px;position:relative;overflow:hidden}
.hero.has-bg{background-size:cover;background-position:center}
.hero .wrap{position:relative;z-index:2}
.hero h1{font-size:clamp(2.4rem,6vw,5rem);max-width:18ch}
.hero h1 .grow{color:var(--leaf)}
.hero p.lead{font-size:clamp(1.05rem,2vw,1.3rem);max-width:48ch;margin:24px 0 0;color:var(--char-2)}
.hero .cta-row{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.hero .seed{position:absolute;inset:0;z-index:1;opacity:.5;pointer-events:none}

/* ========== Stats ledger ========== */
.ledger{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper)}
.ledger .grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:30px 24px;border-left:1px solid var(--line)}
.stat:first-child{border-left:0}
.stat .num{font-family:"Space Mono",monospace;font-weight:700;font-size:clamp(1.9rem,3.4vw,2.7rem);color:var(--char);line-height:1}
.stat .num .u{color:var(--sprout)}
.stat .lbl{margin-top:8px;font-size:.82rem;color:var(--stone);line-height:1.35}
@media(max-width:760px){.ledger .grid{grid-template-columns:1fr 1fr}.stat:nth-child(odd){border-left:0}.stat:nth-child(n+3){border-top:1px solid var(--line)}}

/* ========== Section scaffold ========== */
.ye-sec{padding:74px 0}
.ye-sec.tight{padding:48px 0}
.sec-head{max-width:62ch}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.9rem);margin-top:10px}
.sec-head p{color:var(--stone);margin:14px 0 0;font-size:1.05rem}

/* ========== Cards grid ========== */
.ye-cards-grid{display:grid;gap:18px;margin-top:34px;grid-template-columns:repeat(3,1fr)}
.ye-cards-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.ye-cards-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.ye-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:24px 22px;transition:transform .2s var(--ease),border-color .2s,box-shadow .2s;text-decoration:none;color:inherit;display:block}
.ye-card:hover{transform:translateY(-4px);border-color:var(--sprout);box-shadow:0 14px 34px -22px rgba(47,98,51,.6)}
.ye-card .ic{font-size:1.6rem}
.ye-card img{border-radius:10px;margin-bottom:14px;aspect-ratio:3/2;object-fit:cover;width:100%}
.ye-card h3{font-size:1.18rem;margin:12px 0 8px}
.ye-card p{font-size:.92rem;color:var(--stone);margin:0}
@media(max-width:880px){.ye-cards-grid,.ye-cards-grid.cols-2,.ye-cards-grid.cols-4{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.ye-cards-grid,.ye-cards-grid.cols-2,.ye-cards-grid.cols-4{grid-template-columns:1fr}}

/* ========== Image + text ========== */
.ye-split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.ye-split.img-right .ye-split-media{order:2}
.ye-split-media img{border-radius:var(--radius);width:100%}
.ye-split h2{font-size:clamp(1.7rem,3vw,2.4rem)}
.ye-split .body{margin-top:14px;color:var(--char-2)}
@media(max-width:820px){.ye-split{grid-template-columns:1fr;gap:24px}.ye-split.img-right .ye-split-media{order:0}}

/* ========== Logo strip ========== */
.ye-logos{display:flex;flex-wrap:wrap;gap:30px;align-items:center;justify-content:center;margin-top:30px}
.ye-logos .logo{display:grid;place-items:center;min-height:60px}
.ye-logos .logo img{max-height:54px;width:auto;filter:grayscale(1);opacity:.75;transition:.2s}
.ye-logos .logo:hover img{filter:none;opacity:1}
.ye-logos .name{font-family:"Bricolage Grotesque";font-weight:600}

/* ========== Testimonials ========== */
.ye-quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.ye-quote{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.ye-quote blockquote{margin:0;font-size:1.05rem;line-height:1.5}
.ye-quote .who{display:flex;align-items:center;gap:12px;margin-top:18px}
.ye-quote .who img{width:42px;height:42px;border-radius:50%;object-fit:cover}
.ye-quote .who strong{font-family:"Bricolage Grotesque"}
.ye-quote .who span{display:block;font-size:.82rem;color:var(--stone)}
@media(max-width:820px){.ye-quotes{grid-template-columns:1fr}}

/* ========== CTA band ========== */
.ye-cta-band{background:var(--char);color:#F1F3E8;border-radius:0}
.ye-cta-band .eyebrow{color:var(--sprout)}
.ye-cta-band h2{color:#fff;font-size:clamp(1.9rem,3.6vw,2.9rem);margin-top:10px;max-width:24ch}
.ye-cta-band p{color:#B8BCab;margin:14px 0 24px;max-width:54ch}
.ye-cta-band .btn-primary{background:var(--sprout);color:var(--char)}
.ye-cta-band .btn-primary:hover{background:#8ab93b;color:var(--char)}

/* ========== Gallery ========== */
.ye-gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:30px}
.ye-gallery-grid img{border-radius:10px;aspect-ratio:1;object-fit:cover;width:100%}
@media(max-width:720px){.ye-gallery-grid{grid-template-columns:repeat(2,1fr)}}

/* ========== Accordion ========== */
.ye-acc{margin-top:30px;border-top:1px solid var(--line)}
.ye-acc details{border-bottom:1px solid var(--line)}
.ye-acc summary{cursor:pointer;list-style:none;padding:20px 4px;font-family:"Bricolage Grotesque";font-weight:600;font-size:1.1rem;display:flex;justify-content:space-between;align-items:center}
.ye-acc summary::-webkit-details-marker{display:none}
.ye-acc summary::after{content:"+";color:var(--leaf);font-size:1.3rem}
.ye-acc details[open] summary::after{content:"–"}
.ye-acc .acc-body{padding:0 4px 20px;color:var(--char-2)}

/* ========== Team grid ========== */
.ye-team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:34px}
.ye-team-card{text-align:left}
.ye-team-card img{border-radius:var(--radius);aspect-ratio:3/4;object-fit:cover;width:100%;margin-bottom:12px;background:var(--line)}
.ye-team-card h3{font-size:1.05rem}
.ye-team-card .role{font-size:.85rem;color:var(--leaf);font-weight:600}
.ye-team-card .org{font-size:.82rem;color:var(--stone)}
@media(max-width:880px){.ye-team-grid{grid-template-columns:1fr 1fr}}

/* ========== Regions ========== */
.ye-regions{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.ye-region{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--sprout);border-radius:var(--radius);padding:24px}
.ye-region h3{font-size:1.2rem;margin-bottom:8px}
.ye-region p{color:var(--stone);margin:0;font-size:.92rem}
@media(max-width:820px){.ye-regions{grid-template-columns:1fr}}

/* ========== Embed ========== */
.ye-embed{margin-top:30px;border-radius:var(--radius);overflow:hidden}
.ye-embed iframe{width:100%;min-height:420px;border:0;display:block}

/* ========== Forms ========== */
.form-band{background:var(--char);color:#F1F3E8}
.form-band .eyebrow{color:var(--sprout)}
.form-band h2{color:#fff}
.form-band .sec-head p{color:#B8BCab}
.ye-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:30px}
.ye-form .ye-field{display:flex;flex-direction:column;gap:7px;margin:0}
.ye-form .ye-field.full{grid-column:1/-1}
.ye-form label{font-size:.8rem;letter-spacing:.02em;color:var(--stone);font-weight:500}
.form-band .ye-form label{color:#9aa08b}
.ye-form input,.ye-form select,.ye-form textarea{background:#fff;border:1px solid var(--line-strong);color:var(--char);border-radius:10px;padding:13px 14px;font:inherit;font-size:.95rem;width:100%}
.form-band .ye-form input,.form-band .ye-form select,.form-band .ye-form textarea{background:var(--char-2);border-color:#3a3527;color:#fff}
.ye-form input:focus,.ye-form select:focus,.ye-form textarea:focus{outline:none;border-color:var(--sprout)}
.ye-form textarea{resize:vertical;min-height:96px}
.ye-form .ye-req{color:var(--clay)}
.form-band .ye-form .btn-primary{background:var(--sprout);color:var(--char)}
.ye-consent{flex-direction:row!important;align-items:flex-start;gap:8px;font-size:.85rem}
.ye-consent input{width:auto}
.ye-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.ye-form-ok{background:rgba(116,161,47,.12);border:1px solid var(--sprout);border-radius:var(--radius);padding:20px;margin-bottom:20px}
.form-band .ye-form-ok{background:var(--char-2);color:#cdd0c0}
.ye-form-error{background:rgba(181,103,58,.12);border:1px solid var(--clay);border-radius:var(--radius);padding:16px;margin-bottom:20px;color:var(--clay)}
@media(max-width:680px){.ye-form-grid{grid-template-columns:1fr}}

/* ========== Join Us page ========== */
.roles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:34px}
.role{text-align:left;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:24px 22px;cursor:pointer;font:inherit;color:inherit;transition:transform .2s var(--ease),border-color .2s,box-shadow .2s}
.role:hover{transform:translateY(-4px);border-color:var(--sprout)}
.role .ic{font-size:1.5rem}
.role h3{font-size:1.15rem;margin:14px 0 8px}
.role p{font-size:.9rem;color:var(--stone);margin:0}
.role[aria-expanded="true"]{border-color:var(--leaf);box-shadow:0 0 0 2px var(--leaf) inset}
.role .go{margin-top:16px;font-family:"Space Mono",monospace;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--leaf)}
@media(max-width:880px){.roles{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.roles{grid-template-columns:1fr}}
.join-detail{display:none;background:var(--paper);border:1px solid var(--line-strong);border-radius:var(--radius);padding:30px;margin-top:24px}
.join-detail.active{display:block}
.join-detail h3{font-size:1.5rem;margin-bottom:8px}
.join-detail .cols{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-top:20px}
.join-detail ul{padding-left:0;list-style:none;margin:10px 0 0}
.join-detail li{position:relative;padding-left:22px;margin-bottom:9px;color:var(--char-2)}
.join-detail li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;border-radius:50%;background:var(--sprout)}
@media(max-width:760px){.join-detail .cols{grid-template-columns:1fr}}
.paths{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:38px}
.path{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;display:flex;flex-direction:column}
.path .tag{font-family:"Space Mono",monospace;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay)}
.path h3{font-size:1.4rem;margin:10px 0 16px}
.path ul{list-style:none;padding:0;margin:0 0 24px;display:flex;flex-direction:column;gap:11px}
.path li{position:relative;padding-left:24px;font-size:.95rem;color:var(--char-2)}
.path li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;border-radius:50%;background:var(--sprout)}
.path .btn{margin-top:auto;justify-content:center}
@media(max-width:880px){.paths{grid-template-columns:1fr}}

/* ========== Jobs ========== */
.filters{display:flex;gap:10px;margin-top:30px;flex-wrap:wrap}
.filters button{border:1px solid var(--line-strong);background:transparent;border-radius:999px;padding:8px 18px;font:inherit;font-size:.86rem;font-weight:600;color:var(--stone);cursor:pointer}
.filters button.on{background:var(--char);color:#fff;border-color:var(--char)}
.jobs{margin-top:26px;border-top:1px solid var(--line)}
.job{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center;padding:22px 4px;border-bottom:1px solid var(--line);transition:padding-left .2s var(--ease)}
.job:hover{padding-left:14px}
.job .title{font-family:"Bricolage Grotesque";font-weight:600;font-size:1.18rem}
.job .title a{text-decoration:none}
.job .meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.chip{font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:6px;border:1px solid var(--line-strong);color:var(--stone)}
.chip.type{color:var(--leaf);border-color:#bcd3a3;background:#eef4e3}
.chip.open{color:#fff;background:var(--sprout);border-color:var(--sprout)}
.chip.closed{color:#fff;background:var(--clay);border-color:var(--clay)}
.job .apply{white-space:nowrap;font-weight:600;font-size:.9rem;text-decoration:none;color:var(--leaf);display:inline-flex;gap:7px;align-items:center}
.job .apply:hover{color:#26512a}
@media(max-width:560px){.job{grid-template-columns:1fr}}
.past-jobs{margin-top:50px}
.past-jobs h3{font-size:1.3rem;margin-bottom:8px}

/* ========== Jobs page (SLRD job-titles style) ========== */
.jobs-hero{padding:80px 0 30px;position:relative}
.jobs-hero h1{font-size:clamp(2.6rem,6vw,4.6rem);margin-top:12px}
.jobs-hero .lead{font-size:clamp(1.05rem,2vw,1.3rem);max-width:54ch;margin:18px 0 0;color:var(--char-2)}
.jobs-hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.jobs-hero-badges span{font-family:"Space Mono",monospace;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--line-strong);background:var(--paper);border-radius:999px;padding:7px 14px;color:var(--leaf)}
.jobs-count{color:var(--stone);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
.loc-filter{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px}
.loc-filter button{border:1px solid var(--line-strong);background:transparent;border-radius:999px;padding:8px 18px;font:inherit;font-size:.86rem;font-weight:600;color:var(--stone);cursor:pointer;transition:.15s}
.loc-filter button.on{background:var(--char);color:#fff;border-color:var(--char)}
.ye-jobs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ye-jobs-grid.is-past{grid-template-columns:repeat(4,1fr);margin-top:18px}
.ye-job-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s var(--ease),box-shadow .2s,border-color .2s}
.ye-job-card:hover{transform:translateY(-4px);border-color:var(--sprout);box-shadow:0 16px 38px -24px rgba(47,98,51,.6)}
.ye-job-thumb{display:block;aspect-ratio:16/9;background:#e7ecdb;overflow:hidden}
.ye-job-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.ye-job-thumb-fallback{display:flex;align-items:center;justify-content:center;height:100%;font-family:"Space Mono",monospace;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--leaf)}
.ye-job-body{padding:18px 20px 22px;display:flex;flex-direction:column;flex:1}
.ye-job-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.ye-job-title{font-size:1.18rem;line-height:1.2;margin:0 0 8px}
.ye-job-title a{text-decoration:none}
.ye-job-title a:hover{color:var(--leaf)}
.ye-job-facts{font-size:.78rem;color:var(--stone);display:flex;gap:6px;flex-wrap:wrap}
.ye-job-snip{font-size:.9rem;color:var(--char-2);margin:12px 0 16px}
.ye-job-view{margin-top:auto;font-weight:600;font-size:.9rem;text-decoration:none;color:var(--leaf);display:inline-flex;gap:7px;align-items:center}
.ye-job-view:hover{color:#26512a}
.ye-job-view .arr{transition:transform .2s var(--ease)}
.ye-job-view:hover .arr{transform:translateX(3px)}
.ye-job-card.is-closed{opacity:.85}
.ye-job-card.is-closed .ye-job-body{padding:16px 18px}
.ye-jobs-empty{background:var(--paper);border:1px dashed var(--line-strong);border-radius:var(--radius);padding:44px 30px;text-align:center}
.ye-jobs-empty h3{font-size:1.4rem;margin-bottom:8px}
.ye-jobs-empty p{color:var(--stone);max-width:48ch;margin:0 auto 18px}
.related-sections .rel-links{display:flex;gap:14px;flex-wrap:wrap;margin-top:20px}
.related-sections .rel-links a{background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:12px 22px;text-decoration:none;font-weight:600;font-size:.92rem;display:inline-flex;gap:8px;align-items:center}
.related-sections .rel-links a:hover{border-color:var(--sprout);color:var(--leaf)}
@media(max-width:880px){.ye-jobs-grid{grid-template-columns:1fr 1fr}.ye-jobs-grid.is-past{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.ye-jobs-grid,.ye-jobs-grid.is-past{grid-template-columns:1fr}}

/* Job single */
.job-single .job-hero{background:var(--paper);border-bottom:1px solid var(--line)}
.job-single .job-hero .wrap{padding-top:48px;padding-bottom:40px}
.job-single .job-hero h1{font-size:clamp(2rem,4vw,3rem);max-width:20ch}
.job-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:46px;align-items:start;padding:60px 0}
.job-body h2{font-size:1.4rem;margin:30px 0 12px}
.job-body ul{padding-left:20px}
.job-body li{margin-bottom:8px}
.job-aside{position:sticky;top:90px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.job-aside .row{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.job-aside .row:last-of-type{border-bottom:0}
.job-aside .row span:first-child{color:var(--stone)}
.job-aside .btn{width:100%;justify-content:center;margin-top:18px}
@media(max-width:820px){.job-grid{grid-template-columns:1fr;gap:30px;padding:36px 0}.job-aside{position:static}}

/* ========== Credibility ========== */
.cred{background:var(--char-2);color:#E8EBDD}
.cred .wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:46px;align-items:center}
.cred h2{color:#fff;font-size:clamp(1.7rem,3.2vw,2.5rem)}
.cred p{color:#B9BDAC;margin-top:16px}
.badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.badges span{font-family:"Space Mono",monospace;font-size:.72rem;letter-spacing:.08em;border:1px solid #3c3829;border-radius:8px;padding:7px 12px;color:#cfd2c2}
@media(max-width:820px){.cred .wrap{grid-template-columns:1fr;gap:30px}}

/* ========== Archives / blog ========== */
.page-hero{padding:60px 0 30px}
.page-hero h1{font-size:clamp(2rem,4.4vw,3.2rem)}
.page-hero p{color:var(--stone);margin-top:12px;max-width:60ch}
.archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;padding:40px 0 70px}
.post-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .2s var(--ease),box-shadow .2s}
.post-card:hover{transform:translateY(-4px);box-shadow:0 14px 34px -22px rgba(47,98,51,.5)}
.post-card .thumb{aspect-ratio:3/2;object-fit:cover;width:100%;background:var(--line)}
.post-card .pad{padding:20px 22px 24px}
.post-card .cat{font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--clay)}
.post-card h3{font-size:1.2rem;margin:8px 0}
.post-card p{font-size:.9rem;color:var(--stone)}
@media(max-width:880px){.archive-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.archive-grid{grid-template-columns:1fr}}

/* Single content */
.entry{padding:50px 0 70px}
.entry .wrap.narrow{max-width:760px}
.entry-header h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:12px}
.entry-meta{color:var(--stone);font-size:.9rem;margin-bottom:24px;font-family:"Space Mono",monospace}
.entry-thumb{border-radius:var(--radius);margin:20px 0 30px;width:100%}
.entry-content{font-size:1.06rem}
.entry-content h2{font-size:1.6rem;margin:32px 0 12px}
.entry-content h3{font-size:1.3rem;margin:26px 0 10px}
.entry-content p{margin:0 0 18px}
.entry-content ul,.entry-content ol{margin:0 0 18px;padding-left:24px}
.entry-content img{border-radius:10px;margin:18px 0}
.entry-content a{color:var(--leaf);text-decoration:underline}
.entry-content blockquote{border-left:4px solid var(--sprout);margin:24px 0;padding:6px 0 6px 22px;color:var(--char-2);font-size:1.15rem}
.alignleft{float:left;margin:6px 24px 16px 0}
.alignright{float:right;margin:6px 0 16px 24px}
.aligncenter{margin:18px auto;display:block}
.wp-caption-text{font-size:.85rem;color:var(--stone);text-align:center}

/* Pagination */
.ye-pagination{display:flex;gap:8px;justify-content:center;padding:10px 0 60px;flex-wrap:wrap}
.ye-pagination .page-numbers{padding:9px 15px;border:1px solid var(--line-strong);border-radius:8px;text-decoration:none;font-weight:600;font-size:.9rem}
.ye-pagination .current{background:var(--leaf);color:#fff;border-color:var(--leaf)}

/* Related + share */
.related{padding:40px 0 70px;border-top:1px solid var(--line)}
.share{display:flex;gap:10px;margin:24px 0}
.share a{width:40px;height:40px;border-radius:50%;border:1px solid var(--line-strong);display:grid;place-items:center;font-size:.85rem;text-decoration:none;color:var(--stone)}
.share a:hover{background:var(--leaf);color:#fff;border-color:var(--leaf)}

/* ========== Footer ========== */
.site-footer{background:var(--char);color:#cdd0c0;padding:56px 0 30px;margin-top:0}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px}
.site-footer h4{font-family:"Bricolage Grotesque";color:#fff;font-size:1.05rem;margin:0 0 14px}
.site-footer a{display:block;text-decoration:none;color:#b3b7a6;font-size:.92rem;padding:4px 0}
.site-footer a:hover{color:var(--sprout)}
.foot-about{color:#9ea291;max-width:34ch;font-size:.92rem}
.foot-social{display:flex;gap:10px;margin-top:16px}
.foot-social a{padding:0;width:38px;height:38px;border:1px solid #36321f;border-radius:50%;display:grid;place-items:center;font-family:"Space Mono",monospace;font-size:.7rem}
.foot-bottom{border-top:1px solid #322e1f;margin-top:40px;padding-top:22px;font-size:.8rem;color:#85897a;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* ========== Reveal ========== */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important}.reveal{opacity:1;transform:none;transition:none}.ye-card:hover,.job:hover,.post-card:hover{transform:none}}
