@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=Space+Grotesk:wght@400;500;700&display=swap";:root{color:#111;background:#080808;font-family:Space Grotesk,Trebuchet MS,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}html,body,#root{width:100%;height:100%}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100dvh;background:#080808;color:#111;overflow-x:hidden;overflow-y:auto}body,button,input{font-family:inherit}a{color:inherit;text-decoration:none}button,input{font:inherit}button,input,textarea{appearance:none;-webkit-appearance:none}img{display:block;max-width:100%}::selection{background:#d7d1c7;color:#000}.app-shell{min-height:100dvh;padding:14px;background:radial-gradient(circle at top,rgba(255,255,255,.05) 0,transparent 26%),#050505;color:#f3eee7}.portfolio{width:min(980px,100%);margin:0 auto;display:grid;gap:40px}.panel{padding:0 0 34px;border-bottom:1px solid #171717}.hero,.section-head,.stack-list,.focus-list,.contact-list,.project-list,.project-body{display:grid}.hero{gap:16px;padding-top:8px}.eyebrow,.action-link,.contact-label,.tag,.project-year,.skill-chip{font-family:IBM Plex Mono,monospace;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.eyebrow{margin:0;color:#8e877e;font-weight:500}.hero-title,.section-title,.project-title,.focus-item h3{margin:0;font-family:Space Grotesk,sans-serif;font-weight:700;line-height:1;letter-spacing:.02em;text-transform:uppercase;color:#f3eee7}.hero-title{font-size:clamp(2.2rem,8vw,4.9rem)}.hero-copy,.project-summary,.project-points li,.focus-item p,.info-row p,.contact-value{margin:0;color:#b0a79b;line-height:1.65;overflow-wrap:anywhere}.hero-copy{max-width:58ch;font-size:.98rem}.hero-actions{display:flex;flex-wrap:wrap;gap:14px}.action-link{color:#f3eee7;text-decoration:none;padding-bottom:4px;border-bottom:1px solid #36312b;transition:border-color .15s ease,color .15s ease}.action-link:hover{border-color:#f3eee7}.section-grid{display:grid;gap:32px;align-items:start}.section-head{gap:10px;margin-bottom:18px}.section-title{font-size:clamp(1.45rem,4vw,2.1rem)}.stack-list,.focus-list,.contact-list{gap:0}.stack-list>*+*,.focus-list>*+*,.contact-list>*+*{margin-top:16px;padding-top:16px;border-top:1px solid #141414}.info-row{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;align-items:start}.row-marker{width:6px;height:6px;margin-top:10px;border-radius:999px;background:#8e877e}.skill-list,.tag-list{display:flex;flex-wrap:wrap;gap:10px 14px}.skill-chip,.tag,.project-year{color:#d8d1c7}.project-list{gap:28px}.project-card{padding:0}.project-list>.project-card+.project-card{padding-top:28px;border-top:1px solid #171717}.project-layout{display:grid;gap:18px}.project-visual{overflow:hidden;border-radius:14px;background:#0d0d0d;padding:0;border:0;cursor:zoom-in}.project-visual img{width:100%;display:block;aspect-ratio:16 / 10;object-fit:cover;filter:grayscale(1) contrast(1.04) brightness(.82);transition:transform .18s ease,filter .18s ease}.project-visual:hover img{transform:scale(1.02);filter:grayscale(1) contrast(1.06) brightness(.9)}.project-body{gap:14px}.project-top{display:grid;gap:10px}.project-title{margin-bottom:8px;font-size:1.08rem}.project-points{margin:0;padding-left:18px;display:grid;gap:8px}.project-points li::marker{color:#f3eee7}.focus-item{display:grid;gap:8px}.focus-item h3{font-size:.95rem}.contact-item{display:grid;gap:6px;color:inherit;text-decoration:none;transition:color .15s ease}.contact-item:hover .contact-value{color:#f3eee7}.contact-label{color:#8e877e;font-weight:500}.contact-value{color:#c8bfb3;font-size:.95rem}.image-lightbox{position:fixed;inset:0;display:grid;place-items:center;padding:16px;background:#000000d6}.image-lightbox-panel{width:min(1080px,100%);max-height:92vh;display:grid;gap:14px}.image-lightbox-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#f3eee7;font-family:IBM Plex Mono,monospace;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.image-lightbox-close{border:0;padding:0;background:transparent;color:#f3eee7;font:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer;border-bottom:1px solid #4a4a4a}.image-lightbox-close:hover{border-color:#f3eee7}.image-lightbox-image{width:100%;max-height:calc(92vh - 36px);object-fit:contain;border-radius:14px;background:#0d0d0d}a{color:inherit}button,a,input{-webkit-tap-highlight-color:transparent}a:focus-visible,button:focus-visible{outline:2px solid #5e5e5e;outline-offset:3px}@media(min-width:760px){.app-shell{padding:24px}.section-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.section-grid-bottom{grid-template-columns:1.05fr .95fr}.project-layout{grid-template-columns:minmax(260px,320px) minmax(0,1fr);align-items:start}.project-top{grid-template-columns:minmax(0,1fr) auto;align-items:start}}@media(max-width:759px){.portfolio{gap:32px}.hero-actions{display:grid;grid-template-columns:1fr;gap:10px}.action-link{width:fit-content}}@media(max-width:480px){.app-shell{padding:10px}.portfolio{gap:28px}.panel{padding-bottom:26px}.hero-title{font-size:clamp(1.9rem,11vw,2.8rem)}.section-title{font-size:1.28rem}.project-visual img{aspect-ratio:16 / 11}.image-lightbox{padding:12px}}
