.hero{display:flex;align-items:center;justify-content:flex-start;position:relative;overflow:hidden;padding-top:8rem;cursor:pointer}.hero-content{max-width:64rem;padding:0 1.5rem;opacity:0;transform:translateY(2rem);text-align:start}.hero-content.visible{opacity:1;transform:translateY(0);padding:0 16px}.hero-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.5rem}.profile-photo{width:4rem;height:4rem;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid rgba(255,255,255,.1)}.profile-photo img{width:100%;height:100%;object-fit:cover}.hero-title{font-size:1.5rem;font-weight:900;color:#fafafa;margin:0;line-height:1.1}.hero-subtitle{font-size:1rem;color:#d4d4d4;margin-bottom:1.5rem;line-height:1.4;max-width:48rem;margin-left:auto;margin-right:auto}.hero-description{max-width:48rem;margin:0 auto}.hero-text{color:#d4d4d4;line-height:1.6;margin-bottom:1rem}.hero-text-secondary{color:#d4d4d4;line-height:1.6}@media (max-width: 1500px){.hero{cursor:default}}@media (max-width: 768px){.hero{padding:2rem 0;justify-content:center;text-align:start}.hero-content{padding:0;text-align:start}.hero-header{flex-direction:row;gap:1rem;align-items:center}.profile-photo{width:3.5rem;height:3.5rem}.hero-title{font-size:1.3rem;text-align:start}.hero-subtitle{font-size:1rem;text-align:start}.hero-description{text-align:start}.hero-text,.hero-text-secondary{font-size:1rem;text-align:start}}@font-face{font-family:Garamond Classico SC;src:url(/assets/Garamond%20Classico%20SC-edq2oHFy.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}:root{--card-scale: .6}*{box-sizing:border-box}.card-shell{position:fixed;right:5%;transform:translate(120%);width:auto;display:flex;align-items:flex-start;justify-content:center;padding:24px 0 48px;font-family:Garamond Classico SC;z-index:1000;opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s ease,transform .4s ease;pointer-events:none}.card-shell.card-visible{opacity:1;visibility:visible;transform:translate(0);pointer-events:auto}.card-scene{perspective:1200px;width:min(100%,960px);display:flex;align-items:center;justify-content:center}.card{width:480px;height:calc(480px * 452 / 800);padding:24px 28px;position:relative;background:radial-gradient(circle at 20% 15%,#ffffffc2,#f9f7ecc9 42%,#f7f6ed);border:1.5px solid rgba(84,78,68,.2);box-shadow:0 16px 42px #2f2b2529,0 8px 18px #2f2b2524;transform-style:preserve-3d;transition:transform .16s ease-out,box-shadow .16s ease-out;will-change:transform,box-shadow;isolation:isolate;overflow:hidden}.card__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url(/assets/card_overlay-z9HmKiYM.png);opacity:.5;mix-blend-mode:multiply;filter:contrast(.98) brightness(1.04);pointer-events:none;z-index:0}.card__inner{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:space-between}.card__inline{white-space:nowrap}.engraved-text{color:transparent;background-color:#2c2925;-webkit-background-clip:text;background-clip:text;text-shadow:-.6px -.7px 1.1px rgba(32,26,22,.55),.6px .75px 0 rgba(255,255,255,.28)}.engraved-tight{color:transparent;background-color:#302c29;-webkit-background-clip:text;background-clip:text;text-shadow:-.55px -.65px .95px rgba(32,26,22,.5),.55px .65px 0 rgba(255,255,255,.26)}.card__top,.card__bottom{display:flex;justify-content:space-between;color:#24211cc7}.card__phone{align-self:flex-start;margin-right:40px;font-size:calc(34px * var(--card-scale));letter-spacing:-.07em}.card__company{display:flex;flex-direction:column;align-items:flex-end;gap:0;text-align:right}.card__company-line{display:flex;align-items:baseline;gap:calc(1px * var(--card-scale))}.card__company-word{font-size:calc(34px * var(--card-scale));letter-spacing:.02em}.card__company-ampersand{font-size:calc(29px * var(--card-scale));letter-spacing:.02em;transform:translateY(calc(-2px * var(--card-scale)))}.card__company-tagline{font-size:calc(20px * var(--card-scale));letter-spacing:.01em;font-variant:small-caps;margin-top:-6px}.card__center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:calc(10px * var(--card-scale));letter-spacing:0;color:#201d19d9;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:calc(100% - 56px)}.card__person{display:flex;flex-direction:row;align-items:baseline;gap:calc(6px * var(--card-scale));margin-left:calc(-6px * var(--card-scale))}.card__person-first{font-size:calc(34px * var(--card-scale));font-variant:small-caps;letter-spacing:-.015em}.card__person-first{letter-spacing:-.02em;margin-left:calc(-2px * var(--card-scale))}.card__person-last{font-size:calc(34px * var(--card-scale));letter-spacing:-.01em;text-transform:uppercase}.card__title{font-variant:small-caps;font-size:calc(34px * var(--card-scale));letter-spacing:-.01em}.card__bottom{font-size:calc(26px * var(--card-scale));font-variant:small-caps;letter-spacing:0;white-space:nowrap;margin-left:calc(-12px * var(--card-scale))}.card__bottom-line{display:flex;justify-content:space-between;width:100%}.card__bottom-address{letter-spacing:-.04em;word-spacing:-.05em}.card__bottom-contact{display:inline-flex;align-items:baseline;gap:calc(6px * var(--card-scale))}.card__bottom-label,.card__bottom-value{font-size:calc(28px * var(--card-scale));letter-spacing:-.07em}.card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background-image:radial-gradient(circle at top left,rgba(255,255,255,.9),transparent 56%);mix-blend-mode:screen;pointer-events:none;z-index:-1}.card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background-image:repeating-linear-gradient(135deg,rgba(90,84,74,.028) 0px,rgba(90,84,74,.028) 1px,transparent 1px,transparent 3px);opacity:.26;pointer-events:none;z-index:-1}.card:hover{box-shadow:0 28px 70px #2f2b2538}.card__inline-telex{font-size:13px;letter-spacing:.03em;font-variant:small-caps}.email{margin-left:auto;text-align:right;justify-content:flex-end}@media (max-width: 1500px){.card-shell{display:none}}.portfolio{padding-top:2rem;padding-bottom:4rem}.section-header{text-align:center;margin-bottom:4rem}.section-title{font-size:clamp(2.5rem,6vw,4rem);font-weight:800;color:#fafafa;margin-bottom:1rem}.section-subtitle{font-size:1.25rem;color:#d4d4d4;max-width:48rem;margin:0 auto;line-height:1.6}.projects-section{display:flex;flex-direction:column}.screenshot-lightbox__image{width:100%;height:auto;max-width:min(100%,48rem);max-height:80vh;object-fit:contain}.projects-list{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.project-item{position:relative;padding:1rem;border-radius:.5rem;background:#ffffff0d}.project-marker{position:absolute;left:.5rem;top:.5rem;width:1rem;height:1rem;background:#fafafa;border-radius:50%;border:2px solid #0a0a0a}.project-image{position:relative;overflow:hidden;aspect-ratio:16/9;background:#0f0f0f;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;border-radius:.5rem}.project-image img{width:70%;height:70%;object-fit:contain}.project-header{margin-bottom:.75rem;display:flex;align-items:center;gap:.75rem}.project-title{font-size:1rem;font-weight:700;color:#fafafa;margin:0}.project-info{display:flex;align-items:center;gap:.5rem;flex-shrink:0;flex-wrap:wrap}.project-logo{width:1.5rem;height:1.5rem;border-radius:.25rem;overflow:hidden;flex-shrink:0}.project-logo a{display:block;width:100%;height:100%;transition:transform .15s ease,opacity .15s ease}.project-logo a:hover{transform:scale(1.05);opacity:.8}.project-logo img{width:100%;height:100%;object-fit:cover;cursor:pointer}.project-description{color:#d4d4d4;line-height:1.6;font-size:.95rem}.project-screenshots{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.project-screenshot-button{border:none;background:transparent;padding:0;border-radius:.5rem;overflow:hidden;cursor:pointer;transition:transform .15s ease;height:5rem;display:flex;align-items:center;justify-content:center}.project-screenshot-button:hover,.project-screenshot-button:focus-visible{transform:translateY(-2px);outline:none}.project-screenshot{display:block;width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain}.screenshot-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#06080aeb;display:flex;align-items:center;justify-content:center;padding:2rem;z-index:1000}.screenshot-lightbox__content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;justify-content:center}.screenshot-lightbox__image{width:100%;height:auto;object-fit:contain;border-radius:.75rem}.screenshot-lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);border:none;background:#0f1113a6;color:#fafafa;width:2.75rem;height:2.75rem;border-radius:9999px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;cursor:pointer;transition:background .15s ease,transform .15s ease}.screenshot-lightbox__nav--prev{left:-3rem}.screenshot-lightbox__nav--next{right:-3rem}.screenshot-lightbox__nav:hover,.screenshot-lightbox__nav:focus-visible{background:#141618d9;transform:translateY(-50%) scale(1.05);outline:none}.screenshot-lightbox__close{position:absolute;top:-2.5rem;right:-.5rem;border:none;background:#0f1113a6;color:#fafafa;width:1.5rem;height:1.5rem;border-radius:9999px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;cursor:pointer;transition:background .2s ease,transform .2s ease}.screenshot-lightbox__close:hover,.screenshot-lightbox__close:focus-visible{background:#141618d9;transform:scale(1.05);outline:none}.screenshot-lightbox__dots{position:relative;margin-top:1rem;display:flex;align-items:center;gap:.5rem}.screenshot-lightbox__dot{width:.5rem;height:.5rem;border-radius:9999px;border:none;background:#ffffff59;padding:0;cursor:pointer;transition:transform .2s ease,background .2s ease}.screenshot-lightbox__dot--active{background:#fffffff2;transform:scale(1.2)}.screenshot-lightbox__dot:focus-visible{outline:2px solid rgba(255,255,255,.75);outline-offset:2px}@media (max-width: 768px){.portfolio{padding:2rem 0}.projects-list{grid-template-columns:1fr;gap:1rem}.project-header{gap:.5rem}.project-logo{width:1.25rem;height:1.25rem}.project-title{font-size:.9rem}.section-header{margin-bottom:2rem}.section-title{margin-bottom:.75rem}.project-screenshot{gap:.5rem}.screenshot-lightbox{padding:1.5rem 3rem}.screenshot-lightbox__nav{width:2rem;height:2rem;font-size:1.25rem}.screenshot-lightbox__nav--prev{left:-2.5rem}.screenshot-lightbox__nav--next{right:-2.5rem}.screenshot-lightbox__close{display:flex;top:-3rem;right:0;width:2.25rem;height:2.25rem;font-size:1.25rem}.screenshot-lightbox__dots{gap:.4rem}.screenshot-lightbox__dot{width:.45rem;height:.45rem}}.experience{padding-top:2rem}.section-title{font-size:1.2rem;font-weight:700;color:#fafafa;text-align:start;margin:0;padding:0}.section-header{margin-bottom:2rem}.experience-section{display:flex;flex-direction:column}.timeline{position:relative}.timeline:before{content:"";position:absolute;left:1rem;top:0;height:calc(100% - 1rem);width:1px;background:#262626}.timeline-item{position:relative;margin-bottom:3rem;padding-left:3rem}.timeline-item:last-child{margin-bottom:0}.timeline-item:last-child .timeline-description{margin-bottom:1rem}.timeline-marker{position:absolute;left:.5rem;top:.5rem;width:1rem;height:1rem;background:#fafafa;border-radius:50%;border:2px solid #0a0a0a}.timeline-header{margin-bottom:.75rem;display:flex;flex-direction:column;gap:.5rem}.position{font-size:1rem;font-weight:800;color:#fafafa;margin:0;order:1}.company-info{display:flex;align-items:center;gap:.5rem;flex-shrink:0;order:2;flex-wrap:wrap}.company-logo{width:1.5rem;height:1.5rem;border-radius:.25rem;overflow:hidden;flex-shrink:0}.company-logo a{display:block;width:100%;height:100%;transition:transform .15s ease,opacity .15s ease}.company-logo a:hover{transform:scale(1.05);opacity:.8}.company-logo img{width:100%;height:100%;object-fit:cover;cursor:pointer}.company-name{font-size:1rem;font-weight:500;color:#d4d4d4;margin:0;display:block}.period{font-size:.875rem;color:#a3a3a3;background:#0a0a0a;padding:.25rem .75rem;border-radius:1rem;margin:0;flex-shrink:0}.timeline-description{color:#d4d4d4;line-height:1.6;margin-bottom:1rem}@media (max-width: 768px){.experience{padding:2rem 0}.experience-content{grid-template-columns:1fr;gap:3rem;margin-top:2rem}.subsection-title{margin-bottom:1.5rem}.timeline-item{padding-left:2.5rem}.timeline-header{gap:.4rem}.company-logo{width:1.25rem;height:1.25rem}.company-name,.position{font-size:.9rem}}.contact-methods{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;margin:0 auto}.contact-method{display:flex;align-items:center}.contact-icon{width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;border-radius:50%;color:#d4d4d4;transition:all .15s ease}.contact-link:hover .contact-icon{background:#2563eb}.contact-link:hover .contact-icon svg{stroke:#fff}@media (max-width: 768px){.contact{padding:0}.contact-methods{padding:0 1rem}.contact-method{padding-right:1rem}.contact-icon{width:2.5rem;height:2.5rem}}.card-reaction-gif{position:fixed;bottom:20px;left:20px;z-index:1000;animation:slideInFromLeft .8s ease-out}.card-reaction-gif__image{max-width:300px;max-height:300px;width:auto;height:auto;border-radius:8px;box-shadow:0 4px 20px #0000004d}@keyframes slideInFromLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.card-reaction-gif{bottom:10px;left:10px}.card-reaction-gif__image{max-width:200px;max-height:200px}}.reading-list-container{padding:4rem 2rem;max-width:1400px;margin:0 auto}.reading-list-title{font-size:1.5rem;color:#fafafa;letter-spacing:-.02em;margin-bottom:0}.reading-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;padding:0 2rem}.filter-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.1);border-radius:20px;color:#fff;cursor:pointer;transition:all .2s ease}.filter-button:hover{background:#ffffff26}.filter-button:hover svg{stroke:#fff}.filter-button:not(.active):hover svg{fill:#dc2626;stroke:#dc2626}.filter-button.active:hover svg{fill:none}.filter-button.active{background:#ffffff26;border-color:#ffffff80;color:#fff}.reading-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:3rem 2rem;padding:0 2rem}.book-card{display:flex;flex-direction:column;position:relative}.book-cover-container{position:relative;width:100%;aspect-ratio:2/3;border-radius:8px;transition:transform .3s ease,box-shadow .3s ease;margin-bottom:1rem;overflow:hidden}.book-cover-image{width:100%;height:100%;object-fit:contain;display:block}.book-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#333,#444);color:#fff3;font-size:3rem;font-weight:700}.favorite-badge{position:absolute;top:8px;right:8px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5));z-index:2}.book-info{display:flex;flex-direction:column;gap:.3rem}.book-title{font-family:Inter,sans-serif;font-size:.95rem;font-weight:600;color:#fff;line-height:1.3;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.book-author{font-family:Inter,sans-serif;font-size:.85rem;color:#ffffff80;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.reading-list-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:2rem 1rem;padding:0}.reading-list-header{padding:0}.filter-button{background-color:transparent!important;border:none}.filter-button:hover{background:none;border:none}.filter-button svg{width:24px;height:24px}.filter-text{display:none}.filter-button.active:hover svg{fill:#dc2626!important;stroke:#dc2626!important}.filter-button:not(.active):hover svg{fill:none!important;stroke:#fff!important}}.footer{padding:1rem 0;display:flex;justify-content:center}.footer-link{color:#fff9;text-decoration:none;transition:color .2s ease}.footer-link:hover{color:#2563eb}*{box-sizing:border-box;padding:0;margin:0}html{background:#171717;max-width:100vw;overflow-x:hidden;transition:all 1s ease}body{color:#fafafa;max-width:100vw;overflow-x:hidden;transition:all 1s ease;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}.app{min-height:100vh;margin-left:33%;margin-right:33%}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.text-center{text-align:center}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-16{padding-top:4rem;padding-bottom:4rem}.h-screen{height:100vh}.flex{display:flex}.items-center{align-items:center}.justify-center{justify-content:center}.relative{position:relative}.absolute{position:absolute}.z-10{z-index:10}.max-w-5xl{max-width:64rem}.max-w-3xl{max-width:48rem}.mx-auto{margin-left:auto;margin-right:auto}.leading-tight{line-height:1.25}.leading-relaxed{line-height:1.625}@media (max-width: 768px){.container{padding:0 .75rem}.app{margin-top:25%;margin-left:32px;margin-right:32px}}
