/* ============================================================
   TÓTH László — redesign system
   Dark = "Quiet Garden"  ·  Light = "Field Notes"
   ============================================================ */

@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:800;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:800;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/jetbrains-mono-400-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/jetbrains-mono-400-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/jetbrains-mono-400-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/jetbrains-mono-400-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Spectral';font-style:italic;font-weight:400;font-display:swap;src:url('/assets/fonts/spectral-400-italic-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Spectral';font-style:italic;font-weight:400;font-display:swap;src:url('/assets/fonts/spectral-400-italic-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Spectral';font-style:italic;font-weight:500;font-display:swap;src:url('/assets/fonts/spectral-500-italic-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Spectral';font-style:italic;font-weight:500;font-display:swap;src:url('/assets/fonts/spectral-500-italic-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Spectral';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/spectral-400-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Spectral';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/spectral-400-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Spectral';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/spectral-500-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Spectral';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/spectral-500-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Spectral';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/spectral-600-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Spectral';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/spectral-600-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}

/* ---------- tokens ---------- */
:root{
  --serif:"Spectral",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --maxw:860px;
  --nav-maxw:1180px;
  --read:720px;
  --r:10px;
  --ease:cubic-bezier(.4,0,.2,1);
}

/* dark — Quiet Garden (default) */
html[data-theme="dark"]{
  --bg:#1b1a1e;
  --bg-2:#1f1d22;
  --surface:#26242b;
  --surface-2:#2c2a31;
  --line:rgba(255,255,255,.10);
  --line-soft:rgba(255,255,255,.06);
  --ink:#ececee;
  --dim:#a4a3aa;
  --faint:#76757c;
  --accent:#6fc191;
  --accent-ink:#0f2419;
  --gold:#e0b341;
  --mark-a:#ff4d8d;
  --mark-b:#2dd4d4;
  --shadow:0 30px 70px rgba(0,0,0,.5);
  color-scheme:dark;
  /* legacy custom.css bridge */
  --color-bg-main:#1b1a1e;
  --color-bg-sub:#26242b;
  --color-text-main:#ececee;
  --color-text-sub:#a4a3aa;
  --color-text-link:#6fc191;
  --color-border-dark:#ececee;
  --color-border:rgba(255,255,255,.10);
  --color-border-light:rgba(255,255,255,.06);
}

/* light — Field Notes */
html[data-theme="light"]{
  --bg:#f4f0e7;
  --bg-2:#efeade;
  --surface:#ece6d8;
  --surface-2:#e6dfce;
  --line:#d9d1c0;
  --line-soft:#e3dccb;
  --ink:#23211c;
  --dim:#5f5a4f;
  --faint:#8d8779;
  --accent:#3f7a4e;
  --accent-ink:#fff;
  --gold:#b6852a;
  --mark-a:#ff4d8d;
  --mark-b:#2dd4d4;
  --shadow:0 24px 60px rgba(60,46,30,.16);
  color-scheme:light;
  /* legacy custom.css bridge */
  --color-bg-main:#f4f0e7;
  --color-bg-sub:#ece6d8;
  --color-text-main:#23211c;
  --color-text-sub:#5f5a4f;
  --color-text-link:#3f7a4e;
  --color-border-dark:#23211c;
  --color-border:#d9d1c0;
  --color-border-light:#e3dccb;
}

*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:18px;line-height:1.65;
  -webkit-font-smoothing:antialiased;
  transition:background .35s var(--ease),color .35s var(--ease);
  min-height:100vh;display:flex;flex-direction:column;
}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none;transition:color .15s}
a:hover{text-decoration:underline;text-underline-offset:3px}

.mono{font-family:var(--mono)}
.serif{font-family:var(--serif)}
.label{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.dim{color:var(--dim)}

/* ---------- layout ---------- */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 40px}
.read{max-width:var(--read);margin:0 auto;padding:0 40px}
main{flex:1;width:100%}
.section{margin-top:56px}
.static-content .section{margin-top:16px}
.static-content .section~.section{margin-top:48px}
section[id]{scroll-margin-top:70px}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 86%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft)}
.nav-in{max-width:var(--nav-maxw);margin:0 auto;padding:18px 40px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:18px;letter-spacing:.01em;color:var(--ink);white-space:nowrap}
.brand:hover{text-decoration:none}
.brand .light{font-weight:500;color:var(--dim)}
.mark{width:30px;height:30px;border-radius:50%;flex:0 0 auto;background:linear-gradient(128deg,var(--mark-a) 0%,var(--mark-a) 46%,var(--mark-b) 54%,var(--mark-b) 100%)}
.menu{display:flex;align-items:center;gap:24px;font-size:15px}
.menu a{color:var(--dim)}
.menu a.active{color:var(--ink);font-weight:600}
.menu a:hover{color:var(--ink);text-decoration:none}
.menu .has{position:relative}
.menu .has>span:first-child{cursor:default;color:var(--dim)}
.dropdown{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(6px);background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:8px;min-width:170px;display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;transition:.18s var(--ease);box-shadow:var(--shadow)}
.menu .has:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown a{padding:8px 12px;border-radius:7px;font-size:14px;color:var(--dim)}
.dropdown a:hover{background:var(--surface-2);color:var(--ink)}
.theme-btn{appearance:none;background:none;border:1px solid var(--line);width:34px;height:34px;border-radius:50%;cursor:pointer;color:var(--dim);display:grid;place-items:center;flex:0 0 auto;transition:.18s}
.theme-btn:hover{color:var(--ink);border-color:var(--ink)}
.theme-btn svg{width:17px;height:17px}
.theme-btn .moon{display:none}
html[data-theme="light"] .theme-btn .sun{display:none}
html[data-theme="light"] .theme-btn .moon{display:block}
.burger{display:none;appearance:none;background:none;border:1px solid var(--line);border-radius:8px;width:36px;height:34px;cursor:pointer;color:var(--ink)}

/* ---------- page head ---------- */
.crumb{display:inline-flex;gap:8px;align-items:center;margin-bottom:30px}
.crumb a{color:var(--accent)}
.page-head{padding:40px 0 10px}
h1.title{font-family:var(--serif);font-weight:500;font-size:64px;line-height:.95;letter-spacing:-.02em}
h1.title em{font-style:italic;color:var(--accent)}
.lede{font-family:var(--serif);font-size:22px;line-height:1.5;color:var(--dim);max-width:60ch;margin-top:18px}
.head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap}
.head-aside{font-size:14px;color:var(--faint);line-height:1.9;text-align:right}
.head-aside b{color:var(--ink)}
.head-aside .aside-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em;display:block}

/* ---------- section header ---------- */
.shead{display:flex;align-items:baseline;gap:14px;padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:26px}
.shead h2{font-family:var(--serif);font-style:italic;font-size:24px;font-weight:500;color:var(--ink)}
.shead .num{margin-left:auto;font-family:var(--mono);font-size:12px;color:var(--faint)}
.shead .more{margin-left:auto;font-size:13px}

/* ---------- pills / chips ---------- */
.pill{border:1px solid var(--line);border-radius:999px;padding:5px 13px;font-size:12.5px;color:var(--dim);display:inline-flex;gap:7px;align-items:center}
.dot{width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px color-mix(in srgb,var(--gold) 18%,transparent)}
.dot.live{background:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 18%,transparent)}
.chip{appearance:none;cursor:pointer;font-family:var(--mono);font-size:12.5px;border:1px solid var(--line);background:none;color:var(--dim);border-radius:999px;padding:6px 13px;display:inline-flex;align-items:center;gap:6px;transition:.15s}
.chip:hover{color:var(--ink);border-color:var(--ink)}
.chip.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--surface);color:var(--ink);padding:10px 18px;border-radius:999px;font-weight:600;font-size:14px;cursor:pointer;transition:.15s}
.btn:hover{text-decoration:none;border-color:var(--ink);transform:translateY(-1px)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}

/* ---------- inputs ---------- */
.search{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:15px 18px;color:var(--ink);font-family:var(--sans);font-size:16px}
.search::placeholder{color:var(--faint)}
.search:focus{outline:none;border-color:var(--accent)}

/* ---------- blog post list ---------- */
.posts{margin-top:8px}
.posts-list{margin-top:16px}
.post{display:flex;align-items:baseline;justify-content:space-between;gap:24px;padding:17px 0;color:var(--ink);text-decoration:none}
.post:hover{text-decoration:none}
.post-title{font-family:var(--serif);font-size:19px;font-weight:400;color:var(--accent);transition:opacity .15s}
.post:hover .post-title{opacity:.75}
.post .when{font-family:var(--mono);font-size:12px;color:var(--faint);white-space:nowrap;flex-shrink:0}
.post-flat{display:grid;grid-template-columns:32px 1fr;gap:14px;align-items:baseline;border-bottom:1px solid var(--line-soft);padding:14px 0}
.post-flat:last-child{border-bottom:0}
.post-flat:first-child{padding-top:0}
.post-idx{font-family:var(--mono);font-size:11px;color:var(--faint);padding-top:3px}
.posts-indexed .post-title{color:var(--ink);transition:color .15s}
.post-flat:hover .post-title{color:var(--accent)}

/* ---------- note / list cards ---------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:0 48px}
.entry{display:block;padding:22px 0;border-bottom:1px solid var(--line-soft);color:var(--ink)}
.entry:hover{text-decoration:none}
.entry h3{font-family:var(--serif);font-size:22px;font-weight:600;line-height:1.2;margin-bottom:6px;transition:color .15s}
.entry:hover h3{color:var(--accent)}
.entry p{font-size:15.5px;color:var(--dim);line-height:1.55}
.entry .meta{margin-top:10px}

/* ---------- generic cards ---------- */
.cardgrid{display:grid;gap:18px}
.card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r);padding:24px;transition:.18s var(--ease);color:var(--ink);display:block}
a.card:hover{text-decoration:none;border-color:var(--line);transform:translateY(-3px);box-shadow:var(--shadow)}
.card h3{font-family:var(--serif);font-size:21px;font-weight:600;margin-bottom:6px}
.card .sub{color:var(--faint);font-size:13.5px}
.card p{color:var(--dim);font-size:15px;margin-top:8px}
.stars{color:var(--gold);letter-spacing:2px;font-size:13px}

/* ---------- code ---------- */
.code{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:var(--r);padding:18px 20px;font-family:var(--mono);font-size:14px;line-height:1.85;color:var(--dim);overflow:auto;white-space:pre}
.code .k{color:var(--mark-a)}
.code .v{color:var(--accent)}
.code .s{color:#ff8a5b}

/* ---------- inline article body ---------- */
.prose p{color:var(--dim);margin:18px 0}
.prose h2{font-family:var(--serif);font-size:30px;font-weight:600;margin:42px 0 6px;color:var(--ink)}
.prose h3{font-family:var(--serif);font-size:22px;margin:30px 0 4px}
.prose ul{margin:18px 0 18px 22px;color:var(--dim)}
.prose li{margin:6px 0}
.prose blockquote{border-left:2px solid var(--accent);padding-left:20px;margin:24px 0;font-family:var(--serif);font-style:italic;font-size:21px;color:var(--ink)}
.prose code{font-family:var(--mono);font-size:.86em;background:var(--surface);border:1px solid var(--line-soft);border-radius:5px;padding:1px 6px}
.prose strong{color:var(--ink);font-weight:600}

/* ---------- note single page ---------- */
.note-head{padding:48px 0 16px}
.note-head .crumb{margin-bottom:20px}
.note-head h1{font-family:var(--serif);font-size:42px;font-weight:600;line-height:1.15;margin-bottom:12px}
.note-meta{font-family:var(--mono);font-size:12px;color:var(--faint);margin-bottom:32px}
.note-body{padding-bottom:80px}

/* ---------- photo placeholders ---------- */
.ph{background:
  repeating-linear-gradient(45deg,transparent 0 11px,color-mix(in srgb,var(--ink) 4%,transparent) 11px 22px),
  var(--surface);
  border:1px solid var(--line-soft);display:flex;align-items:center;justify-content:center;color:var(--faint);overflow:hidden}
.ph .label{background:color-mix(in srgb,var(--bg) 70%,transparent);padding:4px 10px;border-radius:5px}

/* ---------- hero (homepage) ---------- */
.hero{padding-top:70px;padding-bottom:60px}
.hero h1{font-family:var(--serif);font-weight:500;font-size:88px;line-height:.95;letter-spacing:-.025em}
.hero .role{font-size:22px;color:var(--dim);margin-top:10px;font-family:var(--serif)}
.hero .loc{display:inline-flex;align-items:center;gap:8px;margin-top:18px;color:var(--faint);font-size:15px}
.hero .intro{margin-top:34px;max-width:60ch}
.hero .intro p{color:var(--dim);font-size:19px}
.hero .intro p+p{margin-top:16px}
.now-strip{margin-top:28px;display:inline-flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line-soft);border-radius:999px;padding:8px 8px 8px 16px;font-size:14px;color:var(--ink)}
.now-strip:hover{text-decoration:none;border-color:var(--line)}
.now-strip .label{color:var(--dim)}
.now-strip b{color:var(--ink);font-weight:600}

/* ---------- socials ---------- */
.socials{display:flex;gap:12px;margin-top:24px}
.socials a{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink)}
.socials a:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}
.socials svg{width:18px;height:18px}

/* ---------- footer ---------- */
.foot{border-top:1px solid var(--line-soft);margin-top:90px}
.foot-in{max-width:var(--nav-maxw);margin:0 auto;padding:30px 40px;text-align:center}
.foot-in .links{display:flex;gap:20px;justify-content:center;margin-bottom:14px;flex-wrap:wrap}
.foot-in .links a{color:var(--dim);font-size:14px}
.foot-in .links a:hover{color:var(--ink);text-decoration:none}
.foot-in .copy{font-family:var(--mono);font-size:12.5px;color:var(--faint)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- static / note content body ---------- */
.content-body{padding:24px 0 60px}
.static-content.content-body{padding-top:8px}
.content-body h1{font-family:var(--serif);font-size:36px;font-weight:600;margin:40px 0 8px}
.content-body h2{font-family:var(--serif);font-size:28px;font-weight:600;margin:36px 0 8px}
.content-body h3{font-family:var(--serif);font-size:22px;font-weight:500;margin:28px 0 6px}
.content-body p{color:var(--dim);margin:14px 0;line-height:1.7}
.content-body ul,.content-body ol{margin:14px 0 14px 22px;color:var(--dim)}
.content-body li{margin:6px 0}
.content-body a{color:var(--accent)}
.content-body blockquote{border-left:2px solid var(--accent);padding-left:20px;margin:20px 0;font-family:var(--serif);font-style:italic;font-size:19px;color:var(--ink)}
.content-body code{font-family:var(--mono);font-size:.86em;background:var(--surface);border:1px solid var(--line-soft);border-radius:5px;padding:1px 6px}
.content-body pre{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:var(--r);padding:18px 20px;font-family:var(--mono);font-size:14px;line-height:1.75;overflow:auto;margin:20px 0}
.content-body pre code{background:none;border:none;padding:0}

/* ---------- syntax highlighting (Rouge) ---------- */
.highlight .c,.highlight .c1,.highlight .cm,.highlight .cs{color:#6a9a6a;font-style:italic}
.highlight .cp{color:#c586c0;font-style:italic}
.highlight .k,.highlight .kd,.highlight .kc,.highlight .kr,.highlight .kp{color:#569cd6;font-weight:500}
.highlight .kn{color:#c586c0;font-weight:500}
.highlight .kt{color:#4ec9b0}
.highlight .s,.highlight .s1,.highlight .s2,.highlight .sb,.highlight .sc,.highlight .sd,.highlight .se,.highlight .sh,.highlight .si,.highlight .sx,.highlight .ss{color:#ce9178}
.highlight .sr{color:#d16969}
.highlight .m,.highlight .mf,.highlight .mh,.highlight .mi,.highlight .mo,.highlight .il{color:#b5cea8}
.highlight .nf,.highlight .nl{color:#dcdcaa}
.highlight .nc{color:#4ec9b0}
.highlight .na{color:#9cdcfe}
.highlight .nb{color:#4ec9b0}
.highlight .nt{color:#569cd6}
.highlight .nv,.highlight .vc,.highlight .vg,.highlight .vi{color:#9cdcfe}
.highlight .no{color:#9cdcfe}
.highlight .nd{color:#dcdcaa}
.highlight .o,.highlight .ow{color:var(--dim)}
.highlight .n,.highlight .nx,.highlight .nn{color:var(--ink)}
.highlight .err{color:#f44747}
.highlight .gd{color:#f44747}
.highlight .gi{color:var(--accent)}
.content-body strong{color:var(--ink);font-weight:600}
.content-body img{border-radius:var(--r);margin:20px 0}
.content-body table{width:100%;border-collapse:collapse;margin:20px 0;font-size:15px}
.content-body th,.content-body td{padding:10px 14px;border-bottom:1px solid var(--line-soft);text-align:left}
.content-body th{color:var(--ink);font-weight:600}
.content-body td{color:var(--dim)}

/* ---------- static page section headers (About, Now, Uses, Projects) ---------- */
.static-content{counter-reset:section}
.static-content>h2,.static-content>h2+*~h2{counter-increment:section}
.static-content>h2{
  counter-increment:section;
  display:flex;align-items:baseline;gap:14px;
  padding-bottom:16px;border-bottom:1px solid var(--line);
  margin:56px 0 28px;
  font-family:var(--serif);font-style:italic;font-size:24px;font-weight:500;color:var(--ink);
}
.static-content>h2::after{
  content:counter(section,decimal-leading-zero);
  margin-left:auto;font-family:var(--mono);font-size:12px;color:var(--faint);font-style:normal;letter-spacing:.04em;
}
.static-content>h3{font-family:var(--serif);font-size:20px;font-weight:600;margin:28px 0 6px;color:var(--ink)}
.static-content>p{color:var(--dim);margin:12px 0;line-height:1.7}
.static-content>ul,.static-content>ol{margin:12px 0 12px 22px;color:var(--dim)}
.static-content li{margin:6px 0;color:var(--dim)}
.static-content a{color:var(--accent)}
.static-content strong{color:var(--ink);font-weight:600}
.static-content blockquote{border-left:2px solid var(--accent);padding-left:20px;margin:20px 0;font-family:var(--serif);font-style:italic;font-size:19px;color:var(--ink)}
.static-content code{font-family:var(--mono);font-size:.86em;background:var(--surface);border:1px solid var(--line-soft);border-radius:5px;padding:1px 6px}
.static-content pre{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:var(--r);padding:18px 20px;font-family:var(--mono);font-size:14px;line-height:1.75;overflow:auto;margin:20px 0}
.static-content pre code{background:none;border:none;padding:0}
.static-content table{width:100%;border-collapse:collapse;margin:16px 0;font-size:15px}
.static-content th,.static-content td{padding:10px 14px;border-bottom:1px solid var(--line-soft);text-align:left}
.static-content th{color:var(--ink);font-weight:600}
.static-content td{color:var(--dim)}
.static-content img:not(.portrait){border-radius:var(--r);margin:12px 0;max-height:28px;width:auto}

/* ---------- now page live indicator ---------- */
.now-meta{display:flex;align-items:center;gap:14px;margin:20px 0 32px;flex-wrap:wrap}
.now-meta .pill{font-size:12px}
.now-meta .loc-tag{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.now-meta .date-tag{font-family:var(--mono);font-size:11px;color:var(--faint)}

/* ---------- post/note meta tags ---------- */
.meta-tags{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:10px}
.meta-tag{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);background:var(--surface);border:1px solid var(--line-soft);border-radius:5px;padding:2px 8px}

/* ---------- skills as chips (About) ---------- */
.skills img{display:none}
.skill-chip{display:inline-flex;align-items:center;font-family:var(--mono);font-size:12px;border:1px solid var(--line);color:var(--dim);border-radius:999px;padding:4px 12px;margin:3px 4px 3px 0;background:none}

/* ---------- uses page overrides ---------- */
.uses-cat-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r);overflow:hidden;margin-bottom:1.5rem}
.uses-cat-header{display:flex;align-items:center;gap:0.55rem;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:500;color:var(--faint);padding:14px 20px;background:none;border-bottom:1px solid var(--line-soft)}
.uses-cat-info{font-size:13px;color:var(--faint);padding:10px 20px;border-bottom:1px solid var(--line-soft)}
.uses-cat-rows{display:flex;flex-direction:column}
.uses-cat-row{display:flex;align-items:flex-start;gap:14px;padding:16px 20px;border-bottom:1px solid var(--line-soft);transition:background .15s}
.uses-cat-rows .uses-cat-row:last-child{border-bottom:none}
.uses-cat-row:hover{background:var(--surface-2)}
.uses-cat-row-icon{opacity:.4;font-size:.95rem;flex-shrink:0;min-width:18px;text-align:center;margin-top:2px;color:var(--dim)}
.uses-cat-row-body{flex:1;display:flex;flex-direction:column;gap:3px}
.uses-cat-row-sublabel{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.uses-cat-row-name{font-size:15px;font-weight:600;color:var(--ink)}
.uses-cat-row-note{font-size:13.5px;color:var(--dim);line-height:1.5}
.uses-item-link{color:var(--ink)!important;text-decoration:none!important}
.uses-item-link:hover{color:var(--accent)!important;text-decoration:none!important}
.uses-ext-icon{font-size:.6rem;margin-left:4px;opacity:.5;vertical-align:middle}

/* ---------- experience / project entries overrides ---------- */
.flex-container{display:flex;gap:32px;padding:24px 0;border-bottom:1px solid var(--line-soft);margin-top:0!important;flex-wrap:wrap}
.flex-container .data{flex:0 0 200px;min-width:0}
.flex-container .data .maintitle{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);margin-bottom:4px}
.flex-container .data .subtitle{font-size:14px;font-weight:400;color:var(--dim);margin-bottom:2px}
.flex-container .data .other{font-family:var(--mono);font-size:12px;color:var(--faint);font-style:normal;margin-bottom:0}
.flex-container .data a{color:var(--dim);font-size:13px}
.flex-container .data a:hover{color:var(--accent)}
.flex-container .data a[href^="http"]{background-image:none!important;padding-right:0!important}
.flex-container .details{flex:1;min-width:0;color:var(--dim);font-size:15px;line-height:1.65}
.flex-container .details ul{padding-left:18px;list-style:disc;margin-top:4px}
.flex-container .details li{margin:5px 0;color:var(--dim)}

/* ---------- backlinks ---------- */
.backlinks{margin-top:48px;border-left:2px solid var(--line);padding-left:16px}
.backlinks .bl-label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:10px}
.backlinks .bl-list{display:flex;flex-direction:column;gap:6px}
.backlinks .bl-list a{font-family:var(--sans);font-size:14px;color:var(--dim);text-decoration:none;display:flex;align-items:center;gap:6px;transition:color .15s}
.backlinks .bl-list a::before{content:"←";font-size:11px;color:var(--faint)}
.backlinks .bl-list a:hover{color:var(--accent)}

/* ---------- responsive ---------- */
@media(max-width:860px){
  body{font-size:17px}
  .container,.read{padding:0 22px}
  .nav-in{padding:14px 22px}
  .menu{position:fixed;inset:62px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:var(--bg);border-bottom:1px solid var(--line);padding:8px 22px 18px;transform:translateY(-120%);transition:transform .28s var(--ease);font-size:16px}
  .menu.open{transform:none}
  .menu a{padding:12px 0;border-bottom:1px solid var(--line-soft)}
  .menu .has{padding:12px 0;border-bottom:1px solid var(--line-soft)}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;background:none;padding:8px 0 0 14px;min-width:0}
  .menu .has:hover .dropdown{transform:none}
  .menu .theme-btn{display:none}
  .burger{display:grid;place-items:center}
  h1.title{font-size:44px}
  .lede{font-size:19px}
  .page-head{padding:28px 0 8px}
  .two-col{grid-template-columns:1fr;gap:0}
  .head-aside{text-align:left}
  .section{margin-top:40px}
  .hero h1{font-size:54px}
  .flex-container{flex-direction:column;gap:16px}
  .flex-container .data{flex:none}
  .about-container{flex-direction:column}
  .foot-in{padding:24px 22px}
}

/* ---------- wiki-link tooltips ---------- */
.tooltip{position:relative;display:inline}
.tooltip .right.bottom{
  position:absolute;
  left:0;top:100%;
  margin-top:6px;
  min-width:220px;max-width:300px;
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:var(--r);
  box-shadow:var(--shadow);
  padding:12px 14px;
  z-index:100;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .15s,visibility .15s;
}
.tooltip:hover .right.bottom{opacity:1;visibility:visible}
.tooltip-title{display:block;font-family:var(--sans);font-weight:600;font-size:13px;color:var(--ink);margin-bottom:4px}
.tooltip-excerpt{display:block;font-family:var(--sans);font-size:12px;color:var(--dim);line-height:1.5}
.tooltip i{display:none}
.stale-link{color:var(--faint);cursor:default;text-decoration:none}
.notes-search{display:block;width:100%;box-sizing:border-box;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);padding:8px 12px;font-family:var(--sans);font-size:14px;color:var(--ink);outline:none;margin-bottom:16px;transition:border-color .15s}
.notes-search::placeholder{color:var(--faint)}
.notes-search:focus{border-color:var(--accent)}
.posts-empty{color:var(--faint);margin-top:24px}
.feed-rss-row{text-align:center;margin-top:40px;padding-top:24px;border-top:1px solid var(--line-soft)}
.feed-rss-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);text-decoration:none;transition:color .15s}
.feed-rss-link svg{width:13px;height:13px}
.feed-rss-link:hover{color:var(--accent);text-decoration:none}
