@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_777a3675-module__erhN5a__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_777a3675-module__erhN5a__variable{--font-inter:"Inter","Inter Fallback"}
@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/65c558afe41e89d6-s.e2c8389a.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/14e23f9b59180572-s.9c448f3c.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/b49b0d9b851e4899-s.4f3fa681.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/2a65768255d6b625-s.p.d19752fb.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Playfair Display Fallback;src:local(Times New Roman);ascent-override:97.25%;descent-override:22.56%;line-gap-override:0.0%;size-adjust:111.26%}.playfair_display_a5ccb0ff-module__G0vKxa__className{font-family:Playfair Display,Playfair Display Fallback;font-style:normal}.playfair_display_a5ccb0ff-module__G0vKxa__variable{--font-playfair:"Playfair Display","Playfair Display Fallback"}
@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/13bf9871fe164e7f-s.f2220059.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/cc545e633e20c56d-s.f6f1950f.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/71b036adf157cdcf-s.bd5f4d11.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/89b21bb081cb7469-s.51c18f09.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/3fe682a82f50d426-s.23358719.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/70bc3e132a0a741e-s.15008bfb.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:JetBrains Mono Fallback;src:local(Arial);ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.0%;size-adjust:134.59%}.jetbrains_mono_74b4137b-module__1widkq__className{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.jetbrains_mono_74b4137b-module__1widkq__variable{--font-mono:"JetBrains Mono","JetBrains Mono Fallback"}
@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-border-style:solid}}}@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-serif:ui-serif,Georgia,Cambria,"Times New Roman",Times,serif;--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--radius-md:.375rem;--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;-webkit-text-decoration:inherit;-webkit-text-decoration: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}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.flex{display:flex}.grid{display:grid}.hidden{display:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.gap-8{gap:calc(var(--spacing)*8)}.border{border-style:var(--tw-border-style);border-width:1px}@media (min-width:48rem){.md\:col-span-1{grid-column:span 1/span 1}.md\:col-span-2{grid-column:span 2/span 2}.md\:col-span-3{grid-column:span 3/span 3}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:gap-12{gap:calc(var(--spacing)*12)}}}:root{--font-sans:var(--font-inter),system-ui,-apple-system,sans-serif;--font-serif:var(--font-playfair),Georgia,"Times New Roman",serif;--font-mono:var(--font-mono),"JetBrains Mono",ui-monospace,monospace;--space-xs:.25rem;--space-sm:.5rem;--space-md:.75rem;--space-lg:1.5rem;--space-xl:2.5rem;--space-2xl:4rem;--space-3xl:5rem;--color-bg:#faf9f7;--color-bg-subtle:#f3f2ef;--color-text:#2d2a26;--color-text-secondary:#5c5752;--color-text-tertiary:#9c978f;--color-accent:#0f766e;--color-accent-hover:#0d9488;--color-border:#e5e2dc;--color-border-subtle:#f0ede8;--transition-fast:.15s ease;--transition-base:.25s ease;--max-width:72rem;--content-width:48rem;--nav-height:4rem}[data-theme=dark]{--color-bg:#1a1816;--color-bg-subtle:#252320;--color-text:#f5f4f1;--color-text-secondary:#b8b4ad;--color-text-tertiary:#7a756d;--color-accent:#2dd4bf;--color-accent-hover:#5eead4;--color-border:#3d3a36;--color-border-subtle:#2d2a27}*{box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);transition:background-color var(--transition-base),color var(--transition-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.7}::selection{background-color:var(--color-accent);color:#fff}h2,h3,h4,h5,h6{font-family:var(--font-serif);letter-spacing:-.01em;color:var(--color-text);font-weight:500;line-height:1.2}h1{font-family:var(--font-mono);color:var(--color-text);letter-spacing:-.02em;font-size:clamp(2.5rem,5vw,4rem);font-weight:400;line-height:1.2}h2{font-size:clamp(1.75rem,3vw,2.5rem);font-weight:400}h3{font-size:clamp(1.25rem,2vw,1.5rem);font-weight:500}p{color:var(--color-text-secondary)}a{color:var(--color-accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-accent-hover)}a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.tech-tag{font-family:var(--font-mono);color:var(--color-text-tertiary);letter-spacing:.02em;font-size:.75rem}.tech-chip{font-family:var(--font-mono);color:var(--color-accent);background-color:var(--color-accent);font-size:.75rem}@supports (color:color-mix(in lab, red, red)){.tech-chip{background-color:color-mix(in srgb,var(--color-accent)10%,transparent)}}.tech-chip{letter-spacing:.01em;border:1px solid var(--color-accent);border-radius:4px;padding:.25rem .625rem}@supports (color:color-mix(in lab, red, red)){.tech-chip{border:1px solid color-mix(in srgb,var(--color-accent)25%,transparent)}}.container{width:100%;max-width:var(--max-width);padding:0 var(--space-lg);margin:0 auto}.content-width{max-width:var(--content-width)}.section{padding:var(--space-2xl)0}.section-sm{padding:var(--space-lg)0}.nav{height:var(--nav-height);background-color:var(--color-bg);border-bottom:1px solid var(--color-border-subtle);z-index:100;transition:background-color var(--transition-base);position:fixed;top:0;left:0;right:0}.nav-inner{justify-content:space-between;align-items:center;height:100%;display:flex}.nav-links{gap:var(--space-lg);margin:0;padding:0;list-style:none;display:flex}.nav-link{color:var(--color-text-secondary);transition:color var(--transition-fast);letter-spacing:.01em;font-size:.875rem}.nav-link:hover,.nav-link[aria-current=page]{color:var(--color-text)}.nav-logo{justify-content:center;align-items:center;gap:var(--space-sm);color:var(--color-text);letter-spacing:-.02em;font-size:1rem;font-weight:500;display:flex}.theme-toggle{padding:var(--space-sm);cursor:pointer;color:var(--color-text-secondary);transition:color var(--transition-fast);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{color:var(--color-text)}.theme-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.eyebrow{text-transform:uppercase;letter-spacing:.1em;color:var(--color-accent);margin-bottom:var(--space-md);font-size:.75rem;font-weight:500}.divider{background-color:var(--color-border);width:3rem;height:1px;margin:var(--space-xl)0}.divider-sm{background-color:var(--color-border);width:2rem;height:1px;margin:var(--space-lg)0}.project-entry{padding:var(--space-xl)0;border-bottom:1px solid var(--color-border-subtle)}.project-entry:last-child{border-bottom:none}.project-title{margin-bottom:var(--space-md)}.project-meta{gap:var(--space-md);margin-top:var(--space-lg);flex-wrap:wrap;display:flex}.experience-entry{gap:var(--space-md);padding:var(--space-xl)0;border-bottom:1px solid var(--color-border-subtle);grid-template-columns:1fr;display:grid}@media (min-width:768px){.experience-entry{grid-template-columns:12rem 1fr}}.experience-entry:last-child{border-bottom:none}.experience-period{color:var(--color-text-tertiary);font-size:.875rem;font-family:var(--font-mono)}.skill-group{margin-bottom:var(--space-xl)}.skill-list{gap:var(--space-lg);flex-wrap:wrap;margin:0;padding:0;list-style:none;display:flex}.skill-item{align-items:center;gap:var(--space-sm);color:var(--color-text-secondary);font-size:.9375rem;display:flex}.skill-icon{opacity:.8;width:1.25rem;height:1.25rem}.achievement{padding-left:var(--space-lg);position:relative}.achievement:before{content:"";background-color:var(--color-accent);border-radius:2px;width:3px;height:calc(100% - 1rem);position:absolute;top:.5rem;left:0}.footer{padding:var(--space-lg)0;border-top:1px solid var(--color-border-subtle);margin-top:var(--space-lg)}.footer-content{gap:var(--space-lg);flex-direction:column;display:flex}@media (min-width:768px){.footer-content{flex-direction:row;justify-content:space-between;align-items:center}}.footer-text{color:var(--color-text-tertiary);font-size:.875rem}.footer-links{gap:var(--space-lg);margin:0;padding:0;list-style:none;display:flex}.footer-link{color:var(--color-text-secondary);font-size:.875rem}.mobile-menu-btn{padding:var(--space-sm);cursor:pointer;color:var(--color-text);background:0 0;border:none;display:flex}@media (min-width:768px){.mobile-menu-btn{display:none}.nav-links{display:flex}}@media (max-width:767px){.nav-links{top:var(--nav-height);background-color:var(--color-bg);border-bottom:1px solid var(--color-border);padding:var(--space-lg);gap:var(--space-md);flex-direction:column;display:none;position:absolute;left:0;right:0}.nav-links.open{display:flex}}.page-header{padding-top:calc(var(--nav-height) + var(--space-2xl));padding-bottom:var(--space-xl)}.page-intro{color:var(--color-text-secondary);max-width:60ch;font-size:1.25rem;line-height:1.6}.cert-categories{gap:var(--space-lg);grid-template-columns:1fr;display:grid}@media (min-width:768px){.cert-categories{grid-template-columns:repeat(2,1fr)}}.cert-category{gap:var(--space-md);padding:var(--space-lg);background-color:var(--color-bg-subtle);border:1px solid var(--color-border-subtle);border-radius:12px;flex-direction:column;display:flex}.cert-category-title{color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border);font-size:.75rem;font-weight:600}.cert-list{gap:var(--space-xs);flex-direction:column;display:flex}.cert-item{padding:var(--space-sm)0;transition:background-color var(--transition-fast)}.cert-item-content{align-items:flex-start;gap:var(--space-sm);display:flex}.cert-icon{color:var(--color-accent);flex-shrink:0;margin-top:2px}.cert-details{flex-direction:column;gap:2px;display:flex}.cert-name{color:var(--color-text);transition:color var(--transition-fast);font-size:.875rem;font-weight:500;line-height:1.4}.cert-item:hover .cert-name{color:var(--color-accent)}.cert-provider{color:var(--color-text-tertiary);font-size:.75rem}.cert-link{align-items:center;gap:var(--space-xs);color:var(--color-text-tertiary);transition:color var(--transition-fast);margin-top:2px;font-size:.7rem;text-decoration:none;display:inline-flex}.cert-link:hover{color:var(--color-accent)}.contact-link{align-items:center;gap:var(--space-sm);padding:var(--space-md)0;font-size:1.125rem;display:inline-flex}.resume-btn{align-items:center;gap:var(--space-sm);padding:var(--space-md)var(--space-lg);background-color:var(--color-text);color:var(--color-bg);transition:opacity var(--transition-fast);border-radius:4px;font-size:.9375rem;font-weight:500;display:inline-flex}.resume-btn:hover{opacity:.85;color:var(--color-bg)}@media (prefers-reduced-motion:no-preference){.fade-in{animation:.6s forwards fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}}.bento-grid{gap:var(--space-lg);grid-template-columns:1fr;width:100%;display:grid}@media (min-width:640px){.bento-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.bento-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(200px,auto)}}.bento-card{min-height:240px;padding:var(--space-lg);cursor:pointer;transition:border-color var(--transition-base),transform var(--transition-base),box-shadow var(--transition-base);background-color:#1a1816;border:1px solid #3d3a36;border-radius:12px;flex-direction:column;justify-content:flex-end;text-decoration:none;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 8px #00000026}.bento-card:hover{border-color:#2dd4bf;transform:translateY(-2px);box-shadow:0 8px 24px #00000040}.bento-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.bento-card-bg{opacity:.15;transition:opacity var(--transition-base);z-index:0;position:absolute;inset:0}.bento-card:hover .bento-card-bg{opacity:.25}.bento-card-content{z-index:1;gap:var(--space-sm);flex-direction:column;display:flex;position:relative}.bento-category{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:#2dd4bf;font-size:.6875rem;font-weight:500}.bento-title{font-family:var(--font-serif);color:#f5f4f1;margin:0;font-size:1.25rem;font-weight:500;line-height:1.25}.bento-tagline{color:#b8b4ad;margin:0;font-size:.875rem;line-height:1.4}.bento-impact{color:#2dd4bf;margin-top:var(--space-xs);font-size:.75rem;font-weight:500}.bento-meta{align-items:center;gap:var(--space-sm);font-family:var(--font-mono);color:#7a756d;margin-top:var(--space-sm);font-size:.6875rem;display:flex}.bento-status{background-color:#7a756d26;border-radius:3px;padding:2px 6px}.bento-card--hero{min-height:320px}@media (min-width:640px){.bento-card--hero{grid-column:span 2;min-height:300px}.bento-card--hero .bento-title{font-size:1.5rem}}@media (min-width:1024px){.bento-card--hero{grid-area:span 2/span 2;min-height:420px}.bento-card--hero .bento-title{font-size:1.75rem}}.bento-card--normal{min-height:240px}@media (min-width:1024px){.bento-card--normal{grid-column:span 2;min-height:200px}}.bento-card--compact{min-height:180px;padding:var(--space-md)}.bento-card--compact .bento-title{font-size:1rem}.bento-card--compact .bento-tagline{font-size:.8125rem}.project-detail-header{padding-top:calc(var(--nav-height) + var(--space-2xl));padding-bottom:var(--space-xl)}.project-detail-meta{align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.project-detail-category{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent);font-size:.75rem;font-weight:500}.project-detail-year{font-family:var(--font-mono);color:var(--color-text-tertiary);font-size:.75rem}.project-detail-status{font-family:var(--font-mono);background-color:var(--color-accent);border-radius:4px;padding:4px 8px;font-size:.6875rem}@supports (color:color-mix(in lab, red, red)){.project-detail-status{background-color:color-mix(in srgb,var(--color-accent)15%,transparent)}}.project-detail-status{color:var(--color-accent)}.project-detail-description{color:var(--color-text-secondary);max-width:65ch;font-size:1.125rem;line-height:1.7}.project-detail-section{margin-top:var(--space-xl)}.project-detail-section h3{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text);margin-bottom:var(--space-md);font-size:.875rem;font-weight:600;font-family:var(--font-sans)}.project-detail-list{margin:0;padding:0;list-style:none}.project-detail-list li{padding-left:var(--space-lg);color:var(--color-text-secondary);margin-bottom:var(--space-sm);line-height:1.7;position:relative}.project-detail-list li:before{content:"";background-color:var(--color-accent);border-radius:50%;width:6px;height:6px;position:absolute;top:.7em;left:0}.project-detail-links{gap:var(--space-lg);margin-top:var(--space-lg);flex-wrap:wrap;display:flex}.project-detail-link{align-items:center;gap:var(--space-sm);color:var(--color-accent);border:1px solid var(--color-accent);transition:all var(--transition-fast);border-radius:4px;padding:.5rem 1rem;font-size:.9375rem;font-weight:500;text-decoration:none;display:inline-flex}.project-detail-link:hover{background-color:var(--color-accent);color:var(--color-bg);transform:translateY(-1px)}.back-link{align-items:center;gap:var(--space-sm);color:var(--color-text-secondary);margin-bottom:var(--space-lg);transition:color var(--transition-fast);font-size:.875rem;display:inline-flex}.back-link:hover{color:var(--color-text)}.project-demo-section{border-top:1px solid var(--color-border-subtle);padding-top:var(--space-lg)}.project-demo-grid{column-count:1;column-gap:var(--space-md)}@media (min-width:768px){.project-demo-grid{column-count:2}}@media (min-width:1024px){.project-demo-grid{column-count:3}}.project-demo-card{background-color:var(--color-bg-subtle);border:1px solid var(--color-border);width:100%;margin:0 0 var(--space-md);break-inside:avoid;-webkit-column-break-inside:avoid;border-radius:10px;display:inline-block;overflow:hidden}.project-demo-trigger{cursor:zoom-in;background:0 0;border:0;width:100%;margin:0;padding:0;display:block}.project-demo-trigger:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.project-demo-image{object-fit:contain;background:linear-gradient(135deg,var(--color-accent),var(--color-accent));width:100%;height:auto;max-height:min(70vh,680px);display:block}@supports (color:color-mix(in lab, red, red)){.project-demo-image{background:linear-gradient(135deg,color-mix(in srgb,var(--color-accent)24%,transparent),color-mix(in srgb,var(--color-accent)8%,transparent))}}.project-demo-image{transition:transform var(--transition-base),opacity var(--transition-base)}.project-demo-card:hover .project-demo-image{opacity:.95;transform:scale(1.02)}.project-demo-caption{font-size:.8125rem;font-family:var(--font-mono);letter-spacing:.02em;color:var(--color-text-tertiary);padding:0 var(--space-md)var(--space-md)}.project-demo-empty{padding:var(--space-md);border:1px dashed var(--color-border);background-color:var(--color-bg-subtle);color:var(--color-text-secondary);border-radius:10px;margin:0;font-size:small}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}
.yarl__fullsize{width:100%;height:100%}.yarl__relative{position:relative}.yarl__portal{opacity:0;transition:opacity var(--yarl__fade_animation_duration,.25s)var(--yarl__fade_animation_timing_function,ease);z-index:var(--yarl__portal_zindex,9999);position:fixed;inset:0;overflow:hidden}.yarl__portal_open{opacity:1}.yarl__container{background-color:var(--yarl__container_background_color,var(--yarl__color_backdrop,#000));overscroll-behavior:var(--yarl__controller_overscroll_behavior,contain);touch-action:var(--yarl__controller_touch_action,none);-webkit-user-select:none;user-select:none;outline:none;position:absolute;inset:0;overflow:hidden}.yarl__carousel{height:100%;opacity:var(--yarl__pull_opacity,1);transform:translate(var(--yarl__swipe_offset,0),var(--yarl__pull_offset,0));width:calc(100% + (var(--yarl__carousel_slides_count) - 1)*(100% + var(--yarl__carousel_spacing_px,0)*1px + var(--yarl__carousel_spacing_percent,0)*1%));flex:none;place-content:center;align-items:stretch;display:flex}.yarl__carousel_with_slides{-moz-column-gap:calc(var(--yarl__carousel_spacing_px,0)*1px + 100/(var(--yarl__carousel_slides_count)*100 + (var(--yarl__carousel_slides_count) - 1)*var(--yarl__carousel_spacing_percent,0))*var(--yarl__carousel_spacing_percent,0)*1%);column-gap:calc(var(--yarl__carousel_spacing_px,0)*1px + 100/(var(--yarl__carousel_slides_count)*100 + (var(--yarl__carousel_slides_count) - 1)*var(--yarl__carousel_spacing_percent,0))*var(--yarl__carousel_spacing_percent,0)*1%)}.yarl__flex_center{place-content:center;align-items:center;display:flex}.yarl__slide{padding:calc(var(--yarl__carousel_padding_px,0)*1px + 100/(var(--yarl__carousel_slides_count)*100 + (var(--yarl__carousel_slides_count) - 1)*var(--yarl__carousel_spacing_percent,0))*var(--yarl__carousel_padding_percent,0)*1%);flex:1;position:relative;overflow:hidden}[dir=rtl] .yarl__slide{--yarl__direction:-1}.yarl__slide_image{-o-object-fit:contain;object-fit:contain;touch-action:var(--yarl__controller_touch_action,none);-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;max-width:100%;max-height:100%}.yarl__slide_image_cover{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.yarl__slide_image_loading{opacity:0}@media screen and (min-width:800px){.yarl__slide_wrapper:not(.yarl__slide_wrapper_interactive) .yarl__slide_image{-webkit-backface-visibility:hidden;-webkit-transform-style:preserve-3d;-webkit-transform:translateZ(0)}}.yarl__slide_placeholder{line-height:0;position:absolute;top:50%;left:50%;transform:translate(-50%)translateY(-50%)}.yarl__slide_loading{color:var(--yarl__slide_icon_loading_color,var(--yarl__color_button,#fffc));animation:1s linear yarl__delayed_fadein}.yarl__slide_loading line{animation:1s linear infinite yarl__stroke_opacity}.yarl__slide_loading line:first-of-type{animation-delay:-1.875s}.yarl__slide_loading line:nth-of-type(2){animation-delay:-1.75s}.yarl__slide_loading line:nth-of-type(3){animation-delay:-1.625s}.yarl__slide_loading line:nth-of-type(4){animation-delay:-1.5s}.yarl__slide_loading line:nth-of-type(5){animation-delay:-1.375s}.yarl__slide_loading line:nth-of-type(6){animation-delay:-1.25s}.yarl__slide_loading line:nth-of-type(7){animation-delay:-1.125s}.yarl__slide_loading line:nth-of-type(8){animation-delay:-1s}.yarl__slide_error{color:var(--yarl__slide_icon_error_color,red);height:var(--yarl__slide_icon_error_size,48px);width:var(--yarl__slide_icon_error_size,48px)}@media (prefers-reduced-motion){.yarl__portal,.yarl__slide{transition:unset}.yarl__slide_loading,.yarl__slide_loading line{animation:unset}}.yarl__toolbar{padding:var(--yarl__toolbar_padding,8px);justify-content:flex-end;display:flex;position:absolute;inset:0 0 auto auto}[dir=rtl] .yarl__toolbar{inset:0 auto auto 0}.yarl__icon{height:var(--yarl__icon_size,32px);width:var(--yarl__icon_size,32px)}.yarl__button{appearance:none;background-color:var(--yarl__button_background_color,transparent);border:var(--yarl__button_border,0);color:var(--yarl__color_button,#fffc);cursor:pointer;filter:var(--yarl__button_filter,drop-shadow(2px 2px 2px #000c));margin:var(--yarl__button_margin,0);padding:var(--yarl__button_padding,8px);-webkit-tap-highlight-color:transparent;outline:none;line-height:0}.yarl__button:focus{color:var(--yarl__color_button_active,#fff)}.yarl__button:focus:not(:focus-visible){color:var(--yarl__color_button,#fffc)}.yarl__button:focus-visible{color:var(--yarl__color_button_active,#fff)}@media (hover:hover){.yarl__button:focus-visible:hover,.yarl__button:focus:hover,.yarl__button:hover{color:var(--yarl__color_button_active,#fff)}}.yarl__button:disabled{color:var(--yarl__color_button_disabled,#fff6);cursor:default}.yarl__navigation_next,.yarl__navigation_prev{padding:var(--yarl__navigation_button_padding,24px 16px);position:absolute;top:50%;transform:translateY(-50%)}.yarl__navigation_prev{left:0}[dir=rtl] .yarl__navigation_prev{left:unset;right:0;transform:translateY(-50%)rotate(180deg)}.yarl__navigation_next{right:0}[dir=rtl] .yarl__navigation_next{left:0;right:unset;transform:translateY(-50%)rotate(180deg)}.yarl__no_scroll{overscroll-behavior:none;height:100%;overflow:hidden}@keyframes yarl__delayed_fadein{0%{opacity:0}80%{opacity:0}to{opacity:1}}@keyframes yarl__stroke_opacity{0%{stroke-opacity:1}to{stroke-opacity:.125}}
