/* ============================================================
   COMPUTE LAW BLOG · design system v4
   Pine green + ivory + brass. Rounded, soft. Tiempos + Untitled Sans.
   ============================================================ */

@font-face { font-family:'Tiempos Headline'; src:url('fonts/tiempos-headline-regular.woff2') format('woff2'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Tiempos Headline'; src:url('fonts/tiempos-headline-semibold.woff2') format('woff2'); font-weight:600; font-style:normal; font-display:swap; }
@font-face { font-family:'Tiempos Text'; src:url('fonts/tiempos-text-regular.woff2') format('woff2'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Tiempos Text'; src:url('fonts/tiempos-text-medium.woff2') format('woff2'); font-weight:500; font-style:normal; font-display:swap; }
@font-face { font-family:'Untitled Sans'; src:url('fonts/untitled-sans-regular.woff2') format('woff2'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Untitled Sans'; src:url('fonts/untitled-sans-medium.woff2') format('woff2'); font-weight:500; font-style:normal; font-display:swap; }

:root{
  --paper:#F4F1E9; --paper-2:#ECE8DC; --card:#FAF8F2;
  --ink:#14140F; --ink-soft:#4A463C; --ink-faint:#8B8576;
  --green:#1F4733; --green-deep:#173627; --green-soft:#2C5A43;
  --brass:#B98A3E; --brass-light:#D8B274; --brass-deep:#8C6A2E; --brass-link:#82612B;
  --rule:rgba(20,20,15,0.13); --rule-strong:rgba(20,20,15,0.28);
  --grid:rgba(31,71,51,0.06);
  --r:14px; --r-sm:9px; --r-lg:20px;
  --shadow:0 2px 6px rgba(20,30,22,0.05), 0 12px 28px -10px rgba(20,30,22,0.13), 0 30px 56px -24px rgba(20,30,22,0.12);
  --shadow-sm:0 1px 2px rgba(20,30,22,0.05), 0 6px 16px -8px rgba(20,30,22,0.11), 0 30px 56px -24px rgba(20,30,22,0);
  --display:'Tiempos Headline',Georgia,'Times New Roman',serif;
  --serif:'Tiempos Text',Georgia,serif;
  --sans:'Untitled Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --maxw:1280px; --gutter:clamp(1.25rem,4vw,4rem);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scrollbar-width:none;-ms-overflow-style:none;}
html::-webkit-scrollbar,body::-webkit-scrollbar{width:0;height:0;display:none;}
section[id],.pillar-item,.article-cta{scroll-margin-top:92px;}
body{
  background-color:var(--paper);
  background-image:radial-gradient(var(--grid) 1.1px, transparent 1.2px);
  background-size:28px 28px; background-position:14px 14px;
  color:var(--ink);font-family:var(--sans);font-size:1.0625rem;line-height:1.6;overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
::selection{background:var(--green);color:var(--paper);}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);}
.kicker{font-family:var(--sans);font-weight:500;font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--green);}
.hero .kicker{font-size:0.86rem;letter-spacing:0.16em;}
.stamp{display:inline-block;border:1.5px solid var(--green);color:var(--green);font-family:var(--sans);font-weight:500;font-size:0.66rem;letter-spacing:0.18em;text-transform:uppercase;padding:0.5rem 0.9rem;border-radius:var(--r-sm);transform:rotate(-1.2deg);}

/* DOCKET */
.docket{background:var(--green);color:var(--paper);}
.docket .wrap{display:flex;justify-content:space-between;align-items:center;min-height:32px;font-family:var(--sans);font-size:0.66rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;gap:1rem;}
.docket .d-mid{color:rgba(244,241,233,0.6);}
.docket .d-end{color:var(--brass-light);}
@media(max-width:680px){.docket .d-mid{display:none;}}

/* HEADER */
header{position:sticky;top:0;z-index:100;background:var(--paper);border-bottom:1px solid var(--rule);transition:box-shadow .3s ease;}
header .wrap{max-width:1440px;}
header.scrolled{box-shadow:var(--shadow-sm);}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px;position:relative;}
.brand{font-family:var(--display);font-weight:600;font-size:1.34rem;letter-spacing:-0.01em;}
.brand span{color:var(--brass);}
.nav-links{display:flex;gap:1.8rem;list-style:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);}
.nav-links a{font-family:var(--sans);font-size:0.73rem;font-weight:500;letter-spacing:0.13em;text-transform:uppercase;color:var(--ink-soft);position:relative;padding-block:0.4rem;transition:color .3s ease;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--green);border-radius:2px;transition:width .3s cubic-bezier(.22,1,.36,1);}
.nav-links a:hover{color:var(--green);}
.nav-links a:hover::after{width:100%;}
.subscribe-btn{font-family:var(--sans);font-size:0.73rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;background:var(--green);border:1.5px solid var(--green);color:var(--paper);padding:0.55rem 1.2rem;border-radius:999px;transition:all .25s ease;white-space:nowrap;box-shadow:var(--shadow-sm);}
.subscribe-btn:hover{background:var(--brass);border-color:var(--brass);color:var(--ink);transform:translateY(-1px);}
.menu-btn{display:none;background:none;border:0;cursor:pointer;width:32px;height:30px;padding:0;flex-direction:column;align-items:center;justify-content:center;gap:5px;}
.menu-btn span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s ease,opacity .3s ease;}
header.menu-open .menu-btn span:nth-child(1){transform:translateY(7px) rotate(45deg);}
header.menu-open .menu-btn span:nth-child(2){opacity:0;}
header.menu-open .menu-btn span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.nav-sub-mobile{display:none;}
@media(max-width:1000px){
  .menu-btn{display:flex;}
  .subscribe-btn{display:none;}
  .nav-sub-mobile{display:block;}
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--paper);border-bottom:1px solid var(--rule);box-shadow:var(--shadow-sm);padding:0.4rem var(--gutter) 1rem;opacity:0;transform:translateY(-10px);pointer-events:none;transition:opacity .25s ease,transform .25s ease;}
  header.menu-open .nav-links{opacity:1;transform:none;pointer-events:auto;}
  .nav-links a{padding-block:0.85rem;font-size:0.84rem;}
  .nav-links a::after{display:none;}
}

/* HERO */
.hero{position:relative;min-height:560px;display:flex;align-items:flex-start;overflow:hidden;background:var(--paper);}
.hero::after{content:"";position:absolute;top:0;right:0;bottom:0;width:52%;background:linear-gradient(to right,var(--paper),rgba(244,241,233,0) 20%),linear-gradient(to left,var(--paper),rgba(244,241,233,0) 7%),linear-gradient(to bottom,var(--paper),rgba(244,241,233,0) 13%),linear-gradient(to top,var(--paper),rgba(244,241,233,0) 13%),url('hero-right.jpg') center/cover no-repeat;z-index:0;pointer-events:none;}
.hero-inner{position:relative;z-index:2;width:100%;padding-top:clamp(2rem,5vh,4rem);padding-bottom:clamp(3rem,8vh,6rem);padding-left:clamp(1.25rem,calc(11vw - 3.25rem),8.5rem);padding-right:clamp(1.4rem,3vw,3rem);}
.hero-content{display:flex;flex-direction:column;align-items:flex-start;text-align:left;max-width:820px;}
.hero-eyebrow{font-family:var(--sans);font-size:0.86rem;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;color:var(--green);margin-bottom:clamp(0.7rem,1.4vw,1.15rem);}
.hero h1{font-family:var(--display);font-weight:400;font-size:clamp(2.3rem,3.7vw,3.5rem);line-height:1.14;letter-spacing:-0.022em;color:var(--ink);}
.hero h1 em{font-style:italic;color:var(--green);}
.hero-sub{display:flex;flex-direction:column;align-items:flex-start;gap:0.65rem;width:100%;font-family:var(--serif);font-weight:500;font-size:clamp(1.45rem,2vw,1.9rem);color:var(--ink);line-height:1.2;margin-top:clamp(1.7rem,2.4vw,2.2rem);}
@media(max-width:1000px){.hero-content{max-width:100%;}.hero::after{display:none;}}
.sub-phrase{white-space:nowrap;}
.cycle{display:inline-block;height:1.2em;line-height:1.2em;overflow:hidden;vertical-align:bottom;box-sizing:content-box;padding:0 0.14em;}
.cycle-track{display:flex;flex-direction:column;}
.cycle-track>span{display:block;height:1.2em;line-height:1.2em;white-space:nowrap;font-style:italic;font-weight:600;color:var(--brass);}
.btn-solid{font-family:var(--sans);font-weight:500;font-size:0.8rem;letter-spacing:0.08em;text-transform:uppercase;background:var(--green);color:var(--paper);padding:0.9rem 1.6rem;border-radius:999px;transition:transform .25s ease,background .3s ease,box-shadow .3s ease;display:inline-flex;gap:0.5rem;box-shadow:var(--shadow-sm);}
.btn-solid:hover{background:var(--green-deep);transform:translateY(-2px);box-shadow:var(--shadow);}
.btn-outline{font-family:var(--sans);font-weight:500;font-size:0.8rem;letter-spacing:0.08em;text-transform:uppercase;border:1.5px solid var(--green);color:var(--green);padding:0.82rem 1.5rem;border-radius:999px;transition:background .25s ease,color .25s ease;display:inline-flex;gap:0.5rem;align-items:center;}
.btn-outline:hover{background:var(--green);color:var(--paper);}
.btn-outline .arr{transition:transform .3s cubic-bezier(.22,1,.36,1);}
.btn-outline:hover .arr{transform:translateX(4px);}
.link-arrow{font-family:var(--sans);font-weight:500;font-size:0.92rem;color:var(--ink-soft);transition:color .3s ease;display:inline-flex;gap:0.45rem;}
.link-arrow .arr{transition:transform .3s cubic-bezier(.22,1,.36,1);}
.link-arrow:hover{color:var(--green);}
.link-arrow:hover .arr{transform:translateX(4px);}
.hero-doors{margin-top:clamp(1.7rem,2.4vw,2.2rem);display:flex;align-items:stretch;gap:clamp(1.2rem,2vw,1.8rem);width:100%;max-width:520px;}
.door{flex:1 1 0;display:flex;flex-direction:column;justify-content:space-between;gap:0.9rem;text-align:left;transition:transform .4s cubic-bezier(.22,1,.36,1);}
.door:hover{transform:translateY(-5px);}
.door-desc{font-family:var(--serif);font-size:clamp(0.98rem,1.3vw,1.1rem);color:var(--ink-soft);line-height:1.42;max-width:18rem;}
.door-cta{font-family:var(--sans);font-weight:600;font-size:1.05rem;color:var(--brass);display:inline-flex;gap:0.5rem;align-items:center;border-bottom:1.5px solid rgba(185,138,62,0.5);padding-bottom:4px;align-self:flex-start;}
.door-cta em{font-family:var(--serif);font-style:italic;font-weight:600;}
.door-cta .arr{transition:transform .3s cubic-bezier(.22,1,.36,1);}
.door:hover .door-cta .arr{transform:translateX(5px);}
.door-div{flex:0 0 auto;width:1px;align-self:center;height:70px;background:var(--rule-strong);}
@media(max-width:520px){.hero-doors{flex-direction:column;gap:1.4rem;}.door-div{display:none;}}
.hero-signup{margin-top:clamp(1.7rem,2.4vw,2.2rem);width:100%;max-width:480px;display:flex;flex-wrap:nowrap;gap:0.55rem;align-items:center;}
.hero-signup input{flex:1 1 auto;min-width:0;background:var(--card);border:1px solid var(--rule-strong);color:var(--ink);font-family:var(--sans);font-size:0.94rem;padding:0.76rem 1.1rem;border-radius:999px;}
.hero-signup input::placeholder{color:var(--ink-faint);}
.hero-signup input:focus{outline:none;border-color:var(--green);}
.hero-signup button{flex:0 0 auto;font-family:var(--sans);font-weight:600;font-size:0.73rem;letter-spacing:0.07em;text-transform:uppercase;background:var(--green);color:var(--paper);border:0;padding:0.82rem 1.35rem;border-radius:999px;cursor:pointer;transition:background .35s ease,color .35s ease,transform .25s ease;white-space:nowrap;}
.hero-signup button:hover{background:var(--brass);color:var(--ink);transform:translateY(-2px);}
.hero-stamps{margin-top:1.2rem;display:flex;justify-content:flex-start;}
@media(prefers-reduced-motion:reduce){.cycle-track{transition:none!important;}}

/* SECTION */
.section{padding-block:clamp(2.5rem,5vw,4rem);}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:2rem;margin-bottom:2.2rem;}
.sec-head h2{font-family:var(--display);font-weight:400;font-size:clamp(1.8rem,3.2vw,2.8rem);letter-spacing:-0.02em;line-height:1.22;}
.sec-head .meta{font-family:var(--sans);font-size:0.72rem;font-weight:500;letter-spacing:0.16em;color:var(--ink-faint);text-transform:uppercase;white-space:nowrap;}
.sec-dot{color:var(--brass);font-weight:400;vertical-align:middle;margin:0 0.28em;}
.sec-hint{font-family:var(--sans);font-size:0.72rem;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-faint);vertical-align:middle;}

/* ACCORDION PILLARS — rounded cards */
.pillars{display:flex;flex-direction:column;gap:0.75rem;}
.pillar-item{position:relative;border:1px solid var(--rule);border-radius:var(--r);background:var(--card);overflow:hidden;transition:border-color .35s ease,box-shadow .35s ease;}
.pillar-item.open{border-color:var(--green);box-shadow:var(--shadow);}
.pillar-head{width:100%;text-align:left;font:inherit;color:inherit;background:none;border:0;cursor:pointer;position:relative;display:grid;grid-template-columns:74px 1fr auto auto;gap:1.3rem;align-items:start;padding:1.6rem 1.4rem 1.6rem 1.5rem;transition:background-color .3s ease;}
.pillar-head::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--green);transform:scaleY(0);transform-origin:center;transition:transform .4s cubic-bezier(.22,1,.36,1);}
.pillar-item.open .pillar-head::before,.pillar-head:hover::before{transform:scaleY(1);}
.pillar-head:hover{background:var(--paper-2);}
.p-num{display:block;padding-top:0.35rem;font-family:var(--display);font-size:0.92rem;color:var(--brass);letter-spacing:0.02em;}
.p-title{display:block;font-family:var(--display);font-size:clamp(1.3rem,2.3vw,1.85rem);letter-spacing:-0.012em;line-height:1.1;transition:transform .4s cubic-bezier(.22,1,.36,1);}
.pillar-head:hover .p-title{transform:translateX(5px);color:var(--green);}
.p-desc{display:block;font-family:var(--sans);font-size:0.93rem;color:var(--ink-soft);margin-top:0.5rem;max-width:64ch;line-height:1.5;}
.p-count{font-family:var(--sans);font-size:0.72rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-faint);white-space:nowrap;padding-top:0.55rem;}
.pillar-item.open .p-count,.pillar-head:hover .p-count{color:var(--green);}
.p-toggle{font-family:var(--display);font-size:1.5rem;color:var(--green);width:1.4rem;text-align:center;line-height:1;padding-top:0.1rem;transition:transform .5s ease-in-out;}
.pillar-item.open .p-toggle{transform:rotate(45deg);}
.pillar-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .5s ease-in-out;}
.pillar-item.open .pillar-panel{grid-template-rows:1fr;}
.p-inner{overflow:hidden;}
.p-toc{padding:0.4rem 1.4rem 2rem calc(74px + 1.5rem + 1.3rem);}
@media(max-width:720px){.p-toc{padding-left:1.5rem;}}
@media(max-width:600px){
  .pillar-head{grid-template-columns:1fr auto;gap:0.3rem 0.8rem;padding:1.3rem 1.1rem;align-items:center;}
  .p-num{grid-row:1;grid-column:1;padding-top:0;}
  .p-toggle{grid-row:1;grid-column:2;padding-top:0;}
  .pillar-head>span:nth-child(2){grid-row:2;grid-column:1 / -1;}
  .p-count{grid-row:3;grid-column:1 / -1;padding-top:0.6rem;}
  .pillar-head:hover .p-title{transform:none;}
}
.p-group{font-family:var(--sans);font-weight:500;font-size:0.68rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--brass);margin:1.4rem 0 0.5rem;display:flex;align-items:center;gap:0.9rem;}
.p-group::after{content:"";flex:1;height:1px;background:var(--rule);}
.p-list{display:grid;grid-template-columns:1fr;gap:0 2.6rem;}
@media(max-width:760px){.p-list{grid-template-columns:1fr;}}
.toc-link{display:flex;gap:0.85rem;align-items:baseline;padding:0.6rem 0.7rem;border-radius:var(--r-sm);transition:background-color .25s ease;}
.toc-link:hover{background:var(--paper-2);}
.toc-link .tn{font-family:var(--sans);font-size:0.72rem;color:var(--brass);font-variant-numeric:tabular-nums;min-width:2.5rem;flex-shrink:0;}
.toc-link .tt{font-family:var(--serif);font-size:1.0rem;line-height:1.32;transition:color .25s ease;}
.toc-link:hover .tt{color:var(--green);}
.p-viewall{display:inline-flex;align-items:center;gap:0.5rem;margin-top:1.6rem;font-family:var(--sans);font-weight:500;font-size:0.78rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--green);border-bottom:1px solid rgba(31,71,51,0.35);padding-bottom:3px;transition:gap .3s ease,border-color .3s ease;}
.p-viewall:hover{gap:0.85rem;border-color:var(--green);}

/* PLEDGES */
.pledges-sec{padding-block:clamp(2.8rem,5vw,4rem);}
.promises-title{font-family:var(--display);font-weight:600;font-size:clamp(1.9rem,3.8vw,3rem);letter-spacing:-0.02em;line-height:1.12;margin-bottom:2.6rem;}
.pledges{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.6rem,4vw,3rem);}
@media(max-width:760px){.pledges{grid-template-columns:1fr;gap:2rem;}}
.pledge{position:relative;padding-top:1.1rem;border-top:2px solid var(--brass);}
.pledge .pnum{font-family:var(--sans);font-weight:500;font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--brass);}
.pledge h3{font-family:var(--display);font-weight:400;font-size:clamp(1.45rem,2.4vw,1.85rem);letter-spacing:-0.012em;margin-top:0.6rem;}
.pledge p{font-family:var(--sans);font-size:0.96rem;color:var(--ink-soft);margin-top:0.7rem;line-height:1.55;max-width:34ch;}
@media(max-width:760px){.pledge{border-top:none;padding-top:0;}.pledge::before{content:"";display:block;width:56px;height:2px;background:var(--brass);margin-bottom:1.1rem;}}

/* BRIEF */
.brief{background:var(--green);color:var(--paper);padding:clamp(1.7rem,3vw,2.8rem);border-radius:var(--r-lg);position:relative;overflow:hidden;}
.brief::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(244,241,233,0.06) 1px,transparent 1.2px);background-size:28px 28px;pointer-events:none;}
.brief>*{position:relative;}
.brief .kicker{color:var(--brass-light);font-size:0.86rem;letter-spacing:0.16em;}
.brief h2{font-family:var(--display);font-weight:400;font-size:clamp(1.45rem,2.2vw,2rem);color:var(--paper);letter-spacing:-0.02em;margin-top:0.6rem;}
.brief-lead{font-family:var(--serif);font-size:clamp(1rem,1.3vw,1.12rem);color:rgba(244,241,233,0.82);max-width:54ch;margin-top:0.9rem;line-height:1.55;}
.brief-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:0.8rem;margin-top:1.8rem;}
@media(max-width:760px){.brief-cards{grid-template-columns:1fr;}}
.brief-card{background:var(--green-deep);padding:1.5rem 1.4rem;border-radius:var(--r);transition:transform .35s cubic-bezier(.22,1,.36,1);}
.brief-card:hover{transform:translateY(-4px);}
.brief-card .date{font-family:var(--sans);font-size:0.7rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--brass-light);}
.brief-card h3{font-family:var(--display);font-weight:400;font-size:1.06rem;line-height:1.2;margin-top:0.6rem;color:var(--paper);}
.brief-card p{font-family:var(--sans);font-size:0.88rem;color:rgba(244,241,233,0.62);margin-top:0.6rem;}
.signup{margin-top:2.4rem;display:flex;gap:0.8rem;flex-wrap:wrap;align-items:center;}
.signup input{flex:1;min-width:240px;background:rgba(244,241,233,0.08);border:1px solid rgba(244,241,233,0.3);color:var(--paper);font-family:var(--sans);font-size:0.95rem;padding:0.85rem 1.1rem;border-radius:999px;}
.signup input::placeholder{color:rgba(244,241,233,0.5);}
.signup input:focus{outline:none;border-color:var(--brass-light);}
.signup button{font-family:var(--sans);font-weight:500;font-size:0.8rem;letter-spacing:0.08em;text-transform:uppercase;background:var(--brass);color:var(--ink);border:0;padding:0.9rem 1.7rem;border-radius:999px;cursor:pointer;transition:transform .25s ease,background .3s ease;}
.signup button:hover{background:var(--brass-light);transform:translateY(-2px);}
/* Brief archive page signup sits on the light hero, so match the hero button: green, gold on hover. */
.pillar-hero .signup button{background:var(--green);color:var(--paper);}
.pillar-hero .signup button:hover{background:var(--brass);color:var(--ink);}
.pillar-hero .signup input{background:var(--card);border-color:var(--rule-strong);color:var(--ink);flex:0 1 24rem;max-width:24rem;}
.pillar-hero .signup input::placeholder{color:var(--ink-faint);}
.pillar-hero .signup input:focus{border-color:var(--green);}
.pillar-hero .signup .note{color:var(--ink-faint);}
/* "Coming soon" placeholder (Brief not launched yet) */
.coming-soon{text-align:center;padding:clamp(2.5rem,7vw,5.5rem) 1rem;}
.coming-soon .cs-title{font-family:var(--display);font-weight:400;font-size:clamp(2rem,5vw,3.6rem);color:var(--green);letter-spacing:-0.025em;line-height:1;}
.signup .note{width:100%;font-family:var(--sans);font-size:0.76rem;color:rgba(244,241,233,0.55);}
.signup-thanks{width:100%;display:block;font-family:var(--sans);font-size:1.0625rem;font-weight:600;line-height:1.5;padding:0.55rem 0;color:var(--green);}
.brief .signup-thanks,.article-cta .signup-thanks{color:var(--paper);}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
@media(max-width:860px){.cards{grid-template-columns:1fr;}}
.card{position:relative;border:1px solid var(--rule);background:var(--card);border-radius:var(--r);box-shadow:var(--shadow-sm);transition:transform .45s cubic-bezier(.22,1,.36,1);display:flex;flex-direction:column;}
.card::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:var(--shadow);opacity:0;transition:opacity .45s cubic-bezier(.22,1,.36,1);pointer-events:none;}
.card:hover{transform:translateY(-8px);}
.reveal.stagger.is-visible>.card:hover{transform:translateY(-8px);}
.card:hover::after{opacity:1;}
.card-img{aspect-ratio:16/10;border-radius:var(--r) var(--r) 0 0;border-bottom:1px solid var(--rule);background:radial-gradient(circle at 30% 30%, rgba(31,71,51,0.08), transparent 60%), repeating-linear-gradient(135deg,transparent 0 15px,rgba(20,20,15,0.035) 15px 16px);display:grid;place-items:center;}
.card-img .ph-label{font-family:var(--sans);font-size:0.62rem;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-faint);}
.card-body{padding:1.4rem 1.5rem 1.6rem;flex:1;display:flex;flex-direction:column;}
.card .tag{font-family:var(--sans);font-size:0.66rem;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;color:var(--brass);}
.card h3{font-family:var(--display);font-weight:400;font-size:1.3rem;line-height:1.16;margin-top:0.6rem;letter-spacing:-0.01em;}
.card p{font-family:var(--sans);font-size:0.89rem;color:var(--ink-soft);margin-top:0.7rem;flex:1;}
.card .read{margin-top:1.1rem;font-family:var(--sans);font-size:0.74rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--green);display:inline-flex;gap:0.4rem;}
.card .read .arr{transition:transform .3s ease;}.card:hover .read .arr{transform:translateX(4px);}

/* PREVIOUS BRIEFS */
.brief-index{display:grid;grid-template-columns:1fr 1fr;gap:0 2.6rem;}
.brief-index a{display:flex;gap:1.1rem;align-items:baseline;padding:1.15rem 0.6rem;border-bottom:1px solid var(--rule);transition:background-color .25s ease;}
.brief-index a:hover{background:var(--card);}
.brief-index .bdate{font-family:var(--sans);font-size:0.7rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--brass);white-space:nowrap;min-width:5.4rem;flex-shrink:0;}
.brief-index .bhead{font-family:var(--display);font-size:1.12rem;line-height:1.25;transition:color .25s ease;}
.brief-index a:hover .bhead{color:var(--green);}
@media(max-width:760px){.brief-index{grid-template-columns:1fr;}}
.brief-archive-link{display:inline-flex;align-items:center;gap:0.5rem;margin-top:1.9rem;font-family:var(--sans);font-weight:500;font-size:0.8rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--green);border-bottom:1px solid rgba(31,71,51,0.35);padding-bottom:3px;transition:gap .3s ease;}
.brief-archive-link:hover{gap:0.85rem;}

/* ABOUT */
.about{display:grid;grid-template-columns:0.32fr 0.68fr;column-gap:clamp(1.6rem,4vw,3.5rem);row-gap:1.6rem;align-items:start;}
@media(max-width:760px){.about{grid-template-columns:1fr;}.about .label,.about .portrait,.about-body{grid-column:1;grid-row:auto;}}
.about .label{grid-column:1;grid-row:1;font-family:var(--sans);font-size:0.86rem;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;color:var(--green);}
.about p{font-family:var(--serif);font-size:1.16rem;color:var(--ink);line-height:1.6;}
.about p+p{margin-top:1rem;}
.about .small{font-size:1.04rem;color:var(--ink-soft);}
.byline{font-family:var(--sans);font-size:0.8rem;letter-spacing:0.04em;color:var(--ink-faint);margin-top:1.4rem;}
.about-body{grid-column:2;grid-row:2;}
.portrait{grid-column:1;grid-row:2;display:block;width:100%;max-width:300px;height:auto;aspect-ratio:1/1;object-fit:cover;border-radius:var(--r);box-shadow:var(--shadow-sm);transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s cubic-bezier(.22,1,.36,1);}
.portrait:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
@media(max-width:760px){.portrait{max-width:240px;}}
/* About intro: portrait + narrative side by side */
.about-intro{display:flex;gap:clamp(1.6rem,4vw,3rem);align-items:flex-start;margin:1.8rem 0 2.8rem;}
.about-intro .portrait{flex:0 0 240px;width:240px;max-width:240px;grid-column:auto;grid-row:auto;margin:0.38rem 0 0;}
.about-intro .about-narrative{flex:1 1 auto;min-width:0;max-width:30rem;font-family:var(--serif);font-size:clamp(1.03125rem,0.82rem + 0.7vw,1.15625rem);line-height:1.5;color:var(--ink);}
.about-intro .about-narrative em{font-style:italic;}
@media(max-width:700px){.about-intro{flex-direction:column;}.about-intro .portrait{flex-basis:auto;margin-top:0;}}
/* About resume: clear visual hierarchy, 1.5 spacing */
.prose.resume{line-height:1.5;}
.resume h2{margin-top:2.9rem;}
.resume-entry{margin:1.4rem 0 2rem;}
.resume-role{font-family:var(--display);font-weight:600;font-size:1.4rem;line-height:1.2;letter-spacing:-0.01em;color:var(--ink);}
.resume-org{color:var(--ink-soft);margin-top:0.25rem;}
.resume-date{font-family:var(--sans);font-size:0.76rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-faint);margin-top:0.45rem;}
.resume-label{font-family:var(--sans);font-size:0.72rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--green);margin:1.35rem 0 0.55rem;}
.resume-line{margin-top:0.55rem;}
.resume .resume-entry>p{margin:0.6rem 0 0;}
.resume .resume-entry ul{margin:0.5rem 0 0 1.2rem;}
.resume .resume-entry li{margin-bottom:0.45rem;}

/* FOOTER */
footer{border-top:1px solid var(--rule);margin-top:clamp(3rem,6vw,5rem);padding-block:clamp(2.6rem,5vw,4rem);}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem;}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr;gap:2.2rem;}}
.foot-brand{font-family:var(--display);font-weight:600;font-size:1.3rem;}
.foot-brand span{color:var(--brass);}
.foot-tag{font-family:var(--serif);font-size:0.96rem;color:var(--ink-soft);margin-top:0.7rem;max-width:30ch;}
.foot-col h4{font-family:var(--sans);font-size:0.86rem;font-weight:600;letter-spacing:0.13em;text-transform:uppercase;color:var(--green);margin-bottom:1.1rem;}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:0.6rem;}
.foot-col a{font-family:var(--sans);font-size:0.92rem;color:var(--ink-soft);transition:color .25s ease;}
.foot-col a:hover{color:var(--green);}
.foot-base{margin-top:clamp(2.4rem,5vw,3.4rem);padding-top:1.6rem;border-top:1px solid var(--rule);text-align:center;}
.foot-base p{font-family:var(--sans);font-size:0.76rem;color:var(--ink-faint);max-width:74ch;margin-inline:auto;line-height:1.6;}

/* MOTION */
@keyframes rise{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}
.load{opacity:0;animation:rise .8s cubic-bezier(.22,1,.36,1) forwards;}
.d1{animation-delay:.04s;}.d2{animation-delay:.12s;}.d3{animation-delay:.2s;}
.d4{animation-delay:.28s;}.d5{animation-delay:.36s;}.d6{animation-delay:.44s;}
.reveal{opacity:0;transform:translateY(14px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1);}
.reveal.is-visible{opacity:1;transform:translateY(0);}
.reveal.stagger>*{opacity:0;transform:translateY(12px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);}
.reveal.stagger.is-visible>*{opacity:1;transform:translateY(0);}
.reveal.stagger.is-visible>*:nth-child(2){transition-delay:.05s;}
.reveal.stagger.is-visible>*:nth-child(3){transition-delay:.1s;}
.reveal.stagger.is-visible>*:nth-child(4){transition-delay:.15s;}
.reveal.stagger.is-visible>*:nth-child(5){transition-delay:.2s;}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;}
  .load,.reveal,.reveal.stagger>*{opacity:1!important;transform:none!important;}
  .seg{opacity:1!important;}
}

/* ARTICLE PAGE */
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--green);z-index:200;transition:width .12s linear;}
.article-wrap{max-width:1080px;margin-inline:auto;padding-inline:var(--gutter);}
.breadcrumb{font-family:var(--sans);font-size:0.72rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-faint);margin-top:clamp(2rem,5vw,3.2rem);display:flex;gap:0.6rem;flex-wrap:wrap;}
.breadcrumb a{color:var(--green);}
.breadcrumb .sep{color:var(--rule-strong);}
.article-head{position:static;z-index:auto;background:none;border-bottom:0;box-shadow:none;scroll-margin-top:96px;}
.article-head h1{font-family:var(--display);font-weight:400;font-size:clamp(2.3rem,4.6vw,3.5rem);line-height:1.07;letter-spacing:-0.022em;margin-top:1.1rem;color:var(--green);}
.article-meta{display:flex;gap:1.4rem;flex-wrap:wrap;align-items:center;font-family:var(--sans);font-size:0.8rem;font-weight:500;letter-spacing:0.04em;color:var(--ink-faint);margin-top:1.4rem;padding-bottom:1.6rem;border-bottom:1px solid var(--rule);}
.share-btn,.contact-btn{display:inline-flex;align-items:center;gap:0.42rem;font-family:var(--sans);font-size:0.76rem;font-weight:500;letter-spacing:0.04em;color:var(--green);background:none;border:1px solid var(--rule-strong);border-radius:999px;padding:0.34rem 0.85rem;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease;}
.share-btn{margin-left:auto;}
@media(max-width:760px){.share-btn{margin-left:0;}}
.share-btn:hover,.contact-btn:hover{background:var(--green);color:var(--paper);border-color:var(--green);}
.share-btn svg,.contact-btn svg{width:14px;height:14px;flex-shrink:0;}
.seg{}
.tldr{background:var(--card);border:1px solid var(--rule);border-left:5px solid var(--green);padding:1.5rem 1.7rem;border-radius:var(--r);margin:2rem 0;}
.tldr .lbl{font-family:var(--sans);font-weight:500;font-size:0.68rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--green);}
.tldr p{font-family:var(--serif);font-size:1.08rem;line-height:1.55;color:var(--ink);margin-top:0.6rem;}
.prose{font-family:var(--serif);font-weight:400;font-size:clamp(1.03125rem,0.82rem + 0.7vw,1.15625rem);line-height:2;color:var(--ink);counter-reset:faq;}
/* FAQ as aligned, numbered Q:/A: rows (number | label | hanging text) */
.faq-q,.faq-a{display:grid;grid-template-columns:2.4em 1.7em 1fr;align-items:baseline;text-align:left;text-indent:0;}
.faq-q{counter-increment:faq;margin-top:1.6rem;}
.faq-q::before{content:counter(faq) ".";font-family:var(--display);font-weight:600;color:var(--green);}
.faq-a::before{content:"";}
.faq-a{margin-top:0.5rem;}
.faq-lbl{font-weight:600;}
.faq-q .faq-tx{font-weight:600;}
.prose h2{font-family:var(--display);font-weight:400;font-size:clamp(1.7rem,3vw,2.4rem);letter-spacing:-0.018em;line-height:1.18;margin:2.9rem 0 1rem;color:var(--green);scroll-margin-top:96px;}
.prose h3{font-family:var(--display);font-weight:400;font-size:1.55rem;margin:2.1rem 0 0.7rem;color:var(--green);scroll-margin-top:96px;}
.prose p{margin-bottom:1.15rem;text-align:justify;hyphens:auto;}
.prose p.indent{text-indent:1.6em;}
.prose ul.indent,.prose ol.indent{margin-left:1.6em;}
.prose blockquote{margin:0;}
.prose hr{display:none;}
.prose a{color:var(--brass-link);border-bottom:1px solid rgba(130,97,43,0.5);transition:border-color .25s ease,background .25s ease;}
.prose a:hover{border-color:var(--brass-link);background:rgba(130,97,43,0.12);}
/* Internal cross-references to other guides are GREEN and distinct from the gold external citations. */
.prose a[href^="/"]{color:var(--green);border-bottom-color:rgba(31,71,51,0.45);}
.prose a[href^="/"]:hover{border-color:var(--green);background:rgba(31,71,51,0.10);}
.prose ul,.prose ol{margin:0 0 1.2rem 1.3rem;}
.prose li{margin-bottom:0.5rem;}
.prose strong{font-weight:600;}
.prose table{border-collapse:collapse;width:100%;margin:2rem 0;font-family:var(--serif);line-height:1.55;}
.prose th,.prose td{border:1px solid var(--rule-strong);padding:0.72rem 0.95rem;text-align:left;vertical-align:top;}
.prose th{background:var(--card);font-weight:600;color:var(--ink);}
.callout{background:var(--card);border:1px solid var(--rule);border-radius:var(--r);padding:1.5rem 1.7rem;margin:1.9rem 0;}
.callout .lbl{font-family:var(--sans);font-weight:500;font-size:0.68rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--green);margin-bottom:0.7rem;}
.callout ul{margin:0 0 0 1.1rem;font-family:var(--sans);font-size:1rem;}.callout li{margin-bottom:0.5rem;}
.faq{padding-left:2.4rem;}@media(max-width:640px){.faq{padding-left:0;}}
.faq>h2{font-family:var(--display);font-weight:400;font-size:clamp(1.7rem,3vw,2.4rem);letter-spacing:-0.015em;margin:2.9rem 0 0.4rem;}
.faq dt{font-family:var(--display);font-size:1.34rem;margin-top:1.6rem;}
.faq dd{font-family:var(--serif);font-size:1.18rem;color:var(--ink-soft);margin-top:0.5rem;line-height:1.9;}
.article-cta{background:var(--green);color:var(--paper);padding:clamp(1.8rem,4vw,2.6rem);border-radius:var(--r-lg);margin:3rem 0;}
.article-cta .kicker{color:var(--brass-light);font-size:0.86rem;letter-spacing:0.16em;}
.article-cta h3{font-family:var(--display);font-weight:400;font-size:1.6rem;color:var(--paper);margin-top:0.5rem;}
.article-cta p{font-family:var(--sans);font-size:0.95rem;color:rgba(244,241,233,0.72);margin-top:0.5rem;}
.author-bio{border-top:1px solid var(--rule);margin-top:2.5rem;padding-top:1.6rem;font-family:var(--sans);font-size:0.86rem;color:var(--ink-faint);line-height:1.6;}
.author-bio a{color:var(--green);}

/* PILLAR LIBRARY PAGE (legacy) */
.pillar-hero{padding-top:clamp(2.2rem,5vw,3.6rem);padding-bottom:clamp(2rem,4vw,3rem);border-bottom:1px solid var(--rule);}
.pillar-hero .num{font-family:var(--sans);font-weight:500;font-size:0.74rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--brass);}
.pillar-hero h1{font-family:var(--display);font-weight:400;font-size:clamp(2.4rem,5.4vw,4.2rem);letter-spacing:-0.024em;line-height:1.0;margin-top:0.7rem;}
.pillar-hero .intro{font-family:var(--serif);font-size:clamp(1.1rem,1.7vw,1.32rem);color:var(--ink-soft);max-width:62ch;margin-top:1.4rem;line-height:1.5;}
.pillar-hero .count{font-family:var(--sans);font-weight:500;font-size:0.74rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-faint);margin-top:2.8rem;}
.subhead{font-family:var(--sans);font-weight:500;font-size:0.72rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--brass);margin:2.8rem 0 1.4rem;display:flex;align-items:center;gap:1rem;}
.subhead::after{content:"";flex:1;height:1px;background:var(--rule);}
.post-row{position:relative;display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:baseline;padding:1.4rem 1rem;border-radius:var(--r);transition:background-color .3s ease;}
.post-row:hover{background:var(--card);}
.post-row h3{font-family:var(--display);font-weight:400;font-size:1.35rem;letter-spacing:-0.01em;line-height:1.18;transition:transform .4s cubic-bezier(.22,1,.36,1);}
.post-row:hover h3{transform:translateX(6px);color:var(--green);}
.post-row p{font-family:var(--sans);font-size:0.92rem;color:var(--ink-soft);margin-top:0.4rem;transition:transform .4s cubic-bezier(.22,1,.36,1);}
.post-row:hover p{transform:translateX(6px);}
.post-row .rmeta{font-family:var(--sans);font-size:0.72rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-faint);white-space:nowrap;}
.post-row:hover .rmeta{color:var(--green);}

/* Article diagram figures (interim treatment; true SVG render is a later pass) */
.diagram{margin:2rem 0;padding:1.3rem 1.5rem;background:var(--card);border:1px solid var(--rule);border-left:3px solid var(--brass);border-radius:var(--r-sm);}
.diagram .diagram-tag{display:block;font-family:var(--sans);font-size:0.7rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--brass);margin-bottom:0.5rem;}
.diagram figcaption{font-family:var(--serif);font-size:1.02rem;line-height:1.55;color:var(--ink-soft);}

/* Article table of contents: a normal article heading + a normal article list (no boxes, no dividers, never Untitled) */
.article-toc{margin:2.6rem 0;}
.article-toc h2{font-family:var(--display);font-weight:400;font-size:clamp(1.7rem,3vw,2.4rem);letter-spacing:-0.018em;line-height:1.18;margin:0 0 1rem;color:var(--green);}
.article-toc ul{list-style:disc;margin:0 0 1.2rem 1.3rem;padding:0;font-family:var(--serif);}
.article-toc li{margin-bottom:0.5rem;line-height:1.9;}
.article-toc a{color:var(--ink);border-bottom:0;}
.article-toc a:hover{text-decoration:underline;background:none;}

/* Article-page nav sections in green (TOC label, This topic in other states, Related guides) */
.article-wrap .subhead{color:var(--green);}
.article-wrap .post-row h3{color:var(--green);}

/* Sitemap page: links are navigation, not citations -> black with a plain underline (not gold) */
.prose.sitemap-index a{color:var(--ink);border-bottom:1px solid rgba(20,20,15,0.35);}
.prose.sitemap-index a:hover{color:var(--green);border-color:var(--green);background:none;}
