:root{--bg: #0c0b09;--bg-elevated: #15130f;--bg-overlay: #1a1814;--fg: #e0d8c6;--fg-dim: #8a8478;--fg-muted: #4a463e;--accent: #d4925a;--accent-bright: #f0b378;--border: #1f1d18;--border-bright: #2d2a23;--success: #8fa66e;--link: #c9b87f;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--max-w: 760px;--pad: clamp(1.25rem, 4vw, 2.5rem)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{background:var(--bg);color:var(--fg);font-family:var(--font-mono);font-size:15px;line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{min-height:100vh;position:relative;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.012) 0px,rgba(255,255,255,.012) 1px,transparent 1px,transparent 3px);z-index:1}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse at center,transparent 55%,rgba(0,0,0,.35) 100%);z-index:1}::selection{background:var(--accent);color:var(--bg)}a{color:var(--link);text-decoration:none;border-bottom:1px solid var(--fg-muted);transition:color .12s ease,border-color .12s ease}a:hover{color:var(--accent-bright);border-bottom-color:var(--accent-bright)}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}.app{position:relative;z-index:2;min-height:100vh;display:flex;flex-direction:column}.window{max-width:var(--max-w);width:100%;margin:0 auto;padding:0 var(--pad);flex:1;display:flex;flex-direction:column}.titlebar{display:flex;flex-direction:column;border-bottom:1px solid var(--border);background:var(--bg-elevated);font-size:.8rem;color:var(--fg-dim);position:sticky;top:0;z-index:10;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.titlebar-row{display:flex;align-items:center;justify-content:space-between;padding:.65rem var(--pad)}.titlebar-row-top{border-bottom:1px solid var(--border)}.titlebar-left{display:flex;align-items:center;gap:.6rem}.dots{display:flex;gap:.35rem}.dot{width:10px;height:10px;border-radius:50%;background:var(--border-bright)}.dot.accent{background:var(--accent)}.titlebar-path{font-weight:500;letter-spacing:.02em}.titlebar-right{font-variant-numeric:tabular-nums}.tabs{display:flex;gap:0;padding:0 var(--pad);overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{display:inline-flex;align-items:center;padding:.55rem .9rem;font-size:.82rem;color:var(--fg-dim);border:none;border-bottom:2px solid transparent;text-decoration:none;transition:color .12s ease,border-color .12s ease,background .12s ease;white-space:nowrap;font-weight:400;letter-spacing:.01em}.tab:hover{color:var(--fg);background:var(--bg-overlay)}.tab-active{color:var(--accent);border-bottom-color:var(--accent)}.tab-active:hover{color:var(--accent-bright);background:transparent}.hero{padding:4rem 0 3rem;border-bottom:1px dashed var(--border-bright)}.hero-mark{color:var(--accent);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:1.2rem}.hero-title{font-size:clamp(2rem,6vw,3rem);font-weight:700;line-height:1.1;letter-spacing:-.02em;color:var(--fg);margin-bottom:1rem}.hero-title .slash{color:var(--fg-muted);font-weight:400}.hero-tag{color:var(--fg-dim);font-size:.95rem;max-width:42ch}.section{padding:3rem 0;border-bottom:1px dashed var(--border-bright)}.section:last-of-type{border-bottom:none}.prompt{display:flex;align-items:baseline;gap:.5rem;margin-bottom:1.4rem;font-size:.95rem}.prompt-glyph{color:var(--accent);font-weight:500}.prompt-cmd{color:var(--fg);font-weight:500}.prompt-cmd .arg{color:var(--fg-dim);font-weight:400}.section-body{padding-left:1.5rem;border-left:1px solid var(--border)}.section-body p+p{margin-top:1rem}.section-body p{color:var(--fg)}.projects{display:flex;flex-direction:column;gap:0}.project{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;padding:.9rem 0;border-bottom:1px solid var(--border);align-items:baseline;transition:background .15s ease,padding .15s ease;position:relative}.project:hover{background:var(--bg-elevated);padding-left:.5rem;padding-right:.5rem}.project:hover .project-name{color:var(--accent-bright)}.project:hover .project-name:before{content:"▸";position:absolute;left:-1rem;color:var(--accent)}.project-perm{color:var(--fg-muted);font-size:.8rem;font-weight:400;white-space:nowrap}.project-main{display:flex;flex-direction:column;gap:.2rem;min-width:0}.project-name{color:var(--fg);font-weight:500;font-size:.95rem;transition:color .15s ease;position:relative}.project-desc{color:var(--fg-dim);font-size:.85rem;line-height:1.5}.project-tags{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:flex-end}.tag{font-size:.7rem;color:var(--fg-dim);padding:.1rem .4rem;border:1px solid var(--border-bright);border-radius:2px;white-space:nowrap}.tag.active{color:var(--success);border-color:var(--success)}.tag.wip{color:var(--accent);border-color:var(--accent)}.footer{padding:2.5rem 0 3rem;display:flex;flex-direction:column;gap:1rem;color:var(--fg-dim);font-size:.8rem}.footer-prompt{display:flex;align-items:center;gap:.4rem;color:var(--accent)}.cursor{display:inline-block;width:.55rem;height:1rem;background:var(--fg);vertical-align:-2px;animation:blink 1.1s steps(2) infinite}@keyframes blink{50%{opacity:0}}.footer-meta{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-top:1.2rem;border-top:1px dashed var(--border-bright)}.footer-links{display:flex;gap:1rem}.weather{display:flex;flex-direction:column;gap:.4rem;font-variant-numeric:tabular-nums}.weather-main{display:flex;align-items:baseline;gap:.6rem;flex-wrap:wrap}.weather-glyph{font-size:1.3rem;color:var(--accent);line-height:1}.weather-temp{font-size:1.4rem;font-weight:500;color:var(--fg);letter-spacing:-.01em}.weather-desc{color:var(--fg)}.weather-sep{color:var(--fg-muted)}.weather-meta{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--fg-dim);flex-wrap:wrap}.weather-meta-row{font-size:.8rem}.weather-fallback{color:var(--fg-muted);font-size:.75rem;font-style:italic}.weather-loading{display:flex;align-items:center;gap:.4rem;color:var(--fg-dim)}.weather-line{color:var(--fg-dim)}.weather-dots{display:inline-flex;gap:2px}.weather-dots span{width:4px;height:4px;background:var(--accent);border-radius:50%;animation:weather-pulse 1.2s ease-in-out infinite}.weather-dots span:nth-child(2){animation-delay:.15s}.weather-dots span:nth-child(3){animation-delay:.3s}@keyframes weather-pulse{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.weather-error{color:var(--fg-dim)}.fade-in{opacity:0;transform:translateY(6px);animation:fade-in .6s cubic-bezier(.2,.7,.3,1) forwards}@keyframes fade-in{to{opacity:1;transform:translateY(0)}}.stagger>*{opacity:0;transform:translateY(6px);animation:fade-in .5s cubic-bezier(.2,.7,.3,1) forwards}.stagger>*:nth-child(1){animation-delay:60ms}.stagger>*:nth-child(2){animation-delay:.14s}.stagger>*:nth-child(3){animation-delay:.22s}.stagger>*:nth-child(4){animation-delay:.3s}.stagger>*:nth-child(5){animation-delay:.38s}.stagger>*:nth-child(6){animation-delay:.46s}.stagger>*:nth-child(7){animation-delay:.54s}.stagger>*:nth-child(8){animation-delay:.62s}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.cursor{animation:none;opacity:1}}@media(max-width:540px){html{font-size:14px}.project{grid-template-columns:1fr;gap:.3rem}.project-perm{font-size:.72rem}.project-tags{justify-content:flex-start}.titlebar-right{display:none}.tab{padding:.5rem .7rem;font-size:.78rem}}
