:root{color-scheme:light;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;--bg:#f8f8f8;--surface:#fff;--surface-2:#f8fafc;--text:#0f172a;--muted:#475569;--muted-2:#64748b;--border:#e2e8f0;--border-strong:#cbd5e1;--brand:#2563eb;--brand-hover:#1d4ed8;--shadow-sm:0 8px 24px rgba(15,23,42,.05);--shadow-md:0 12px 32px rgba(0,0,0,.16);--r-lg:16px;--r-md:12px;--r-sm:8px;--container:960px;--nav-h:56px}*{box-sizing:border-box}body,html{height:100%}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}a:focus-visible,button:focus-visible{outline:3px solid rgba(37,99,235,.35);outline-offset:2px}.container{max-width:var(--container);margin:0 auto;padding:80px 16px 48px}@media (max-width:640px){.container{padding:72px 14px 40px}}.nav{z-index:10;min-height:var(--nav-h);padding:12px 20px;background:hsla(0,0%,100%,.9);border-bottom:1px solid var(--border)}.nav-left{gap:16px}.logo{font-weight:700;letter-spacing:.2px}.logo,.nav-actions,.nav-links{font-size:14px}.progress{color:var(--text);font-weight:600}button{font:inherit;cursor:pointer;border:1px solid var(--border-strong);background:var(--surface);border-radius:var(--r-sm);padding:8px 14px;transition:.15s ease}button:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(15,23,42,.08)}button:disabled{cursor:not-allowed;opacity:.6}.primary{background:var(--brand);color:#fff;border-color:var(--brand)}.primary:not(:disabled):hover{background:var(--brand-hover)}.hint{color:var(--muted-2)}.hero{background:var(--surface);padding:32px;border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.hero h1{margin:0 0 12px;letter-spacing:-.2px}.stacked{display:grid;grid-gap:16px;gap:16px}.section{background:var(--surface);padding:24px;border-radius:var(--r-md);border:1px solid var(--border)}.home{display:grid;grid-gap:16px;gap:16px}.section-title{margin:0 0 12px;font-size:18px}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-gap:12px;gap:12px}.card{text-align:left;padding:16px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);transition:.15s ease}.card:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(15,23,42,.1);border-color:rgba(226,232,240,.85)}.card h3{margin:0 0 8px;font-size:16px;letter-spacing:-.1px}.card p{margin:0;color:var(--muted);font-size:14px}.card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.card-tag-pill{display:inline-block;font-size:10px;padding:2px 6px;border-radius:999px;background-color:#e2e8f0;color:#475569;font-weight:500;white-space:nowrap}.card-tag-count{font-style:italic}.tag-filter{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.tag-chip{padding:6px 12px;font-size:13px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;transition:.15s ease}.tag-chip:hover{border-color:var(--brand);color:var(--text)}.tag-chip.active{background:var(--brand);color:#fff;border-color:var(--brand)}.project-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px}.project-card{display:flex;flex-direction:column;gap:6px;padding:16px 18px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-2);transition:.15s ease}.project-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(15,23,42,.1);border-color:rgba(226,232,240,.85)}.project-title{margin:0;font-size:15px;font-weight:600}.project-desc{margin:0;font-size:14px;color:var(--muted)}.project-cta{margin-top:4px;font-size:12px;color:var(--brand)}.project-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.project-tag{display:inline-block;padding:4px 10px;font-size:12px;line-height:1.4;border-radius:999px;border:1px solid rgba(0,0,0,.08);background:rgba(0,0,0,.04);color:#444;white-space:nowrap;transition:all .15s ease}.project-card:hover .project-tag{background:rgba(0,0,0,.06);border-color:rgba(0,0,0,.15)}@media (max-width:640px){.project-grid{grid-template-columns:1fr}}.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.35);display:flex;justify-content:center;align-items:flex-start;padding:calc(var(--nav-h) + 16px) 16px 16px;z-index:40}.modal{border-radius:var(--r-md);padding:20px;max-width:560px;width:100%;box-shadow:var(--shadow-md);max-height:calc(100vh - (var(--nav-h) + 16px) - 32px);overflow-y:auto}.modal,.modal-header{background:var(--surface)}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:8px;position:-webkit-sticky;position:sticky;top:0;padding-bottom:8px;margin-bottom:12px;z-index:1;border-bottom:1px solid rgba(226,232,240,.7)}.modal-header h3{margin:0;font-size:16px}.close{border:none;background:transparent;font-size:18px;padding:4px 8px;border-radius:10px}.close:not(:disabled):hover{background:rgba(15,23,42,.06);transform:none;box-shadow:none}.cta{gap:10px;margin-top:16px}.cta,.status{display:flex;align-items:center}.status{gap:8px;font-size:14px}.pre-line{white-space:pre-line}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.modal-summary{margin:0;font-size:14px;color:#334155}.modal-summary-toggle{margin-top:6px;font-size:12px;padding:4px 8px}.modal-section{margin-top:12px;padding:10px 12px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2)}.modal-section-title{margin:0 0 6px;font-size:13px;font-weight:600;color:var(--text)}.modal-list,.modal-section-body{margin:0;font-size:13px;line-height:1.55;color:var(--muted)}.modal-list{padding-left:20px}.modal-list li+li{margin-top:4px}.logo.is-active{color:var(--brand)}.nav-meta{opacity:.8;font-style:italic}.nav-divider{margin:0 8px;opacity:.4}.mobile-menu a.is-active,.nav a.is-active,.nav-links a.is-active{font-weight:700;color:var(--brand);position:relative}.mobile-menu a.is-active:after,.nav-links a.is-active:after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--brand);border-radius:2px}.nav{position:-webkit-sticky;position:sticky;top:0;z-index:40;justify-content:space-between;flex-wrap:wrap;padding:12px 16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.nav,.nav-left{display:flex;align-items:center;gap:12px}.nav-left{min-width:240px;flex:1 1 auto}.nav-links{align-items:center;gap:12px;flex-wrap:wrap}.nav-links,.nav-links-desktop{display:flex}.nav-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.progress{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;line-height:1}.hint,.progress{font-size:12px;white-space:nowrap}.hint{opacity:.8}.nav-toggle{border-radius:var(--r-sm);padding:8px 10px;font-size:16px;line-height:1}.mobile-menu,.nav-toggle{display:none}@media (max-width:640px){.nav{padding:10px 12px}.nav-left{min-width:0}.nav-links-desktop{display:none}.nav-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:40px}.mobile-menu{display:none;position:-webkit-sticky;position:sticky;top:var(--nav-h);z-index:40;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:0 6px 16px rgba(15,23,42,.08);padding:10px 16px 14px;gap:10px;flex-direction:column}.mobile-menu a{padding:8px 0;font-weight:600;color:var(--text)}.mobile-menu.is-open{display:flex}.hide-on-mobile{display:none!important}}.reflection-container{max-width:760px;margin:0 auto;padding:80px 20px 60px;display:flex;flex-direction:column;gap:64px}.reflection-hero{padding-bottom:24px;border-bottom:1px solid var(--border);text-align:left}.reflection-title{font-size:36px;font-weight:700;letter-spacing:-.02em;margin:0 0 16px}.reflection-subtitle{font-size:18px;color:var(--muted);line-height:1.6;margin:0;max-width:600px}.reflection-section{display:flex;flex-direction:column;gap:24px}.reflection-section-title{font-size:24px;font-weight:600;letter-spacing:-.01em;margin:0;color:var(--text)}.reflection-content{display:flex;flex-direction:column;gap:20px;font-size:16px;line-height:1.75;color:#334155}.reflection-content p{margin:0}.reflection-quote{margin:16px 0;padding:24px 32px;border-left:3px solid var(--brand);background:var(--surface-2);border-radius:0 var(--r-md) var(--r-md) 0;font-style:italic;font-size:18px;color:var(--text);line-height:1.6}@media (max-width:640px){.reflection-container{padding:60px 16px 40px;gap:48px}.reflection-title{font-size:28px}.reflection-subtitle{font-size:16px}.reflection-section-title{font-size:20px}.reflection-quote{padding:20px;font-size:16px}}