:root{--bg: #ffffff;--fg: #0a0a0a;--muted: #737373;--border: #e5e5e5;--card: #fafafa;--primary: #0a0a0a;--primary-fg: #fafafa;--accent: #f5f5f5;--input: #e5e5e5;--ring: #0a0a0a;--nav-bg: rgba(255, 255, 255, .8);--nav-shadow: 0 0 0 1px rgba(0, 0, 0, .05), 0 2px 4px rgba(0, 0, 0, .05), 0 12px 24px rgba(0, 0, 0, .05)}[data-theme=dark]{--bg: #08090a;--fg: #fafafa;--muted: #a1a1aa;--border: #27272a;--card: #09090b;--primary: #fafafa;--primary-fg: #09090b;--accent: #27272a;--input: #27272a;--ring: #d4d4d8;--nav-bg: rgba(9, 9, 11, .8);--nav-shadow: 0 -20px 80px -20px #ffffff1f inset, 0 0 0 1px rgba(255, 255, 255, .1)}*{box-sizing:border-box;margin:0;padding:0}html{color-scheme:dark}[data-theme=light]{color-scheme:light}body{font-family:Geist,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--fg);min-height:100vh;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s;font-size:14px;line-height:1.6}.home-page,.projects-page{min-height:100vh}.home-container{max-width:42rem;margin:0 auto;padding:3rem 1.5rem 6rem;display:flex;flex-direction:column;gap:2.5rem}@media (min-width: 640px){.home-container{padding-top:6rem}}@media (max-width: 640px){.home-container{padding:2rem 1rem 6rem}#hero .inner{gap:1rem}.avatar{width:5.5rem;height:5.5rem}.card{gap:.75rem}.card-icon{width:2.5rem;height:2.5rem}.card-date{font-size:.7rem}}@keyframes blurIn{0%{opacity:0;filter:blur(8px);transform:translateY(8px)}to{opacity:1;filter:blur(0);transform:translateY(0)}}.blur-in{opacity:0;filter:blur(6px);transform:translateY(6px);will-change:transform,opacity,filter;animation:blurIn .6s ease forwards}#hero .inner{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}#hero h1{font-size:clamp(1.75rem,5vw,3rem);font-weight:700;letter-spacing:-.05em;line-height:1.1}#hero .age-line{font-size:.875rem;color:var(--muted);margin-top:.375rem}#hero .age-line span{font-variant-numeric:tabular-nums}.avatar{width:7rem;height:7rem;border-radius:9999px;border:1px solid var(--border);overflow:hidden;flex-shrink:0;background:var(--accent);display:flex;align-items:center;justify-content:center}.avatar img{width:100%;height:100%;object-fit:cover}h2{font-size:1.25rem;font-weight:700;margin-bottom:.75rem}#about .prose p{font-size:.875rem;color:var(--muted);margin-bottom:.5rem}#about .prose a{color:var(--fg);text-underline-offset:3px}.card-list{display:flex;flex-direction:column;gap:.5rem}.card{width:100%;display:flex;align-items:flex-start;gap:1rem;padding:.5rem .25rem;border-radius:.5rem;cursor:pointer;text-decoration:none;color:inherit;transition:background .15s;border:0;background:transparent;text-align:left}.card:hover{background:var(--accent)}.card-icon{width:3rem;height:3rem;border-radius:9999px;border:1px solid var(--border);background:var(--accent);flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.card-icon img{width:100%;height:100%;object-fit:cover;border-radius:9999px}.card-body{flex:1;min-width:0}.card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.card-name{display:inline-flex;align-items:center;gap:.25rem;font-size:.8125rem;font-weight:600;line-height:1}.card-date{font-size:.75rem;color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums}.card-role{font-size:.75rem;color:var(--muted);margin-top:.125rem}.card-desc{font-size:.8125rem;color:var(--muted);overflow:hidden;max-height:0;opacity:0;transition:max-height .3s ease,opacity .25s ease,margin .25s;margin-top:0}.card-desc.open{max-height:120px;opacity:1;margin-top:.5rem}#newsletter p{font-size:.875rem;color:var(--muted);margin-bottom:1rem}.sub-form{display:flex;flex-wrap:wrap;gap:.5rem;max-width:28rem}.sub-form input{flex:1 1 160px;height:2.25rem;padding:.25rem .75rem;border-radius:.375rem;border:1px solid var(--input);background:transparent;color:var(--fg);font-size:.875rem;font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s}.sub-form input:focus{border-color:var(--ring);box-shadow:0 0 0 1px var(--ring)}.sub-form input::placeholder{color:var(--muted)}.sub-form button{height:2.25rem;padding:0 1rem;border-radius:.375rem;background:var(--primary);color:var(--primary-fg);font-size:.875rem;font-weight:600;font-family:inherit;border:none;cursor:pointer;transition:opacity .15s}.sub-form button:hover{opacity:.85}.badge-wrap{display:flex;flex-wrap:wrap;gap:.25rem}.badge{display:inline-flex;align-items:center;border-radius:.375rem;border:none;background:var(--primary);color:var(--primary-fg);padding:.125rem .625rem;font-size:.75rem;font-weight:600;box-shadow:0 1px 3px #0000001f}#contact{text-align:center;padding:3rem 1rem}#contact p{color:var(--muted)}#contact a{color:#3b82f6;text-decoration:none}#contact a:hover{text-decoration:underline}.dock-wrap{pointer-events:none;position:fixed;left:0;right:0;bottom:0;z-index:30;margin-bottom:1rem;display:flex;justify-content:center;padding:0 .75rem}.dock-blur{position:fixed;bottom:0;left:0;right:0;height:4rem;background:var(--bg);-webkit-mask-image:linear-gradient(to top,black,transparent);mask-image:linear-gradient(to top,black,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none}.dock{pointer-events:auto;position:relative;z-index:50;display:flex;align-items:center;gap:0;padding:.25rem;border-radius:9999px;border:1px solid var(--border);background:var(--nav-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:var(--nav-shadow)}.dock-btn{width:2.5rem;height:2.5rem;border-radius:9999px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;color:var(--fg);text-decoration:none;transition:background .15s,transform .15s;padding:0}.dock-btn:hover{background:var(--accent);transform:scale(1.1) translateY(-2px)}.dock-btn svg{width:1rem;height:1rem}.dock-sep{width:1px;height:2rem;background:var(--border);margin:0 .125rem;flex-shrink:0}[data-tip]{position:relative}[data-tip]:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--fg);color:var(--bg);padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s}[data-tip]:hover:after{opacity:1}.projects-container{max-width:52rem;margin:0 auto;padding:2.5rem 1rem 4rem}@media (min-width: 768px){.projects-container{padding:4rem 1.5rem}}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}.projects-page h1{font-size:clamp(1.5rem,4vw,2.4rem);line-height:1.1;letter-spacing:-.03em}.back-link{text-decoration:none;color:var(--fg);border:1px solid var(--border);padding:.45rem .85rem;border-radius:999px;font-size:.85rem;transition:background .2s ease}.back-link:hover{background:var(--accent)}.intro{color:var(--muted);margin-bottom:1.5rem;max-width:42rem}.grid{display:grid;grid-template-columns:1fr;gap:.75rem}@media (min-width: 720px){.grid{grid-template-columns:1fr 1fr}}.project{border:1px solid var(--border);background:var(--card);border-radius:.85rem;padding:1rem}.project h2{font-size:1rem;margin-bottom:.35rem;letter-spacing:-.01em}.project p{color:var(--muted);font-size:.88rem;margin-bottom:.75rem}.project a{text-decoration:none;font-size:.82rem;font-weight:600;color:var(--primary);background:var(--primary-fg);padding:.35rem .65rem;border-radius:.45rem;display:inline-block}
