:root{--bg:#fbf6ec;--bg-soft:#f3ecdb;--ink:#1f2733;--ink-soft:#4a5568;--rule:#e3d9c3;--blue-deep:#0b3f6a;--blue:#2674b5;--cyan:#02a5d2;--pale:#e5f2f9;--yellow:#fef5c4;--sage:#789a6f;--maxw:680px}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:Avenir Next,Avenir,Nunito Sans,Helvetica Neue,system-ui,sans-serif;font-weight:400;font-size:18px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:var(--blue-deep);text-decoration:none;border-bottom:1px solid rgba(11,63,106,.25);transition:.2s}a:hover{color:var(--cyan);border-bottom-color:var(--cyan)}h1,h2,h3{font-weight:600;letter-spacing:-.01em;color:var(--ink);line-height:1.25;margin:0}::selection{background:var(--yellow)}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;width:100%}.hl{background:linear-gradient(transparent 60%,var(--yellow) 60%);padding:0 .12em}section.page-hero{padding:48px 0 40px}section.page-hero h1{font-size:42px;letter-spacing:-.02em;margin-bottom:16px}section.page-hero p{font-size:18px;color:var(--ink-soft);max-width:46ch;margin:0;white-space:pre-line}.feature{background:var(--pale);border-radius:16px;padding:28px;display:flex;gap:24px;align-items:center;border:1px solid #d6e7f1;margin-bottom:48px;text-decoration:none;transition:transform .25s,box-shadow .25s,border-color .25s}.feature:hover{transform:translateY(-2px);border-color:var(--cyan);box-shadow:0 18px 36px -22px #02a5d266}.feature .cover{width:140px;height:236px;border-radius:5px;overflow:hidden;flex-shrink:0;background:#f5e9d0;box-shadow:0 14px 34px -10px #0b3f6a73,0 2px 6px #0000000f;display:flex;flex-direction:column;justify-content:space-between;padding:16px 14px;color:#fff}.feature .cover img{width:100%;height:100%;object-fit:cover;display:block;image-rendering:high-quality}.feature .cover.cover-image{padding:0}.feature .cover .cover-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;opacity:.85}.feature .cover .cover-title{font-size:22px;font-weight:700;letter-spacing:-.02em;line-height:1.05}.feature .cover.cover-tis{background:linear-gradient(135deg,#0b3f6a,#1a72b5,#02a5d2)}.feature .cover.cover-ccc{background:linear-gradient(160deg,#0b3f6a,#02a5d2,#fef5c4 110%)}.feature.feature-warm{background:#fff5c4;border-color:#ecdfa1}.feature.feature-warm:hover{border-color:#d6c46a;box-shadow:0 18px 36px -22px #d6c46a8c}.feature .meta small{display:block;font-size:11px;color:var(--blue);font-weight:600;letter-spacing:.16em;text-transform:uppercase;margin-bottom:6px}.feature .meta h3{font-size:22px;margin-bottom:8px;color:var(--ink)}.feature .meta p{margin:0 0 10px;font-size:15px;color:var(--ink-soft);line-height:1.55;white-space:pre-line}.feature .meta .cta{display:inline-block;font-size:14px;font-weight:500;color:var(--blue-deep);border-bottom:1px solid var(--blue-deep);padding-bottom:1px;margin-top:4px}.section-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue-deep);font-weight:600;margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--rule)}.pieces{display:flex;flex-direction:column}.piece{display:block;padding:22px 0;border-bottom:1px solid var(--rule);transition:transform .25s;color:inherit;text-decoration:none;border-bottom-color:var(--rule)}.piece:last-child{border-bottom:none}.piece:hover{transform:translate(4px)}.piece:hover h3{color:var(--blue-deep)}.piece h3{margin-bottom:6px;font-size:19px}.piece p{margin:0;font-size:15.5px;color:var(--ink-soft);white-space:pre-line}.projects{display:grid;grid-template-columns:1fr 1fr;gap:14px}.project{border:1px solid var(--rule);background:#fff;border-radius:12px;padding:18px;display:flex;flex-direction:column;gap:6px;text-decoration:none;transition:.25s;color:inherit}.project:hover{transform:translateY(-2px);border-color:var(--cyan);box-shadow:0 14px 28px -22px #02a5d266}.project h3{font-size:17px;color:var(--ink)}.project p{margin:0;font-size:14.5px;color:var(--ink-soft);line-height:1.5;white-space:pre-line}.project .tag{margin-top:auto;font-size:10.5px;color:var(--cyan);font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding-top:8px}.project .tag.idea{color:var(--ink-soft)}.project .tag.shipped{color:#5a8a3a}footer.site{padding:64px 0 48px;color:var(--ink-soft);font-size:13.5px;border-top:1px solid var(--rule);margin-top:48px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px}@media(max-width:560px){section.page-hero h1{font-size:32px}.feature{flex-direction:column;align-items:flex-start;text-align:left}.feature .cover{width:108px;height:182px}.feature .cover .cover-title{font-size:18px}.projects{grid-template-columns:1fr}}header[data-astro-cid-3ef6ksr2].site{padding:36px 0 12px;display:flex;align-items:center;justify-content:space-between}header[data-astro-cid-3ef6ksr2].site .name[data-astro-cid-3ef6ksr2]{font-weight:600;font-size:16px;letter-spacing:.01em;color:var(--ink);text-decoration:none;border-bottom:none;transition:color .2s}header[data-astro-cid-3ef6ksr2].site .name[data-astro-cid-3ef6ksr2]:hover{color:var(--blue-deep)}header[data-astro-cid-3ef6ksr2].site nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]{margin-left:22px;font-size:14px;color:var(--ink-soft);border-bottom:none;text-transform:lowercase;letter-spacing:.02em;padding-bottom:2px;text-decoration:none;transition:.2s}header[data-astro-cid-3ef6ksr2].site nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]:hover{color:var(--blue-deep)}header[data-astro-cid-3ef6ksr2].site nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2].active{color:var(--blue-deep);border-bottom:1px solid var(--blue-deep)}
