@import "https://fonts.googleapis.com/css2?family=Archivo:wght@300;400;500;600;700&family=Space+Grotesk:wght@300;400;500;600;700&display=swap";@layer components;@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-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}}}@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;--spacing:.25rem;--radius-sm:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--font-display:"Archivo", "Segoe UI", sans-serif;--font-body:"Space Grotesk", "Segoe UI", sans-serif;--color-primary:oklch(59% .19 257);--color-accent:oklch(73% .11 196);--color-surface:oklch(98% .01 256);--color-surface-elevated:oklch(100% 0 0);--color-text:oklch(29% .03 258);--color-text-muted:oklch(45% .03 257);--color-danger:oklch(63% .21 25);--color-line:oklch(86% .02 256)}}@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 utilities{.static{position:static}.end{inset-inline-end:var(--spacing)}.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}}.block{display:block}.hidden{display:none}.inline{display:inline}.table{display:table}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.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,)}}:root{--bg:var(--color-surface);--bg-deep:var(--color-surface-elevated);--text:var(--color-text);--text-soft:var(--color-text-muted);--line:var(--color-line);--brand:var(--color-primary);--brand-soft:#dbeafc}@supports (color:color-mix(in lab, red, red)){:root{--brand-soft:color-mix(in oklab, var(--color-primary), white 84%)}}:root{--danger:var(--color-danger);--shadow-color:var(--color-text);--shadow:4px 4px 0px var(--shadow-color);--shadow-hover:6px 6px 0px var(--brand);--font-heading:var(--font-display);--bg-grad-1:#c8eced}@supports (color:color-mix(in lab, red, red)){:root{--bg-grad-1:color-mix(in oklab, var(--color-accent), white 72%)}}:root{--bg-grad-2:#cee2fb}@supports (color:color-mix(in lab, red, red)){:root{--bg-grad-2:color-mix(in oklab, var(--color-primary), white 78%)}}:root{--bg-grad-3:var(--bg);--bg-grad-4:oklch(59% .19 257)}@supports (color:color-mix(in lab, red, red)){:root{--bg-grad-4:color-mix(in oklab, var(--color-primary), var(--bg) 92%)}}:root{--radius-sm:0px;--radius-md:0px;--radius-lg:0px;--radius-pill:0px;--border-width:2px}:root[data-theme=dark]{--bg:oklch(21% .03 258);--bg-deep:oklch(16% .03 258);--text:oklch(95% .01 256);--text-soft:oklch(77% .03 256);--line:oklch(39% .03 258);--brand:oklch(69% .14 254);--brand-soft:oklch(38% .09 252);--danger:oklch(71% .17 23);--shadow-color:oklch(47% .04 257);--bg-grad-1:var(--bg)}@supports (color:color-mix(in lab, red, red)){:root[data-theme=dark]{--bg-grad-1:color-mix(in oklab, var(--bg), var(--brand) 8%)}}:root[data-theme=dark]{--bg-grad-2:var(--brand)}@supports (color:color-mix(in lab, red, red)){:root[data-theme=dark]{--bg-grad-2:color-mix(in oklab, var(--brand), var(--bg) 70%)}}:root[data-theme=dark]{--bg-grad-3:var(--bg);--bg-grad-4:var(--bg-deep)}@supports (color:color-mix(in lab, red, red)){:root[data-theme=dark]{--bg-grad-4:color-mix(in oklab, var(--bg-deep), black 12%)}}*{box-sizing:border-box}html,body,#root{min-height:100%}body{font-family:var(--font-body);color:var(--text);background:radial-gradient(circle at 10% 10%, var(--bg-grad-1) 0, transparent 34%), radial-gradient(circle at 85% 8%, var(--bg-grad-2) 0, transparent 36%), linear-gradient(180deg, var(--bg-grad-3) 0%, var(--bg-grad-4) 100%), var(--bg);text-rendering:optimizelegibility;margin:0;line-height:1.6}body:before{content:"";pointer-events:none;opacity:.07;background-image:radial-gradient(circle at 1px 1px, var(--text) 1px, transparent 0);mix-blend-mode:multiply;z-index:-1;background-size:14px 14px;position:fixed;inset:0}*{transition:background-color .2s,border-color .2s,color .2s}input,textarea,select,button,a{color:inherit}img{aspect-ratio:auto}h1,h2,h3{color:var(--text);margin:0;line-height:1.2}h1,h2{font-family:var(--font-heading)}h1{letter-spacing:-.02em;font-size:clamp(2rem,6vw,3.6rem)}h2{font-size:clamp(1.5rem,3vw,2.1rem)}p{color:var(--text-soft);margin:0}.page-shell{background:var(--bg-deep);width:min(1120px,100%);margin:0 auto}@supports (color:color-mix(in lab, red, red)){.page-shell{background:color-mix(in oklab, var(--bg-deep), transparent 5%)}}.page-shell{border-inline:none;min-height:100vh}.app-suspense-fallback{min-height:100vh}.container{width:min(900px,100% - 1.25rem);margin:0 auto}.site-header{z-index:10;background:var(--bg-deep);border-bottom:2px solid var(--text);flex-direction:column;justify-content:flex-start;align-items:stretch;gap:1rem;padding:1.5rem 1rem;display:flex;position:sticky;top:0}.header-controls{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.75rem;width:100%;display:flex}.nav-toggle{border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep);font:inherit;cursor:pointer;box-shadow:2px 2px 0px var(--shadow-color);padding:.35rem .7rem;font-size:.86rem;font-weight:700}.brand{font-weight:800;font-family:var(--font-heading);text-transform:uppercase;letter-spacing:-.02em;text-decoration:none}.site-nav{border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep);width:100%;box-shadow:4px 4px 0px var(--shadow-color);flex-direction:column;align-items:flex-start;gap:.35rem;padding:.55rem;display:none}.site-nav.expanded{display:flex}.site-nav a{color:var(--text-soft);text-transform:uppercase;border:1px solid #0000;width:100%;padding:.4rem .6rem;font-size:.9rem;font-weight:600;text-decoration:none;position:relative}.site-nav a:hover{color:var(--text);border-color:var(--text)}.site-nav a.active{color:var(--bg-deep);background:var(--text);border-color:var(--text)}.site-nav a.active:after{display:none}.theme-toggle{border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep);font:inherit;cursor:pointer;box-shadow:2px 2px 0px var(--shadow-color);align-items:center;gap:.35rem;padding:.35rem .65rem;font-size:.86rem;display:inline-flex}.theme-toggle:hover,.nav-toggle:hover{box-shadow:3px 3px 0px var(--brand);transform:translate(-1px,-1px)}.theme-toggle span:last-child,.social-inline a span{display:none}:root[data-theme=dark] .outcome{background:var(--brand)}@supports (color:color-mix(in lab, red, red)){:root[data-theme=dark] .outcome{background:color-mix(in oklab, var(--brand), var(--bg-deep) 76%)}}:root[data-theme=dark] .outcome{border-color:var(--brand);color:var(--text)}.eyebrow{text-transform:uppercase;letter-spacing:.15em;color:var(--brand);font-size:.85rem;font-weight:700}.hero-copy,.hero-intro{max-width:68ch;margin-top:.85rem}.hero-actions{flex-wrap:wrap;gap:.8rem;margin-top:1.2rem;display:flex}.hero-kpis{grid-template-columns:1fr;gap:.8rem;margin-top:1.2rem;display:grid}.hero-kpis article{border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep);box-shadow:var(--shadow);padding:1.2rem;transition:transform .2s,box-shadow .2s}.hero-kpis article:hover{box-shadow:var(--shadow-hover);transform:translate(-2px,-2px)}.hero-kpis strong{letter-spacing:-.02em;font-size:1.5rem;font-family:var(--font-heading)}.button{border:var(--border-width) solid var(--shadow-color);cursor:pointer;box-shadow:4px 4px 0px var(--shadow-color);text-transform:uppercase;letter-spacing:.05em;justify-content:center;align-items:center;padding:.75rem 1.5rem;font-weight:700;text-decoration:none;transition:transform .2s,box-shadow .2s;display:inline-flex}.button:hover{box-shadow:6px 6px 0px var(--text);transform:translate(-2px,-2px)}.button:active{box-shadow:2px 2px 0px var(--shadow-color);transform:translate(1px,1px)}.button:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.button.solid{background:var(--brand);color:var(--bg-deep)}.button.ghost{background:var(--bg-deep);border-color:var(--shadow-color)}.section-block{border-top:1px solid var(--line);content-visibility:auto;contain-intrinsic-size:1px 620px;gap:1rem;padding:2.1rem 0;display:grid}.split-layout{grid-template-columns:1fr;align-items:start}.section-head{flex-direction:column;justify-content:flex-start;align-items:flex-start;gap:1rem;display:flex}.card-grid{grid-template-columns:1fr;gap:1rem;display:grid}.card{background:var(--bg-deep);border:var(--border-width) solid var(--shadow-color);box-shadow:var(--shadow);gap:.8rem;padding:1.5rem;transition:transform .2s,box-shadow .2s;display:grid;container-type:inline-size}.card:hover{box-shadow:var(--shadow-hover);transform:translate(-3px,-3px)}.outcome{color:var(--brand);background:var(--brand);font-weight:700}@supports (color:color-mix(in lab, red, red)){.outcome{background:color-mix(in oklab, var(--brand), var(--bg-deep) 84%)}}.outcome{border:var(--border-width) solid var(--brand);box-shadow:2px 2px 0px var(--brand);padding:.5rem .65rem}.chip-row{flex-wrap:wrap;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.chip-row li,.chip-row span{border:var(--border-width) solid var(--shadow-color);color:var(--text-soft);box-shadow:2px 2px 0px var(--shadow-color);padding:.2rem .65rem;font-size:.85rem;font-weight:600}.row-links{flex-wrap:wrap;gap:1rem;display:flex}.row-links a,.section-head a,.card a,.blog-item a,.post-content+a{color:var(--brand);font-weight:700;text-decoration:none}.timeline{gap:.9rem;display:grid}.timeline-item{border-left:3px solid var(--brand-soft);padding:.25rem 0 .25rem .85rem}.meta{color:var(--text-soft);font-size:.85rem}.blog-list{gap:1rem;display:grid}.blog-list-grid{grid-template-columns:1fr}.blog-toolbar{grid-template-columns:1fr;gap:.8rem;display:grid}.blog-filter-field{min-width:0}.blog-filter-field select{font:inherit;border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep);box-shadow:inset 2px 2px 0px var(--text);padding:.8rem}@supports (color:color-mix(in lab, red, red)){.blog-filter-field select{box-shadow:inset 2px 2px 0px color-mix(in oklab, var(--text), transparent 94%)}}.blog-filter-field select:focus{box-shadow:inset 4px 4px 0px var(--text), 0 0 0 2px var(--brand);outline:none}@supports (color:color-mix(in lab, red, red)){.blog-filter-field select:focus{box-shadow:inset 4px 4px 0px color-mix(in oklab, var(--text), transparent 94%), 0 0 0 2px var(--brand)}}.blog-item{border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep);box-shadow:var(--shadow);gap:.6rem;padding:1.5rem;transition:transform .2s,box-shadow .2s;display:grid;container-type:inline-size}.blog-item:hover{box-shadow:var(--shadow-hover);transform:translate(-3px,-3px)}.blog-item-cover-link{border:var(--border-width) solid var(--shadow-color);box-shadow:2px 2px 0px var(--shadow-color);display:block;overflow:hidden}.blog-item-cover{aspect-ratio:16/9;object-fit:cover;width:100%;transition:transform .25s;display:block;transform:scale(1.001)}.blog-item:hover .blog-item-cover{transform:scale(1.03)}.contact-form{gap:.9rem;display:grid}.required-indicator,.field-error{color:var(--danger)}.field-error{font-size:.88rem;font-weight:600}.contact-form label{gap:.3rem;font-weight:600;display:grid}.contact-form input,.contact-form textarea,.contact-form select{font:inherit;border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep);box-shadow:inset 2px 2px 0px var(--text);padding:.8rem}@supports (color:color-mix(in lab, red, red)){.contact-form input,.contact-form textarea,.contact-form select{box-shadow:inset 2px 2px 0px color-mix(in oklab, var(--text), transparent 94%)}}.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{box-shadow:inset 4px 4px 0px var(--text), 0 0 0 2px var(--brand);outline:none}@supports (color:color-mix(in lab, red, red)){.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{box-shadow:inset 4px 4px 0px color-mix(in oklab, var(--text), transparent 94%), 0 0 0 2px var(--brand)}}.contact-form button:disabled{opacity:.45;cursor:not-allowed;box-shadow:2px 2px 0px var(--shadow-color);transform:none}.form-status{color:var(--brand);font-weight:600}.form-status.error{color:var(--danger)}.post-content{grid-template-columns:minmax(0,1fr);gap:1rem;width:100%;max-width:72ch;display:grid}.post-content *{overflow-wrap:break-word;word-wrap:break-word;word-break:break-word}.post-content pre{margin:0;padding:0}.cr-code-lang{color:var(--text-soft);text-transform:uppercase;-webkit-user-select:none;user-select:none;font-size:.75rem;font-family:var(--font-body);letter-spacing:.05em;border-bottom:1px solid var(--line);margin-bottom:.8rem;padding-bottom:.25rem;font-weight:600;display:inline-block}.post-content pre code{word-break:normal;overflow-wrap:normal}.markdown-content{gap:1rem;display:grid}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4{color:var(--text);margin:0;line-height:1.2}.markdown-content blockquote{border-left:4px solid var(--brand);background:var(--bg-deep);margin:0;padding:.9rem 1rem}@supports (color:color-mix(in lab, red, red)){.markdown-content blockquote{background:color-mix(in oklab, var(--bg-deep), var(--brand) 8%)}}.markdown-content ul,.markdown-content ol{margin:0;padding-left:1.25rem}.markdown-content img{border:var(--border-width) solid var(--shadow-color);width:100%;height:auto;box-shadow:var(--shadow)}.markdown-content table{border-collapse:collapse;width:100%}.markdown-content th,.markdown-content td{border:1px solid var(--line);padding:.5rem}.detail-panel{border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep);box-shadow:var(--shadow);gap:.8rem;padding:1.5rem;display:grid}.clean-panel{background:var(--bg);padding:2rem}@supports (color:color-mix(in lab, red, red)){.clean-panel{background:color-mix(in oklab, var(--bg), var(--bg-deep) 30%)}}.clean-panel{border-radius:var(--radius-sm);border:1px solid var(--line);gap:1rem;display:grid}.contact-layout{grid-template-columns:1fr;gap:1.5rem;display:grid}.site-footer{border-top:1px solid var(--line);color:var(--text-soft);flex-direction:column;justify-content:flex-start;align-items:flex-start;gap:1rem;margin-top:2.5rem;padding:1.25rem 1rem 2rem;display:flex}.projects-grid{grid-template-columns:1fr}.projects-toolbar{gap:1rem;display:grid}.chip-button{border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep);font:inherit;cursor:pointer;color:var(--text-soft);min-height:44px;box-shadow:2px 2px 0px var(--shadow-color);justify-content:center;align-items:center;padding:.4rem .9rem;font-weight:600;transition:transform .1s,box-shadow .1s;display:inline-flex}.chip-button:hover{box-shadow:3px 3px 0px var(--brand);transform:translate(-1px,-1px)}.chip-button:active{box-shadow:1px 1px 0px var(--shadow-color);transform:translate(1px,1px)}.chip-button.active{background:var(--color-accent);color:var(--text);border-color:var(--color-accent)}.search-field{gap:.3rem;font-weight:600;display:grid}.search-field input{font:inherit;border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep);box-shadow:inset 2px 2px 0px var(--text);padding:.8rem}@supports (color:color-mix(in lab, red, red)){.search-field input{box-shadow:inset 2px 2px 0px color-mix(in oklab, var(--text), transparent 94%)}}.search-field input:focus{box-shadow:inset 4px 4px 0px var(--text), 0 0 0 2px var(--brand);outline:none}@supports (color:color-mix(in lab, red, red)){.search-field input:focus{box-shadow:inset 4px 4px 0px color-mix(in oklab, var(--text), transparent 94%), 0 0 0 2px var(--brand)}}.social-inline{flex-wrap:wrap;gap:.9rem;display:flex}.social-inline a{border:var(--border-width) solid var(--shadow-color);color:var(--text-soft);background:var(--bg-deep);box-shadow:2px 2px 0px var(--shadow-color);align-items:center;gap:.45rem;padding:.4rem .8rem;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s;display:inline-flex}.social-inline a:hover{box-shadow:4px 4px 0px var(--brand);transform:translate(-2px,-2px)}.social-inline a svg{width:16px;height:16px}.reveal,.reveal .card,.reveal .blog-item,.reveal .detail-panel{animation:.7s both fadeUp}.reveal .card:nth-child(2),.reveal .blog-item:nth-child(2),.reveal .detail-panel:nth-child(2){animation-delay:80ms}.reveal .card:nth-child(3),.reveal .blog-item:nth-child(3),.reveal .detail-panel:nth-child(3){animation-delay:.16s}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.reveal,.reveal .card,.reveal .blog-item,.reveal .detail-panel,.hero-highlight{animation:none}}@media (width>=640px){.container{width:min(900px,100% - 2rem)}.section-head{flex-direction:row;justify-content:space-between;align-items:baseline}.hero-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.theme-toggle span:last-child,.social-inline a span{display:inline}.blog-toolbar{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width>=768px){.site-header{flex-direction:row;justify-content:space-between;align-items:center}.header-controls{flex-wrap:nowrap;justify-content:flex-end;align-items:center;width:auto}.nav-toggle{display:none}.site-nav{background:0 0;border:0;border-radius:0;flex-flow:wrap;align-items:center;gap:.85rem;width:auto;padding:0;display:flex}.site-nav a{border-radius:0;width:auto;padding:.35rem .75rem}.site-nav a.active:after{display:none}.card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.split-layout{grid-template-columns:1.2fr 1fr}.projects-grid,.blog-list-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.contact-layout{grid-template-columns:1fr 1.2fr}.site-footer{flex-direction:row;justify-content:space-between;align-items:center}}@media (width>=900px){.page-shell{border-inline:1px solid var(--line)}.hero-kpis{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width>=1024px){.card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=640px){.page-shell{border-inline:none}.container{width:min(900px,100% - 1.25rem)}.header-controls{gap:.55rem}}.about-hero{align-items:center;gap:2rem;margin-bottom:2rem;display:grid}.about-content{flex-direction:column;gap:1.25rem;display:flex}.about-paragraph{font-size:1.1rem}.about-actions{margin-top:1rem}.about-image-wrapper{width:100%;max-width:350px;margin:0 auto;position:relative}.about-image-wrapper:after{content:"";border:var(--border-width) solid var(--shadow-color);z-index:-1;background:var(--brand-soft);position:absolute;inset:0;transform:translate(12px,12px)}.about-image{aspect-ratio:1;object-fit:cover;border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep);width:100%;height:auto}.about-grid{grid-template-columns:1fr;gap:1.5rem;margin-bottom:3rem;display:grid}.fast-facts-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.fast-facts-list .fact-item{padding-left:1.5rem;position:relative}.fast-facts-list .fact-item:before{content:"→";color:var(--brand);font-weight:700;position:absolute;left:0}.block-timeline{border-left:none;padding-left:0;position:relative}.experience-list{color:var(--text-soft);margin:1rem 0;padding-left:1.25rem;list-style-type:square}.experience-list li{margin-bottom:.5rem;line-height:1.6}.experience-list li::marker{color:var(--brand)}.block-timeline .timeline-item{border-left:none;margin-bottom:2rem;padding-left:3rem;position:relative}.block-timeline .timeline-dot{background:var(--brand);border:var(--border-width) solid var(--bg);z-index:2;width:20px;height:20px;box-shadow:2px 2px 0px var(--shadow-color);border-radius:0;position:absolute;top:24px;left:8px}:root[data-theme=dark] .block-timeline .timeline-dot{border-color:var(--bg)}@media (width>=768px){.about-hero{grid-template-columns:1.2fr 1fr}.about-grid{grid-template-columns:1fr 1fr}}.hero-spacious{flex-direction:column;align-items:flex-start;padding:6rem 0 4rem;display:flex}.hero-bento-layout{gap:1rem;width:100%;display:grid;container-type:inline-size}.hero-intro-block,.hero-highlight{border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep)}@supports (color:color-mix(in lab, red, red)){.hero-intro-block,.hero-highlight{background:color-mix(in oklab, var(--bg-deep), transparent 4%)}}.hero-intro-block,.hero-highlight{box-shadow:var(--shadow)}.hero-intro-block{padding:1.4rem}.hero-highlight{align-content:start;gap:.7rem;padding:1.2rem;animation:5s ease-in-out infinite orbitFloat;display:grid}.hero-highlight h2{font-size:clamp(1.15rem,3vw,1.55rem)}.hero-spacious h1{text-transform:uppercase;letter-spacing:-.04em;margin-top:1rem;font-size:clamp(3rem,8vw,5rem);line-height:.9}.hero-spacious .hero-copy{color:var(--text);font-size:clamp(1.2rem,3vw,1.8rem);font-family:var(--font-heading);margin-top:1.5rem}.hero-spacious .hero-intro{max-width:60ch;margin-top:1.5rem;font-size:1.1rem}.hero-kpis-row{border-top:2px solid var(--text);border-bottom:2px solid var(--text);background:var(--bg-deep);flex-direction:column;width:100%;margin-top:0;display:flex}@supports (color:color-mix(in lab, red, red)){.hero-kpis-row{background:color-mix(in oklab, var(--bg-deep), transparent 10%)}}.hero-kpis-row{padding:.4rem 1rem}.hero-kpis-row article{border-bottom:1px solid var(--line);justify-content:space-between;align-items:baseline;padding:1rem 0;display:flex}.hero-kpis-row article:last-child{border-bottom:none}.hero-kpis-row .meta{text-transform:uppercase;color:var(--text);font-size:1rem;font-weight:600}.hero-kpis-row strong{font-size:2rem;font-family:var(--font-heading)}@media (width>=768px){.hero-kpis-row{flex-direction:row;gap:3rem;padding:1.5rem 0}.hero-kpis-row article{border-bottom:none;border-right:1px solid var(--line);flex-direction:column;flex:1;justify-content:flex-start;align-items:flex-start;padding:0 1.5rem 0 0}.hero-kpis-row article:last-child{border-right:none;padding-right:0}.hero-kpis-row strong{font-size:3rem}}@keyframes orbitFloat{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-5px)rotate(-.4deg)}}.naked-list{flex-direction:column;width:100%;margin-top:2rem;display:flex}.naked-item{border-top:1px solid var(--text);gap:1rem;padding:2rem 0;display:grid}.naked-item:first-child{border-top:2px solid var(--text)}.naked-item h3{font-size:1.5rem}.naked-item .meta{text-transform:uppercase;color:var(--brand);font-weight:600}.template-case-study .post-content{max-width:80ch;font-size:1.1rem}.template-tech-deep-dive .post-content{font-family:var(--font-body);max-width:68ch}.template-tech .post-content{max-width:72ch}.template-story .post-content{max-width:65ch;font-family:Georgia,serif;font-size:1.15rem;line-height:1.8}.template-gallery .project-body .content-renderer,.template-photo-essay .post-content .content-renderer{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));align-items:start;gap:2rem;display:grid}.template-gallery .project-body .content-renderer .media-block,.template-photo-essay .post-content .content-renderer .media-block{height:100%;margin:0}.template-video-focus .post-content{max-width:90ch;margin:0 auto}.content-renderer{min-width:0;max-width:100%}figure.media-block{background:var(--bg-deep);margin:2rem 0;padding:1rem}@supports (color:color-mix(in lab, red, red)){figure.media-block{background:color-mix(in oklab, var(--bg-deep), transparent 50%)}}figure.media-block{border:var(--border-width) solid var(--shadow-color);box-shadow:4px 4px 0px var(--shadow-color);max-width:100%}figure.media-block img{aspect-ratio:16/9;object-fit:cover;width:100%;height:auto;display:block}figcaption{color:var(--text-soft);text-align:center;text-transform:uppercase;letter-spacing:.05em;margin-top:.75rem;font-size:.85rem;font-weight:600}blockquote.quote-block{border-left:4px solid var(--brand);background:var(--bg-deep);color:var(--text);overflow-wrap:break-word;word-break:break-word;max-width:100%;margin:2rem 0;padding:1.5rem 1.5rem 1.5rem 2rem;font-size:1.25rem;font-style:italic}.code-block{background:var(--bg-deep);margin:2rem 0;padding:1.5rem}@supports (color:color-mix(in lab, red, red)){.code-block{background:color-mix(in oklab, var(--bg-deep), var(--text) 88%)}}.code-block{color:var(--bg-deep)}@supports (color:color-mix(in lab, red, red)){.code-block{color:color-mix(in oklab, var(--bg-deep), white 9%)}}.code-block{border:var(--border-width) solid var(--shadow-color);box-shadow:4px 4px 0px var(--shadow-color);min-width:0;max-width:100%;font-family:monospace;font-size:.95rem;overflow-x:auto}.code-block pre{min-width:0;margin:0}.code-block code{color:inherit;word-break:normal;overflow-wrap:normal}.mermaid-block{background:var(--bg-deep);border:var(--border-width) solid var(--shadow-color);box-shadow:4px 4px 0px var(--shadow-color);justify-content:center;max-width:100%;margin:2rem 0;padding:2rem;display:flex;overflow-x:auto}:root[data-theme=dark] .mermaid-block{background:var(--bg-deep)}@supports (color:color-mix(in lab, red, red)){:root[data-theme=dark] .mermaid-block{background:color-mix(in oklab, var(--bg-deep), var(--text) 88%)}}.cr-youtube{width:100%;max-width:100%;margin:2rem 0;padding-bottom:56.25%;position:relative}.cr-youtube iframe{border:none;width:100%;height:100%;position:absolute;top:0;left:0}.cr-youtube-caption{text-align:center;color:var(--text-soft);margin-top:.5rem;font-size:.85rem}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;justify-content:center;align-items:flex-start;padding:1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-content{background:var(--bg-deep);border:var(--border-width) solid var(--shadow-color);box-shadow:6px 6px 0px var(--shadow-color);flex-direction:column;width:100%;max-width:900px;max-height:90vh;margin-top:2rem;display:flex}.modal-header h2{margin:0;font-size:1.5rem}.modal-close{background:var(--bg-deep);border:var(--border-width) solid var(--shadow-color);cursor:pointer;color:var(--text);min-width:44px;min-height:44px;box-shadow:2px 2px 0px var(--shadow-color);justify-content:center;align-items:center;padding:.5rem .75rem;font:1.2rem/1 sans-serif;display:flex}.modal-body{background:var(--bg);flex:1;justify-content:center;align-items:flex-start;padding:1rem;display:flex;overflow-y:auto}@supports (color:color-mix(in lab, red, red)){.modal-body{background:color-mix(in oklab, var(--bg), var(--bg-deep) 50%)}}.modal-body embed{border:1px solid var(--line);width:100%;height:100%;min-height:500px}.resume-modal .modal-body{min-height:600px}@media (width<=640px){.modal-content{border-bottom:none;max-height:95vh}.modal-body{min-height:400px}.modal-header{flex-direction:column;align-items:flex-start}.modal-header h2{flex:1}.modal-footer{flex-wrap:wrap}}:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.button-fit{width:fit-content}.about-section-gap{margin-top:3rem}.about-links-gap{margin-top:1.25rem}.brand-accent{color:var(--brand)}.admin-shell{background:var(--bg);min-height:100vh;color:var(--text);display:flex}.admin-sidebar{border-right:1px solid var(--line);background:var(--bg-deep);width:min(17rem,100%);padding:1.5rem}@supports (color:color-mix(in lab, red, red)){.admin-sidebar{background:color-mix(in oklab, var(--bg-deep), var(--bg) 15%)}}.admin-sidebar{grid-template-rows:auto 1fr auto;gap:1rem;display:grid}.admin-main{flex:1;padding:1.5rem;overflow:auto}.admin-title{font-family:var(--font-heading);color:var(--brand);font-size:clamp(1.25rem,3vw,1.75rem);line-height:1.15}.admin-heading{font-family:var(--font-heading);margin-bottom:1rem;font-size:clamp(1.5rem,4vw,2.2rem);line-height:1.1}.admin-nav{gap:.65rem;display:grid}.admin-nav-link{border:var(--border-width) solid transparent;color:var(--text-soft);padding:.65rem .85rem;font-weight:600;text-decoration:none;display:block}.admin-nav-link:hover,.admin-nav-link.active{color:var(--text);border-color:var(--brand);background:var(--brand)}@supports (color:color-mix(in lab, red, red)){.admin-nav-link:hover,.admin-nav-link.active{background:color-mix(in oklab, var(--brand), var(--bg-deep) 82%)}}.admin-panel{border:1px solid var(--line);background:var(--bg-deep)}@supports (color:color-mix(in lab, red, red)){.admin-panel{background:color-mix(in oklab, var(--bg-deep), var(--bg) 10%)}}.admin-panel{box-shadow:var(--shadow);padding:1rem}.admin-grid{gap:1rem;display:grid}.admin-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-actions{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.admin-button{border:var(--border-width) solid var(--shadow-color);background:var(--bg-deep);color:var(--text);font:inherit;cursor:pointer;min-height:44px;box-shadow:2px 2px 0px var(--shadow-color);padding:.55rem 1rem;font-weight:700}.admin-button:hover{box-shadow:3px 3px 0px var(--brand);transform:translate(-1px,-1px)}.admin-button:active{box-shadow:1px 1px 0px var(--shadow-color);transform:translate(1px,1px)}.admin-button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.admin-button.primary{background:var(--brand);color:var(--bg-deep)}.admin-button.danger{border-color:var(--danger);color:var(--danger)}.admin-form{gap:.9rem;display:grid}.admin-field{gap:.35rem;display:grid}.admin-span-2{grid-column:1/-1}.admin-field label{color:var(--text-soft);font-weight:600}.admin-input,.admin-textarea,.admin-select{background:var(--bg-deep);border:var(--border-width) solid var(--shadow-color);width:100%;color:var(--text);font:inherit;min-height:44px;padding:.65rem .75rem}.admin-textarea{resize:vertical;min-height:6rem}.admin-checkbox{width:1.25rem;height:1.25rem;accent-color:var(--brand);margin:0}@supports (color:color-mix(in lab, red, red)){.admin-checkbox{accent-color:color-mix(in oklab, var(--brand), white 6%)}}.admin-input:focus,.admin-textarea:focus,.admin-select:focus{box-shadow:0 0 0 2px var(--brand);outline:none}.admin-table-wrap{border:1px solid var(--line);overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;min-width:44rem}.admin-table th,.admin-table td{border-bottom:1px solid var(--line);text-align:left;vertical-align:top;padding:.75rem}.admin-table th{color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem}.admin-table tr:hover td{background:var(--brand)}@supports (color:color-mix(in lab, red, red)){.admin-table tr:hover td{background:color-mix(in oklab, var(--brand), var(--bg-deep) 90%)}}.admin-status{color:var(--text-soft)}.admin-status.error{color:var(--danger)}.admin-link{color:var(--brand);font-weight:700;text-decoration:none}.admin-loading{place-items:center;min-height:100vh;display:grid}.admin-login-card{width:min(30rem,100% - 1.25rem)}.loading-indicator{border:2px solid var(--brand);border-top-color:#0000;border-radius:999px;width:1rem;height:1rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=900px){.admin-shell{display:block}.admin-sidebar{border-right:0;border-bottom:1px solid var(--line);width:100%}.admin-grid.cols-2{grid-template-columns:1fr}}:focus-visible,button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--brand);outline-offset:2px}@media (width<=640px){button,a[href],.button,.chip-button,input[type=checkbox],input[type=radio]{min-width:48px;min-height:48px}.button,.chip-button{padding:.6rem 1rem}h1{font-size:clamp(1.5rem,5vw,3.6rem)}h2{font-size:clamp(1.25rem,4vw,2.1rem)}p{font-size:clamp(.95rem,2.5vw,1.1rem)}.modal-content{width:min(95vw,600px);max-height:95vh}.modal-body{max-height:calc(95vh - 140px)}@supports (font-size:clamp(1rem, 1.5vw, 2rem)){html{font-size:clamp(14px,2.5vw,16px)}}}@media (width>=320px) and (width<=480px){body{font-size:16px}.container{width:min(900px,100% - 1rem)}.chip-row{gap:.4rem}.chip-row li,.chip-row span{padding:.15rem .5rem;font-size:.8rem}}@media (orientation:portrait) and (width<=640px){.split-layout,.about-hero,.hero-kpis{grid-template-columns:1fr}.modal-overlay{align-items:center;padding:.5rem}.modal-content{width:min(100%,100vw - 1rem);max-height:min(90vh,800px)}}@media (orientation:landscape) and (height<=500px){.site-header{gap:.5rem;padding:.75rem 1rem}.modal-body{max-height:calc(80vh - 120px)}.hero-spacious{padding:2rem 0 1.5rem}}.scroll-reveal{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(20px)}.scroll-reveal.in-view{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion:reduce){.scroll-reveal,.scroll-reveal.in-view{opacity:1;transition:none;animation:none;transform:none}}@media (prefers-contrast:more){:root{--text:oklch(15% .03 258);--text-soft:oklch(35% .03 257)}:root[data-theme=dark]{--text:oklch(99% .01 256);--text-soft:oklch(85% .03 256)}button,.button,.chip-button{border-width:3px}}.modal-overlay{justify-content:center;align-items:flex-start;padding-top:2rem;display:flex}.modal-content{background:var(--bg-deep);border:var(--border-width) solid var(--shadow-color);box-shadow:var(--shadow);border-radius:4px;width:min(90vw,600px);max-width:600px;max-height:90vh;position:relative;overflow:auto}.modal-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:1rem;padding:1.5rem;display:flex}.modal-header h2{flex:1;margin:0}.modal-close{border:var(--border-width) solid var(--shadow-color);cursor:pointer;width:48px;height:48px;color:var(--text);box-shadow:2px 2px 0px var(--shadow-color);background:0 0;justify-content:center;align-items:center;font-size:1.25rem;transition:transform .2s,box-shadow .2s;display:flex}.modal-close:hover{box-shadow:3px 3px 0px var(--brand);transform:translate(-1px,-1px)}.modal-close:focus-visible{outline:3px solid var(--brand);outline-offset:2px}.modal-body{max-height:60vh;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--line);justify-content:flex-end;gap:1rem;padding:1.5rem;display:flex}.resume-modal{max-width:700px}.resume-modal .modal-body embed{border:none;width:100%;min-height:500px}@media (width<=320px){h1{font-size:clamp(1.25rem,4vw,3.6rem)}h2{font-size:clamp(1rem,3vw,2.1rem)}.button,.chip-button{padding:.5rem .8rem;font-size:.75rem}.container{width:min(900px,100% - .75rem)}}@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-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}
