@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.absolute{position:absolute}.contents{display:contents}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}}::selection{color:#f0f3fa;background:#96b4f040}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0a0f1a}::-webkit-scrollbar-thumb{background:#8ca5dc2e;border:2px solid #0a0f1a;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#96b4f061}::-webkit-scrollbar-corner{background:#0a0f1a}*{scrollbar-width:thin;scrollbar-color:#8ca5dc2e #0a0f1a}:root{color:#e8ecf4;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0f1a;font-family:Inter,SF Pro Display,Segoe UI,Roboto,sans-serif;font-weight:400;line-height:1.4}*{box-sizing:border-box}body{scrollbar-gutter:stable;color:#e8ecf4;background:repeating-linear-gradient(0deg,#6478a00f 0 1px,#0000 1px 56px),repeating-linear-gradient(90deg,#6478a00f 0 1px,#0000 1px 56px),#0a0f1a;min-height:100vh;margin:0;padding:3rem 1.5rem 4rem;overflow-y:scroll}a{color:inherit;text-decoration:none}.page-shell{gap:4rem;max-width:1060px;margin:0 auto;display:grid}h1,h2,h3,p{margin:0}h1{letter-spacing:-.035em;color:#f0f3fa;font-size:clamp(2.4rem,6vw,4.5rem);font-weight:700;line-height:1.02}h2{letter-spacing:-.01em;color:#e8ecf4;margin-bottom:.6rem;font-size:1rem}h3{letter-spacing:-.01em;color:#e8ecf4;margin-bottom:.35rem;font-size:.95rem}p{color:#c8d2e699;font-size:.9rem;line-height:1.65}.muted{color:#c8d2e666}.mt{margin-top:1rem}.link{color:#96b4f0b3;transition:color .14s}.link:hover{color:#96b4f0e6}.eyebrow{letter-spacing:.11em;text-transform:uppercase;color:#96b4f0cc;font-size:.82rem;font-weight:600}.action-row{flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.25rem;display:flex}.btn{cursor:pointer;color:#c8d2e699;background:0 0;border:1px solid #8ca5dc1f;border-radius:.5rem;align-items:center;gap:.35rem;padding:.5rem .9rem;font-family:inherit;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .14s,border-color .14s,background .14s;display:inline-flex}.btn:hover{color:#e8ecf4;background:#ffffff08;border-color:#a0b9e64d}.btn--primary{color:#e8ecf4;background:#ffffff0f;border-color:#8ca5dc33;font-weight:600}.btn--primary:hover{color:#fff;background:#ffffff17;border-color:#a0b9e64d}.btn-arrow{font-size:1rem;transition:transform .14s}.btn--primary:hover .btn-arrow{transform:translate(2px)}.hero{padding:0}.hero-main{align-items:center;gap:1.5rem;display:grid}.hero-content{gap:.65rem;display:grid}.hero-title{max-width:none}.hero-copy{max-width:70ch;font-size:1rem;line-height:1.7}.profile-panel{flex-direction:column;justify-self:center;align-items:center;gap:.65rem;display:flex}.photo-frame{border:2px solid #8ca5dc26;border-radius:50%;width:150px;height:150px;overflow:hidden}.profile-photo{object-fit:cover;width:100%;height:100%;display:block}.profile-info{text-align:center;gap:.15rem;display:grid}.profile-name{text-transform:uppercase;letter-spacing:.1em;color:#96b4f0b3;font-size:.75rem;font-weight:600}.profile-detail{color:#c8d2e673;font-size:.82rem;line-height:1.5}.section{content-visibility:auto;contain-intrinsic-size:780px;gap:1.25rem;display:grid;overflow-x:hidden}.section-eyebrow{letter-spacing:.11em;text-transform:uppercase;color:#96b4f0b3;margin-bottom:-.75rem;font-size:.8rem;font-weight:600}.section-title{letter-spacing:-.03em;color:#f0f3fa;margin-bottom:0;font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:650;line-height:1.1}.flat-card{background:#ffffff06;border:1px solid #8ca5dc1a;border-radius:1rem;padding:1.4rem;transition:color .21s,border-color .21s,background .21s,box-shadow .21s;position:relative;overflow:hidden}.flat-card:before{content:"";transform-origin:bottom;background:#96b4f08c;border-radius:3px 0 0 3px;width:3px;transition:transform .28s;position:absolute;top:0;bottom:0;left:0;transform:scaleY(0)}.flat-card:hover{background:#ffffff08;border-color:#a0b9e647;box-shadow:0 0 0 1px #96b4f00a,0 8px 32px #00000047}.flat-card:hover:before{transform:scaleY(1)}.flat-card:hover .skill-label{color:#96b4f0b3}.flat-card:hover p{color:#c8d2e6b3}.grid-row,.experience-list{gap:.75rem;display:grid}.experience-item{background:#ffffff06;border:1px solid #8ca5dc1a;border-radius:1rem;gap:.55rem;padding:1.25rem;transition:color .28s,border-color .28s,background .28s,box-shadow .28s;display:grid;position:relative;overflow:hidden}.experience-item:before{content:"";transform-origin:bottom;background:#96b4f08c;border-radius:3px 0 0 3px;width:3px;transition:transform .28s;position:absolute;top:0;bottom:0;left:0;transform:scaleY(0)}.experience-item:hover{background:#ffffff08;border-color:#a0b9e647;box-shadow:0 0 0 1px #96b4f00a,0 8px 32px #00000047}.experience-item:hover:before{transform:scaleY(1)}.experience-item:hover .experience-summary,.experience-item:hover .experience-points li{color:#c8d2e6b3}.experience-item:hover .experience-head .experience-meta,.experience-item:hover .experience-head .experience-period{color:#c8d2e699}.experience-head{gap:.12rem;display:grid}.experience-company{color:#e8ecf4;font-size:1rem;font-weight:620}.experience-meta,.experience-period{color:#c8d2e673;font-size:.82rem}.experience-points{gap:.35rem;margin:0;padding:0;list-style:none;display:grid}.experience-points li{color:#c8d2e699;padding-left:.9rem;font-size:.9rem;line-height:1.55;position:relative}.experience-points li:before{content:"·";color:#96b4f066;font-weight:700;position:absolute;left:.15rem}.skills-list{gap:.55rem;display:grid}.skill-row{border-bottom:1px solid #8ca5dc12;gap:.15rem;padding:.6rem 0;display:grid}.skill-row:last-child{border-bottom:none}.skill-label{text-transform:uppercase;letter-spacing:.1em;color:#96b4f099;font-size:.75rem;font-weight:600}.skills-grid{gap:.75rem;display:grid}.project-stack{flex-wrap:wrap;gap:.35rem;display:flex}.stack-badge{color:#96b4f0bf;letter-spacing:.03em;background:#96b4f012;border:1px solid #96b4f026;border-radius:.3rem;padding:.2rem .55rem;font-family:JetBrains Mono,Fira Code,Cascadia Code,Consolas,monospace;font-size:.72rem}.project-link-icon{color:#96b4f073;flex-shrink:0;width:.6rem;height:.6rem;transition:transform .21s,color .21s;display:inline-block}.project-link-icon svg{width:100%;height:100%}.project-tagline{text-transform:uppercase;letter-spacing:.09em;color:#96b4f099;margin:0;font-size:.75rem;font-weight:600}.project-desc{color:#c8d2e680;margin:.1rem 0 0;font-size:.875rem;line-height:1.62;transition:color .21s}.project-snippet pre{background:#00000052;border:1px solid #8ca5dc14;border-radius:.5rem;margin:0;padding:.75rem 1rem;overflow-x:auto}.project-snippet code{color:#c8d2e680;white-space:pre;font-family:JetBrains Mono,Fira Code,Cascadia Code,Consolas,monospace;font-size:.72rem;line-height:1.75}.project-featured{color:inherit;background:#96b4f006;border:1px solid #8ca5dc1a;border-top:2px solid #96b4f02e;border-radius:1.25rem;padding:1.75rem;text-decoration:none;transition:border-top-color .28s,background .28s,box-shadow .28s;display:block;overflow:hidden}.project-featured:hover{background:#96b4f00b;border-top-color:#96b4f099;box-shadow:0 6px 36px #00000047}.project-featured:hover .project-link-icon{color:#96b4f0e6;transform:translate(3px,-3px)}.project-featured:hover .project-desc{color:#c8d2e6b8}.pf-top{flex-direction:column;gap:1.5rem;display:flex}.pf-text{flex-direction:column;gap:.45rem;display:flex}.pf-meta{align-items:center;gap:.65rem;margin-bottom:.25rem;display:flex}.pf-meta .project-link-icon{margin-left:auto}.pf-num{color:#96b4f073;letter-spacing:.12em;font-family:JetBrains Mono,Fira Code,Cascadia Code,Consolas,monospace;font-size:.8rem;font-weight:600}.pf-name{color:#f0f3fa;letter-spacing:-.03em;margin:0;font-size:clamp(1.4rem,3vw,2rem);font-weight:700;line-height:1.1;transition:color .28s}.project-featured:hover .pf-name{color:#fff}.project-featured .project-snippet{margin-top:0}.projects-header{justify-content:space-between;align-items:center;display:flex}.projects-toggle{color:#96b4f08c;cursor:pointer;background:0 0;border:1px solid #8ca5dc26;border-radius:.45rem;flex-shrink:0;justify-content:center;align-items:center;width:2.1rem;height:2.1rem;font-family:inherit;font-size:.65rem;transition:background .28s,border-color .28s,color .28s;display:inline-flex}.projects-toggle:hover{color:#96b4f0e6;background:#96b4f014;border-color:#96b4f04d}.toggle-chevron{transition:transform .28s;display:inline-block}.toggle-chevron.rotated{transform:rotate(90deg)}.project-rows{border-top:1px solid #8ca5dc12;flex-direction:column;display:flex}.project-row{color:inherit;border-bottom:1px solid #8ca5dc12;border-radius:.5rem;grid-template-columns:2.25rem 1fr;align-items:start;gap:0 .85rem;padding:.9rem .5rem;text-decoration:none;transition:background .28s;display:grid}.project-row:hover{background:#96b4f00a}.project-row:hover .project-link-icon{color:#96b4f0e6;transform:translate(3px,-3px)}.pr-num{color:#96b4f052;letter-spacing:.1em;padding-top:.18rem;font-family:JetBrains Mono,Fira Code,Cascadia Code,Consolas,monospace;font-size:.8rem;font-weight:600}.pr-body{flex-direction:column;gap:.3rem;display:flex}.pr-name-row{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.75rem;display:flex}.pr-name{color:#e8ecf4;font-size:.95rem;font-weight:620;transition:color .14s}.project-row:hover .pr-name{color:#fff}.pr-right{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.pr-tagline{color:#c8d2e666;font-size:.82rem;line-height:1.45;transition:color .14s}.project-row:hover .pr-tagline{color:#c8d2e6a6}.pr-snippet{grid-template-rows:0fr;margin-top:0;transition:grid-template-rows .28s,margin-top .28s;display:grid;overflow:hidden}.project-row:hover .pr-snippet,.project-rows.expanded .project-row .pr-snippet{grid-template-rows:1fr;margin-top:.75rem}.pr-snippet-inner{flex-direction:column;gap:.65rem;min-height:0;display:flex}.pr-desc{color:#c8d2e68c;margin:0;font-size:.875rem;line-height:1.6;transition:color .14s}.project-row:hover .pr-desc{color:#c8d2e6bf}.pr-snippet-inner pre{background:#0000004d;border:1px solid #8ca5dc12;border-radius:.45rem;margin:0;padding:.6rem .85rem;overflow:hidden}.pr-snippet-inner code{color:#c8d2e680;white-space:pre;font-family:JetBrains Mono,Fira Code,Cascadia Code,Consolas,monospace;font-size:.72rem;line-height:1.7}@media(prefers-reduced-motion:reduce){*,:before,:after{transition:none!important}}@media(min-width:760px){body{padding:4rem 2.5rem 5rem}.hero-main{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:1.25rem}.grid-row,.skills-grid{grid-template-columns:1.4fr 1fr}.pf-top{grid-template-columns:1fr 1fr;align-items:start;gap:2.5rem;display:grid}}@media(max-width:640px){.btn{padding:.5rem .6rem;font-size:.8rem}.projects-toggle{display:none}.profile-panel{flex-direction:row;justify-self:stretch;gap:1rem}.photo-frame{flex-shrink:0;width:80px;height:80px}.profile-info{text-align:left}.hero-copy{max-width:100%}.action-row{gap:.4rem}.pr-snippet{grid-template-rows:1fr}.pr-desc{color:#c8d2e6a6}.pr-tagline{color:#c8d2e680}.pr-name-row{flex-direction:column;align-items:flex-start;gap:.4rem}.pr-right{flex-shrink:1}.pr-body{gap:.45rem}.project-row{grid-template-columns:.8rem 1fr}}@media(max-width:429px){body{padding:3rem 1rem 4rem}}@media(max-width:374px){body{padding:2.5rem 1rem 3rem}.btn{padding:.5rem .4rem}.project-featured{padding:1.1rem}.flat-card,.experience-item{padding:1rem}.pf-name{font-size:1.25rem}.project-row{flex-direction:column;padding:.75rem .25rem;display:flex}.section-title{font-size:1.4rem}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ease{syntax:"*";inherits:false}
