:root{--bg:#f5f2ec;--text:#0f0f10;--text-muted:#6b6864;--text-dim:#bdb9b2;--accent:#290f12;--accent-soft:#4a1f23;--accent-dim:#290f1214;--blue:#3a5c8e;--border:#0f0f101a;--border-strong:#0f0f1033;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100svh;line-height:1.5;overflow:hidden auto}body:before{content:"";pointer-events:none;z-index:0;background-image:linear-gradient(#0f0f1009 1px,#0000 1px),linear-gradient(90deg,#0f0f1009 1px,#0000 1px);background-size:72px 72px;position:fixed;inset:0;-webkit-mask-image:radial-gradient(#000 0%,#0000 85%);mask-image:radial-gradient(#000 0%,#0000 85%)}body:after{content:"";pointer-events:none;z-index:1;opacity:.04;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:fixed;inset:0}#app{z-index:2;position:relative}.snap{width:100%;min-height:100svh;position:relative}.hero{flex-direction:column;justify-content:center;padding:3rem 3rem 6rem;display:flex}.hero-inner{opacity:0;z-index:2;flex:1;grid-template-columns:1.15fr 1fr;align-items:center;gap:7rem;width:100%;max-width:1400px;margin:0 auto;animation:1s cubic-bezier(.2,.8,.2,1) .15s forwards fadeUp;display:grid;position:relative}.hero-text{min-width:0}.hero-label{font-family:var(--font-mono);letter-spacing:.28em;color:var(--accent-soft);text-transform:lowercase;align-items:center;gap:.75rem;margin-bottom:2rem;font-size:.72rem;display:inline-flex}.hero-name{letter-spacing:-.05em;color:var(--text);text-transform:lowercase;margin-bottom:1.75rem;font-size:clamp(3.2rem,10vw,9rem);font-weight:800;line-height:.9}.scramble{display:inline-block}.dud{color:var(--accent);opacity:.7;font-weight:700}.social-link{border:1px solid var(--border-strong);border-radius:10px;justify-content:center;align-items:center;width:42px;height:42px;text-decoration:none;transition:transform .3s,background .3s,color .3s,border-color .3s;display:inline-flex}.social-link:hover{border-color:#0000;transform:translateY(-2px)}.social-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.social-link.github{color:#24292e;border-color:#24292e40}.social-link.github:hover{color:#fff;background:#24292e}.social-link.linkedin{color:#0077b5;border-color:#0077b540}.social-link.linkedin:hover{color:#fff;background:#0077b5}.social-link.email{color:#d44638;border-color:#d4463840}.social-link.email:hover{color:#fff;background:#d44638}.things-i-like{border-left:1px solid var(--border-strong);align-self:center;padding-left:1.5rem}.marquee-track{flex-direction:column;gap:1.5rem;display:flex}.marquee-item{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.05em;white-space:normal;word-break:break-word;align-items:baseline;gap:.9rem;font-size:.95rem;line-height:1.4;display:flex}.marquee-item .label-text{color:var(--text);font-weight:400}.type-cursor{color:var(--accent);opacity:0;margin-left:2px;font-weight:400}.type-cursor.typing{opacity:1;animation:.5s step-end infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-scroll{width:fit-content;color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.22em;text-transform:lowercase;opacity:0;z-index:4;cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:.85rem;margin:0 auto;padding:.5rem 1rem;font-size:.65rem;transition:color .3s;animation:1s cubic-bezier(.2,.8,.2,1) .9s forwards fadeUp;display:flex;position:absolute;bottom:3rem;left:0;right:0}.hero-scroll:hover{color:var(--accent)}.hero-scroll:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.scroll-arrow{color:var(--accent);font-size:.95rem;animation:2s ease-in-out infinite bounce}@keyframes bounce{0%,to{opacity:.6;transform:translateY(0)}50%{opacity:1;transform:translateY(5px)}}.content{scroll-snap-type:x mandatory;overscroll-behavior-x:none;scrollbar-width:none;flex-direction:row;display:flex;overflow:auto hidden}.content::-webkit-scrollbar{display:none}.page{z-index:2;scroll-snap-align:start;scroll-snap-stop:always;flex-direction:column;flex:0 0 100vw;max-width:100vw;min-height:100svh;padding:1.75rem 3rem;display:flex;position:relative}.page-inner{flex-direction:column;flex:1;width:100%;max-width:1400px;min-height:0;margin:0 auto;display:flex}.gallery-header{z-index:5;position:absolute;top:2rem;left:3rem}.photo-gallery{justify-content:center;align-items:center;gap:1rem;display:flex;position:absolute;inset:5rem 2rem 2.5rem}.gallery-photo{object-fit:cover;max-width:calc(20% - .8rem);max-height:100%;box-shadow:0 6px 20px var(--accent-dim);border:1px solid var(--text);border-radius:6px;flex:0 auto;transition:transform .35s cubic-bezier(.2,.8,.2,1)}.gallery-photo:hover{transform:scale(1.03)}.gallery-end{text-align:center;font-family:var(--font-mono);letter-spacing:.22em;color:var(--text-muted);text-transform:lowercase;font-size:.65rem;position:absolute;bottom:.75rem;left:0;right:0}.page-scroll-right{color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.22em;text-transform:lowercase;z-index:4;cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:.85rem;padding:.5rem 1rem;font-size:.65rem;transition:color .3s;display:flex;position:absolute;bottom:3rem;right:2rem}.page-scroll-right:hover{color:var(--accent)}.page-scroll-right:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.scroll-arrow-right{color:var(--accent);font-size:.95rem;animation:2s ease-in-out infinite bounce-right}@keyframes bounce-right{0%,to{opacity:.6;transform:translate(0)}50%{opacity:1;transform:translate(5px)}}.grid{grid-template-columns:1.15fr 1fr;align-items:stretch;gap:7rem;margin:auto 0;padding:2rem 0;display:grid}.label{font-family:var(--font-mono);letter-spacing:.28em;color:var(--accent-soft);text-transform:lowercase;margin-bottom:1.25rem;font-size:.72rem}.intro{flex-direction:column;max-width:560px;display:flex}.name{letter-spacing:-.04em;color:var(--text);margin-bottom:1.75rem;font-size:clamp(2.4rem,5.4vw,4.6rem);font-weight:800;line-height:.92}.bio{color:var(--text);max-width:500px;margin-bottom:1.75rem;font-size:.98rem;line-height:1.7}.bio strong{font-weight:600}.stack{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.14em;border-top:1px solid var(--border);padding-top:1rem;font-size:.68rem;display:inline-block}.meta{flex-direction:column;gap:2.5rem;display:flex}.block{border-left:1px solid var(--border-strong);padding-left:1.5rem}.focus{flex-direction:column;gap:.9rem;list-style:none;display:flex}.focus li{color:var(--text);gap:.75rem;max-width:440px;font-size:.88rem;line-height:1.55;display:flex}.focus .num{font-family:var(--font-mono);color:var(--accent);letter-spacing:.08em;flex-shrink:0;min-width:1.2rem;padding-top:.15rem;font-size:.72rem;font-weight:600}.project-link{color:var(--accent);-webkit-text-decoration:underline dotted var(--blue);text-decoration:underline dotted var(--blue);text-underline-offset:3px;font-weight:600;transition:color .25s}.project-link:hover{color:var(--accent-soft);-webkit-text-decoration-color:var(--accent-soft);text-decoration-color:var(--accent-soft)}.project-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.block-week,.block-note{margin-top:1.5rem}.note-field{max-width:340px;position:relative}.note-input{width:100%;font-family:var(--font-mono);border:1px solid var(--border-strong);background:var(--bg);color:var(--text);resize:none;border-radius:8px;padding:.6rem 2.5rem .6rem .85rem;font-size:.8rem;line-height:1.5;transition:border-color .25s}.note-input::placeholder{color:var(--text-dim)}.note-input:focus{border-color:var(--accent);outline:2px solid var(--accent);outline-offset:-1px}.note-send{cursor:pointer;width:24px;height:24px;color:var(--text-dim);background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:color .2s,transform .2s;display:inline-flex;position:absolute;bottom:.55rem;right:.6rem}.note-send:hover{color:var(--accent);transform:translate(1px)translateY(-1px)}.note-send:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.note-send svg{display:block}.page-socials-section{margin-top:auto;padding-top:1.5rem}.page-socials-section>.label{margin-bottom:.75rem}.page-socials{align-items:center;gap:1.25rem;display:flex}footer{border-top:1px solid var(--border);color:var(--text-dim);font-size:.72rem;font-family:var(--font-mono);letter-spacing:.28em;text-transform:lowercase;justify-content:center;align-items:center;padding-top:1rem;display:flex}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (width<=900px){.hero{padding:2rem 1.5rem 10rem}.hero-scroll{bottom:2rem}.hero-inner{grid-template-columns:1fr;gap:2rem}.things-i-like{border-left:none;border-top:1px solid var(--border-strong);padding-top:1rem;padding-left:0}.marquee-track{gap:.75rem}.marquee-item{font-size:.82rem}.page{padding:1.25rem 1.5rem}.grid{grid-template-columns:1fr;gap:2.5rem;padding:1.5rem 0}.bio,.focus li{max-width:100%}.content{overflow-y:auto}.photo-gallery{grid-template-rows:1fr 1fr;grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid;inset:4rem 1rem 3rem}.gallery-photo{object-fit:cover;width:100%;min-width:0;max-width:100%;height:100%}.gallery-header{left:1.5rem}footer{text-align:center;flex-direction:column;gap:.5rem;padding-top:1.5rem}}@media (width<=500px){.hero{padding:1.5rem 1rem 8rem}.hero-name{font-size:clamp(2.4rem,14vw,4rem)}.marquee-track{gap:.5rem}.marquee-item{font-size:.75rem}.page{padding:1rem}.photo-gallery{grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(2,1fr);gap:.4rem;inset:3.5rem .75rem 2.5rem}}
