/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@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-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--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;--color-neutral-100:oklch(97% 0 0);--color-neutral-200:oklch(92.2% 0 0);--color-neutral-400:oklch(70.8% 0 0);--color-neutral-500:oklch(55.6% 0 0);--color-neutral-600:oklch(43.9% 0 0);--color-neutral-700:oklch(37.1% 0 0);--color-neutral-900:oklch(20.5% 0 0);--spacing:.25rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-5xl:3rem;--text-5xl--line-height:1;--text-6xl:3.75rem;--text-6xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--leading-relaxed:1.625;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--ease-in:cubic-bezier(.4, 0, 1, 1);--ease-out:cubic-bezier(0, 0, .2, 1);--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]){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;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{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.left-0{left:calc(var(--spacing) * 0)}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.mb-12{margin-bottom:calc(var(--spacing) * 12)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-4{height:calc(var(--spacing) * 4)}.h-6{height:calc(var(--spacing) * 6)}.h-24{height:calc(var(--spacing) * 24)}.h-28{height:calc(var(--spacing) * 28)}.h-32{height:calc(var(--spacing) * 32)}.h-full{height:100%}.w-4{width:calc(var(--spacing) * 4)}.w-6{width:calc(var(--spacing) * 6)}.w-24{width:calc(var(--spacing) * 24)}.w-28{width:calc(var(--spacing) * 28)}.w-32{width:calc(var(--spacing) * 32)}.w-full{width:100%}.max-w-full{max-width:100%}.grow{flex-grow:1}.grow\!{flex-grow:1!important}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-not-allowed{cursor:not-allowed}.resize{resize:both}.list-inside{list-style-position:inside}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-8{gap:calc(var(--spacing) * 8)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.border-neutral-200{border-color:var(--color-neutral-200)}.bg-neutral-100{background-color:var(--color-neutral-100)}.bg-neutral-900{background-color:var(--color-neutral-900)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-5{padding-inline:calc(var(--spacing) * 5)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.pt-2{padding-top:calc(var(--spacing) * 2)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-neutral-400{color:var(--color-neutral-400)}.text-neutral-500{color:var(--color-neutral-500)}.text-neutral-600{color:var(--color-neutral-600)}.text-neutral-700{color:var(--color-neutral-700)}.text-neutral-900{color:var(--color-neutral-900)}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.ordinal{--tw-ordinal:ordinal;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.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,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{--tw-ease:var(--ease-in);transition-timing-function:var(--ease-in)}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}@media (width>=40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width>=48rem){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=64rem){.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}}.home-showcase-tags{flex-wrap:wrap;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.home-showcase-tags--compact .home-showcase-tag{padding:.15rem .45rem;font-size:.6875rem}.home-showcase-tag{border-radius:var(--radius-full);background:var(--color-accent-tag-bg);color:var(--color-accent-tag-text);padding:.2rem .5rem;font-size:.75rem;font-weight:600}.home-layout-bento-hero-section-label{letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-secondary);margin:.35rem 0 0;font-size:.75rem;font-weight:700}.home-showcase-highlights{color:var(--color-text-primary);margin:.25rem 0 0;padding:0 0 0 1.1rem;font-size:.8125rem;line-height:1.45;list-style-type:disc}.home-showcase-highlights li{margin:.25rem 0;padding-left:.15rem}.home-showcase-highlights--compact{margin:.1rem 0 0;padding-left:1rem;font-size:.6875rem;line-height:1.35}.home-showcase-highlights--compact li{margin:.15rem 0}.home-showcase-secondary-links{flex-wrap:wrap;align-items:center;gap:.35rem .75rem;margin-top:.5rem;display:flex}.home-showcase-secondary-links--compact{gap:.25rem .5rem;margin-top:.15rem}.home-showcase-secondary-link{color:var(--color-accent);border-bottom:1px solid #0000;font-size:.8125rem;font-weight:600;text-decoration:none}.home-showcase-secondary-link:hover{border-bottom-color:currentColor}.home-showcase-secondary-links--compact .home-showcase-secondary-link{font-size:.6875rem}.home-layout-bento{z-index:2;padding:var(--spacing-lg) var(--spacing-md) var(--spacing-2xl);position:relative}.home-layout-bento-featured-chip{margin:0 0 var(--spacing-xs);letter-spacing:.06em;text-transform:none;color:var(--color-accent-tag-text);background:var(--color-accent-tag-bg);border-radius:var(--radius-full);align-self:flex-start;padding:.3rem .65rem;font-size:.6875rem;font-weight:700;display:inline-block}.home-layout-bento-grid{gap:var(--spacing-sm);grid-template-columns:1fr;display:grid}@media (width>=1024px){.home-layout-bento-grid{gap:var(--spacing-md);grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(108px,auto)}.home-layout-bento-cell--hero{grid-area:1/1/span 2/span 2}.home-layout-bento-cell--solitaire{grid-area:1/3}.home-layout-bento-cell--nav-projects{grid-area:1/4}.home-layout-bento-cell--nav-skills{grid-area:2/3}.home-layout-bento-cell--nav-contact{grid-area:2/4}}.home-layout-bento-cell{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:transform var(--transition-base), box-shadow var(--transition-base);flex-direction:column;display:flex;overflow:hidden}.home-layout-bento-cell:hover{box-shadow:var(--shadow-md)}.home-layout-bento-cell--hero{padding:var(--spacing-sm);gap:var(--spacing-xs);border:1px solid var(--md-sys-color-outline);overflow:visible}@supports (color:color-mix(in lab, red, red)){.home-layout-bento-cell--hero{border:1px solid color-mix(in srgb, var(--md-sys-color-outline) 22%, transparent)}}.home-layout-bento-cell--hero{border-left:4px solid var(--color-accent);background:linear-gradient(180deg, var(--md-sys-color-primary-container) 0%, #fffef9 100%)}@supports (color:color-mix(in lab, red, red)){.home-layout-bento-cell--hero{background:linear-gradient(180deg, color-mix(in srgb, var(--md-sys-color-primary-container) 10%, #fffef9) 0%, #fffef9 100%)}}.home-layout-bento-cell--hero{box-shadow:0 6px 22px #1c191714}.home-layout-bento-cell--hero:hover{transform:translateY(-2px);box-shadow:0 10px 28px #1c19171a}.home-layout-bento-cell--hero .home-layout-bento-featured-chip,.home-layout-bento-cell--tile .home-layout-bento-featured-chip{margin-bottom:0}.home-layout-bento-hero-inner{gap:var(--spacing-sm);flex-direction:column;flex:1;width:100%;min-height:0;display:flex}.home-layout-bento-cell--hero .home-layout-bento-tile-top{margin-bottom:var(--spacing-xs)}.home-layout-bento-hero-body{flex-direction:column;flex:1;gap:.55rem;width:100%;min-width:0;display:flex}.home-layout-bento-meta{color:var(--color-text-secondary);margin:0;font-size:.6875rem;font-weight:600}.home-layout-bento-hero-title{font-family:var(--font-display);font-optical-sizing:auto;margin:0;font-size:clamp(1.2rem,2.5vw,1.5rem);line-height:1.2}.home-layout-bento-hero-title a{color:var(--color-text-primary);text-decoration:none}.home-layout-bento-hero-title a:hover{color:var(--color-accent)}.home-layout-bento-hero-summary{color:var(--color-text-secondary);margin:0;font-size:.9375rem;line-height:1.55}.home-layout-bento-badge-row{flex-wrap:wrap;align-items:center;gap:.4rem .65rem;margin-top:.45rem;display:flex}.home-layout-bento-badge-link{line-height:0}.home-layout-bento-badge-img{width:auto;height:auto;max-height:20px;display:block}.home-layout-bento-hero-body .home-showcase-tags{margin-top:.35rem}img.home-layout-bento-tile-visual[src*=stitch_counter_v2]{box-shadow:0 8px 24px var(--color-shadow), 0 2px 8px #1c19170f;border-radius:22.37%}.home-layout-bento-hero-actions{align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;margin-top:.35rem;padding-top:.25rem;display:flex}.home-layout-bento-cell--tile{padding:var(--spacing-sm);gap:var(--spacing-xs);min-height:168px}.home-layout-bento-cell--solitaire{border-top:3px solid var(--home-bento-solitaire-rail);transition:transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base), border-width var(--transition-base)}.home-layout-bento-cell--tile:hover{transform:translateY(-2px)}.home-layout-bento-cell--solitaire:hover,.home-layout-bento-cell--solitaire:focus-within{border-top:1px solid var(--color-border);border-bottom:3px solid var(--home-bento-solitaire-rail)}.home-layout-bento-cell--nav .nav-card{border-radius:var(--radius-lg)}.home-layout-bento-tile-lead{color:var(--color-text-secondary);margin:0;font-size:.6875rem;line-height:1.45}.home-layout-bento-tile-top{min-height:96px;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-sm);background:linear-gradient(165deg, #fff 0%, var(--md-sys-color-primary-container) 100%);justify-content:center;align-items:center;display:flex}@supports (color:color-mix(in lab, red, red)){.home-layout-bento-tile-top{background:linear-gradient(165deg, color-mix(in srgb, #fff 55%, var(--md-sys-color-surface-container-highest)) 0%, color-mix(in srgb, var(--md-sys-color-primary-container) 42%, var(--md-sys-color-surface-container-highest)) 100%)}}.home-layout-bento-tile-top{border-radius:var(--radius-md);border:1px solid var(--md-sys-color-outline)}@supports (color:color-mix(in lab, red, red)){.home-layout-bento-tile-top{border:1px solid color-mix(in srgb, var(--md-sys-color-outline) 12%, transparent)}}@media (width>=768px){.home-layout-bento-tile-top{min-height:112px}}.home-layout-bento-tile-visual{-o-object-fit:contain;object-fit:contain;width:auto;max-width:100%;height:auto;max-height:88px;filter:drop-shadow(0 4px 10px var(--color-shadow))}img.home-layout-bento-tile-visual[src*=kmp-solitaire-app-icon\.png]{border-radius:22.37%}@media (width>=768px){.home-layout-bento-tile-visual{max-height:96px}}span.home-layout-bento-tile-visual{filter:drop-shadow(0 3px 10px var(--color-shadow));font-size:clamp(2.75rem,10vw,4rem);line-height:1}.home-layout-bento-tile-title{margin:0;font-size:.8125rem;line-height:1.25}.home-layout-bento-tile-title a{color:var(--color-text-primary);text-decoration:none}.home-layout-bento-tile-title a:hover{color:var(--color-accent)}.home-layout-bento-tile-cta{margin-top:auto;padding:.28rem .65rem;font-size:.75rem;line-height:1.2}.home-layout-bento-cell--nav{box-shadow:none;background:0 0;border:none;padding:0}.home-layout-bento-cell--nav:hover{box-shadow:none}.home-layout-bento-nav-link{text-align:center;box-sizing:border-box;flex-direction:column;align-items:center;height:100%;min-height:100%;text-decoration:none;display:flex}.home-layout-bento-nav-link.nav-card{width:100%;min-width:0;max-width:none;min-height:176px;margin:0}@media (width>=768px){.home-layout-bento-nav-link.nav-card{flex:1;min-height:0}}:root{--case-study-img-border:4px solid var(--md-sys-color-outline-variant,#d6d3ce);--case-study-img-radius:var(--radius-md)}.case-study__headline-accent{background:var(--gradient-primary);color:#0000;background-clip:text}#stitch-counter-case-studies,#case-study-engineering-delivery,#case-study-feature-development,#case-study-android-ui-ux{scroll-margin-top:5.5rem}.case-study__engineering-delivery{margin-top:var(--spacing-md);margin-bottom:var(--spacing-lg)}.case-study__text-link{color:var(--color-accent);text-underline-offset:2px;text-decoration:underline}.case-study__text-link:hover{color:var(--color-accent-hover)}.case-study__inline-code{font-family:var(--font-mono);background:var(--md-sys-color-primary);font-size:.9em}@supports (color:color-mix(in lab, red, red)){.case-study__inline-code{background:color-mix(in srgb, var(--md-sys-color-primary) 10%, transparent)}}.case-study__inline-code{border-radius:4px;padding:.15em .35em}.case-study__page-section-title{font-family:var(--font-display);font-optical-sizing:auto;color:var(--color-text-primary);letter-spacing:-.02em;margin-bottom:var(--spacing-sm);font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700}.case-study__page-section-title:after{content:"";width:6rem;height:4px;margin-top:var(--spacing-sm);background:var(--gradient-primary);border-radius:2px;display:block}.case-study__doc{margin-top:var(--spacing-xl)}.case-study__doc:first-of-type{margin-top:var(--spacing-md)}.case-study__doc-intro-title{font-family:var(--font-display);font-optical-sizing:auto;color:var(--color-text-primary);letter-spacing:-.02em;font-size:clamp(1.35rem,3.5vw,1.85rem);font-weight:700;line-height:1.2}.case-study__hero-band{background:linear-gradient(135deg, var(--md-sys-color-primary) 0%, var(--md-sys-color-secondary) 50%, var(--md-sys-color-tertiary) 100%)}@supports (color:color-mix(in lab, red, red)){.case-study__hero-band{background:linear-gradient(135deg, color-mix(in srgb, var(--md-sys-color-primary) 10%, transparent) 0%, color-mix(in srgb, var(--md-sys-color-secondary) 8%, transparent) 50%, color-mix(in srgb, var(--md-sys-color-tertiary) 9%, transparent) 100%)}}.case-study__hero-band{border-bottom:1px solid var(--color-border)}.case-study__hero-band-inner{padding:var(--spacing-lg) var(--spacing-lg)}@media (width>=768px){.case-study__hero-band-inner{padding:var(--spacing-lg) var(--spacing-xl)}}.case-study__doc>.case-study__hero-band .case-study__hero-band-inner{padding-top:var(--spacing-xl);padding-bottom:var(--spacing-xl)}.case-study__hero-band .hero{background:0 0}.case-study__hero-chips{gap:var(--spacing-sm);margin-top:var(--spacing-sm);flex-wrap:wrap;justify-content:center;display:flex}@media (width>=768px){.case-study__hero-chips{justify-content:flex-start}}.case-study__chip{font-size:.8125rem;font-weight:600;font-family:var(--font-mono);border-radius:var(--radius-full);background:var(--color-card);color:var(--color-accent-tag-text);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);align-items:center;padding:.5rem 1.1rem;display:inline-flex}.case-study__section{padding-top:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.case-study__section:last-of-type{border-bottom:none}#stitch-counter-case-studies .site-container>section.case-study__section:first-of-type,.case-study__doc>.case-study__section:first-of-type{padding-top:var(--spacing-md)}.case-study__section>.case-study__card:first-child{margin-top:0}.case-study__section-title{font-family:var(--font-display);font-optical-sizing:auto;color:var(--color-text-primary);letter-spacing:-.02em;font-size:clamp(1.35rem,3vw,1.75rem);font-weight:700;line-height:1.2}.case-study__section-title--accent:after{content:"";width:6rem;height:4px;margin-top:var(--spacing-sm);background:var(--gradient-primary);border-radius:2px;display:block}.case-study__section-lead{margin-top:var(--spacing-sm);max-width:42rem;color:var(--color-text-secondary);line-height:1.65}.case-study__card{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg) var(--spacing-lg);margin-top:var(--spacing-md)}.case-study__card--tint{background:var(--gradient-primary);color:#fff8f5;border:none}.case-study__card--tint .case-study__card-body{color:#fff8f5eb}.case-study__card--tint .case-study__kicker,.case-study__card--tint .case-study__block-title{color:#fff8f5c7}.case-study__card-body{color:var(--color-text-secondary);line-height:1.65}.case-study__kicker{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);font-size:.75rem;font-weight:700}.case-study__block-title{font-family:var(--font-display);font-optical-sizing:auto;color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:1.25rem;font-weight:700}.case-study__block{padding-top:var(--spacing-md);margin-top:var(--spacing-md);border-top:1px solid var(--color-border)}.case-study__block:first-of-type{border-top:none;margin-top:0;padding-top:0}.case-study__block h4{color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:1rem;font-weight:600}.case-study__block p,.case-study__block li{color:var(--color-text-secondary);font-size:.9375rem;line-height:1.6}.case-study__block ul>li{display:list-item}.case-study__block ul{margin:0;padding-left:1.5rem;list-style-type:disc;list-style-position:outside}.case-study__block ul>li+li{margin-top:.35rem}.case-study__two-col{gap:var(--spacing-lg);align-items:start;display:grid}@media (width>=900px){.case-study__two-col{grid-template-columns:1fr 1fr}}.case-study__bullet-list{gap:var(--spacing-sm);margin-top:var(--spacing-md);flex-direction:column;display:flex}.case-study__bullet{gap:var(--spacing-sm);color:var(--color-text-primary);align-items:flex-start;font-weight:600;line-height:1.45;display:flex}.case-study__bullet-dot{background:var(--color-accent);border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:.35rem}.case-study__thumb-wrap{flex-direction:column;align-items:center;width:auto;min-width:0;max-width:100%;display:flex}.case-study__label-pill{text-align:center;width:100%;max-width:18rem;min-height:2.75rem;margin-bottom:var(--spacing-sm);letter-spacing:.04em;text-transform:uppercase;color:#fff8f5eb;border:1px solid var(--md-sys-color-outline);background:#0000009e;justify-content:center;align-items:center;padding:.35rem .75rem;font-size:.6875rem;font-weight:700;display:flex}@supports (color:color-mix(in lab, red, red)){.case-study__label-pill{border:1px solid color-mix(in srgb, var(--md-sys-color-outline) 35%, transparent)}}.case-study__label-pill{border-radius:var(--radius-full);line-height:1.25}.case-study__thumb-btn{cursor:zoom-in;border-radius:var(--case-study-img-radius);background:0 0;border:none;max-width:100%;padding:0;display:block}.case-study__thumb-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.case-study__thumb-btn img{vertical-align:middle;border:var(--case-study-img-border);border-radius:var(--case-study-img-radius);box-sizing:border-box;width:auto;max-width:100%;height:auto;display:block}.case-study__thumb-btn--hero img{max-height:min(70vh,520px)}.case-study__thumb-btn--default img{max-height:420px}@media (width<=767px){.case-study__thumb-btn--default img{max-height:320px}}.case-study__thumb-btn--strip img{max-height:220px}@media (width>=768px){.case-study__thumb-btn--strip img{max-height:260px}}.case-study__thumb-btn--pair img{max-height:340px}@media (width<=767px){.case-study__thumb-btn--pair img{max-height:260px}}.case-study__row--2{margin-top:var(--spacing-md);flex-flow:wrap;justify-content:center;align-items:flex-start;gap:clamp(.75rem,2vw,1.5rem);display:flex}@media (width>=768px){.case-study__row--2{flex-wrap:nowrap}}.case-study__row--2 .case-study__thumb-wrap{flex:0 auto;width:auto;min-width:0}.case-study__strip{margin-top:var(--spacing-md);flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:clamp(.5rem,1.5vw,1rem);display:flex}.case-study__strip .case-study__thumb-wrap{flex:0 auto;width:auto;min-width:0}.case-study__frame{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-md);margin-top:var(--spacing-md)}.case-study__lightbox-backdrop{z-index:200;padding:max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));background:#0f172ad1;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.case-study__lightbox-close{top:max(.75rem, env(safe-area-inset-top));right:max(.75rem, env(safe-area-inset-right));z-index:201;border-radius:var(--radius-full);color:#fff;cursor:pointer;width:2.75rem;height:2.75rem;transition:background var(--transition-base);background:#ffffff1f;border:none;justify-content:center;align-items:center;display:flex;position:fixed}.case-study__lightbox-close:hover{background:#ffffff38}.case-study__lightbox-close:focus-visible{outline-offset:2px;outline:2px solid #fff}.case-study__lightbox-close svg{width:1.25rem;height:1.25rem;display:block}.case-study__lightbox-img-wrap{justify-content:center;align-items:center;max-width:min(96vw,1200px);max-height:min(88vh,900px);display:flex}.case-study__lightbox-img-wrap img,.case-study__lightbox-img-wrap .case-study__lightbox-video{-o-object-fit:contain;object-fit:contain;border:var(--case-study-img-border);border-radius:var(--case-study-img-radius);box-sizing:border-box;width:auto;max-width:100%;height:auto;max-height:min(88vh,900px);display:block}.case-study__hub-grid{gap:var(--spacing-lg);padding-top:var(--spacing-xl);padding-bottom:var(--spacing-3xl);display:grid}@media (width>=768px){.case-study__hub-grid{grid-template-columns:repeat(2,1fr)}}.case-study__hub-card{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg);transition:transform var(--transition-base), box-shadow var(--transition-base);color:inherit;flex-direction:column;text-decoration:none;display:flex}.case-study__hub-card:hover{box-shadow:var(--shadow-lg);color:inherit;transform:translateY(-4px)}.case-study__hub-card h2{margin-bottom:var(--spacing-sm);color:var(--color-text-primary);font-size:1.25rem}.case-study__hub-card p{margin-bottom:var(--spacing-md);flex:1}.case-study__hub-cta{color:var(--color-accent);font-weight:600}.case-study__skills-links{margin-top:var(--spacing-md);gap:var(--spacing-xs);flex-direction:column;display:flex}.case-study__skills-links a{font-size:.9375rem;font-weight:600}.case-study__case-split{gap:var(--spacing-lg);align-items:start;display:grid}@media (width>=900px){.case-study__case-split{grid-template-columns:1fr 1fr}}.case-study__case-split-media{gap:var(--spacing-md);flex-direction:column;min-width:0;display:flex}:root{color-scheme:light;--md-sys-color-primary:#9c4e38;--md-sys-color-on-primary:#fffaf8;--md-sys-color-primary-container:#f4e8e4;--md-sys-color-on-primary-container:#4c261c;--md-sys-color-secondary:#57534e;--md-sys-color-on-secondary:#faf7f2;--md-sys-color-secondary-container:#e7e5e4;--md-sys-color-on-secondary-container:#292524;--md-sys-color-tertiary:#78716c;--md-sys-color-on-tertiary:#faf7f2;--md-sys-color-tertiary-container:#e8e6e3;--md-sys-color-on-tertiary-container:#44403c;--md-sys-color-surface:#faf7f2;--md-sys-color-on-surface:#1c1917;--md-sys-color-on-surface-variant:#57534e;--md-sys-color-surface-container-highest:#fffef9;--md-sys-color-surface-variant:#f0ebe4;--md-sys-color-outline:#a8a29e;--md-sys-color-outline-variant:#d6d3ce;--md-sys-color-cta:var(--md-sys-color-primary);--md-sys-color-on-cta:var(--md-sys-color-on-primary);--md-sys-color-cta-hover:#b85c42;--gradient-primary:linear-gradient(135deg, #6d3a2c 0%, #9c4e38 48%, #c06d52 100%);--gradient-soft:linear-gradient(165deg, #fdfcfa 0%, #faf7f2 48%, #f8f5ef 100%);--gradient-hero:linear-gradient(165deg, #ebe4dc 0%, #efe8e0 28%, #f3ece4 55%, #f7f1ea 82%, #faf7f2 100%);--gradient-card:linear-gradient(180deg, #fffef9 0%, #faf6f0 100%);--color-bg:var(--md-sys-color-surface);--color-card:var(--md-sys-color-surface-container-highest);--color-text-primary:var(--md-sys-color-on-surface);--color-text-secondary:var(--md-sys-color-on-surface-variant);--color-hero-headline:var(--md-sys-color-on-surface)}@supports (color:color-mix(in lab, red, red)){:root{--color-hero-headline:color-mix(in srgb, var(--md-sys-color-on-surface) 62%, var(--md-sys-color-on-surface-variant) 38%)}}:root{--color-hero-subtext:var(--md-sys-color-on-surface-variant)}@supports (color:color-mix(in lab, red, red)){:root{--color-hero-subtext:color-mix(in srgb, var(--md-sys-color-on-surface-variant) 82%, var(--md-sys-color-surface) 18%)}}:root{--color-accent:var(--md-sys-color-primary);--color-accent-hover:#7a3d2c;--color-accent-light:var(--md-sys-color-primary)}@supports (color:color-mix(in lab, red, red)){:root{--color-accent-light:color-mix(in srgb, var(--md-sys-color-primary) 9%, var(--md-sys-color-surface))}}:root{--color-accent-tag-bg:var(--md-sys-color-primary-container);--color-accent-tag-text:var(--md-sys-color-on-primary-container);--color-border:var(--md-sys-color-outline)}@supports (color:color-mix(in lab, red, red)){:root{--color-border:color-mix(in srgb, var(--md-sys-color-outline) 22%, transparent)}}:root{--color-shadow:#1c191714;--home-bento-solitaire-rail:#634a3d;--font-primary:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display:"Fraunces", "Source Serif 4", "Georgia", "Times New Roman", serif;--font-mono:"JetBrains Mono", "Courier New", monospace;--spacing-xs:.5rem;--spacing-sm:1rem;--spacing-md:1.5rem;--spacing-lg:2rem;--spacing-xl:3rem;--spacing-2xl:4rem;--spacing-3xl:6rem;--hero-overlap-full:clamp(7rem, 11vw, 10rem);--hero-overlap-compact:clamp(5rem, 8vw, 7rem);--hero-subtitle-safe-space:clamp(1rem, 2.5vw, 2rem);--radius-sm:12px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--radius-full:9999px;--shadow-sm:0 1px 2px var(--color-shadow), 0 1px 3px 1px #1c19170a;--shadow-md:0 1px 3px #1c191712, 0 4px 12px 2px #1c19170f;--shadow-lg:0 4px 8px #1c191714, 0 12px 28px 4px #1c191712;--shadow-xl:0 8px 16px #1c191717, 0 24px 48px 6px #1c191714;--transition-fast:.2s ease-in-out;--transition-base:.25s ease-in-out;--transition-slow:.3s ease-in-out}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-primary);color:var(--color-text-primary);background:var(--gradient-soft);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-attachment:fixed;min-height:100vh;font-size:1rem;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-optical-sizing:auto;color:var(--color-text-primary);font-weight:600;line-height:1.2}h1{letter-spacing:-.02em;font-size:clamp(2.5rem,5vw,3.5rem);font-weight:700}h2{letter-spacing:-.01em;font-size:clamp(2rem,4vw,2.5rem)}h3{font-size:clamp(1.5rem,3vw,1.875rem)}p{color:var(--color-text-secondary);line-height:1.7}a{color:var(--color-accent);transition:all var(--transition-base);text-decoration:none}a:hover{color:var(--color-accent-hover)}a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}.site-container{max-width:1200px;padding:0 var(--spacing-md);margin:0 auto}@media (width>=768px){.site-container{padding:0 var(--spacing-lg)}}.section-title{font-family:var(--font-display);font-optical-sizing:auto;text-align:center;margin-bottom:var(--spacing-2xl);font-weight:600}.nav{z-index:100;background:var(--gradient-card);backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);position:sticky;top:0}.nav-container{max-width:1200px;padding:var(--spacing-md) var(--spacing-md);justify-content:space-between;align-items:center;gap:var(--spacing-md);margin:0 auto;display:flex}.nav-logo{font-family:var(--font-display);font-optical-sizing:auto;color:var(--color-text-primary);transition:all var(--transition-base);font-size:1.25rem;font-weight:700}.nav-logo:hover{color:var(--color-accent);transform:scale(1.05)}.nav-toggle{cursor:pointer;padding:var(--spacing-xs);z-index:101;border-radius:var(--radius-sm);transition:background var(--transition-base);background:0 0;border:none;flex-direction:column;gap:5px;display:flex}.nav-toggle:hover{background:var(--color-accent-light)}.nav-toggle span{background:var(--gradient-primary);width:24px;height:3px;transition:all var(--transition-base);border-radius:var(--radius-full)}.nav-toggle[aria-expanded=true] span:first-child{transform:rotate(45deg)translate(7px,7px)}.nav-toggle[aria-expanded=true] span:nth-child(2){opacity:0}.nav-toggle[aria-expanded=true] span:nth-child(3){transform:rotate(-45deg)translate(7px,-7px)}.nav-menu{gap:var(--spacing-md);align-items:center;list-style:none;display:flex}.nav-cta-item{list-style:none}@media (width>=768px){.nav-cta-item{margin-left:auto}}.nav-link{color:var(--color-text-secondary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);transition:all var(--transition-base);font-weight:500}.nav-link:hover{color:var(--color-accent);background:var(--color-accent-light)}.nav-link.active{color:var(--color-accent);background:var(--color-accent-light);font-weight:600}.nav-cta{background:var(--md-sys-color-cta);color:var(--md-sys-color-on-cta);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-md);box-shadow:0 2px 14px var(--md-sys-color-cta);font-weight:600}@supports (color:color-mix(in lab, red, red)){.nav-cta{box-shadow:0 2px 14px color-mix(in srgb, var(--md-sys-color-cta) 38%, transparent)}}.nav-cta{border:1px solid var(--md-sys-color-on-cta)}@supports (color:color-mix(in lab, red, red)){.nav-cta{border:1px solid color-mix(in srgb, var(--md-sys-color-on-cta) 18%, transparent)}}.nav-cta{transition:all var(--transition-base)}.nav-cta:hover{color:var(--md-sys-color-on-cta);background:var(--md-sys-color-cta-hover);box-shadow:0 6px 22px var(--md-sys-color-cta);transform:translateY(-4px)}@supports (color:color-mix(in lab, red, red)){.nav-cta:hover{box-shadow:0 6px 22px color-mix(in srgb, var(--md-sys-color-cta) 45%, transparent)}}@media (width<=767px){.nav-toggle{display:flex}.nav-menu{background:var(--gradient-card);width:80%;max-width:320px;height:100vh;padding:var(--spacing-2xl) var(--spacing-md);gap:var(--spacing-sm);box-shadow:var(--shadow-xl);transition:right var(--transition-base);border-left:1px solid var(--color-border);flex-direction:column;align-items:flex-start;position:fixed;top:0;right:-100%}.nav-menu[aria-expanded=true]{right:0}.nav-link{width:100%;padding:var(--spacing-sm);background:0 0;font-size:1.125rem}.nav-link:hover{background:0 0}.nav-link.active{color:var(--color-accent);background:0 0}.nav-cta-item{width:100%}.nav-cta{text-align:center;width:100%;margin-top:var(--spacing-sm);box-sizing:border-box;display:block}}@media (width>=768px){.nav-toggle{display:none}}.hero{height:70vh;padding-top:clamp(1rem, 2vh, var(--spacing-2xl));padding-bottom:calc(clamp(1rem, 2vh, var(--spacing-2xl)) + var(--hero-subtitle-safe-space));background:var(--gradient-hero);z-index:1;isolation:isolate;clip-path:polygon(0% 0%,100% 0%,100% 88%,99% 88.5%,97.5% 89.2%,95% 90.2%,92% 91.5%,88% 93%,83% 94.3%,77% 95.3%,70% 96%,62% 96.4%,50% 96.5%,38% 96.4%,30% 96%,23% 95.3%,17% 94.3%,12% 93%,8% 91.5%,5% 90.2%,2.5% 89.2%,1% 88.5%,0% 88%);align-items:stretch;padding-left:0;padding-right:0;display:flex;position:relative;overflow:visible;box-shadow:0 18px 40px -18px #1c191712}.hero--compact{height:auto;min-height:clamp(320px,44vh,460px);padding-bottom:calc(clamp(1rem, 2vh, var(--spacing-lg)) + var(--hero-subtitle-safe-space));flex-direction:column;justify-content:center;align-items:stretch}.hero--compact .site-container{flex:auto;justify-content:center;width:100%;min-height:0}.hero--compact .hero-content{flex:none;align-content:start;align-items:start;min-height:0}@media (width<=767px){.hero--compact{clip-path:none;height:auto;min-height:min(44vh,420px);padding-top:clamp(var(--spacing-lg), 7vw, var(--spacing-2xl));padding-bottom:clamp(var(--spacing-xl), 9vw, var(--spacing-3xl))}.hero--compact .hero-content{gap:var(--spacing-md)}.hero--compact .hero-graphic{display:none}.hero.hero--compact+*{margin-top:0}}.hero:before{content:"";background:radial-gradient(ellipse 85% 70% at 18% 22%, #ffffff8c 0%, transparent 52%), radial-gradient(ellipse 60% 55% at 92% 88%, var(--md-sys-color-primary) 0%, transparent 48%);position:absolute;inset:0}@supports (color:color-mix(in lab, red, red)){.hero:before{background:radial-gradient(ellipse 85% 70% at 18% 22%, #ffffff8c 0%, transparent 52%), radial-gradient(ellipse 60% 55% at 92% 88%, color-mix(in srgb, var(--md-sys-color-primary) 7%, transparent) 0%, transparent 48%)}}.hero:before{pointer-events:none}.hero .site-container{z-index:3;flex-direction:column;align-items:flex-start;width:100%;height:100%;min-height:0;display:flex;position:relative}.hero-content{gap:clamp(1rem, 2vh, var(--spacing-2xl));flex:1;grid-template-columns:1fr;align-content:start;align-items:start;width:100%;min-height:0;display:grid;overflow:visible}@media (width>=768px){.hero-content{gap:var(--spacing-3xl);grid-template-columns:1.5fr 1fr;align-content:start;align-items:start}.hero--compact .hero-content{grid-template-columns:1fr}.hero--compact .site-container>.hero-graphic{top:50%;right:var(--spacing-md);z-index:0;pointer-events:none;width:min(38%,340px);max-width:340px;margin:0;position:absolute;transform:translateY(-50%)}.hero--compact .site-container>.hero-graphic svg{max-width:100%;max-height:min(28vh,320px)}.hero--compact .site-container:has(>.hero-graphic)>.hero-content{z-index:1;padding-right:min(44%,400px);position:relative}}.hero-text{text-align:left;min-height:0;overflow:visible}.hero-text-with-icon{align-items:center;gap:clamp(.75rem,2vw,1.25rem);display:flex}.hero-leading-icon{-o-object-fit:cover;object-fit:cover;border-radius:1.1rem;flex-shrink:0;width:calc(clamp(4rem,8vw,5.5rem) + 40px);height:calc(clamp(4rem,8vw,5.5rem) + 40px);box-shadow:0 10px 24px #00000024}.hero-leading-icon--compact{width:calc(clamp(3.5rem,7vw,4.75rem) + 40px);height:calc(clamp(3.5rem,7vw,4.75rem) + 40px)}@media (width<=767px){.hero-text-with-icon{align-items:flex-start}}.hero-headline{margin-bottom:clamp(.5rem, 1.5vh, var(--spacing-lg));color:var(--color-hero-headline);text-shadow:0 1px #ffffff38;font-size:clamp(3rem,8vh,clamp(4rem,9vw,6rem));line-height:1.1}.hero-headline--compact{font-size:clamp(2rem,5vw,3rem);line-height:1.16}.hero-text-smaller{font-size:.7em;font-weight:400}.hero-subtext{margin-bottom:0;margin-top:clamp(.5rem, 1vh, var(--spacing-sm));color:var(--color-hero-subtext);text-align:left;white-space:normal;max-width:600px;font-size:clamp(1.125rem,2.6vh,1.35rem);line-height:1.4}.hero-subtext--compact{font-size:clamp(1rem,2.2vh,1.125rem)}.hero-graphic{justify-content:center;align-items:center;width:100%;max-width:700px;margin:-4rem auto 0;display:flex;overflow:visible}.hero-graphic svg{filter:drop-shadow(0 4px 16px #0000001a);width:100%;max-width:min(600px,35vh);height:auto;max-height:35vh}.hero-graphic--compact svg{max-width:min(400px,20vh);max-height:20vh}@media (width>=768px){.hero-graphic{max-width:60%;margin:-4rem 0 0 max(-8%,-4rem)}.hero-graphic svg{max-width:100%}}.hero-subtext strong{color:var(--color-hero-headline);font-weight:600}.hero-cta{gap:var(--spacing-md);margin-top:clamp(1rem, 2.5vh, var(--spacing-xl));flex-wrap:wrap;justify-content:flex-start;display:flex}.hero-scroll-hint{color:var(--color-text-secondary);flex-direction:column;justify-content:flex-end;align-self:center;align-items:center;gap:.125rem;margin-top:auto;padding-bottom:clamp(.25rem,1vh,.75rem);display:flex}@supports (color:color-mix(in lab, red, red)){.hero-scroll-hint{color:color-mix(in srgb, var(--color-text-secondary) 88%, transparent)}}.hero-scroll-hint{letter-spacing:.12em;text-transform:uppercase;user-select:none;font-size:.6875rem;font-weight:600}.hero-scroll-hint-icon{color:var(--color-text-secondary);display:flex}@media (prefers-reduced-motion:no-preference){.hero-scroll-hint-icon{animation:2.2s ease-in-out infinite hero-scroll-hint-bob}}@keyframes hero-scroll-hint-bob{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.hero+*{z-index:2;margin-top:calc(-1 * var(--hero-overlap-full));position:relative}.hero.hero--compact+*{margin-top:calc(-1 * var(--hero-overlap-compact))}.home-page{--home-bento-overlap:clamp(5.75rem, 10vw, 8.5rem);--home-hero-to-bento-gap:calc(var(--spacing-sm) - .5rem)}.home-page .hero+.home-layout-bento{margin-top:calc(-1 * var(--home-bento-overlap) + var(--home-hero-to-bento-gap))}.home-page .home-layout-bento{padding-top:calc(2 * var(--spacing-sm))}@media (width<=767px){.home-page{--home-bento-overlap:clamp(3.5rem, 8vw, 5rem)}}.nav-cards{gap:var(--spacing-sm);padding:var(--spacing-xl) var(--spacing-md);z-index:2;box-sizing:border-box;grid-template-columns:1fr;justify-items:center;width:100%;display:grid;position:relative}@media (width>=768px){.nav-cards{justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl) var(--spacing-lg);grid-template-columns:repeat(3,minmax(200px,1fr))}}@media (width>=1024px){.nav-cards{grid-template-columns:repeat(3,minmax(240px,280px))}}.nav-card{background:var(--gradient-card);border-radius:var(--radius-md);padding:var(--spacing-md);text-align:center;transition:all var(--transition-base);box-sizing:border-box;border:2px solid #0000;flex-direction:column;align-items:center;width:100%;min-width:200px;max-width:260px;min-height:100%;margin:0 auto;text-decoration:none;display:flex;box-shadow:0 8px 24px #00000026,0 4px 8px #0000001a}.nav-card:focus-visible{outline:3px solid var(--color-accent);outline-offset:3px}.nav-card:focus:not(:focus-visible){outline:none}@media (width>=768px){.nav-card{width:100%;min-width:200px;max-width:100%}}@media (width>=1024px){.nav-card{min-width:240px;max-width:280px}}.nav-card:hover{transform:translateY(-8px);box-shadow:0 12px 28px #1c19171a,0 6px 12px #1c19170f}.nav-card-icon{width:48px;height:48px;margin:0 auto var(--spacing-xs);color:var(--color-accent);transition:all var(--transition-base);justify-content:center;align-items:center;display:flex}.nav-card-icon svg{stroke-width:1.5px;width:100%;height:100%}.nav-card:hover .nav-card-icon{color:var(--color-accent-hover);transform:scale(1.1)}.nav-card-title{color:var(--color-text-primary);margin-bottom:.25rem;font-size:1rem}.nav-card-description{color:var(--color-text-secondary);flex:auto;font-size:.8125rem;font-weight:500;line-height:1.5}.nav-card-action{margin-top:var(--spacing-sm);letter-spacing:.02em;color:var(--color-accent);transition:color var(--transition-base), transform var(--transition-base);font-size:.8125rem;font-weight:700;display:inline-block}.nav-card:hover .nav-card-action,.nav-card:focus-visible .nav-card-action{color:var(--color-accent-hover)}.nav-card:hover .nav-card-action{transform:translate(2px)}.nav-card-skills .nav-card-action,.nav-card-contact .nav-card-action,.nav-card-projects .nav-card-action{color:var(--color-accent)}.nav-card-skills:hover .nav-card-action,.nav-card-skills:focus-visible .nav-card-action,.nav-card-contact:hover .nav-card-action,.nav-card-contact:focus-visible .nav-card-action,.nav-card-projects:hover .nav-card-action,.nav-card-projects:focus-visible .nav-card-action{color:var(--color-accent-hover)}.nav-card-skills{background:#f1ece6}.nav-card-skills .nav-card-title{color:var(--color-text-primary)}.nav-card-skills .nav-card-description{color:var(--color-text-secondary);font-weight:500}.nav-card-skills .nav-card-icon{color:var(--color-accent);font-family:var(--font-mono);white-space:nowrap;letter-spacing:-.35em;width:auto;min-width:48px;font-size:36px;font-weight:700;line-height:1}.nav-card-skills:hover .nav-card-icon{color:var(--color-accent-hover);transform:scale(1.1)}.nav-card-contact{background:#e8e4dc}.nav-card-contact .nav-card-title{color:var(--color-text-primary)}.nav-card-contact .nav-card-description{color:var(--color-text-secondary);font-weight:500}.nav-card-contact .nav-card-icon{color:var(--color-accent)}.nav-card-contact:hover .nav-card-icon{color:var(--color-accent-hover);transform:scale(1.1)}.nav-card-projects{background:#f6f3ee}.nav-card-projects .nav-card-title{color:var(--color-text-primary)}.nav-card-projects .nav-card-description{color:var(--color-text-secondary);font-weight:500}.nav-card-projects .nav-card-icon{color:var(--color-text-secondary)}.nav-card-projects:hover .nav-card-icon{color:var(--color-accent);transform:scale(1.1)}.home-page .hero{align-items:center;height:auto;min-height:min(72vh,700px);max-height:none}.home-page .hero-content{align-content:center;align-items:center}@media (width<=767px){.home-page .hero{min-height:min(68vh,620px)}.home-page .hero-graphic{margin-top:-1.5rem}.home-page .hero-graphic svg{max-width:min(260px,58vw);max-height:20vh}.home-page .hero-headline{font-size:clamp(2.25rem,10vw,3.25rem)}}.home-page .hero-text{border-left:3px solid var(--md-sys-color-primary)}@supports (color:color-mix(in lab, red, red)){.home-page .hero-text{border-left:3px solid color-mix(in srgb, var(--md-sys-color-primary) 38%, transparent)}}.home-page .hero-text{padding-left:var(--spacing-md);margin-left:0}@media (width>=768px){.home-page .hero-text{padding-left:var(--spacing-lg)}}.home-page .hero-cta{align-items:center}.home-page .home-hero-cta{border-radius:var(--radius-md);transition:background var(--transition-base), color var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);border:none;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:600;text-decoration:none}.home-page .home-hero-cta-primary{background:var(--md-sys-color-cta);color:var(--md-sys-color-on-cta);border:1px solid var(--md-sys-color-on-cta)}@supports (color:color-mix(in lab, red, red)){.home-page .home-hero-cta-primary{border:1px solid color-mix(in srgb, var(--md-sys-color-on-cta) 20%, transparent)}}.home-page .home-hero-cta-primary{box-shadow:0 4px 22px var(--md-sys-color-cta)}@supports (color:color-mix(in lab, red, red)){.home-page .home-hero-cta-primary{box-shadow:0 4px 22px color-mix(in srgb, var(--md-sys-color-cta) 38%, transparent)}}.home-page .home-hero-cta-primary:hover{background:var(--md-sys-color-cta-hover);color:var(--md-sys-color-on-cta);box-shadow:0 6px 26px var(--md-sys-color-cta);transform:translateY(-2px)}@supports (color:color-mix(in lab, red, red)){.home-page .home-hero-cta-primary:hover{box-shadow:0 6px 26px color-mix(in srgb, var(--md-sys-color-cta) 48%, transparent)}}.home-page .home-hero-cta-primary:focus-visible{outline:2px solid var(--md-sys-color-primary);outline-offset:3px}.home-page .home-hero-cta-link{color:var(--color-accent);text-underline-offset:.22em;text-decoration:underline 1px;text-decoration-color:var(--color-accent);align-items:center;margin-left:.125rem;padding:.35rem .25rem;font-size:.9375rem;font-weight:600;display:inline-flex}@supports (color:color-mix(in lab, red, red)){.home-page .home-hero-cta-link{text-decoration-color:color-mix(in srgb, var(--color-accent) 42%, transparent)}}.home-page .home-hero-cta-link{transition:color var(--transition-base), text-decoration-color var(--transition-base);background:0 0;border:none}.home-page .home-hero-cta-link:hover{color:var(--color-accent-hover);text-decoration-color:var(--color-accent-hover)}@supports (color:color-mix(in lab, red, red)){.home-page .home-hero-cta-link:hover{text-decoration-color:color-mix(in srgb, var(--color-accent-hover) 55%, transparent)}}.home-page .home-hero-cta-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px;border-radius:var(--radius-sm)}.home-page-narrow{max-width:960px}.home-page .nav-card,.home-page .nav-card-projects,.home-page .nav-card-skills,.home-page .nav-card-contact{background:var(--gradient-card);border:1px solid var(--color-border);transition:transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base), border-width var(--transition-base);box-shadow:0 4px 14px #00000012,0 2px 4px #0000000d}.home-page .nav-card-projects{border-top:3px solid var(--md-sys-color-outline-variant)}.home-page .nav-card-skills{border-top:3px solid var(--md-sys-color-primary)}.home-page .nav-card-contact{border-top:3px solid var(--md-sys-color-tertiary)}.home-page .nav-card-projects:hover,.home-page .nav-card-projects:focus-visible{border-top:1px solid var(--color-border);border-bottom:3px solid var(--md-sys-color-outline-variant)}.home-page .nav-card-skills:hover,.home-page .nav-card-skills:focus-visible{border-top:1px solid var(--color-border);border-bottom:3px solid var(--md-sys-color-primary)}.home-page .nav-card-contact:hover,.home-page .nav-card-contact:focus-visible{border-top:1px solid var(--color-border);border-bottom:3px solid var(--md-sys-color-tertiary)}.home-page .nav-card-skills .nav-card-title,.home-page .nav-card-contact .nav-card-title,.home-page .nav-card-projects .nav-card-title{color:var(--color-text-primary)}.home-page .nav-card-skills .nav-card-description,.home-page .nav-card-contact .nav-card-description,.home-page .nav-card-projects .nav-card-description{color:var(--color-text-secondary)}.home-page .nav-card-skills .nav-card-icon,.home-page .nav-card-contact .nav-card-icon,.home-page .nav-card-projects .nav-card-icon{color:var(--color-accent)}.home-page .nav-card-skills:hover .nav-card-icon,.home-page .nav-card-contact:hover .nav-card-icon,.home-page .nav-card-projects:hover .nav-card-icon{color:var(--color-accent-hover)}.home-page .nav-card-skills .nav-card-action,.home-page .nav-card-contact .nav-card-action,.home-page .nav-card-projects .nav-card-action{color:var(--color-accent)}.home-page .nav-card-skills:hover .nav-card-action,.home-page .nav-card-skills:focus-visible .nav-card-action,.home-page .nav-card-contact:hover .nav-card-action,.home-page .nav-card-contact:focus-visible .nav-card-action,.home-page .nav-card-projects:hover .nav-card-action,.home-page .nav-card-projects:focus-visible .nav-card-action{color:var(--color-accent-hover)}.home-page .nav-card:hover{transform:translateY(-4px);box-shadow:0 8px 22px #0000001a,0 3px 8px #0000000f}.btn{border-radius:var(--radius-md);transition:all var(--transition-base);cursor:pointer;font-size:1rem;font-weight:600;font-family:var(--font-primary);text-align:center;border:none;justify-content:center;align-items:center;padding:1rem 2rem;text-decoration:none;display:inline-flex}.btn-primary{background:var(--md-sys-color-cta);color:var(--md-sys-color-on-cta);box-shadow:var(--shadow-md);border:2px solid var(--md-sys-color-on-cta)}@supports (color:color-mix(in lab, red, red)){.btn-primary{border:2px solid color-mix(in srgb, var(--md-sys-color-on-cta) 22%, transparent)}}.btn-primary:hover{color:var(--md-sys-color-on-cta);background:var(--md-sys-color-cta-hover);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.btn-secondary{background:var(--gradient-card);color:var(--color-text-primary);border:2px solid var(--color-border);box-shadow:var(--shadow-md)}.btn-secondary:hover{color:var(--color-accent);background:var(--color-accent-light);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.home-page .home-layout-bento-tile-cta.btn-secondary{box-shadow:0 3px 10px var(--md-sys-color-primary)}@supports (color:color-mix(in lab, red, red)){.home-page .home-layout-bento-tile-cta.btn-secondary{box-shadow:0 3px 10px color-mix(in srgb, var(--md-sys-color-primary) 16%, #e8ddd0)}}.home-page .home-layout-bento-tile-cta.btn-secondary:hover,.home-page .home-layout-bento-tile-cta.btn-secondary:focus-visible{box-shadow:0 6px 16px var(--md-sys-color-primary)}@supports (color:color-mix(in lab, red, red)){.home-page .home-layout-bento-tile-cta.btn-secondary:hover,.home-page .home-layout-bento-tile-cta.btn-secondary:focus-visible{box-shadow:0 6px 16px color-mix(in srgb, var(--md-sys-color-primary) 22%, #ddcebd)}}.card{background:var(--gradient-card);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-md);border:1px solid var(--color-border);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.projects{padding-top:var(--spacing-xl);padding-bottom:var(--spacing-lg)}.projects .card{max-width:800px;margin:0 auto}.projects .card:hover{box-shadow:var(--shadow-md);transform:none}.projects-grid{gap:var(--spacing-xl);grid-template-columns:1fr;display:grid}.projects .projects-grid{grid-template-columns:1fr}@media (width>=768px){.projects-grid,.projects .projects-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.projects-grid,.projects .projects-grid{grid-template-columns:repeat(3,1fr)}}.project-card{background:var(--gradient-card);border-radius:var(--radius-lg);transition:all var(--transition-base);box-shadow:var(--shadow-md);border:1px solid var(--color-border);flex-direction:column;display:flex;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-8px)}.project-card-active{box-shadow:var(--shadow-lg)}.project-card-active:hover{box-shadow:var(--shadow-xl)}.project-card-coming-soon{opacity:.85;border:2px solid var(--color-border);filter:grayscale(60%)saturate(70%);position:relative}.project-card-coming-soon:before{content:"";background:linear-gradient(135deg, var(--md-sys-color-primary) 0%, var(--md-sys-color-tertiary) 100%);position:absolute;inset:0}@supports (color:color-mix(in lab, red, red)){.project-card-coming-soon:before{background:linear-gradient(135deg, color-mix(in srgb, var(--md-sys-color-primary) 8%, transparent) 0%, color-mix(in srgb, var(--md-sys-color-tertiary) 6%, transparent) 100%)}}.project-card-coming-soon:before{pointer-events:none;z-index:0}.project-card-coming-soon:hover{opacity:.9;transform:translateY(-4px)}.project-image{gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--gradient-soft);border-bottom:1px solid var(--color-border);z-index:1;display:flex;position:relative}.project-mockup{border-radius:var(--radius-md);background:var(--gradient-card);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);flex:1;overflow:hidden}.project-mockup-mobile{aspect-ratio:9/16;max-width:120px}.project-mockup-desktop{aspect-ratio:16/9;flex:2}.project-mockup img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;display:block}.mockup-placeholder{width:100%;height:100%;color:var(--color-text-secondary);background:var(--gradient-soft);justify-content:center;align-items:center;font-size:.875rem;display:flex}.project-content{padding:var(--spacing-lg);z-index:1;flex-direction:column;flex:1;display:flex;position:relative}.project-content h4{padding-bottom:var(--spacing-md)}.project-title{margin-bottom:var(--spacing-sm);align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;font-size:1.5rem;display:flex}.project-title-icon{-o-object-fit:cover;object-fit:cover;border-radius:8px;flex-shrink:0;width:2rem;height:2rem}.project-title-icon-placeholder{background:var(--gradient-soft);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1.25rem;display:inline-flex}.project-description{margin-bottom:var(--spacing-md);font-size:.9375rem}.project-tags{gap:var(--spacing-xs);margin-bottom:var(--spacing-md);flex-wrap:wrap;display:flex}.chip-groups{gap:var(--spacing-md);margin-bottom:var(--spacing-md);grid-template-columns:1fr;display:grid}.chip-groups .chip-group{min-width:0}@media (width>=768px){.chip-groups{align-items:start;gap:var(--spacing-lg);grid-template-columns:1fr 1fr}}.chip-group-title{margin:0 0 var(--spacing-md) 0;font-size:.95rem}.project-tags .year-chip:first-child{margin-left:0}.project-links{gap:var(--spacing-sm);flex-wrap:wrap;margin-top:auto;display:flex}.project-links-vertical{flex-direction:column;align-items:flex-start}.tech-tag{font-family:var(--font-mono);background:var(--color-accent-tag-bg);color:var(--color-accent-tag-text);border-radius:var(--radius-full);transition:all var(--transition-base);padding:.5rem 1rem;font-size:.8125rem;font-weight:500;display:inline-block}.tech-tag:hover{background:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);transform:scale(1.05)}.skills{padding-top:var(--spacing-xl);padding-bottom:var(--spacing-3xl)}.skills-grid{gap:var(--spacing-xl);grid-template-columns:1fr;display:grid}@media (width>=640px){.skills-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.skills-grid{grid-template-columns:repeat(3,1fr)}}.skill-group{background:var(--gradient-card);padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-md);transition:all var(--transition-base);text-align:left}.skill-group:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.skill-group-title{margin-bottom:var(--spacing-md);color:var(--color-text-primary);font-size:1.5rem}.skill-list{gap:var(--spacing-sm);flex-wrap:wrap;list-style:none;display:flex}.skill-list li{display:flex}.about{padding-top:var(--spacing-xl);padding-bottom:var(--spacing-3xl)}.about-card{background:var(--gradient-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border);text-align:left}.about-card h3{margin-bottom:var(--spacing-md)}.about-text{margin-bottom:var(--spacing-md);font-size:1.0625rem}.about-text:last-child{margin-bottom:0}.contact{padding-top:var(--spacing-xl);padding-bottom:var(--spacing-3xl)}.contact-content{text-align:center;max-width:1000px;margin:0 auto}.contact-grid{gap:var(--spacing-xl);grid-template-columns:1fr;display:grid}@media (width>=768px){.contact-grid{grid-template-columns:2fr 1fr}}.contact-intro{background:var(--gradient-card);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.contact-text{margin-bottom:var(--spacing-lg);color:var(--color-text-secondary);font-size:1.125rem}.contact-links-column{justify-content:center;align-items:flex-start;display:flex}.contact-links-card{background:var(--gradient-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border);text-align:left;width:100%;max-width:320px}.contact-links{gap:var(--spacing-md);flex-direction:column;width:100%;display:flex}.contact-link{background:var(--gradient-card);padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);box-shadow:var(--shadow-md);border:2px solid var(--color-border);transition:all var(--transition-base);align-items:center;gap:var(--spacing-sm);color:var(--color-text-primary);font-size:1rem;font-weight:600;text-decoration:none;display:inline-flex}.contact-link:hover{color:var(--color-accent);background:var(--color-accent-light);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.contact-link--cta{background:var(--md-sys-color-cta);color:var(--md-sys-color-on-cta);border-color:var(--md-sys-color-on-cta)}@supports (color:color-mix(in lab, red, red)){.contact-link--cta{border-color:color-mix(in srgb, var(--md-sys-color-on-cta) 22%, transparent)}}.contact-link--cta{box-shadow:0 2px 14px var(--md-sys-color-cta)}@supports (color:color-mix(in lab, red, red)){.contact-link--cta{box-shadow:0 2px 14px color-mix(in srgb, var(--md-sys-color-cta) 32%, transparent)}}.contact-link--cta:hover{color:var(--md-sys-color-on-cta);background:var(--md-sys-color-cta-hover);border-color:var(--md-sys-color-on-cta)}@supports (color:color-mix(in lab, red, red)){.contact-link--cta:hover{border-color:color-mix(in srgb, var(--md-sys-color-on-cta) 18%, transparent)}}.contact-link--cta:hover{box-shadow:0 6px 22px var(--md-sys-color-cta)}@supports (color:color-mix(in lab, red, red)){.contact-link--cta:hover{box-shadow:0 6px 22px color-mix(in srgb, var(--md-sys-color-cta) 42%, transparent)}}.contact-link--cta:focus-visible{outline:2px solid var(--md-sys-color-cta-hover);outline-offset:3px}.contact-form{background:var(--gradient-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border);text-align:left;max-width:600px;margin:0 auto}.form-group{margin-bottom:var(--spacing-md);text-align:left}.form-label{margin-bottom:var(--spacing-xs);color:var(--color-text-primary);font-weight:500;display:block}.form-input,.form-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-primary);transition:all var(--transition-base);background:var(--color-card);color:var(--color-text-primary);font-size:1rem}.form-input:focus,.form-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light);outline:none}.form-textarea{resize:vertical;min-height:150px}.form-input::-moz-placeholder{color:var(--color-text-secondary);opacity:.85}.form-textarea::-moz-placeholder{color:var(--color-text-secondary);opacity:.85}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-secondary);opacity:.85}.contact-form-alert{padding:var(--spacing-md);margin-bottom:var(--spacing-md);border-radius:var(--radius-sm);border:1px solid var(--color-border);font-weight:500}.contact-form-alert--success{background:var(--md-sys-color-primary-container)}@supports (color:color-mix(in lab, red, red)){.contact-form-alert--success{background:color-mix(in srgb, var(--md-sys-color-primary-container) 72%, var(--md-sys-color-surface))}}.contact-form-alert--success{color:var(--md-sys-color-on-primary-container);border-color:var(--md-sys-color-primary)}@supports (color:color-mix(in lab, red, red)){.contact-form-alert--success{border-color:color-mix(in srgb, var(--md-sys-color-primary) 24%, transparent)}}.contact-form-alert--error{background:#cf6679}@supports (color:color-mix(in lab, red, red)){.contact-form-alert--error{background:color-mix(in srgb, #cf6679 28%, var(--md-sys-color-surface))}}.contact-form-alert--error{color:#3d1119;border-color:#cf66795c}.footer{padding:var(--spacing-xl) 0;border-top:1px solid var(--color-border);background:var(--gradient-card);margin-top:var(--spacing-3xl)}.footer-inner{align-items:center;gap:var(--spacing-md);text-align:center;flex-direction:column;display:flex}@media (width>=640px){.footer-inner{text-align:left;flex-flow:wrap;justify-content:space-between;align-items:center}}.footer-text{color:var(--color-text-secondary);margin:0;font-size:.875rem}.footer-links{gap:var(--spacing-md);flex-wrap:wrap;justify-content:center;display:flex}@media (width>=640px){.footer-links{justify-content:flex-end}}.footer-link{color:var(--color-accent);transition:color var(--transition-base);font-size:.875rem;font-weight:600;text-decoration:none}.footer-link:hover{color:var(--color-accent-hover);text-decoration:underline}.carousel{width:100%;margin:0 auto;position:relative}.carousel-viewport{border-radius:var(--radius-xl);background:var(--gradient-soft);width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--color-border);position:relative;overflow:hidden}.carousel-media-trigger{border-radius:inherit;cursor:zoom-in;width:100%;height:100%;color:inherit;background:0 0;border:none;margin:0;padding:0;display:block}.carousel-media-trigger:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.carousel-track{will-change:transform;transition:transform .6s cubic-bezier(.4,0,.2,1);display:flex}.carousel-slide{opacity:0;pointer-events:none;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;min-width:100%;transition:opacity .6s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.carousel-slide.active{opacity:1;pointer-events:auto}.carousel-media{-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;width:100%;height:100%;max-height:none;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;display:block}.carousel-slide video{background:0 0}.carousel-slide img[src*=landscape]{max-width:none;max-height:none}.carousel-slide-text{padding:var(--spacing-sm) var(--spacing-md);color:#fff;text-align:center;border-radius:0 0 var(--radius-xl) var(--radius-xl);backdrop-filter:blur(2px);background:linear-gradient(#0000 0%,#0003 50%,#00000080 100%);justify-content:center;align-items:center;height:2.5rem;font-size:.8125rem;font-weight:500;display:flex;position:absolute;bottom:0;left:0;right:0}.carousel-controls{justify-content:center;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding:0 var(--spacing-xs);display:flex}.carousel-btn{background:var(--gradient-card);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;width:40px;height:40px;transition:all var(--transition-base);color:var(--color-text-primary);box-shadow:var(--shadow-md);flex-shrink:0;justify-content:center;align-items:center;display:flex}.carousel-btn:hover{color:var(--color-accent);background:var(--color-accent-light);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.carousel-btn:active{transform:scale(.95)}.carousel-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.carousel-btn svg{stroke-width:2.5px;width:18px;height:18px}.carousel-indicators{padding:0 var(--spacing-sm);align-items:center;gap:.5rem;display:flex}.carousel-indicator{border-radius:var(--radius-full);background:var(--md-sys-color-primary);border:none;width:8px;height:8px}@supports (color:color-mix(in lab, red, red)){.carousel-indicator{background:color-mix(in srgb, var(--md-sys-color-primary) 32%, transparent)}}.carousel-indicator{cursor:pointer;padding:0;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.carousel-indicator:before{content:"";border-radius:var(--radius-full);background:0 0;transition:background .3s;position:absolute;inset:-4px}.carousel-indicator:hover:before{background:var(--md-sys-color-primary)}@supports (color:color-mix(in lab, red, red)){.carousel-indicator:hover:before{background:color-mix(in srgb, var(--md-sys-color-primary) 12%, transparent)}}.carousel-indicator.active{background:var(--color-accent);width:24px;box-shadow:0 2px 8px var(--md-sys-color-primary)}@supports (color:color-mix(in lab, red, red)){.carousel-indicator.active{box-shadow:0 2px 8px color-mix(in srgb, var(--md-sys-color-primary) 35%, transparent)}}.carousel-indicator:hover{background:var(--md-sys-color-primary)}@supports (color:color-mix(in lab, red, red)){.carousel-indicator:hover{background:color-mix(in srgb, var(--md-sys-color-primary) 45%, transparent)}}.carousel-indicator.active:hover{background:var(--color-accent-hover)}.project-detail-hero{text-align:center;padding:var(--spacing-3xl) 0;background:var(--gradient-hero);z-index:1;position:relative;overflow:hidden;box-shadow:0 16px 36px -16px #1c19170f}.project-detail-hero:before{content:"";background:radial-gradient(ellipse 80% 65% at 50% 18%, #ffffff80 0%, transparent 50%), radial-gradient(ellipse 55% 50% at 88% 92%, var(--md-sys-color-primary) 0%, transparent 45%);position:absolute;inset:0}@supports (color:color-mix(in lab, red, red)){.project-detail-hero:before{background:radial-gradient(ellipse 80% 65% at 50% 18%, #ffffff80 0%, transparent 50%), radial-gradient(ellipse 55% 50% at 88% 92%, color-mix(in srgb, var(--md-sys-color-primary) 7%, transparent) 0%, transparent 45%)}}.project-detail-hero:before{pointer-events:none}.project-detail-hero .site-container{z-index:1;position:relative}.project-detail-icon{border-radius:var(--radius-lg);width:112px;height:112px;box-shadow:var(--shadow-xl);margin:0 auto var(--spacing-lg);background:var(--gradient-card);display:block}.project-detail-hero h2{color:var(--color-hero-headline);text-shadow:0 1px #ffffff38}.project-detail-hero p{color:var(--color-hero-subtext)}.project-detail-section{background:var(--gradient-card);padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid var(--color-border);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-md)}.project-detail-section h3{margin-bottom:var(--spacing-md);font-size:1.5rem}.project-detail-section ul{padding-left:var(--spacing-lg);margin-top:var(--spacing-sm);list-style:outside}.project-detail-section li{margin-bottom:var(--spacing-xs);color:var(--color-text-secondary)}.project-link{align-items:center;gap:var(--spacing-xs);border-radius:var(--radius-md);border:2px solid var(--color-border);background:var(--gradient-card);color:var(--color-text-primary);transition:all var(--transition-base);box-shadow:var(--shadow-md);padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;display:inline-flex}.project-link:hover{color:var(--color-accent);background:var(--color-accent-light);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.project-link--primary{background:var(--md-sys-color-cta);color:var(--md-sys-color-on-cta);border-color:var(--md-sys-color-on-cta)}@supports (color:color-mix(in lab, red, red)){.project-link--primary{border-color:color-mix(in srgb, var(--md-sys-color-on-cta) 22%, transparent)}}.project-link--primary{box-shadow:0 2px 14px var(--md-sys-color-cta)}@supports (color:color-mix(in lab, red, red)){.project-link--primary{box-shadow:0 2px 14px color-mix(in srgb, var(--md-sys-color-cta) 32%, transparent)}}.project-link--primary:hover{color:var(--md-sys-color-on-cta);background:var(--md-sys-color-cta-hover);border-color:var(--md-sys-color-on-cta)}@supports (color:color-mix(in lab, red, red)){.project-link--primary:hover{border-color:color-mix(in srgb, var(--md-sys-color-on-cta) 18%, transparent)}}.project-link--primary:hover{box-shadow:0 6px 22px var(--md-sys-color-cta)}@supports (color:color-mix(in lab, red, red)){.project-link--primary:hover{box-shadow:0 6px 22px color-mix(in srgb, var(--md-sys-color-cta) 42%, transparent)}}.project-link--primary:focus-visible{outline:2px solid var(--md-sys-color-cta-hover);outline-offset:3px}.project-link svg{width:18px;height:18px}.btn svg,.btn-secondary svg,.project-link svg,.contact-link svg,.btn:hover svg,.btn-secondary:hover svg,.project-link:hover svg,.contact-link:hover svg{fill:currentColor}svg.github-mark,svg.github-mark path,.project-link svg.github-mark,.project-link:hover svg.github-mark,.btn svg.github-mark,.btn:hover svg.github-mark,.btn-secondary svg.github-mark,.btn-secondary:hover svg.github-mark,.contact-link svg.github-mark,.contact-link:hover svg.github-mark{fill:#000}.contact-link[href*=linkedin] svg,.contact-link[href*=linkedin]:hover svg{fill:#0077b5}.project-link.disabled{opacity:.5;cursor:not-allowed}.project-link.disabled:hover{background:var(--gradient-card);color:var(--color-text-primary);border-color:var(--color-border);box-shadow:var(--shadow-sm);transform:none}.archived-projects{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:2px solid var(--color-border)}.archived-projects .section-title{margin-bottom:var(--spacing-xl)}.archived-projects .project-image{padding:var(--spacing-xl);justify-content:center}.archived-projects .project-mockup-mobile{aspect-ratio:auto;width:auto;max-width:none;box-shadow:none;background:0 0;border:none;flex:none}.archived-projects .project-mockup img{-o-object-fit:contain;object-fit:contain;width:auto;max-width:100%;height:auto;max-height:200px}.year-chip{font-family:var(--font-mono);background:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);border:1px solid var(--md-sys-color-primary);padding:.5rem 1rem;font-size:.8125rem;font-weight:500;display:inline-block}@supports (color:color-mix(in lab, red, red)){.year-chip{border:1px solid color-mix(in srgb, var(--md-sys-color-primary) 22%, transparent)}}.year-chip{border-radius:var(--radius-full);transition:all var(--transition-base);margin-left:var(--spacing-xs)}.year-chip:hover{background:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);border-color:var(--md-sys-color-on-primary)}@supports (color:color-mix(in lab, red, red)){.year-chip:hover{border-color:color-mix(in srgb, var(--md-sys-color-on-primary) 22%, transparent)}}.year-chip:hover{transform:scale(1.05)}.project-header{gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-direction:column;display:flex}.project-header-row{align-items:center;gap:var(--spacing-md);display:flex}.project-header-icon{border-radius:var(--radius-md);width:80px;height:80px;box-shadow:var(--shadow-md);margin:0}.project-header-row>img[src*=kmp-solitaire-app-icon\.png]{-o-object-fit:cover;object-fit:cover;background:0 0;border-radius:22.37%;display:block}.project-title-icon[src*=kmp-solitaire-app-icon\.png]{border-radius:22.37%}.project-header-title{margin:0;display:inline-block}.project-year-tag{margin-left:var(--spacing-sm)}.hero-subtext-centered{max-width:700px;margin:0 auto}.project-section{padding-bottom:var(--spacing-2xl)}.project-detail-hero+.project-section{padding-top:var(--spacing-xl)}.project-detail{padding-top:var(--spacing-xl);padding-bottom:var(--spacing-3xl)}.stitch-tracker-detail.project-detail{padding-top:var(--spacing-lg);padding-bottom:var(--spacing-md)}.stitch-tracker-detail .project-header{gap:var(--spacing-sm)}.stitch-tracker-detail .chip-groups{padding-top:var(--spacing-lg)}.stitch-tracker-detail .engineering-snapshot-row{position:relative}@media (width>=768px){.stitch-tracker-detail .engineering-snapshot-col-text{width:calc(50% - .75rem);max-width:calc(50% - .75rem)}.stitch-tracker-detail .engineering-snapshot-col-carousel{flex-direction:column;height:100%;min-height:0;display:flex;position:absolute;top:0;left:calc(50% + .75rem);right:0}}.carousel--fill{flex-direction:column;height:100%;min-height:0;display:flex}.carousel--fill .carousel-viewport{flex:auto;min-height:0}@media (width<=767.98px){.carousel--fill{height:auto}.carousel--fill .carousel-viewport{flex:none;height:570px;min-height:570px}}#stitch-counter-case-studies.project-detail{padding-top:var(--spacing-md);padding-bottom:var(--spacing-lg)}.project-detail-stat-tile{padding:var(--spacing-md) var(--spacing-lg);align-items:flex-start;gap:var(--spacing-sm);flex-direction:column;display:flex}.project-detail-stat-tile--metric{background:var(--md-sys-color-primary-container)}@supports (color:color-mix(in lab, red, red)){.project-detail-stat-tile--metric{background:color-mix(in srgb, var(--md-sys-color-primary-container) 55%, var(--md-sys-color-surface))}}.project-detail-stat-tile--metric{border:1px solid var(--color-border);border-top:3px solid var(--md-sys-color-cta);border-radius:var(--radius-md)}.project-detail-stat-tile__label{color:var(--color-text-secondary);font-size:.875rem;line-height:1.4}.project-detail-stat-tile__value{color:var(--md-sys-color-cta);font-size:1.25rem;font-weight:600;line-height:1.35}.text-neutral-900{color:var(--color-text-primary)}.text-neutral-600,.text-neutral-500{color:var(--color-text-secondary)}.text-neutral-400{color:var(--md-sys-color-on-surface-variant)}@supports (color:color-mix(in lab, red, red)){.text-neutral-400{color:color-mix(in srgb, var(--md-sys-color-on-surface-variant) 85%, transparent)}}.bg-neutral-50{background:var(--md-sys-color-surface-container-highest)}@supports (color:color-mix(in lab, red, red)){.bg-neutral-50{background:color-mix(in srgb, var(--md-sys-color-surface-container-highest) 88%, var(--md-sys-color-surface))}}.bg-neutral-100{background:var(--md-sys-color-primary)}@supports (color:color-mix(in lab, red, red)){.bg-neutral-100{background:color-mix(in srgb, var(--md-sys-color-primary) 8%, var(--md-sys-color-surface))}}.border-neutral-200{border-color:var(--color-border)}.text-accent-link{color:var(--color-accent);text-underline-offset:.18em;text-decoration:underline 1px;text-decoration-color:var(--color-accent)}@supports (color:color-mix(in lab, red, red)){.text-accent-link{text-decoration-color:color-mix(in srgb, var(--color-accent) 45%, transparent)}}.text-accent-link{transition:color var(--transition-base), text-decoration-color var(--transition-base)}.text-accent-link:hover{color:var(--color-accent-hover);text-decoration-color:var(--color-accent-hover)}@supports (color:color-mix(in lab, red, red)){.text-accent-link:hover{text-decoration-color:color-mix(in srgb, var(--color-accent-hover) 55%, transparent)}}.text-neutral-700{color:var(--color-text-secondary)}.leading-relaxed{line-height:1.7}.text-base{font-size:1rem}.mb-6{margin-bottom:var(--spacing-md)}.mt-6{margin-top:var(--spacing-md)}.mb-8{margin-bottom:var(--spacing-lg)}.inline-block{display:inline-block}.mx-auto{margin-left:auto;margin-right:auto}.korge-solitaire-embed-shell{max-width:calc(1.77778*min(85vh,720px))}.korge-solitaire-embed-ratio{width:100%;padding-top:56.25%;position:relative}@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-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
