/* paulodevries.com — shared editorial stylesheet (light, Fraunces, rust accent) */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400;1,9..144,500&display=swap');

:root{
  --paper:#f6f3ec; --panel:#efe9dd; --panel2:#e7e0d2;
  --ink:#221f1a; --soft:#6c655a; --faint:#9a9285;
  --rule:rgba(34,31,26,.13); --rule2:rgba(34,31,26,.28);
  --accent:#a8432b;
  --serif:"Fraunces","Iowan Old Style","Charter",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
::selection{background:var(--accent);color:var(--paper)}
body{margin:0;background:var(--paper);color:var(--ink);
     font:18px/1.66 var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
     padding:clamp(30px,7vw,72px) 24px 96px}
.wrap{max-width:660px;margin:0 auto}
a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--rule2);transition:color .15s,border-color .15s}
a:hover{color:var(--accent);border-color:var(--accent)}
a:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}

.back{font-size:.9rem;color:var(--soft);border-bottom:0}
.back:hover{color:var(--accent)}

h1{font-family:var(--serif);font-weight:440;font-optical-sizing:auto;
   font-size:clamp(2rem,5.8vw,2.95rem);line-height:1.07;letter-spacing:-.015em;margin:.5em 0 .3em;text-wrap:balance}
.meta{color:var(--faint);font-size:.86rem;margin:0 0 32px}
.meta a{color:var(--ink)}

article h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.38rem,3.6vw,1.7rem);
           letter-spacing:-.01em;line-height:1.18;margin:1.85em 0 .45em}
article p{margin:0 0 1.1em;color:var(--ink)}
article strong{font-weight:600}
article em{font-style:italic}
article ol,article ul{padding-left:1.2em;margin:0 0 1.2em}
article li{margin:0 0 .7em}

blockquote{margin:1.7em 0;font-family:var(--serif);font-weight:430;font-style:italic;
           font-size:clamp(1.24rem,3.4vw,1.55rem);line-height:1.36;letter-spacing:-.01em;color:var(--ink);
           border-left:2px solid var(--accent);padding:3px 0 3px 22px;max-width:30ch}
blockquote .by{display:block;font-family:var(--sans);font-style:normal;font-size:.8rem;color:var(--faint);margin-top:16px}

/* callout box (essays) */
.box{background:var(--panel);border:1px solid var(--rule);border-radius:12px;padding:20px;margin:1.8em 0}
.box .tag{font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;color:var(--soft);border-bottom:0}
.box .tag::before{content:none}
.box h3{font-family:var(--serif);margin:9px 0 7px;font-size:1.2rem;font-weight:500}
.box h3 a{border-bottom:0}
.box h3 a:hover{color:var(--accent)}
.box p{margin:0 0 12px;color:var(--soft);font-size:.96rem}
.box code{font-family:var(--mono);font-size:.84rem;background:var(--panel2);border:1px solid var(--rule);
          border-radius:7px;padding:7px 11px;display:inline-block;color:var(--ink)}

/* author byline (essays) */
.author{display:flex;align-items:center;gap:14px;margin:48px 0 0;padding:22px 0 0;border-top:1px solid var(--rule)}
.author img{width:52px;height:52px;border-radius:50%;object-fit:cover;border:1px solid var(--rule)}
.author .n{font-weight:600}
.author .n a{border-bottom:0}
.author .r{color:var(--soft);font-size:.88rem;line-height:1.5}

/* tool pages */
.tag{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--soft);
     margin:26px 0 0;display:flex;align-items:center;gap:10px;border-bottom:0}
.tag::before{content:"";width:18px;height:1px;background:var(--accent);flex:0 0 auto}
.lead{font-size:clamp(1.06rem,3.2vw,1.22rem);line-height:1.5;color:var(--soft);margin:0 0 22px;max-width:48ch}
.install{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:0 0 10px}
code.pill{font-family:var(--mono);font-size:.9rem;background:var(--panel2);border:1px solid var(--rule);
          border-radius:8px;padding:10px 14px;color:var(--ink)}
h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.3rem,3.4vw,1.6rem);letter-spacing:-.01em;margin:1.9em 0 .5em}
p{color:var(--ink)}
pre{background:var(--panel);border:1px solid var(--rule);border-radius:12px;padding:18px;overflow:auto;margin:0 0 1.1em}
pre code{font-family:var(--mono);font-size:.84rem;line-height:1.7;color:#34302a}
table{width:100%;border-collapse:collapse;margin:0 0 1.2em;font-size:.94rem}
td{border-top:1px solid var(--rule);padding:10px;vertical-align:top;color:var(--ink)}
td.k{font-family:var(--mono);font-size:.83rem;color:var(--accent);white-space:nowrap}
.pair{display:grid;gap:12px;grid-template-columns:1fr;margin:1.4em 0 0}
@media(min-width:560px){.pair{grid-template-columns:1fr 1fr}}
.pcard{background:var(--panel);border:1px solid var(--rule);border-radius:12px;padding:16px}
.pcard .t{font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--soft)}
.pcard h3{font-family:var(--serif);margin:8px 0 5px;font-size:1.05rem;font-weight:500}
.pcard h3 a{border-bottom:0}
.pcard p{margin:0;color:var(--soft);font-size:.92rem}

footer{margin:46px 0 0;padding-top:20px;border-top:1px solid var(--rule);color:var(--soft);font-size:.86rem}
footer a{color:var(--ink)}
@media(prefers-reduced-motion:reduce){*{transition:none!important}}
