.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}@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-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking: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-outline-style:solid;--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-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial;--portfolio-resume-border-angle:0deg}}}@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-red-500:oklch(63.7% .237 25.331);--color-lime-200:oklch(93.8% .127 124.321);--color-green-500:oklch(72.3% .219 149.579);--color-emerald-400:oklch(76.5% .177 163.223);--color-cyan-200:oklch(91.7% .08 205.041);--color-sky-200:oklch(90.1% .058 230.902);--color-sky-300:oklch(82.8% .111 230.318);--color-sky-400:oklch(74.6% .16 232.661);--color-blue-500:oklch(62.3% .214 259.815);--color-indigo-300:oklch(78.5% .115 274.713);--color-gray-200:oklch(92.8% .006 264.531);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-6xl:72rem;--container-7xl:80rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--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);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-wide:.025em;--tracking-wider:.05em;--tracking-widest:.1em;--leading-relaxed:1.625;--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;--drop-shadow-lg:0 4px 4px #00000026;--ease-in:cubic-bezier(.4, 0, 1, 1);--ease-out:cubic-bezier(0, 0, .2, 1);--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--animate-bounce:bounce 1s infinite;--blur-md:12px;--blur-xl:24px;--blur-2xl:40px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.\@container{container-type:inline-size}.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.top-0{top:calc(var(--spacing) * 0)}.top-1\.5{top:calc(var(--spacing) * 1.5)}.top-1\/2{top:50%}.top-2{top:calc(var(--spacing) * 2)}.top-4{top:calc(var(--spacing) * 4)}.top-\[var\(--window-top\)\]{top:var(--window-top)}.right-0{right:calc(var(--spacing) * 0)}.right-1{right:calc(var(--spacing) * 1)}.right-2{right:calc(var(--spacing) * 2)}.right-4{right:calc(var(--spacing) * 4)}.-bottom-1{bottom:calc(var(--spacing) * -1)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-\[48px\]{bottom:48px}.left-0{left:calc(var(--spacing) * 0)}.left-1\/2{left:50%}.left-4{left:calc(var(--spacing) * 4)}.left-\[var\(--window-left\)\]{left:var(--window-left)}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.z-\[900\]{z-index:900}.z-\[1000\]{z-index:1000}.z-\[2000\]{z-index:2000}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.m-6{margin:calc(var(--spacing) * 6)}.mx-auto{margin-inline:auto}.mt-1{margin-top:calc(var(--spacing) * 1)}.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-5{margin-top:calc(var(--spacing) * 5)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-auto{margin-top:auto}.mr-2{margin-right:calc(var(--spacing) * 2)}.mr-auto{margin-right:auto}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.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-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.ml-4{margin-left:calc(var(--spacing) * 4)}.ml-auto{margin-left:auto}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.line-clamp-3{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.size-6{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.h-1{height:calc(var(--spacing) * 1)}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2\.5{height:calc(var(--spacing) * 2.5)}.h-3{height:calc(var(--spacing) * 3)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-10{height:calc(var(--spacing) * 10)}.h-12{height:calc(var(--spacing) * 12)}.h-14{height:calc(var(--spacing) * 14)}.h-16{height:calc(var(--spacing) * 16)}.h-20{height:calc(var(--spacing) * 20)}.h-28{height:calc(var(--spacing) * 28)}.h-48{height:calc(var(--spacing) * 48)}.h-\[1px\]{height:1px}.h-\[var\(--window-height\)\]{height:var(--window-height)}.h-full{height:100%}.max-h-\[min\(720px\,80vh\)\]{max-height:min(720px,80vh)}.min-h-0{min-height:calc(var(--spacing) * 0)}.w-0{width:calc(var(--spacing) * 0)}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-2\.5{width:calc(var(--spacing) * 2.5)}.w-3{width:calc(var(--spacing) * 3)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-7{width:calc(var(--spacing) * 7)}.w-8{width:calc(var(--spacing) * 8)}.w-10{width:calc(var(--spacing) * 10)}.w-12{width:calc(var(--spacing) * 12)}.w-20{width:calc(var(--spacing) * 20)}.w-24{width:calc(var(--spacing) * 24)}.w-28{width:calc(var(--spacing) * 28)}.w-32{width:calc(var(--spacing) * 32)}.w-64{width:calc(var(--spacing) * 64)}.w-\[200px\]{width:200px}.w-\[220px\]{width:220px}.w-\[404px\]{width:404px}.w-\[min\(640px\,94vw\)\]{width:min(640px,94vw)}.w-\[var\(--window-width\)\]{width:var(--window-width)}.w-full{width:100%}.max-w-6xl{max-width:var(--container-6xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-\[24ch\]{max-width:24ch}.max-w-\[46ch\]{max-width:46ch}.max-w-\[52ch\]{max-width:52ch}.max-w-\[360px\]{max-width:360px}.max-w-\[calc\(100vw-20px\)\]{max-width:calc(100vw - 20px)}.min-w-0{min-width:calc(var(--spacing) * 0)}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.scale-0{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-90{--tw-scale-x:90%;--tw-scale-y:90%;--tw-scale-z:90%;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-95{--tw-scale-x:95%;--tw-scale-y:95%;--tw-scale-z:95%;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-100{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y)}.-rotate-45{rotate:-45deg}.rotate-45{rotate:45deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-bounce{animation:var(--animate-bounce)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.content-start{align-content:flex-start}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-5{gap:calc(var(--spacing) * 5)}.gap-6{gap:calc(var(--spacing) * 6)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.\!rounded-full{border-radius:3.40282e38px!important}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\[8px\]{border-radius:8px}.rounded-\[10px\]{border-radius:10px}.rounded-\[12px\]{border-radius:12px}.rounded-\[14px\]{border-radius:14px}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-t-lg{border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-4{border-style:var(--tw-border-style);border-width:4px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-\[\#72c9ff66\]{border-color:#72c9ff66}.border-black\/20{border-color:#0003}@supports (color:color-mix(in lab,red,red)){.border-black\/20{border-color:color-mix(in oklab,var(--color-black) 20%,transparent)}}.border-current{border-color:currentColor}.border-gray-200{border-color:var(--color-gray-200)}.border-sky-300\/20{border-color:#77d4ff33}@supports (color:color-mix(in lab,red,red)){.border-sky-300\/20{border-color:color-mix(in oklab,var(--color-sky-300) 20%,transparent)}}.border-transparent{border-color:#0000}.border-white\/5{border-color:#ffffff0d}@supports (color:color-mix(in lab,red,red)){.border-white\/5{border-color:color-mix(in oklab,var(--color-white) 5%,transparent)}}.border-white\/6{border-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.border-white\/6{border-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.border-white\/8{border-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.border-white\/8{border-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.border-white\/10{border-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.border-white\/10{border-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.border-t-transparent{border-top-color:#0000}.bg-\[\#72c9ff1c\]{background-color:#72c9ff1c}.bg-\[rgba\(13\,18\,28\,0\.68\)\]{background-color:#0d121cad}.bg-black\/20{background-color:#0003}@supports (color:color-mix(in lab,red,red)){.bg-black\/20{background-color:color-mix(in oklab,var(--color-black) 20%,transparent)}}.bg-blue-500{background-color:var(--color-blue-500)}.bg-current{background-color:currentColor}.bg-green-500{background-color:var(--color-green-500)}.bg-red-500{background-color:var(--color-red-500)}.bg-sky-400\/10{background-color:#00bcfe1a}@supports (color:color-mix(in lab,red,red)){.bg-sky-400\/10{background-color:color-mix(in oklab,var(--color-sky-400) 10%,transparent)}}.bg-transparent{background-color:#0000}.bg-white\/5{background-color:#ffffff0d}@supports (color:color-mix(in lab,red,red)){.bg-white\/5{background-color:color-mix(in oklab,var(--color-white) 5%,transparent)}}.bg-white\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.bg-white\/10{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.bg-white\/15{background-color:#ffffff26}@supports (color:color-mix(in lab,red,red)){.bg-white\/15{background-color:color-mix(in oklab,var(--color-white) 15%,transparent)}}.bg-white\/40{background-color:#fff6}@supports (color:color-mix(in lab,red,red)){.bg-white\/40{background-color:color-mix(in oklab,var(--color-white) 40%,transparent)}}.bg-white\/80{background-color:#fffc}@supports (color:color-mix(in lab,red,red)){.bg-white\/80{background-color:color-mix(in oklab,var(--color-white) 80%,transparent)}}.bg-white\/\[0\.04\]{background-color:#ffffff0a}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.04\]{background-color:color-mix(in oklab,var(--color-white) 4%,transparent)}}.bg-white\/\[0\.06\]{background-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.06\]{background-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-\[linear-gradient\(180deg\,rgba\(27\,35\,52\,0\.9\)\,rgba\(14\,20\,31\,0\.84\)\)\]{background-image:linear-gradient(#1b2334e6,#0e141fd6)}.bg-\[linear-gradient\(180deg\,rgba\(255\,255\,255\,0\.06\)\,rgba\(255\,255\,255\,0\.03\)\)\]{background-image:linear-gradient(#ffffff0f,#ffffff08)}.from-blue-500{--tw-gradient-from:var(--color-blue-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-blue-500\/60{--tw-gradient-from:#3080ff99}@supports (color:color-mix(in lab,red,red)){.from-blue-500\/60{--tw-gradient-from:color-mix(in oklab, var(--color-blue-500) 60%, transparent)}}.from-blue-500\/60{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-emerald-400\/60{--tw-gradient-from:#00d29499}@supports (color:color-mix(in lab,red,red)){.from-emerald-400\/60{--tw-gradient-from:color-mix(in oklab, var(--color-emerald-400) 60%, transparent)}}.from-emerald-400\/60{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-sky-400\/60{--tw-gradient-from:#00bcfe99}@supports (color:color-mix(in lab,red,red)){.from-sky-400\/60{--tw-gradient-from:color-mix(in oklab, var(--color-sky-400) 60%, transparent)}}.from-sky-400\/60{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-cyan-200\/30{--tw-gradient-to:#a2f4fd4d}@supports (color:color-mix(in lab,red,red)){.to-cyan-200\/30{--tw-gradient-to:color-mix(in oklab, var(--color-cyan-200) 30%, transparent)}}.to-cyan-200\/30{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-indigo-300\/30{--tw-gradient-to:#a4b3ff4d}@supports (color:color-mix(in lab,red,red)){.to-indigo-300\/30{--tw-gradient-to:color-mix(in oklab, var(--color-indigo-300) 30%, transparent)}}.to-indigo-300\/30{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-lime-200\/30{--tw-gradient-to:#d8f9994d}@supports (color:color-mix(in lab,red,red)){.to-lime-200\/30{--tw-gradient-to:color-mix(in oklab, var(--color-lime-200) 30%, transparent)}}.to-lime-200\/30{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.object-cover{object-fit:cover}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.px-0\.5{padding-inline:calc(var(--spacing) * .5)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-8{padding-inline:calc(var(--spacing) * 8)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-5{padding-block:calc(var(--spacing) * 5)}.py-8{padding-block:calc(var(--spacing) * 8)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pr-6{padding-right:calc(var(--spacing) * 6)}.pb-0{padding-bottom:calc(var(--spacing) * 0)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.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))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.72rem\]{font-size:.72rem}.text-\[1\.4rem\]{font-size:1.4rem}.text-\[1\.45rem\]{font-size:1.45rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.leading-5{--tw-leading:calc(var(--spacing) * 5);line-height:calc(var(--spacing) * 5)}.leading-6{--tw-leading:calc(var(--spacing) * 6);line-height:calc(var(--spacing) * 6)}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.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)}.tracking-\[0\.08em\]{--tw-tracking:.08em;letter-spacing:.08em}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.break-words{overflow-wrap:break-word}.whitespace-nowrap{white-space:nowrap}.text-red-500{color:var(--color-red-500)}.text-sky-200{color:var(--color-sky-200)}.text-white{color:var(--color-white)}.text-white\/42{color:#ffffff6b}@supports (color:color-mix(in lab,red,red)){.text-white\/42{color:color-mix(in oklab,var(--color-white) 42%,transparent)}}.text-white\/44{color:#ffffff70}@supports (color:color-mix(in lab,red,red)){.text-white\/44{color:color-mix(in oklab,var(--color-white) 44%,transparent)}}.text-white\/46{color:#ffffff75}@supports (color:color-mix(in lab,red,red)){.text-white\/46{color:color-mix(in oklab,var(--color-white) 46%,transparent)}}.text-white\/56{color:#ffffff8f}@supports (color:color-mix(in lab,red,red)){.text-white\/56{color:color-mix(in oklab,var(--color-white) 56%,transparent)}}.text-white\/58{color:#ffffff94}@supports (color:color-mix(in lab,red,red)){.text-white\/58{color:color-mix(in oklab,var(--color-white) 58%,transparent)}}.text-white\/72{color:#ffffffb8}@supports (color:color-mix(in lab,red,red)){.text-white\/72{color:color-mix(in oklab,var(--color-white) 72%,transparent)}}.text-white\/74{color:#ffffffbd}@supports (color:color-mix(in lab,red,red)){.text-white\/74{color:color-mix(in oklab,var(--color-white) 74%,transparent)}}.text-white\/88{color:#ffffffe0}@supports (color:color-mix(in lab,red,red)){.text-white\/88{color:color-mix(in oklab,var(--color-white) 88%,transparent)}}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.underline{text-decoration-line:underline}.opacity-0{opacity:0}.opacity-40{opacity:.4}.opacity-60{opacity:.6}.opacity-80{opacity:.8}.opacity-90{opacity:.9}.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-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_4px_20px_rgba\(0\,0\,0\,0\.1\)\]{--tw-shadow:0 4px 20px 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-\[0_18px_40px_rgba\(0\,0\,0\,0\.28\)\]{--tw-shadow:0 18px 40px var(--tw-shadow-color,#00000047);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)}.shadow-sm{--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)}.ring,.ring-1{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-white\/20{--tw-ring-color:#fff3}@supports (color:color-mix(in lab,red,red)){.ring-white\/20{--tw-ring-color:color-mix(in oklab, var(--color-white) 20%, transparent)}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);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,)}.drop-shadow{--tw-drop-shadow-size:drop-shadow(0 1px 2px var(--tw-drop-shadow-color,#0000001a)) drop-shadow(0 1px 1px var(--tw-drop-shadow-color,#0000000f));--tw-drop-shadow:drop-shadow(0 1px 2px #0000001a) drop-shadow(0 1px 1px #0000000f);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,)}.drop-shadow-\[0_1px_2px_rgba\(0\,0\,0\,0\.8\)\]{--tw-drop-shadow-size:drop-shadow(0 1px 2px var(--tw-drop-shadow-color,#000c));--tw-drop-shadow:var(--tw-drop-shadow-size);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,)}.drop-shadow-lg{--tw-drop-shadow-size:drop-shadow(0 4px 4px var(--tw-drop-shadow-color,#00000026));--tw-drop-shadow:drop-shadow(var(--drop-shadow-lg));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,)}.grayscale-\[0\.2\]{--tw-grayscale:grayscale(.2);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,)}.grayscale-\[0\.5\]{--tw-grayscale:grayscale(.5);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,)}.sepia{--tw-sepia:sepia(100%);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,)}.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,)}.backdrop-blur-2xl{--tw-backdrop-blur:blur(var(--blur-2xl));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-blur-md{--tw-backdrop-blur:blur(var(--blur-md));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-blur-xl{--tw-backdrop-blur:blur(var(--blur-xl));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.ease-in{--tw-ease:var(--ease-in);transition-timing-function:var(--ease-in)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media(hover:hover){.group-hover\:bg-white:is(:where(.group):hover *){background-color:var(--color-white)}.group-hover\:bg-white\/10:is(:where(.group):hover *){background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.group-hover\:bg-white\/10:is(:where(.group):hover *){background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.group-hover\:bg-white\/80:is(:where(.group):hover *){background-color:#fffc}@supports (color:color-mix(in lab,red,red)){.group-hover\:bg-white\/80:is(:where(.group):hover *){background-color:color-mix(in oklab,var(--color-white) 80%,transparent)}}}.group-active\:scale-90:is(:where(.group):active *){--tw-scale-x:90%;--tw-scale-y:90%;--tw-scale-z:90%;scale:var(--tw-scale-x) var(--tw-scale-y)}.placeholder\:text-white\/30::placeholder{color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.placeholder\:text-white\/30::placeholder{color:color-mix(in oklab,var(--color-white) 30%,transparent)}}.last\:border-0:last-child{border-style:var(--tw-border-style);border-width:0}@media(hover:hover){.hover\:border-white\/8:hover{border-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.hover\:border-white\/8:hover{border-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.hover\:bg-white\/5:hover{background-color:#ffffff0d}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/5:hover{background-color:color-mix(in oklab,var(--color-white) 5%,transparent)}}.hover\:bg-white\/6:hover{background-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/6:hover{background-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.hover\:bg-white\/10:hover{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/10:hover{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.hover\:opacity-80:hover{opacity:.8}.hover\:opacity-100:hover{opacity:1}}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-blue-500:focus{--tw-ring-color:var(--color-blue-500)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:bg-white\/10:focus-visible{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.focus-visible\:bg-white\/10:focus-visible{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-blue-500:focus-visible{--tw-ring-color:var(--color-blue-500)}.active\:scale-90:active{--tw-scale-x:90%;--tw-scale-y:90%;--tw-scale-z:90%;scale:var(--tw-scale-x) var(--tw-scale-y)}.active\:scale-95:active{--tw-scale-x:95%;--tw-scale-y:95%;--tw-scale-z:95%;scale:var(--tw-scale-x) var(--tw-scale-y)}@media(min-width:40rem){.sm\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.sm\:grid-cols-\[minmax\(0\,0\.34fr\)_minmax\(0\,0\.66fr\)\]{grid-template-columns:minmax(0,.34fr) minmax(0,.66fr)}.sm\:gap-4{gap:calc(var(--spacing) * 4)}.sm\:px-6{padding-inline:calc(var(--spacing) * 6)}}@media(min-width:48rem){.md\:px-6{padding-inline:calc(var(--spacing) * 6)}}@media(min-width:64rem){.lg\:block{display:block}.lg\:grid-cols-\[minmax\(0\,1\.1fr\)_minmax\(0\,0\.9fr\)\]{grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr)}}@media(min-width:80rem){.xl\:grid-cols-\[minmax\(0\,0\.9fr\)_minmax\(0\,1\.1fr\)\]{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr)}}}:root{color-scheme:dark;--motion-fast:.18s;--motion-medium:.26s;--ease-enter:cubic-bezier(.16, 1, .3, 1);--ease-exit:cubic-bezier(.32, 0, .67, 0);--ease-standard:cubic-bezier(.22, 1, .36, 1);--bg:#06101f;--ink:#f6f8ff;--text:#e8edf7;--muted:#a8b4c7;--soft-strong:#152034d6;--window-bg:#131b2b;--window-titlebar-bg:#101827;--window-panel-bg:#192235;--line:#ffffff1f;--line-light:#ffffff2e;--accent:#60cdff;--accent-2:#2d7dff;--danger:#ff5f57;--shadow-soft:0 18px 52px #00000047;--blur:blur(28px) saturate(1.32);--blur-mobile:blur(18px) saturate(1.1);font-family:Segoe UI Variable Text,Segoe UI Variable Display,Segoe UI,Segoe UI Symbol,system-ui,sans-serif}@keyframes app-drawer-enter{0%{opacity:0;transform:translate(50%)translateY(14px)scale(.965)}to{opacity:1;transform:translate(50%)translateY(0)scale(1)}}@keyframes menu-socials-label-glow{0%{transform:translate(-135%)}to{transform:translate(135%)}}@keyframes notification-enter{0%{opacity:0;transform:translate(28px)translateY(10px)scale(.985)}to{opacity:1;transform:translate(0)translateY(0)scale(1)}}@keyframes window-enter{0%{opacity:0;transform:scale(.94)translateZ(0)}to{opacity:1;transform:scale(1)translateZ(0)}}@keyframes route-ripple-reveal{0%{clip-path:circle(0px at var(--route-ripple-x,50%) var(--route-ripple-y,50%))}to{clip-path:circle(var(--route-ripple-end-radius,150vmax) at var(--route-ripple-x,50%) var(--route-ripple-y,50%))}}@keyframes route-ripple-conceal{0%{clip-path:circle(150% at var(--route-ripple-x,50%) var(--route-ripple-y,50%))}to{clip-path:circle(0% at var(--route-ripple-x,50%) var(--route-ripple-y,50%))}}@keyframes route-app-fade-out{0%{opacity:1}to{opacity:0}}@keyframes route-app-fade-in{0%{opacity:0}to{opacity:1}}@media(prefers-reduced-motion:no-preference){html[data-route-transition]{--route-transition-duration:1.05s}html[data-route-transition=enter-app]{--route-transition-duration:1.8s}html[data-route-transition]::view-transition-group(root){animation-duration:var(--route-transition-duration);isolation:isolate;animation-timing-function:cubic-bezier(.22,1,.36,1)}html[data-route-transition]::view-transition-group(root){will-change:transform,opacity,clip-path;transform:translateZ(0)}html[data-route-transition]::view-transition-old(root){height:100%;animation-duration:var(--route-transition-duration);backface-visibility:hidden;mix-blend-mode:normal;will-change:clip-path,transform,opacity;animation-timing-function:cubic-bezier(.22,1,.36,1);animation-fill-mode:both;transform:translateZ(0)}html[data-route-transition]::view-transition-new(root){height:100%;animation-duration:var(--route-transition-duration);backface-visibility:hidden;mix-blend-mode:normal;will-change:clip-path,transform,opacity;animation-timing-function:cubic-bezier(.22,1,.36,1);animation-fill-mode:both;transform:translateZ(0)}html[data-route-transition=enter-app]::view-transition-old(root){z-index:1;animation:none}html[data-route-transition=enter-app]::view-transition-new(root){z-index:2;animation-name:route-ripple-reveal}html[data-route-transition=exit-app]::view-transition-old(root){z-index:2;animation-name:route-ripple-conceal}html[data-route-transition=exit-app]::view-transition-new(root){z-index:1;animation:none}html[data-route-transition=app-crossfade]::view-transition-old(root){z-index:1;animation-name:route-app-fade-out;animation-duration:.24s}html[data-route-transition=app-crossfade]::view-transition-new(root){z-index:2;animation-name:route-app-fade-in;animation-duration:.32s}}@media(prefers-reduced-motion:reduce),(update:slow){html[data-route-transition=enter-app]::view-transition-new(root){animation-name:route-app-fade-in;animation-duration:.32s}}@keyframes app-drawer-enter-mobile{0%{opacity:0;transform:translateY(14px)scale(.972)}to{opacity:1;transform:translateY(0)scale(1)}}.desktop-reveal-curtain{z-index:99999;pointer-events:auto;background:0 0;display:none;position:fixed;inset:0;overflow:hidden}.show-curtain .desktop-reveal-curtain{display:block}.desktop-reveal-circle{will-change:width,height;border-radius:50%;width:0;height:0;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 150vmax #000}.desktop-reveal-circle.is-animating{animation:2s forwards curtain-circle-reveal-grow}@keyframes curtain-circle-reveal-grow{0%{width:0;height:0}60%{width:40vmax;height:40vmax}to{width:300vmax;height:300vmax}}*{box-sizing:border-box}html,body{scrollbar-width:none;-ms-overflow-style:none;min-height:100%;margin:0}html::-webkit-scrollbar{width:0;height:0;display:none}body::-webkit-scrollbar{width:0;height:0;display:none}body{background:var(--bg);color:var(--text)}body.desktop-body{background-image:linear-gradient(#0208141f,#02081429),url(/win11.jpg);background-position:50%;background-size:cover}button,input,textarea,select{font:inherit}a{color:inherit}button,a,input,textarea,select{outline-offset:2px}:where(input,textarea,select):focus-visible{outline:1.5px solid var(--accent)}@supports (color:color-mix(in lab,red,red)){:where(input,textarea,select):focus-visible{outline:1.5px solid color-mix(in srgb,var(--accent) 54%,white 18%)}}hr{opacity:1;background:#ffffff29;border:0;height:1px;margin:3.5rem 0}p,li{font-family:Urbanist,sans-serif}.desktop{overscroll-behavior:none;background-image:linear-gradient(#0208141f,#02081429),url(/win11.jpg);background-position:50%;background-size:cover;min-height:100vh;padding:32px 42px 94px;position:relative;overflow:hidden}.desktop:before{pointer-events:none;content:"";background:linear-gradient(90deg,#0000002e,#0000 20% 80%,#00000029);position:absolute;inset:0}.desktop:after{pointer-events:none;content:"";opacity:1;background:linear-gradient(#0000000f,#0000 28%,#00000024);position:absolute;inset:0}.desktop-shortcuts{z-index:3;grid-auto-rows:min-content;grid-auto-flow:row;gap:10px;display:grid;position:absolute;top:34px;left:26px}.desktop-shortcut{width:88px;color:var(--ink);cursor:pointer;text-align:center;transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard);background:0 0;border:1px solid #0000;border-radius:10px;justify-items:center;gap:6px;padding:8px 6px 10px;display:grid}.desktop-shortcut:hover,.desktop-shortcut:focus-visible,.desktop-shortcut--active{background:#ffffff1f;border-color:#ffffff2e;box-shadow:0 10px 24px #08102033}.desktop-shortcut img{object-fit:contain;width:34px;height:34px;display:block}.desktop-shortcut span{color:#f6f8fff5;text-shadow:0 1px 3px #030814cc;word-break:break-word;max-width:100%;font-size:.74rem;font-weight:500;line-height:1.2;display:block}.menu-bar{-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);z-index:60;background:#141f30c7;border:0;border-top:1px solid #ffffff14;border-radius:0;justify-content:space-between;align-items:center;gap:14px;min-height:54px;padding:7px 18px;display:flex;position:fixed;bottom:0;left:0;right:0;transform:translateZ(0);box-shadow:0 -12px 34px #00000052}.menu-brand,.menu-launcher,.menu-socials{align-items:center;display:flex}.menu-brand{z-index:2;gap:8px;width:180px;position:relative}.menu-brand a{text-decoration:none}.menu-brand strong{color:#f6f8ffe0;font-size:.78rem;font-weight:650}.menu-launcher{justify-content:center;align-items:center;gap:4px;width:max-content;display:flex;position:absolute;left:50%;transform:translate(-50%)}.menu-socials{z-index:2;align-items:center;gap:4px;margin-left:auto;display:flex;position:relative}.menu-socials__label{color:#f6f8ffd1;text-shadow:0 0 #90dbff00;letter-spacing:.01em;min-height:30px;transition:border-color var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard),text-shadow var(--motion-fast) var(--ease-standard);white-space:nowrap;background:linear-gradient(135deg,#489dff38,#396cdc1a),#2776ff14;border:1px solid #5cb0ff61;border-radius:999px;justify-content:center;align-items:center;margin:0 8px 0 0;padding:0 12px;font-size:.76rem;font-weight:600;line-height:1;display:inline-flex;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff1f,0 0 18px #307eff14}.menu-socials__label:after{content:"";opacity:0;pointer-events:none;will-change:transform,opacity;background:linear-gradient(110deg,#0000 0% 28%,#9ae4ff0f 42%,#baf0ff85,#9ae4ff14 58%,#0000 72% 100%);position:absolute;inset:0;transform:translate(-135%)}.menu-socials:hover .menu-socials__label,.menu-socials:focus-within .menu-socials__label{text-shadow:0 0 12px #9eeaff6b,0 0 26px #52bfff3d;border-color:#7accffb8;box-shadow:inset 0 1px #ffffff2e,0 0 26px #45a7ff33,0 0 42px #45a7ff1f}.menu-socials:hover .menu-socials__label:after,.menu-socials:focus-within .menu-socials__label:after{opacity:1;animation:1.55s linear infinite menu-socials-label-glow}.menu-clock{min-width:0;color:var(--text-muted);flex:none;justify-content:center;align-items:center;padding:0 1px;font-size:.85rem;font-weight:500;line-height:1;display:flex}.menu-clock__dot{background:var(--accent);border-radius:999px;width:6px;height:6px;position:absolute;top:5px;right:2px}.tray-icon{flex:none;justify-content:center;align-items:center;width:18px;height:18px;display:flex}.tray-icon__svg{width:18px;height:18px}.system-tray{flex:none;justify-content:center;align-items:center;display:flex}.menu-icon.menu-icon--tray{white-space:nowrap;border-radius:8px;flex-direction:row;justify-content:center;align-items:center;gap:0;width:auto;min-width:0;height:40px;margin-left:4px;margin-right:0;padding:0 6px;overflow:hidden;display:inline-flex!important}.menu-icon{width:40px;height:40px;color:var(--text);cursor:pointer;backface-visibility:hidden;will-change:transform;transition:transform var(--motion-fast) var(--ease-standard),background var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard);background:0 0;border:0;border-radius:8px;place-items:center;padding:0;text-decoration:none;display:grid;position:relative}.menu-icon:hover,.menu-icon:focus-visible,.menu-icon--active{background:#ffffff1f;transform:translateY(-2px);box-shadow:inset 0 0 0 1px #ffffff14,0 8px 20px #00000038}.menu-icon--windows{background:#ffffff1a}.menu-icon--task-app:after{content:"";width:7px;height:3px;transition:width var(--motion-fast) var(--ease-standard),height var(--motion-fast) var(--ease-standard),background var(--motion-fast) var(--ease-standard),opacity var(--motion-fast) var(--ease-standard);background:#f6f8ffc2;border-radius:999px;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.menu-icon--task-app.menu-icon--active:after{background:var(--accent);width:18px;height:4px}.menu-icon--task-app-minimized:after{opacity:.44}.menu-icon img{object-fit:contain;width:23px;height:23px;display:block}.menu-icon--social img{filter:brightness(0)invert();opacity:.92;width:19px;height:19px}.menu-icon span{display:none}.app-drawer{z-index:65;-webkit-backdrop-filter:blur(40px)saturate(1.18);backdrop-filter:blur(40px)saturate(1.18);contain:layout paint;transform-origin:bottom;width:min(640px,100vw - 32px);height:min(720px,100vh - 96px);animation:app-drawer-enter .22s var(--ease-enter);background:linear-gradient(#ffffff14,#ffffff08 18%,#00000014),#13182170;border:1px solid #ffffff24;border-radius:9px;grid-template-rows:auto minmax(0,1fr) auto;display:grid;position:fixed;bottom:72px;left:auto;right:50%;overflow:hidden;transform:translate(50%);box-shadow:inset 0 1px #ffffff1f,inset 0 -1px #ffffff08,0 28px 70px #00000047}.app-drawer__search{background:#141b30d1;border:1px solid #6fb0ff3d;border-bottom-color:#53c4fff2;border-radius:5px;align-items:center;gap:10px;min-height:42px;margin:32px 34px 22px;padding:0 12px;display:flex;box-shadow:inset 0 0 0 1px #ffffff09,0 1px #ffffff0d}.app-drawer__search span{border:2px solid #8fdcff;border-radius:999px;width:15px;height:15px;display:block;position:relative}.app-drawer__search span:after{content:"";background:#8fdcff;border-radius:999px;width:7px;height:2px;position:absolute;bottom:-4px;right:-6px;transform:rotate(-45deg)}.app-drawer__search input{color:#edf2ffe6;min-width:0;font:inherit;background:0 0;border:0;outline:0;flex:1}.app-drawer__search input::placeholder{color:#edf2ff9e}.app-drawer__search input::-webkit-search-cancel-button{cursor:pointer}.app-drawer__body{overscroll-behavior:contain;grid-template-rows:minmax(0,1fr);gap:0;min-height:0;padding:18px 44px 22px;display:grid;overflow:hidden}.app-drawer__section{gap:20px;display:grid}.app-drawer__view{gap:22px;min-width:0;min-height:0;display:grid}.app-drawer__view--pinned{grid-template-rows:minmax(0,1fr) auto;align-content:start;height:100%}@media(prefers-reduced-motion:no-preference){.app-drawer__view{animation:app-drawer-view-enter .18s var(--ease-enter)}.app-drawer__view--all-apps{animation-duration:.21s}}@keyframes app-drawer-view-enter{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.app-drawer__section-head{justify-content:space-between;align-items:center;display:flex}.app-drawer__section-head h2,.app-drawer__empty{margin:0}.app-drawer__section-head h2{color:var(--ink);font-size:.9rem;font-weight:650}.app-drawer__section-action{color:#edf2ffb8;min-height:24px;font-size:.73rem;font:inherit;cursor:pointer;transition:border-color var(--motion-fast) var(--ease-standard),background var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard);background:#ffffff0f;border:1px solid #ffffff14;border-radius:4px;align-items:center;gap:7px;padding:0 9px;display:inline-flex}.app-drawer__section-action:hover,.app-drawer__section-action:focus-visible{color:#f6f8ffeb;background:#ffffff1c;border-color:#8bccff5c;outline:0}.app-drawer__section-action:after{content:"";border-top:1.5px solid;border-right:1.5px solid;width:6px;height:6px;display:inline-block;transform:rotate(45deg)}.app-drawer__section-action--back:after{order:-1;transform:rotate(225deg)}.app-drawer__grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:14px 12px;display:grid}.app-drawer__section--pinned-main{align-content:start}.app-drawer__section--all-apps{grid-template-rows:auto minmax(0,1fr);gap:10px}.app-drawer__section-head--all-apps{z-index:1;margin:0;padding:0 0 10px;position:relative}.app-drawer__all-apps-scroll{overscroll-behavior:contain;scrollbar-color:#e8edf752 transparent;scrollbar-width:thin;min-width:0;min-height:0;padding:2px 10px 0 0;overflow:auto}.app-drawer__all-apps-scroll::-webkit-scrollbar{width:12px}.app-drawer__all-apps-scroll::-webkit-scrollbar-track{background:0 0}.app-drawer__all-apps-scroll::-webkit-scrollbar-thumb{background:#e8edf757 padding-box padding-box;border:4px solid #0000;border-radius:999px}.app-drawer__all-apps-scroll::-webkit-scrollbar-thumb:hover{background:#e8edf78a padding-box padding-box}.app-drawer__all-apps{gap:18px;min-width:0;padding-bottom:6px;display:grid}.app-drawer__letter-group{grid-template-columns:32px minmax(0,1fr);align-items:start;gap:16px;min-width:0;display:grid}.app-drawer__letter-heading{color:#edf2ff94;margin:8px 0 0;font-size:.82rem;font-weight:700;line-height:1}.app-drawer__app-list{justify-items:start;gap:4px;min-width:0;display:grid}.app-drawer__app-row{color:#f6f8ffe6;text-align:left;cursor:pointer;max-width:min(100%,520px);min-height:42px;transition:border-color var(--motion-fast) var(--ease-standard),background var(--motion-fast) var(--ease-standard),transform var(--motion-fast) var(--ease-standard);background:0 0;border:1px solid #0000;border-radius:6px;grid-template-columns:32px auto;align-items:center;gap:12px;padding:5px 14px 5px 8px;display:inline-grid}.app-drawer__app-row:hover,.app-drawer__app-row:focus-visible{background:#ffffff17;border-color:#ffffff1c;outline:0;transform:translate(2px)}.app-drawer__app-row img{object-fit:contain;width:28px;height:28px}.app-drawer__app-row span{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:.82rem;font-weight:540;line-height:1.2;overflow:hidden}.app-drawer__empty{color:var(--muted);border:1px dashed #ffffff2e;border-radius:8px;margin-top:24px;padding:18px;font-size:.84rem;line-height:1.5}.app-drawer__item{min-height:56px;box-shadow:none;color:var(--text);text-align:center;cursor:pointer;transition:transform var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard),background var(--motion-fast) var(--ease-standard);background:0 0;border:1px solid #0000;border-radius:6px;align-content:center;justify-items:center;gap:7px;padding:4px;text-decoration:none;display:grid}.app-drawer__item:hover,.app-drawer__item:focus-visible{background:#ffffff17;border-color:#ffffff1a;transform:translateY(-1px);box-shadow:0 8px 22px #0000002e}.app-drawer__item img{object-fit:contain;width:29px;height:29px}.app-drawer__item strong{color:var(--ink);font-size:.72rem;font-weight:500;line-height:1.2;display:block}.app-drawer__section--developer{align-self:end}.app-drawer__developer-card{background:linear-gradient(135deg,#ffffff1c,#ffffff09),#ffffff09;border:1px solid #ffffff17;border-radius:11px;grid-template-columns:78px minmax(0,1fr);align-items:center;gap:16px;padding:12px 14px;display:grid;box-shadow:inset 0 1px #ffffff1a,0 14px 34px #00000024}.app-drawer__developer-card img{object-fit:cover;border:1px solid #ffffff2e;border-radius:50%;width:78px;height:78px;box-shadow:0 12px 24px #00000038}.app-drawer__developer-card div,.app-drawer__developer-card strong,.app-drawer__developer-card span,.app-drawer__developer-card p{min-width:0;display:block}.app-drawer__developer-card strong{color:var(--ink);font-size:.9rem;font-weight:650;line-height:1.2}.app-drawer__developer-card span{color:#edf2ff9e;letter-spacing:.08em;text-transform:uppercase;margin-top:3px;font-size:.72rem;line-height:1.2}.app-drawer__developer-card p{color:#edf2ffad;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:8px 0 0;font-size:.75rem;line-height:1.38;display:-webkit-box;overflow:hidden}.app-drawer__footer{background:#04104257;justify-content:space-between;align-items:center;min-height:66px;padding:12px 66px;display:flex;position:relative}.app-drawer__footer:before{content:"";opacity:1;background:#ffffff1a;height:1px;position:absolute;top:0;left:0;right:0}.app-drawer__user{color:var(--ink);align-items:center;gap:12px;font-size:.82rem;font-weight:650;display:flex}.app-drawer__user img{object-fit:cover;border-radius:999px;width:34px;height:34px}.app-drawer__power{cursor:pointer;width:36px;height:36px;transition:transform var(--motion-fast) var(--ease-standard),background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard);background:#ffffff1a;border:1px solid #0000;border-radius:6px;position:relative}.app-drawer__power:hover,.app-drawer__power:focus-visible{background:#ffffff29;border-color:#8fdcff47;outline:0;transform:translateY(-1px);box-shadow:inset 0 1px #ffffff1f,0 8px 20px #00000038}.app-drawer__power:active{background:#fff3;transform:translateY(0)}.app-drawer__power span{border:2px solid #f6f8ffd1;border-top-color:#0000;border-radius:999px;position:absolute;inset:9px}.app-drawer__power span:before{content:"";background:#f6f8ffd1;border-radius:999px;width:2px;height:10px;position:absolute;top:-6px;left:50%;transform:translate(-50%)}.window-layer{z-index:12;pointer-events:none;position:fixed;inset:0}.app-window{background:var(--window-bg);contain:layout paint;pointer-events:auto;transform-origin:top;backface-visibility:hidden;resize:both;min-width:420px;min-height:320px;transition:opacity var(--motion-medium) var(--ease-standard);border:1px solid #ffffff24;border-radius:12px;flex-direction:column;display:flex;position:absolute;overflow:hidden;transform:translateZ(0)}.app-window--focused{border-color:#60cdff66}.app-window--floating{top:var(--window-top);left:var(--window-left);width:min(var(--window-width),calc(100vw - 120px));height:min(var(--window-height),calc(100vh - 152px));max-width:calc(100vw - 84px);max-height:calc(100vh - 118px)}.app-window--maximized{resize:none;border-radius:10px;width:auto;min-width:0;max-width:none;height:auto;min-height:0;max-height:none;inset:0}.app-window--opening{animation:window-enter .5s var(--ease-enter) forwards}.app-window--minimized{pointer-events:none;animation:.4s cubic-bezier(.85,0,.15,1) forwards window-minimize}@keyframes window-minimize{0%{opacity:1;transform:translate(0)scale(1)translateZ(0)}to{opacity:0;transform:translate(var(--minimize-x,0),var(--minimize-y,0)) scale(var(--minimize-scale,.1)) translateZ(0)}}.app-window--open{opacity:1;transform:scale(1)translateZ(0)}.app-window--closing{opacity:0;pointer-events:none;transition:opacity .5s var(--ease-standard),transform .5s var(--ease-standard);transform:scale(.94)translateZ(0)}.app-window--minimized{opacity:0;pointer-events:none;visibility:hidden;transition:opacity .01ms linear}.window-titlebar{background:var(--window-titlebar-bg);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;border-bottom:1px solid #ffffff14;align-items:center;gap:12px;min-height:44px;padding:0 8px 0 14px;display:flex}.is-dragging-window,.is-dragging-window *{cursor:grabbing!important}.window-meta{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.window-meta img{object-fit:contain;width:17px;height:17px;display:block}.window-titlebar h2{color:var(--ink);text-align:left;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.82rem;font-weight:650;overflow:hidden}.window-toolbar{align-items:center;gap:8px;display:flex}.window-titlebar__action{color:#f6f8ffdb;min-height:28px;transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard);background:#ffffff0d;border:1px solid #ffffff1f;border-radius:7px;justify-content:center;align-items:center;padding:0 12px;font-size:.74rem;font-weight:600;line-height:1;text-decoration:none;display:inline-flex}.window-titlebar__action:hover,.window-titlebar__action:focus-visible{color:var(--ink);background:#60cdff24;border-color:#60cdff57}.window-controls{align-items:center;display:flex}.window-control{width:42px;height:32px;box-shadow:none;cursor:pointer;background:0 0;border:0;border-radius:8px;transition:background .16s;position:relative}.window-control:before,.window-control:after{content:"";background:#f6f8ffdb;border-radius:999px;width:11px;height:1.5px;position:absolute;top:50%;left:50%}.window-control--minimize:before{transform:translate(-50%,-50%)}.window-control--minimize:after{display:none}.window-control--close:before{transform:translate(-50%,-50%)rotate(45deg)}.window-control--close:after{transform:translate(-50%,-50%)rotate(-45deg)}.window-control:hover,.window-control:focus-visible{background:#ffffff14}.window-control--close:hover,.window-control--close:focus-visible{background:#c42b1c}.window-control--close:hover:before,.window-control--close:hover:after,.window-control--close:focus-visible:before,.window-control--close:focus-visible:after{background:#fff}.window-content{background:var(--window-bg);scrollbar-gutter:stable both-edges;flex:1;min-height:0;padding:24px;overflow:auto}.app-window--resume .window-content,.app-window--certifications .window-content,.app-window--tryhackme .window-content,.app-window--hackthebox .window-content,.app-window--terminal .window-content{scrollbar-gutter:auto;padding:0}.app-window--resume .window-content{flex-direction:column;display:flex}.app-window--terminal .window-content{background:#0c0c0c;overflow:hidden}.app-window--tryhackme .window-content,.app-window--hackthebox .window-content,.app-window--certifications .window-content{overflow:hidden}.terminal-app{color:#ccc;background:#0c0c0c;flex-direction:column;height:100%;min-height:0;font-family:Cascadia Mono,Consolas,Agave Nerd Font,Fira Code,monospace;font-size:13px;line-height:1.2;display:flex;overflow:hidden}.terminal-app__surface{cursor:text;scrollbar-width:thin;scrollbar-color:#424242 transparent;flex:1;min-height:0;padding:18px 24px 24px;overflow:auto}.terminal-app__surface::-webkit-scrollbar{width:8px}.terminal-app__surface::-webkit-scrollbar-track{background:0 0}.terminal-app__surface::-webkit-scrollbar-thumb{background:#424242;border-radius:4px}.terminal-app__line{white-space:pre-wrap;word-break:break-word;align-items:baseline;gap:6px;display:flex}.terminal-app__prompt{white-space:nowrap;flex-shrink:0;display:inline}.terminal-app__prompt-ps{color:#f9f1a5}.terminal-app__prompt-path{color:#3b78ff}.terminal-app__prompt-gt{color:#ccc}.terminal-app__input{color:#ccc;word-break:break-word}.terminal-app__input--live{min-width:0;font:inherit;color:#ccc;caret-color:#ccc;background:0 0;border:0;outline:none;flex:1;padding:0}.terminal-app__output{color:#ccc;margin-bottom:2px}.notification-centre{box-sizing:border-box;height:auto;min-height:0;animation:notification-centre-enter var(--motion-medium) var(--ease-enter) forwards;flex-direction:column;padding:30px 18px 18px;display:flex;top:0;bottom:54px;right:0;transform:translate(100%)}.notification-centre__stack{flex:auto;grid-template-rows:minmax(0,1fr) auto;align-content:end;gap:12px;width:100%;min-height:0;display:grid}.notification-centre__panel{-webkit-backdrop-filter:blur(40px)saturate(1.18);backdrop-filter:blur(40px)saturate(1.18);background:linear-gradient(#ffffff14,#ffffff08 18%,#00000014),#13182170;border:1px solid #ffffff24;border-radius:9px;overflow:hidden;box-shadow:inset 0 1px #ffffff1f,inset 0 -1px #ffffff08,0 28px 70px #00000047}.notification-centre__panel--notifications{min-height:180px;max-height:min(42vh,380px);transition:max-height .22s var(--ease-standard),min-height .22s var(--ease-standard),transform .22s var(--ease-standard);grid-template-rows:auto minmax(0,1fr);align-self:end;display:grid;overflow:clip}.notification-centre__panel--calendar{display:grid}.notification-centre__panel--notifications.is-empty{min-height:0;max-height:206px}.notification-centre__header{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px 12px;display:flex}.notification-centre__heading{color:#f7f7f3fa;letter-spacing:-.02em;margin:0;font-size:1.02rem;font-weight:740}.notification-centre__clear{color:#f7f7f3e0;min-height:32px;font:inherit;transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard);background:#ffffff0f;border:1px solid #ffffff14;border-radius:6px;padding:0 14px;font-size:.8rem;font-weight:700}.notification-centre__clear:hover,.notification-centre__clear:focus-visible{color:#fff;background:#ffffff14;border-color:#ffffff1a}.notification-centre__clear:disabled{opacity:.42;cursor:default}.notification-centre__notifications,.notification-centre__calendar{min-height:0;display:grid}.notification-centre__card,.notification-centre__empty-card,.notification-centre__notifications{background:linear-gradient(#ffffff03,#fff0),0 0;border:0;border-radius:0}.notification-centre__card,.notification-centre__empty-card{box-shadow:none;background:0 0}.notification-centre__notifications{overflow:hidden}.notification-centre__notifications-scroll{min-height:0;transition:padding .22s var(--ease-standard);gap:0;padding:0;display:grid;overflow-y:auto}.notification-centre__card,.notification-centre__empty-card{transition:opacity .18s var(--ease-standard),transform .18s var(--ease-standard);padding:16px 18px 18px}.notification-centre__card+.notification-centre__card{border-top:1px solid #ffffff14}.notification-centre__card-topline{justify-content:space-between;align-items:center;gap:12px;display:flex}.notification-centre__app{color:#f7f7f3e6;align-items:center;gap:10px;min-width:0;font-size:.88rem;font-weight:620;display:inline-flex}.notification-centre__app img{object-fit:contain;width:16px;height:16px;display:block}.notification-centre__actions{align-items:center;display:inline-flex}.notification-centre__icon-button,.notification-centre__calendar-toggle{color:#f7f7f3ad;width:32px;height:32px;transition:border-color var(--motion-fast) var(--ease-standard),background var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard);background:#ffffff0f;border:1px solid #ffffff14;border-radius:6px;justify-content:center;align-items:center;display:inline-flex}.notification-centre__icon-button:hover,.notification-centre__icon-button:focus-visible,.notification-centre__calendar-toggle:hover,.notification-centre__calendar-toggle:focus-visible{color:#f7f7f3eb;background:#fff1;border-color:#ffffff1a}.notification-centre__icon-button svg,.notification-centre__calendar-toggle svg{width:16px;height:16px;display:block}.notification-centre__meta{color:#f7f7f380;margin-top:12px;font-size:.8rem;font-weight:600}.notification-centre__body{margin-top:16px;display:block}.notification-centre__copy{min-width:0}.notification-centre__copy h3,.notification-centre__empty-card h3{color:#f7f7f3f5;margin:0;font-size:.96rem;font-weight:680;line-height:1.3}.notification-centre__copy p,.notification-centre__empty-card p{color:#f7f7f3a8;margin:6px 0 0;font-size:.84rem;line-height:1.5}.notification-centre__link{color:#9cd4fff5;margin-top:12px;font-size:.84rem;font-weight:680;text-decoration:none;display:inline-flex}.notification-centre__link:hover,.notification-centre__link:focus-visible{color:#e2f5ff}.notification-centre__empty-card{text-align:center;justify-items:center;gap:0;padding-top:28px;padding-bottom:28px}.notification-centre__panel--notifications.is-empty .notification-centre__notifications-scroll{padding-bottom:8px}.notification-centre__calendar{padding:0 18px 14px}.notification-centre__calendar-header{background:#04104257;border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:start;gap:14px;margin:0 -18px;padding:18px 22px 16px;display:flex}.notification-centre__calendar-day{color:#f7f7f3eb;letter-spacing:-.02em;margin:0;font-size:.98rem;font-weight:720}.notification-centre__calendar-month{color:#f7f7f3b8;margin:8px 0 0;font-size:.98rem;font-weight:620}.notification-centre__calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px 6px;margin-top:16px;display:grid}.notification-centre__weekday,.notification-centre__day{place-items:center;display:grid}.notification-centre__weekday{color:#f7f7f36b;letter-spacing:.02em;min-height:20px;font-size:.76rem;font-weight:700}.notification-centre__day{color:#f7f7f3e6;border-radius:999px;min-height:34px;font-size:.94rem;font-weight:620}.notification-centre__day.is-outside-month{color:#f7f7f33d}.notification-centre__day.is-today{color:#041018;background:linear-gradient(#5ad0ff,#4a9dff);box-shadow:inset 0 1px #ffffff57,0 0 0 1px #78ccff33,0 10px 24px #40a4ff2e}@keyframes notification-centre-enter{to{transform:translate(0)}}@keyframes notification-centre-mobile-enter{to{transform:translateY(0)}}@media(max-width:640px){.notification-centre{z-index:1200;contain:layout paint;max-height:min(100vh - 68px,620px);padding:0 0 8px;animation:none;width:min(360px,100vw - 20px)!important;max-width:360px!important;inset:auto 10px 58px auto!important;transform:none!important}.notification-centre__stack{grid-template-rows:minmax(0,auto) auto;align-content:end;gap:8px;max-height:min(100vh - 68px,620px)}.notification-centre__panel{-webkit-backdrop-filter:blur(34px)saturate(1.16);backdrop-filter:blur(34px)saturate(1.16);background:linear-gradient(#ffffff1b,#ffffff09 34%,#00000017),#12171fc7;border-radius:12px;box-shadow:inset 0 1px #ffffff24,inset 0 -1px #ffffff0a,0 22px 60px #00000057}.notification-centre__panel--notifications{min-height:0;max-height:min(28vh,220px)}.notification-centre__notifications-scroll{overscroll-behavior:contain}.notification-centre__header{padding:12px 14px 10px}.notification-centre__heading{font-size:.82rem}.notification-centre__clear{min-height:30px;padding:0 12px;font-size:.76rem}.notification-centre__card,.notification-centre__empty-card{padding:11px 12px 12px}.notification-centre__meta{margin-top:8px;font-size:.68rem}.notification-centre__body{margin-top:10px}.notification-centre__copy h3,.notification-centre__empty-card h3{font-size:.84rem}.notification-centre__copy p,.notification-centre__empty-card p{font-size:.76rem;line-height:1.42}.notification-centre__link{font-size:.78rem}.notification-centre__calendar{padding:0 14px 12px}.notification-centre__calendar-header{margin:0 -14px;padding:13px 16px 12px}.notification-centre__calendar-day,.notification-centre__calendar-month{font-size:.8rem}.notification-centre__calendar-grid{gap:4px 3px;margin-top:12px}.notification-centre__weekday{min-height:18px;font-size:.62rem}.notification-centre__day{min-height:26px;font-size:.74rem}}.context-menu{z-index:9999;-webkit-backdrop-filter:blur(40px)saturate(1.18);backdrop-filter:blur(40px)saturate(1.18);min-width:240px;animation:context-menu-enter .12s var(--ease-enter) forwards;transform-origin:0 0;background:linear-gradient(#ffffff14,#ffffff08 18%,#00000014),#13182170;border:1px solid #ffffff1a;border-radius:8px;flex-direction:column;padding:4px;display:flex;position:fixed;box-shadow:inset 0 1px #ffffff1f,inset 0 -1px #ffffff08,0 12px 32px #00000047}@keyframes context-menu-enter{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu__item{color:#fffffff2;text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;align-items:center;gap:12px;width:100%;padding:6px 10px;font-family:inherit;font-size:.85rem;font-weight:400;text-decoration:none;transition:background .1s,color .1s;display:flex}.context-menu__item:hover,.context-menu__item:focus-visible{color:#fff;background:#ffffff14;outline:none}.context-menu__icon{justify-content:center;align-items:center;width:18px;height:18px;display:flex}.context-menu__icon img,.context-menu__icon svg{object-fit:contain;width:100%;height:100%}.context-menu__icon svg{stroke:var(--muted);transition:stroke .12s}.context-menu__item:hover .context-menu__icon svg,.context-menu__item:focus-visible .context-menu__icon svg{stroke:var(--ink)}.context-menu__separator{background:#ffffff1a;height:1px;margin:6px 0}.notification-stack{z-index:70;pointer-events:none;gap:12px;width:min(372px,100vw - 32px);display:grid;position:fixed;bottom:82px;right:22px}.notification-card-enter{animation:notification-enter var(--motion-medium) var(--ease-enter) both}.notification-card{-webkit-backdrop-filter:blur(28px)saturate(1.24);backdrop-filter:blur(28px)saturate(1.24);box-shadow:none;pointer-events:auto;cursor:pointer;-webkit-user-select:none;user-select:none;transform-style:preserve-3d;will-change:transform;background:linear-gradient(#ffffff14,#ffffff06),#141b27bd;border:1px solid #ffffff1f;border-radius:14px;outline:none;grid-template-columns:36px minmax(0,1fr);align-items:start;gap:14px;padding:15px 15px 15px 14px;transition:transform .4s cubic-bezier(.22,1,.36,1);display:grid;position:relative}.notification-card:before{content:"";border-radius:inherit;background:radial-gradient(160px circle at var(--glow-x,50%) var(--glow-y,50%),#78a0ff2e 0%,transparent 70%);opacity:0;pointer-events:none;z-index:0;transition:opacity .2s;position:absolute;inset:-1px}.notification-card:hover:before{opacity:1}.notification-card>*{z-index:1;position:relative}.notification-card--pressed{background:linear-gradient(#ffffff0a,#ffffff03),#0e141ed1;transition:transform 90ms cubic-bezier(.4,0,1,1)}.notification-card--pressed:before{opacity:0}.notification-card__icon{width:36px;height:36px;box-shadow:none;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:11px;place-items:center;display:grid}.notification-card__icon img{object-fit:contain;width:18px;height:18px}.notification-card__body,.notification-card__body h2,.notification-card__body p,.notification-card__eyebrow{margin:0}.notification-card__eyebrow{color:#a8cdffcc;letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px;font-size:.68rem;font-weight:700;line-height:1.2;display:block}.notification-card h2{color:var(--ink);font-size:.92rem;font-weight:600;line-height:1.3}.notification-card p{color:#e2e9f5c2;margin-top:6px;font-size:.82rem;line-height:1.5}.standalone-software{isolation:isolate;color:var(--ink);background:radial-gradient(circle at 50% -18%,#ffffff13,#0000 31%),linear-gradient(#111,#080808 46%,#020202);position:fixed;inset:0;overflow:hidden}.standalone-software:before{pointer-events:none;content:"";background-color:#0000;background-image:linear-gradient(90deg,#ffffff07 1px,#0000 1px),linear-gradient(#ffffff05 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:38px 38px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#00000057,#0000 70%);mask-image:linear-gradient(#00000057,#0000 70%)}.standalone-software__exit{z-index:2;color:#f6f8ffc2;cursor:pointer;min-height:40px;transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard),transform var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard);background:#ffffff0a;border:1px solid #ffffff1a;border-radius:999px;align-items:center;gap:10px;padding:0 16px 0 13px;font-size:.8rem;font-weight:650;line-height:1;text-decoration:none;display:inline-flex;position:absolute;top:22px;left:22px}.standalone-software__exit:hover,.standalone-software__exit:focus-visible{color:var(--ink);background:#ffffff14;border-color:#fff3;transform:translate(-1px);box-shadow:0 10px 24px #00000038}.standalone-software__exit-icon{width:16px;height:16px;display:block;position:relative}.standalone-software__exit-icon:before,.standalone-software__exit-icon:after{content:"";transform-origin:0;background:currentColor;border-radius:999px;width:11px;height:2px;position:absolute;left:1px}.standalone-software__exit-icon:before{top:8px;transform:rotate(38deg)}.standalone-software__exit-icon:after{top:8px;transform:rotate(-38deg)}.standalone-software__exit-label{white-space:nowrap}.browser-url{border:1px solid var(--line);background:var(--window-panel-bg);color:var(--muted);border-radius:8px;margin-bottom:18px;padding:11px 15px;font-size:.9rem}.browser-view,.project-grid article{background:var(--window-panel-bg);border:1px solid #ffffff1a;border-radius:8px;padding:20px}body.portfolio-body{scrollbar-width:none;-ms-overflow-style:none}body.portfolio-body::-webkit-scrollbar{width:0;height:0;display:none}.portfolio-app::-webkit-scrollbar{width:0;height:0;display:none}.portfolio-app{--portfolio-panel:#14161bd6;--portfolio-panel-strong:#1c1f26eb;--portfolio-surface-container:#f5f1e809;--portfolio-surface-container-high:#f5f1e80f;--portfolio-surface-container-highest:#f5f1e81a;--portfolio-surface-tonal:#f5f1e80b;--portfolio-surface-tonal-strong:#f5f1e813;--portfolio-outline-soft:#ffffff14;--portfolio-outline-strong:#ffffff24;--portfolio-shadow-soft:0 18px 56px #00000047;--motion-luxury:1s;--motion-ultra-luxury:1.5s;--portfolio-section-heading-gap:48px;--portfolio-section-heading-gap-compact:32px;--portfolio-hero-intro-padding-top:28svh;--portfolio-hero-intro-padding-bottom:10svh;--portfolio-hero-statement-padding-top:12svh;--portfolio-hero-statement-padding-bottom:12svh;--portfolio-content-padding-top:240px;--portfolio-content-padding-bottom:144px;scrollbar-width:none;-ms-overflow-style:none;color:#f7f7f3;scroll-behavior:smooth;background:linear-gradient(#ffffff09,#0000 18%),radial-gradient(circle at 74% 18%,#6a84b02e,#0000 28%),radial-gradient(circle at 16% 38%,#4d8dff2b,#0000 26%),radial-gradient(circle at 55% 72%,#5ed68614,#0000 32%),#090a0b;overflow:hidden auto}.portfolio-app:before{z-index:0;pointer-events:none;content:"";mix-blend-mode:screen;opacity:.24;background:repeating-radial-gradient(circle at 12% 18%,#ffffff17 0 1px,#0000 1px 5px),repeating-radial-gradient(circle at 84% 64%,#ffffff0e 0 1px,#0000 1px 4px);position:fixed;inset:0}.portfolio-app:after{z-index:0;pointer-events:none;content:"";background:linear-gradient(90deg,#00000094,#0000 28% 72%,#0000007a),linear-gradient(#0000,#00000061);position:fixed;inset:0}.portfolio-app>*{z-index:1;position:relative}.portfolio-app [data-portfolio-section]{scroll-margin-block:96px}.portfolio-app [data-portfolio-snap=start]{scroll-snap-align:start}.portfolio-app [data-portfolio-snap=center]{scroll-snap-align:center}.portfolio-app [data-portfolio-snap=end]{scroll-snap-align:end}.portfolio-app.is-progression-ready [data-portfolio-reveal]{opacity:.24;transition:opacity .62s var(--ease-standard),transform .62s var(--ease-standard);will-change:opacity,transform;transform:translateY(30px)scale(.985)}.portfolio-app.is-progression-ready [data-portfolio-reveal].is-visible{opacity:1;transform:translate(0)scale(1)}.portfolio-app.is-progression-ready [data-portfolio-reveal].is-before{opacity:.38;transform:translateY(-24px)scale(.992)}.portfolio-app.is-progression-ready [data-portfolio-reveal].is-after{opacity:.24;transform:translateY(30px)scale(.985)}.portfolio-section-shell--roadmap,.portfolio-roadmap{opacity:1;transform:none}.portfolio-section-reveal{width:100%}.portfolio-app .standalone-software__exit{z-index:12;position:relative;top:auto;left:auto}.portfolio-nav{z-index:1000;will-change:transform;-webkit-backdrop-filter:blur(10px)saturate(102%);backdrop-filter:blur(10px)saturate(102%);color:#f7f7f3c7;background:#1c1b1d70;border:0;border-radius:999px;grid-template-columns:minmax(0,1fr) minmax(0,auto) minmax(max-content,1fr);align-items:center;gap:14px;width:min(100% - 48px,1180px);min-height:58px;padding:4px 14px;display:grid;position:fixed;top:26px;left:50%;transform:translate(-50%)translateZ(0);box-shadow:inset 0 1px #ffffff05,0 8px 22px #0000001f}.portfolio-nav__actions{justify-self:start;align-items:center;min-width:0;display:flex}.portfolio-app .standalone-software__exit{color:#f7f7f3db;min-height:38px;box-shadow:none;transition:background var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard);background:#f5f1e80b;border:0;border-radius:999px;gap:9px;padding:0 18px 0 14px}.portfolio-app .standalone-software__exit:hover,.portfolio-app .standalone-software__exit:focus-visible{color:#fff;box-shadow:none;background:#f5f1e813}.portfolio-nav__brand{pointer-events:none;color:#f7f7f3db;justify-content:center;justify-self:center;align-items:center;min-width:0;max-width:100%;display:flex}.portfolio-nav__brand-title{text-overflow:ellipsis;white-space:nowrap;text-align:center;color:#f7f7f3eb;letter-spacing:.01em;font-size:.92rem;font-weight:600;overflow:hidden}.portfolio-nav__utilities{justify-self:end;align-items:center;gap:10px;display:flex}.portfolio-nav__quick-links{align-items:center;display:flex;position:relative}.portfolio-nav__socials{align-items:center;gap:8px;display:flex}.portfolio-nav__action{color:#f7f7f3bd;cursor:pointer;width:36px;height:36px;transition:background var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard);background:#f5f1e80a;border:0;border-radius:999px;place-items:center;text-decoration:none;display:grid;position:relative}.portfolio-nav__action:hover,.portfolio-nav__action:focus-visible{color:#fff;box-shadow:none;background:#f5f1e813}.portfolio-nav__icon{z-index:1;width:18px;height:18px;-webkit-mask-image:var(--icon-url);mask-image:var(--icon-url);opacity:.82;transition:opacity var(--motion-fast) var(--ease-standard);background-color:currentColor;position:relative;-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.portfolio-nav__action:hover .portfolio-nav__icon,.portfolio-nav__action:focus-visible .portfolio-nav__icon{opacity:1}.portfolio-nav__menu-icon{gap:3px;display:grid}.portfolio-nav__menu-icon span{opacity:.9;background:currentColor;border-radius:999px;width:14px;height:1.5px;display:block}.portfolio-nav__quick-links-menu{-webkit-backdrop-filter:blur(18px)saturate(125%);backdrop-filter:blur(18px)saturate(125%);background:linear-gradient(#ffffff0b,#ffffff05),#111318f0;border:1px solid #ffffff14;border-radius:16px;gap:4px;min-width:178px;padding:8px;display:grid;position:absolute;top:calc(100% + 12px);right:0;box-shadow:inset 0 1px #ffffff0d,0 18px 38px #00000057}.portfolio-nav__quick-links-menu[hidden]{display:none}.portfolio-nav__quick-links-menu a{color:#f7f7f3c7;transition:background var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard);border-radius:10px;padding:9px 12px;font-size:.82rem;font-weight:580;line-height:1.35;text-decoration:none;display:block}.portfolio-nav__quick-links-menu a:hover,.portfolio-nav__quick-links-menu a:focus-visible{color:#fff;background:#f5f1e813}.portfolio-hero,.portfolio-roadmap__heading,.portfolio-roadmap__mobile-list,.portfolio-grid-section,.portfolio-experience,.portfolio-social-cta,.portfolio-close{width:min(1180px,100% - 48px);margin:0 auto}.portfolio-section-shell{width:100%}.portfolio-hero{min-height:auto;padding:0}.portfolio-hero__frame{align-content:center;min-height:100svh;display:grid}.portfolio-hero__frame--intro{padding-top:var(--portfolio-hero-intro-padding-top);padding-bottom:var(--portfolio-hero-intro-padding-bottom)}.portfolio-hero__frame--statement{padding-top:var(--portfolio-hero-statement-padding-top);padding-bottom:var(--portfolio-hero-statement-padding-bottom)}.portfolio-hero__intro{gap:12px;display:grid}.portfolio-hero__intro-copy{gap:inherit;display:grid}.portfolio-hero__lead{color:#f7f7f3f5;flex-wrap:wrap;align-items:center;gap:12px;margin:0;font-size:5.5rem;font-weight:850;line-height:.96;display:flex}.portfolio-hero__lead>span:not(.portfolio-hero__chip){white-space:nowrap}.portfolio-hero__lead .portfolio-hero__chip span{font-size:.86em}.portfolio-hero__emoji{filter:saturate(.68)brightness(1.08)}.portfolio-hero__sublead{color:#f7f7f3a3;flex-wrap:wrap;align-items:center;gap:10px;margin:0;font-size:clamp(.92rem,1.6vw,1.2rem);font-weight:500;line-height:1.5;display:flex}.portfolio-hero__sublead--secondary{color:#f7f7f394;margin-top:-4px;font-size:clamp(.78rem,1.25vw,.98rem)}.portfolio-hero__title{color:#0000;text-shadow:0 0 18px #ffffff0d;background:linear-gradient(135deg,#f7f7f3 30%,#b3cdf8);-webkit-background-clip:text;background-clip:text;max-width:880px;margin:0;font-size:5.5rem;font-weight:850;line-height:.96}.portfolio-hero__chip{color:#f8fbff;white-space:nowrap;background:0 0;border:1px solid #ffffff14;border-radius:.34em;justify-content:center;align-items:center;gap:.22em;padding:.12em .34em .16em;line-height:.98;display:inline-flex;position:relative;overflow:hidden;box-shadow:0 8px 22px #00000038}.portfolio-hero__chip:before{border-radius:inherit;background:var(--portfolio-chip-gradient);transform-origin:0;content:"";position:absolute;inset:0;transform:scaleX(1);box-shadow:inset 0 1px #ffffff14}.portfolio-hero__chip-content{z-index:1;align-items:center;gap:.22em;display:inline-flex;position:relative}.portfolio-hero__chip--violet{--portfolio-chip-gradient:linear-gradient(135deg, #7d4dff, #9f6bff)}.portfolio-hero__chip--amber{--portfolio-chip-gradient:linear-gradient(135deg, #e48b42, #ffb366)}.portfolio-hero__chip--mint{--portfolio-chip-gradient:linear-gradient(135deg, #4bcf82, #8bf3a6);color:#092012}.portfolio-hero__chip--ice{--portfolio-chip-gradient:linear-gradient(135deg, #5d7fff, #7aa2ff)}.portfolio-hero__title .portfolio-hero__chip em{font-family:Georgia,Times New Roman,serif;font-style:italic;font-weight:400}.portfolio-section-heading h2 .portfolio-hero__chip,.portfolio-roadmap__heading h2 .portfolio-hero__chip,.portfolio-close h2 .portfolio-hero__chip,.portfolio-tech-stack__heading h2 .portfolio-hero__chip{vertical-align:.04em;padding:.08em .26em .12em;box-shadow:0 6px 18px #0000002e}.portfolio-app{--portfolio-chip-intent-delay:.6s}.portfolio-app.is-progression-ready [data-portfolio-chip]{opacity:0;transform:translate(-28px)}.portfolio-app.is-progression-ready [data-portfolio-chip]:before{transform:scaleX(0)}.portfolio-app.is-progression-ready [data-portfolio-chip].is-revealed{animation:1.28s cubic-bezier(.22,1,.36,1) forwards portfolio-chip-slide-in;animation-delay:var(--portfolio-chip-intent-delay,0s)}.portfolio-app.is-progression-ready [data-portfolio-chip].is-revealed:before{animation:1.28s cubic-bezier(.22,1,.36,1) forwards portfolio-chip-fill;animation-delay:var(--portfolio-chip-intent-delay,0s)}@keyframes portfolio-chip-slide-in{0%{opacity:0;transform:translate(-28px)}to{opacity:1;transform:translate(0)}}@keyframes portfolio-chip-fill{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.portfolio-roadmap{width:100%;padding:var(--portfolio-content-padding-top) 0 var(--portfolio-content-padding-bottom)}.portfolio-roadmap__heading,.portfolio-section-heading{margin-bottom:var(--portfolio-section-heading-gap)}.portfolio-roadmap__heading h2,.portfolio-section-heading h2,.portfolio-close h2{color:#f7f7f3;width:fit-content;max-width:min(100%,720px);margin:0;padding-bottom:.42em;font-size:3.35rem;line-height:1.02;position:relative}.portfolio-roadmap__heading h2:after,.portfolio-section-heading h2:after,.portfolio-close h2:after{content:"";pointer-events:none;background:linear-gradient(90deg,var(--project-accent,#4d8dff),#ffffff1f);border-radius:999px;width:min(132px,38%);height:2px;position:absolute;bottom:.08em;left:0}@supports (color:color-mix(in lab,red,red)){.portfolio-roadmap__heading h2:after,.portfolio-section-heading h2:after,.portfolio-close h2:after{background:linear-gradient(90deg,color-mix(in srgb,var(--project-accent,#4d8dff) 72%,#fff),#ffffff1f)}}.portfolio-roadmap__heading h2:after,.portfolio-section-heading h2:after,.portfolio-close h2:after{opacity:.9}.portfolio-roadmap__layout{grid-template-columns:minmax(0,1fr) minmax(280px,380px);align-items:start;gap:clamp(24px,3vw,56px);max-width:1680px;margin:0 auto;padding:0 clamp(24px,4vw,64px);display:grid}.portfolio-roadmap__stage{grid-template-columns:18px minmax(0,1fr);align-items:stretch;gap:22px;height:calc(100vh - 176px);min-height:0;display:grid;position:sticky;top:112px}.portfolio-progress{background:#ffffff1f;border-radius:999px;width:2px;position:relative;overflow:hidden}.portfolio-progress span{border-radius:inherit;background:linear-gradient(180deg,#fff,var(--project-accent,#4d8dff));min-height:8%;transition:height .42s var(--ease-standard);display:block;position:absolute;bottom:auto;left:0;right:0}.portfolio-roadmap__chapters{gap:0;display:grid}.portfolio-roadmap__chapter{opacity:.42;min-height:76vh;transition:opacity var(--motion-medium) var(--ease-standard);align-content:center;place-items:center;padding:10vh 0;scroll-margin-top:120px;display:grid}.portfolio-roadmap__chapter.is-active{opacity:1}.portfolio-roadmap__rail-item{color:#f7f7f38f;text-align:center;cursor:pointer;width:100%;min-height:0;transition:color var(--motion-medium) var(--ease-standard),transform var(--motion-fast) var(--ease-standard);background:0 0;border:0;grid-template-columns:minmax(0,1fr);align-items:start;padding:0;text-decoration:none;display:grid}.portfolio-roadmap__rail-item:hover,.portfolio-roadmap__rail-item:focus-visible{color:#fff;transform:translate(4px)}.portfolio-roadmap__chapter.is-active .portfolio-roadmap__rail-item{color:#fff}.portfolio-roadmap__rail-copy{gap:0;min-width:0;display:grid}.portfolio-roadmap__summary{font-family:Urbanist,sans-serif}.portfolio-roadmap__rail-copy span{color:currentColor;font-size:1rem;line-height:1.7}.portfolio-roadmap__resource{isolation:isolate;color:#f7f7f3d1;width:fit-content;min-height:40px;transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard);background:#f5f1e80b;border:1px solid #ffffff0f;border-radius:999px;align-items:center;gap:10px;margin:20px auto 0;padding:0 18px 0 14px;font-size:.82rem;font-weight:760;text-decoration:none;display:inline-flex;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff0a}.portfolio-roadmap__resource-icon{flex:none;justify-content:center;align-items:center;width:20px;height:20px;display:inline-flex}.portfolio-roadmap__resource-icon img{width:100%;height:100%;display:block}.portfolio-roadmap__resource:before{z-index:-1;content:"";opacity:0;transition:opacity var(--motion-fast) var(--ease-standard);background:#ffffff0f;position:absolute;inset:0}.portfolio-roadmap__resource:hover,.portfolio-roadmap__resource:focus-visible{color:#fff;background:#f5f1e812;border-color:#ffffff1a;box-shadow:inset 0 1px #ffffff0f,0 0 0 1px #ffffff08}.portfolio-roadmap__resource:hover:before,.portfolio-roadmap__resource:focus-visible:before{opacity:1}.portfolio-roadmap__mobile-list{display:none}.portfolio-roadmap__mobile-item{gap:12px;display:grid}.portfolio-roadmap__mobile-meta{grid-template-columns:42px minmax(0,1fr);align-items:center;gap:14px;display:grid}.portfolio-roadmap__mobile-meta>span{color:#fff;background:#ffffff08;border:1px solid #ffffff1f;border-radius:14px;place-items:center;width:42px;height:42px;font-size:.82rem;font-weight:760;display:grid}.portfolio-roadmap__mobile-meta div{gap:4px;display:grid}.portfolio-roadmap__mobile-meta strong{color:#fff;font-size:.96rem;font-weight:650}.portfolio-roadmap__mobile-meta small{color:#f7f7f380;text-transform:uppercase;font-size:.72rem;font-weight:760}.portfolio-roadmap__mobile-summary{color:#f7f7f3b8;margin:0;font-size:.95rem;line-height:1.65}.portfolio-surface{aspect-ratio:16/10;border:1px solid var(--project-accent);align-content:center;align-self:center;justify-items:center;width:100%;max-width:min(100%,160vh - 320px);margin:0;padding:32px 24px 64px;display:grid;position:relative;overflow:hidden}@supports (color:color-mix(in lab,red,red)){.portfolio-surface{border:1px solid color-mix(in srgb,var(--project-accent) 28%,#ffffff29)}}.portfolio-surface{background:linear-gradient(145deg,var(--project-accent),var(--portfolio-surface-container)),#151515;border-radius:28px}@supports (color:color-mix(in lab,red,red)){.portfolio-surface{background:linear-gradient(145deg,color-mix(in srgb,var(--project-accent) 58%,#171717),var(--portfolio-surface-container)),#151515}}.portfolio-surface{box-shadow:var(--portfolio-shadow-soft)}.portfolio-surface:before{pointer-events:none;content:"";opacity:.22;background:repeating-radial-gradient(circle at 26% 20%,#ffffff29 0 1px,#0000 1px 7px),linear-gradient(#0000,#00000052);position:absolute;inset:0}.portfolio-surface__image,.portfolio-surface__video{object-fit:cover;opacity:.18;width:100%;height:100%;position:absolute;inset:0}.portfolio-surface--has-media:before{opacity:0}.portfolio-surface--has-media{background:#0d1015}.portfolio-surface--has-media .portfolio-surface__image,.portfolio-surface--has-media .portfolio-surface__video{opacity:1}.portfolio-surface__device{background:#09090ac7;border:1px solid #ffffff47;border-radius:8px;grid-template-rows:26px 1fr;width:min(250px,72%);min-height:330px;display:grid;position:relative;overflow:hidden;box-shadow:0 24px 52px #0000005c}.portfolio-surface--desktop .portfolio-surface__device,.portfolio-surface--editorial .portfolio-surface__device{width:min(520px,70%);min-height:255px}.portfolio-surface__bar{background:radial-gradient(circle at 20px 13px,#ff6b5f 0 4px,#0000 5px),radial-gradient(circle at 38px 13px,#f4c63d 0 4px,#0000 5px),radial-gradient(circle at 56px 13px,#2fb46f 0 4px,#0000 5px),#ffffff14;border-bottom:1px solid #ffffff24}.portfolio-surface__screen{background:linear-gradient(135deg,#ffffff14,transparent),radial-gradient(circle at 76% 24%,var(--project-accent),transparent 26%);align-content:end;gap:8px;padding:24px;display:grid}@supports (color:color-mix(in lab,red,red)){.portfolio-surface__screen{background:linear-gradient(135deg,#ffffff14,transparent),radial-gradient(circle at 76% 24%,color-mix(in srgb,var(--project-accent) 68%,transparent),transparent 26%)}}.portfolio-surface__screen span,.portfolio-surface figcaption span{color:#f7f7f39e}.portfolio-surface__screen strong{color:#fff;font-size:1.48rem;line-height:1.08}.portfolio-surface__screen small{color:#f7f7f394;line-height:1.5}.portfolio-surface figcaption{color:#fff;-webkit-backdrop-filter:blur(12px)saturate(120%);backdrop-filter:blur(12px)saturate(120%);background:#0a0c10ad;border:1px solid #ffffff14;border-radius:16px;gap:6px;padding:14px 16px;font-size:.94rem;display:grid;position:absolute;bottom:22px;left:22px;right:22px;box-shadow:0 8px 32px #0000003d}.portfolio-surface figcaption span{color:#f7f7f39e;letter-spacing:.03em;font-size:.76rem;font-weight:760}.portfolio-surface figcaption strong{color:#fff;font-size:1.15rem;font-weight:680;line-height:1.2}.portfolio-grid-section{padding:var(--portfolio-content-padding-top) 0 var(--portfolio-content-padding-bottom)}.portfolio-video-section{width:min(1180px,100% - 48px);padding:var(--portfolio-content-padding-top) 0 var(--portfolio-content-padding-bottom);margin:0 auto}.portfolio-experience{padding:var(--portfolio-content-padding-top) 0 var(--portfolio-content-padding-bottom)}.portfolio-experience__heading{justify-content:space-between;align-items:end;gap:24px;display:flex}.portfolio-experience__title{max-width:100%}.portfolio-experience__layout{grid-template-columns:minmax(280px,420px) minmax(0,1fr);align-items:center;gap:42px;display:grid}.portfolio-experience__actions{justify-content:center;width:min(1180px,100% - 48px);margin:36px auto 0;display:flex}.portfolio-experience__resume{gap:12px;margin:0}.portfolio-experience__resume-icon{flex:none;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.portfolio-experience__resume-icon img{object-fit:contain;width:100%;height:100%;display:block}.portfolio-experience__timeline{gap:0;padding:8px 0;display:grid}.portfolio-experience-step{width:100%;color:inherit;text-align:left;cursor:pointer;transition:transform .22s var(--ease-standard);background:0 0;border:0;grid-template-columns:56px minmax(0,1fr);align-items:start;gap:18px;padding:0;display:grid}.portfolio-experience-step__rail{grid-template-rows:36px minmax(28px,1fr);justify-items:center;display:grid}.portfolio-experience-step__node{width:36px;height:36px;transition:border-color .28s var(--ease-standard),background .28s var(--ease-standard),box-shadow .42s var(--ease-standard),transform .32s var(--ease-standard);background:radial-gradient(circle at 30% 30%,#ffffff1c,#0000 58%),#ffffff07;border:1px solid #ffffff24;border-radius:999px;place-items:center;display:grid;position:relative}.portfolio-experience-step__node:before{border-radius:inherit;background:radial-gradient(circle,var(--experience-step-accent,var(--experience-accent,#68b8ff)),transparent 70%);position:absolute;inset:-10px}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-step__node:before{background:radial-gradient(circle,color-mix(in srgb,var(--experience-step-accent,var(--experience-accent,#68b8ff)) 36%,transparent),transparent 70%)}}.portfolio-experience-step__node:before{opacity:0;filter:blur(12px);transition:opacity .32s var(--ease-standard),transform .42s var(--ease-standard);content:"";transform:scale(.72)}.portfolio-experience-step__node span{z-index:1;width:12px;height:12px;transition:background .28s var(--ease-standard),transform .32s var(--ease-standard),box-shadow .32s var(--ease-standard);background:#f7f7f36b;border-radius:999px;position:relative}.portfolio-experience-step__line{background:#ffffff1a;border-radius:999px;width:2px;min-height:78px;position:relative;overflow:hidden}.portfolio-experience-step__line-fill{border-radius:inherit;background:linear-gradient(180deg,var(--experience-step-accent,var(--experience-accent,#68b8ff)),var(--experience-step-accent,var(--experience-accent,#68b8ff)));position:absolute;inset:0}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-step__line-fill{background:linear-gradient(180deg,color-mix(in srgb,var(--experience-step-accent,var(--experience-accent,#68b8ff)) 92%,#fff),color-mix(in srgb,var(--experience-step-accent,var(--experience-accent,#68b8ff)) 52%,transparent))}}.portfolio-experience-step__line-fill{box-shadow:0 0 18px var(--experience-step-accent,var(--experience-accent,#68b8ff))}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-step__line-fill{box-shadow:0 0 18px color-mix(in srgb,var(--experience-step-accent,var(--experience-accent,#68b8ff)) 30%,transparent)}}.portfolio-experience-step__line-fill{transform-origin:top;opacity:0;transition:transform .52s cubic-bezier(.22,1,.36,1),opacity .32s var(--ease-standard);transform:scaleY(0)}.portfolio-experience-step__copy{gap:8px;padding:1px 0 32px;display:grid}.portfolio-experience-step__period{color:#f7f7f38f;letter-spacing:.06em;text-transform:uppercase;margin:0;font-size:.74rem;font-weight:780}.portfolio-experience-step__copy strong{color:#f7f7f3f0;font-size:1.22rem;font-weight:600;line-height:1.1}.portfolio-experience-step__copy small{color:#f7f7f394;transition:color .22s var(--ease-standard);font-size:.94rem}.portfolio-experience-step:focus-visible .portfolio-experience-step__node,.portfolio-experience-step.is-active .portfolio-experience-step__node{border-color:var(--experience-step-accent,var(--experience-accent,#68b8ff))}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-step:focus-visible .portfolio-experience-step__node,.portfolio-experience-step.is-active .portfolio-experience-step__node{border-color:color-mix(in srgb,var(--experience-step-accent,var(--experience-accent,#68b8ff)) 68%,#ffffff2e)}}.portfolio-experience-step:focus-visible .portfolio-experience-step__node,.portfolio-experience-step.is-active .portfolio-experience-step__node{background:radial-gradient(circle at 30% 30%,var(--experience-step-accent,var(--experience-accent,#68b8ff)),transparent 58%),#ffffff0a}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-step:focus-visible .portfolio-experience-step__node,.portfolio-experience-step.is-active .portfolio-experience-step__node{background:radial-gradient(circle at 30% 30%,color-mix(in srgb,var(--experience-step-accent,var(--experience-accent,#68b8ff)) 22%,#ffffff14),transparent 58%),#ffffff0a}}.portfolio-experience-step:focus-visible .portfolio-experience-step__node,.portfolio-experience-step.is-active .portfolio-experience-step__node{box-shadow:0 0 0 8px var(--experience-step-accent,var(--experience-accent,#68b8ff)),0 0 26px var(--experience-step-accent,var(--experience-accent,#68b8ff))}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-step:focus-visible .portfolio-experience-step__node,.portfolio-experience-step.is-active .portfolio-experience-step__node{box-shadow:0 0 0 8px color-mix(in srgb,var(--experience-step-accent,var(--experience-accent,#68b8ff)) 11%,transparent),0 0 26px color-mix(in srgb,var(--experience-step-accent,var(--experience-accent,#68b8ff)) 18%,transparent)}}.portfolio-experience-step:focus-visible .portfolio-experience-step__node,.portfolio-experience-step.is-active .portfolio-experience-step__node{transform:scale(1.04)}.portfolio-experience-step:focus-visible .portfolio-experience-step__node span,.portfolio-experience-step.is-active .portfolio-experience-step__node span{background:var(--experience-step-accent,var(--experience-accent,#68b8ff))}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-step:focus-visible .portfolio-experience-step__node span,.portfolio-experience-step.is-active .portfolio-experience-step__node span{background:color-mix(in srgb,var(--experience-step-accent,var(--experience-accent,#68b8ff)) 78%,#fff)}}.portfolio-experience-step:focus-visible .portfolio-experience-step__node span,.portfolio-experience-step.is-active .portfolio-experience-step__node span{box-shadow:0 0 12px var(--experience-step-accent,var(--experience-accent,#68b8ff))}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-step:focus-visible .portfolio-experience-step__node span,.portfolio-experience-step.is-active .portfolio-experience-step__node span{box-shadow:0 0 12px color-mix(in srgb,var(--experience-step-accent,var(--experience-accent,#68b8ff)) 28%,transparent)}}.portfolio-experience-step:focus-visible .portfolio-experience-step__node span,.portfolio-experience-step.is-active .portfolio-experience-step__node span{transform:scale(1.16)}.portfolio-experience-step:focus-visible .portfolio-experience-step__node:before,.portfolio-experience-step.is-active .portfolio-experience-step__node:before{opacity:1;transform:scale(1)}.portfolio-experience-step.is-reached .portfolio-experience-step__line-fill{opacity:1;transform:scaleY(1)}.portfolio-experience-step:focus-visible .portfolio-experience-step__copy strong,.portfolio-experience-step.is-active .portfolio-experience-step__copy strong{color:#fff}.portfolio-experience-step:focus-visible .portfolio-experience-step__copy small,.portfolio-experience-step.is-active .portfolio-experience-step__copy small{color:#f7f7f3bd}.portfolio-experience-step:hover{transform:translateZ(0)}.portfolio-experience-step:focus-visible{outline:none}.portfolio-experience-detail{border:1px solid var(--portfolio-outline-soft);background:radial-gradient(circle at 100% 0%,var(--experience-accent,#68b8ff),transparent 34%),linear-gradient(180deg,#ffffff0b,#ffffff03),#0e1114c2;border-radius:28px;min-height:100%;padding:32px;position:relative}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-detail{background:radial-gradient(circle at 100% 0%,color-mix(in srgb,var(--experience-accent,#68b8ff) 15%,transparent),transparent 34%),linear-gradient(180deg,#ffffff0b,#ffffff03),#0e1114c2}}.portfolio-experience-detail{overflow:hidden;box-shadow:inset 0 1px #ffffff0f,0 24px 64px #0000004d}.portfolio-experience-detail:before{pointer-events:none;background:linear-gradient(135deg,var(--experience-accent,#68b8ff),transparent 32%),linear-gradient(180deg,#ffffff08,transparent 26%);position:absolute;inset:0}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-detail:before{background:linear-gradient(135deg,color-mix(in srgb,var(--experience-accent,#68b8ff) 16%,transparent),transparent 32%),linear-gradient(180deg,#ffffff08,transparent 26%)}}.portfolio-experience-detail:before{content:""}.portfolio-experience-detail__body{z-index:1;align-content:start;gap:24px;display:grid;position:relative}.portfolio-experience-detail__header{gap:10px;display:grid}.portfolio-experience-detail__header div{gap:0;display:grid}.portfolio-experience-detail__header h3{color:#f7f7f3;letter-spacing:-.03em;margin:0;font-size:clamp(1.6rem,2.2vw,2rem);line-height:1.02}.portfolio-experience-detail__highlights{gap:14px;margin:0;padding:0;list-style:none;display:grid}.portfolio-experience-detail__highlights li{color:#f7f7f3b8;padding-left:22px;line-height:1.7;position:relative}.portfolio-experience-detail__highlights li:before{background:var(--experience-accent,#68b8ff);border-radius:999px;width:8px;height:8px;position:absolute;top:.55rem;left:0}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-detail__highlights li:before{background:color-mix(in srgb,var(--experience-accent,#68b8ff) 74%,#fff)}}.portfolio-experience-detail__highlights li:before{box-shadow:0 0 16px var(--experience-accent,#68b8ff)}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-detail__highlights li:before{box-shadow:0 0 16px color-mix(in srgb,var(--experience-accent,#68b8ff) 24%,transparent)}}.portfolio-experience-detail__highlights li:before{content:""}.portfolio-experience-detail__tools{flex-wrap:wrap;gap:12px;display:flex}.portfolio-experience-tool{background:linear-gradient(120deg,var(--experience-accent,#68b8ff),#ffffff3d);border-radius:999px;justify-content:center;align-items:center;min-height:42px;padding:1px;display:inline-flex;position:relative}@supports (color:color-mix(in lab,red,red)){.portfolio-experience-tool{background:linear-gradient(120deg,color-mix(in srgb,var(--experience-accent,#68b8ff) 82%,#fff),#ffffff3d)}}.portfolio-experience-tool{color:#f7f7f3d1;font-size:.84rem;font-weight:700;overflow:hidden}.portfolio-experience-tool:before{border-radius:inherit;content:"";background:linear-gradient(#14171eeb,#0e1116f0);position:absolute;inset:1px}.portfolio-experience-tool__icon,.portfolio-experience-tool__label{z-index:1;position:relative}.portfolio-experience-tool__icon{flex:none;justify-content:center;align-items:center;width:16px;height:16px;margin-left:12px;display:inline-flex}.portfolio-experience-tool__icon img{object-fit:contain;width:100%;height:100%;display:block}.portfolio-experience-tool__label{align-items:center;min-height:40px;padding:0 14px 0 10px;display:inline-flex}.portfolio-tech-stack{width:100%;padding:var(--portfolio-content-padding-top) 0 var(--portfolio-content-padding-bottom)}.portfolio-tech-stack__heading{text-align:center;justify-items:center;gap:10px;width:min(1180px,100% - 48px);margin:0 auto 28px;display:grid}.portfolio-tech-stack__heading p{color:#f7f7f38a;letter-spacing:.06em;text-transform:uppercase;margin:0;font-size:.72rem;font-weight:800}.portfolio-tech-stack__heading h2{color:#f7f7f3eb;margin:0;font-size:1.1rem;font-weight:620}.portfolio-tech-stack__lanes{gap:22px;width:100vw;margin:0 calc(50% - 50vw);display:grid}.portfolio-tech-stack__lane{padding:6px 0;overflow:hidden}.portfolio-tech-stack__track{will-change:transform;align-items:center;gap:14px;width:max-content;animation:19s linear infinite portfolio-tech-stack-forward;display:flex}.portfolio-tech-stack__lane.is-reverse .portfolio-tech-stack__track{animation-name:portfolio-tech-stack-reverse;animation-duration:17s}.portfolio-tech-stack__token{flex:none;place-items:center;width:64px;height:64px;display:grid}.portfolio-tech-stack__token img{object-fit:contain;filter:drop-shadow(0 10px 22px #00000038);width:100%;height:100%;display:block}.portfolio-tech-stack__token span{color:#f7f7f3e0;letter-spacing:.04em;font-size:.98rem;font-weight:820}.portfolio-social-cta{padding:var(--portfolio-content-padding-top) 0 var(--portfolio-content-padding-bottom)}.portfolio-social-cta .portfolio-section-heading{max-width:980px;margin-bottom:38px}.portfolio-social-cta__grid{justify-content:center;align-items:flex-start;gap:28px;padding:18px 0 34px;display:flex;overflow:visible}.portfolio-social-cta__card{width:min(240px,24vw);min-width:190px;min-height:310px;transition:transform var(--motion-medium) var(--ease-standard),border-color var(--motion-medium) var(--ease-standard),background var(--motion-medium) var(--ease-standard),box-shadow var(--motion-medium) var(--ease-standard);background:linear-gradient(#ffffff0a,#ffffff03),#151921f5;border:1px solid #ffffff1a;border-radius:22px;grid-template-rows:1fr auto;text-decoration:none;display:grid;position:relative;overflow:hidden;transform:translateY(0);box-shadow:inset 0 1px #ffffff0d,0 22px 42px #00000047}.portfolio-social-cta__card:after{content:"";opacity:.72;background:linear-gradient(90deg,#0000,#7caeff47,#0000);height:1px;position:absolute;inset:auto 24px 22px}.portfolio-social-cta__card:hover,.portfolio-social-cta__card:focus-visible{background:linear-gradient(#ffffff0d,#ffffff05),#191e27fa;border-color:#ffffff29;transform:translateY(-8px);box-shadow:inset 0 1px #ffffff0f,0 28px 46px #00000052}@media(min-width:981px){.portfolio-social-cta__card{width:245px;min-width:0;height:320px;transform:perspective(1200px) translateY(var(--social-offset,0px)) rotate(var(--social-rotate,0deg));transform-origin:bottom}.portfolio-social-cta__card:hover,.portfolio-social-cta__card:focus-visible{transform:perspective(1200px) translateY(calc(var(--social-offset,0px) - 12px)) rotate(var(--social-rotate,0deg)) scale(1.02)}}.portfolio-social-cta__banner{background:radial-gradient(circle at 78% 20%,#ffffff2e,#0000 34%),linear-gradient(155deg,#ffffff0a,#0000 34%),linear-gradient(#ffffff0f,#ffffff05);border-bottom:1px solid #ffffff0f;place-items:center;min-height:200px;display:grid;position:relative}.portfolio-social-cta__banner:after{content:"";opacity:.4;border:1px solid #ffffff14;border-radius:16px;position:absolute;inset:16px}.portfolio-social-cta__banner-icon{aspect-ratio:1;background:radial-gradient(circle at 36% 36%,#ffffff1f,#0000 48%),linear-gradient(135deg,#ffffff0f,#0000 52%);border-radius:18px;width:62%;position:relative}.portfolio-social-cta__banner-icon:before{content:"";-webkit-mask-image:var(--icon-url);mask-image:var(--icon-url);opacity:1;filter:drop-shadow(0 4px 18px #ffffff1f);background-color:#ffffff7a;position:absolute;inset:18%;-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.portfolio-social-cta__copy{gap:7px;min-width:0;padding:22px 24px 28px;display:grid}.portfolio-social-cta__copy strong{color:#f7f7f3f5;white-space:nowrap;text-overflow:ellipsis;font-size:1.28rem;font-weight:780;overflow:hidden}.portfolio-social-cta__copy span{color:#f7f7f394;white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;line-height:1.45;overflow:hidden}.portfolio-social-cta__card[data-social-platform=linkedin] .portfolio-social-cta__banner{background:radial-gradient(circle at 60% 40%,#3888ff47,#0000 56%),linear-gradient(145deg,#146cff5c,#3888ff1f 52%,#ffffff0a)}.portfolio-social-cta__card[data-social-platform=linkedin] .portfolio-social-cta__banner-icon:before{background-color:#ffffff9e}.portfolio-social-cta__card[data-social-platform=github] .portfolio-social-cta__banner{background:radial-gradient(circle at 56% 40%,#a0aabe2e,#0000 52%),linear-gradient(145deg,#5c657842,#828ca01a 52%,#ffffff08)}.portfolio-social-cta__card[data-social-platform=github] .portfolio-social-cta__banner-icon:before{background-color:#ffffff8a}.portfolio-social-cta__card[data-social-platform=youtube] .portfolio-social-cta__banner{background:radial-gradient(circle at 58% 42%,#ff505042,#0000 54%),linear-gradient(145deg,#ff282857,#ff64641f 52%,#ffffff08)}.portfolio-social-cta__card[data-social-platform=youtube] .portfolio-social-cta__banner-icon:before{background-color:#ffc8c894}.portfolio-social-cta__card[data-social-platform=instagram] .portfolio-social-cta__banner{background:radial-gradient(circle at 58% 42%,#c248ff38,#0000 54%),linear-gradient(145deg,#ff644847,#c248ff38 48%,#8c3cdc14)}.portfolio-social-cta__card[data-social-platform=instagram] .portfolio-social-cta__banner-icon:before{background-color:#ffdcff8f}@keyframes portfolio-tech-stack-forward{0%{transform:translate(0)}to{transform:translate(calc(9px - 50%))}}@keyframes portfolio-tech-stack-reverse{0%{transform:translate(calc(9px - 50%))}to{transform:translate(0)}}.portfolio-section-heading--compact{margin-bottom:var(--portfolio-section-heading-gap-compact)}.portfolio-video-frame{aspect-ratio:16/9;width:min(1070px,100% - clamp(40px,8vw,132px));box-shadow:var(--portfolio-shadow-soft);background:linear-gradient(#ffffff05,#ffffff02),#080a0cf5;border:1px solid #ffffff1a;border-radius:28px;margin:0 auto;position:relative;overflow:hidden}.portfolio-video-frame__player{object-fit:cover;background:#050607;width:100%;height:100%;display:block}.portfolio-video-section__description{text-align:center;color:#f7f7f3b8;flex-direction:column;align-items:center;max-width:820px;margin:24px auto 0;font-size:1.02rem;line-height:1.78;display:flex}.portfolio-video-section__description p{margin:0}.portfolio-video-section__link{white-space:nowrap;gap:10px;min-height:40px;margin-top:16px;margin-left:0;padding:0 16px 0 12px}.portfolio-video-section__link-icon{flex:none;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.portfolio-video-section__link-icon img{width:100%;height:100%;display:block}.portfolio-exhibition{touch-action:pan-y;cursor:grab;margin:0 calc(50% - 50vw);padding:24px max(24px,50vw - 566px) 64px;display:block;overflow:hidden}.portfolio-exhibition__track{will-change:transform;gap:32px;display:flex}.portfolio-exhibition.is-dragging{cursor:grabbing;-webkit-user-select:none;user-select:none}.portfolio-exhibition.is-dragging .portfolio-credential-card,.portfolio-exhibition.is-dragging .portfolio-link{pointer-events:none}.portfolio-credential-card{--card-rotate-x:0deg;--card-rotate-y:0deg;--card-press-x:0px;--card-press-y:0px;--card-sheen-x:50%;--card-sheen-y:50%;--card-drift-x:0px;--card-drift-y:0px;isolation:isolate;width:auto;max-width:min(620px,88vw);height:420px;transform-style:preserve-3d;transition:background var(--motion-luxury) var(--ease-standard),transform var(--motion-luxury) var(--ease-standard),border-color var(--motion-luxury) var(--ease-standard),box-shadow var(--motion-luxury) var(--ease-standard);background:linear-gradient(#ffffff07,#ffffff03),#0f1114c2;border:1px solid #ffffff14;border-radius:22px;flex-shrink:0;grid-template-columns:minmax(0,auto);gap:0;padding:12px;display:grid;position:relative;overflow:hidden}.portfolio-credential-card:hover,.portfolio-credential-card:focus-within{border-color:var(--project-accent,#4d8dff);background:linear-gradient(#ffffff0e,#ffffff05),#0e1115e0}@supports (color:color-mix(in lab,red,red)){.portfolio-credential-card:hover,.portfolio-credential-card:focus-within{border-color:color-mix(in srgb,var(--project-accent,#4d8dff) 22%,#fff3)}}.portfolio-credential-card:hover,.portfolio-credential-card:focus-within{transform:perspective(1400px) translate3d(var(--card-drift-x),var(--card-drift-y),0) rotateX(var(--card-rotate-x)) rotateY(var(--card-rotate-y)) scale(.992);box-shadow:inset 0 1px #ffffff0d,0 12px 26px #00000038}.portfolio-credential-card__media{min-width:0;height:100%;min-height:0;transition:transform var(--motion-luxury) var(--ease-standard);align-content:start;display:grid;transform:translateZ(30px)}.portfolio-credential-card__image{box-sizing:border-box;width:auto;height:100%;min-height:0;box-shadow:none;transition:transform var(--motion-luxury) var(--ease-standard),box-shadow var(--motion-luxury) var(--ease-standard),background var(--motion-luxury) var(--ease-standard);background:0 0;border:0;border-radius:14px;place-items:center;padding:0;display:grid;position:relative;overflow:hidden}.portfolio-credential-card__image img{filter:drop-shadow(0 18px 26px #0000003d);width:auto;min-width:0;max-width:100%;height:auto;min-height:0;max-height:100%;transition:transform var(--motion-luxury) var(--ease-standard);border-radius:8px;display:block}.portfolio-credential-card:hover .portfolio-credential-card__image img{transform:scale(1.035)}.portfolio-credential-card:hover .portfolio-credential-card__media,.portfolio-credential-card:focus-within .portfolio-credential-card__media{transform:translateZ(16px) translateY(calc(var(--card-press-y) * .08)) translate(calc(var(--card-press-x) * .14))}.portfolio-credential-card:hover .portfolio-credential-card__image,.portfolio-credential-card:focus-within .portfolio-credential-card__image{transform:translate(calc(var(--card-press-x) * .2)) translateY(calc(var(--card-press-y) * .22)) translateZ(-12px);box-shadow:none;background:0 0}.portfolio-link.portfolio-credential-card__verify{z-index:2;width:auto;margin:0;position:absolute;top:18px;right:18px}.portfolio-credential-card:before,.portfolio-link:before{content:"";z-index:10;border-radius:inherit;background:radial-gradient(400px circle at var(--mouse-x,-999px) var(--mouse-y,-999px),#f5f1e838,transparent 60%);pointer-events:none;opacity:0;transition:opacity .4s var(--ease-standard);padding:1px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.portfolio-credential-card:after,.portfolio-link:after{content:"";z-index:5;pointer-events:none;background:radial-gradient(600px circle at var(--mouse-x,-999px) var(--mouse-y,-999px),#ffffff0f,transparent 40%);opacity:0;transition:opacity .4s var(--ease-standard);border-radius:inherit;position:absolute;inset:0}.portfolio-credential-card:after{background:radial-gradient(560px circle at var(--mouse-x,50%) var(--mouse-y,50%),#ffffff1f,transparent 34%),linear-gradient(180deg,#ffffff14,#ffffff03 38%,#03070d2e);opacity:.72;mix-blend-mode:screen}.portfolio-credential-card:hover:before,.portfolio-link:hover:before,.portfolio-credential-card:hover:after,.portfolio-link:hover:after,.portfolio-credential-card:focus-within:before,.portfolio-credential-card:focus-within:after{opacity:1}.portfolio-card__visual div{background:var(--portfolio-surface-container-high);width:min(320px,72%);min-height:210px;box-shadow:var(--portfolio-shadow-soft);border:1px solid #ffffff2e;border-radius:8px;align-content:end;gap:10px;padding:24px;display:grid;position:relative}.portfolio-card__visual span{color:#f7f7f394;font-size:.82rem;font-weight:850}.portfolio-card__visual strong{color:#fff;font-size:1.55rem;line-height:1.08}.portfolio-card p{color:#f7f7f38a;gap:10px;margin:0;font-size:.82rem;line-height:1.45;display:flex}.portfolio-card p strong{color:#fff;flex:none}.portfolio-link{isolation:isolate;background:var(--project-accent,#4d8dff);border:1px solid #7caeff24;border-radius:999px;justify-content:center;align-items:center;min-height:44px;margin-top:30px;padding:0 18px;display:inline-flex;position:relative}@supports (color:color-mix(in lab,red,red)){.portfolio-link{background:color-mix(in srgb,var(--project-accent,#4d8dff) 38%,#f5f1e829)}}.portfolio-link{color:#f6fbff;cursor:pointer;transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard);font-size:.88rem;font-weight:760;text-decoration:none}.portfolio-link:hover,.portfolio-link:focus-visible{background:var(--project-accent,#4d8dff);border-color:#7caeff33}@supports (color:color-mix(in lab,red,red)){.portfolio-link:hover,.portfolio-link:focus-visible{background:color-mix(in srgb,var(--project-accent,#4d8dff) 48%,#f5f1e82e)}}.portfolio-link:hover,.portfolio-link:focus-visible{color:#fff;box-shadow:inset 0 1px #ffffff0f,0 0 0 1px #7caeff14}.portfolio-link--quiet{color:#f7f7f3;background:#f5f1e80b;border-color:#ffffff0f;margin-left:10px}.portfolio-link--quiet:hover,.portfolio-link--quiet:focus-visible{color:#fff;background:#f5f1e812;border-color:#ffffff1a}.portfolio-detail-hero,.portfolio-detail-section{width:min(1180px,100% - 48px);margin:0 auto}.portfolio-detail-hero{align-items:center;min-height:100svh;padding:184px 0 108px;display:grid}.portfolio-detail-hero__frame{gap:24px;max-width:860px;display:grid}.portfolio-detail-hero__eyebrow{color:#f7f7f385;letter-spacing:.22em;text-transform:uppercase;margin:0;font-size:.84rem;font-weight:700}.portfolio-detail-hero__title{color:#f8f8f4fa;letter-spacing:-.05em;text-wrap:balance;margin:0;font-size:clamp(3.6rem,9vw,6.8rem);line-height:.96}.portfolio-detail-hero__summary{color:#f7f7f3b8;max-width:720px;margin:0;font-size:clamp(1.02rem,1.5vw,1.18rem);line-height:1.8}.portfolio-detail-hero__chips,.portfolio-detail-hero__actions{flex-wrap:wrap;gap:12px;display:flex}.portfolio-detail-section{padding-bottom:144px}.portfolio-detail-section--video{padding-top:12px}.portfolio-video-frame--detail iframe{background:#050607;border:0;width:100%;height:100%;display:block}.portfolio-detail-card,.portfolio-detail-download{box-shadow:var(--portfolio-shadow-soft);background:linear-gradient(#ffffff08,#ffffff03),#0a0c0fdb;border:1px solid #ffffff17;border-radius:28px;position:relative;overflow:hidden}.portfolio-detail-card{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:0;display:grid}.portfolio-detail-card__media{background:radial-gradient(circle at 18% 16%,#4d8dff2e,#0000 36%),#06080af0;border-right:1px solid #ffffff12;min-height:100%;margin:0}.portfolio-detail-card__media img{object-fit:cover;width:100%;height:100%;min-height:420px;display:block}.portfolio-detail-card__copy{align-content:center;align-items:start;gap:18px;padding:42px;display:grid}.portfolio-detail-card__copy p{color:#f7f7f3bd;margin:0;font-size:1rem;line-height:1.82}.portfolio-detail-card__actions{justify-content:center;margin-top:8px;padding-top:12px;display:flex}.portfolio-detail-card__action{gap:10px;min-width:220px;margin-top:0}.portfolio-detail-card__action--youtube{color:#fff7f7;background:#fd6b6270;border-color:#ff5c5c2e}.portfolio-detail-card__action--youtube:hover,.portfolio-detail-card__action--youtube:focus-visible{color:#fff;background:#fd685f8b;border-color:#ff6e6e47;box-shadow:inset 0 1px #ffffff14,0 0 0 1px #ff5c5c1a}.portfolio-detail-card__action-icon{flex:none;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.portfolio-detail-card__action-icon img{width:100%;height:100%;display:block}.portfolio-detail-downloads{gap:18px;display:grid}.portfolio-detail-download{justify-content:space-between;align-items:center;gap:24px;padding:28px 30px;display:flex}.portfolio-detail-download__copy{align-items:flex-start;gap:18px;min-width:0;display:flex}.portfolio-detail-download__icon{background:#ffffff0a;border-radius:10px;flex:none;justify-content:center;align-items:center;width:32px;height:32px;display:inline-flex}.portfolio-detail-download__icon img{width:20px;height:20px;display:block}.portfolio-detail-download h3,.portfolio-detail-download p{margin:0}.portfolio-detail-download h3{color:#f8f8f4f5;font-size:1.14rem;font-weight:700}.portfolio-detail-download p{color:#f7f7f39e;margin-top:8px;line-height:1.7}.portfolio-close--detail{padding-top:12px}.portfolio-experience__resume{color:#fbfdff;letter-spacing:0;min-height:62px;transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard),transform var(--motion-fast) var(--ease-standard);-webkit-backdrop-filter:blur(20px)saturate(135%);backdrop-filter:blur(20px)saturate(135%);background:linear-gradient(#ffffff1f,#ffffff08 38%,#ffffff0d),linear-gradient(#48505c7a,#2127306b);border:0;margin:0;padding:2px 35px;font-size:1rem;overflow:hidden;box-shadow:inset 0 1px #ffffff52,inset 0 -10px 24px #ffffff06,0 16px 34px #050a1247,0 0 0 1px #ffffff0d}.portfolio-experience__resume>span{z-index:2;position:relative}.portfolio-experience__resume:before{content:"";z-index:1;border-radius:inherit;opacity:.88;pointer-events:none;transition:opacity var(--motion-fast) var(--ease-standard),transform var(--motion-fast) var(--ease-standard);background:linear-gradient(#ffffff57,#ffffff14 18%,#ffffff05 44%,#ffffff1f),linear-gradient(125deg,#0000 30%,#ffffff38 42%,#ffffff0f 53%,#0000 65%);position:absolute;inset:0}.portfolio-experience__resume:after{--portfolio-resume-border-angle:0deg;content:"";z-index:0;border-radius:inherit;background:linear-gradient(var(--portfolio-resume-border-angle),#ffffff1a,#ffffffb3 18%,#d1e7ff57 34%,#ffffff14 50%,#ffffffb8 68%,#ffffff1a);opacity:.9;pointer-events:none;transition:opacity var(--motion-fast) var(--ease-standard),filter var(--motion-fast) var(--ease-standard);padding:2px;animation:8s linear infinite portfolio-resume-border-rotate;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.portfolio-experience__resume:hover,.portfolio-experience__resume:focus-visible{background:linear-gradient(#ffffff29,#ffffff0d 38%,#ffffff14),linear-gradient(#545e6c80,#252b3675);transform:translateY(-1px);box-shadow:inset 0 1px #ffffff6b,inset 0 -12px 26px #ffffff0a,0 18px 38px #050a1252,0 0 0 1px #ffffff12}.portfolio-experience__resume:hover:before,.portfolio-experience__resume:focus-visible:before{opacity:1;transform:translate(4px,-1px)}.portfolio-experience__resume:hover:after,.portfolio-experience__resume:focus-visible:after{opacity:1;filter:brightness(1.16)}.portfolio-experience__resume:focus-visible{outline-offset:4px;outline:2px solid #e6f1ffc2}@keyframes portfolio-resume-border-rotate{to{--portfolio-resume-border-angle:360deg}}@property --portfolio-resume-border-angle{syntax:"<angle>";inherits:false;initial-value:0deg}.portfolio-close{isolation:isolate;min-height:68vh;padding:var(--portfolio-content-padding-top) 0 var(--portfolio-content-padding-bottom);position:relative;overflow:visible}.portfolio-close>:not(.portfolio-dotted-surface-host){z-index:1;position:relative}.portfolio-dotted-surface-host{z-index:0;opacity:.86;pointer-events:none;position:absolute;inset:-150px calc(50% - 50vw) -130px;overflow:hidden;-webkit-mask-image:linear-gradient(#0000 0%,#000 18% 82%,#0000 100%);mask-image:linear-gradient(#0000,#000 18% 82%,#0000)}.portfolio-dotted-surface{pointer-events:none;position:absolute;inset:0;overflow:hidden}.portfolio-dotted-surface .blog-dotted-surface__canvas{z-index:1}.portfolio-close h2{max-width:940px}@media(max-width:980px){.portfolio-app{--portfolio-section-heading-gap:40px;--portfolio-section-heading-gap-compact:28px;--portfolio-hero-intro-padding-top:24svh;--portfolio-hero-intro-padding-bottom:10svh;--portfolio-hero-statement-padding-top:12svh;--portfolio-hero-statement-padding-bottom:12svh;--portfolio-content-padding-top:184px;--portfolio-content-padding-bottom:128px}.portfolio-nav,.portfolio-hero,.portfolio-roadmap__heading,.portfolio-roadmap__mobile-list,.portfolio-grid-section,.portfolio-experience,.portfolio-social-cta,.portfolio-close,.portfolio-detail-hero,.portfolio-detail-section{width:min(100% - 32px,760px)}.portfolio-hero{min-height:auto;padding-bottom:0}.portfolio-detail-hero{min-height:auto;padding:156px 0 88px}.portfolio-detail-hero__frame{gap:18px}.portfolio-detail-hero__title{font-size:clamp(3rem,12vw,4.8rem)}.portfolio-hero__intro{gap:10px}.portfolio-hero__lead{font-size:4.1rem}.portfolio-hero__sublead{font-size:clamp(.9rem,1.8vw,1.08rem)}.portfolio-hero__sublead--secondary{font-size:clamp(.78rem,1.6vw,.95rem)}.portfolio-hero__title{font-size:4.1rem}.portfolio-roadmap__layout{display:none}.portfolio-social-cta__grid{flex-wrap:wrap;justify-content:center;align-items:flex-end;gap:20px}.portfolio-experience__heading{flex-direction:column;align-items:start}.portfolio-experience__layout{grid-template-columns:1fr;align-items:start;gap:30px}.portfolio-credential-card{grid-template-columns:minmax(0,auto);gap:22px;max-width:min(560px,88vw);height:390px}.portfolio-roadmap__chapters{display:none}.portfolio-roadmap__mobile-list{gap:30px;margin-top:28px;display:grid}.portfolio-roadmap__mobile-item figcaption{display:none!important}.portfolio-roadmap__heading{text-align:left}.portfolio-surface{aspect-ratio:16/10;min-height:auto;padding:16px 12px 48px}.portfolio-surface__device{min-height:235px}.portfolio-grid{grid-template-columns:1fr;gap:30px}.portfolio-card,.portfolio-card:nth-child(2),.portfolio-card:nth-child(3),.portfolio-card:nth-child(4){grid-column:auto;margin-top:0}.portfolio-detail-card{grid-template-columns:minmax(0,1fr)}.portfolio-detail-card__media{border-bottom:1px solid #ffffff12;border-right:0}.portfolio-detail-card__copy{padding:32px}.portfolio-detail-card__media img{min-height:320px}.portfolio-detail-card__actions{justify-content:flex-start}.portfolio-detail-download{flex-direction:column;align-items:flex-start;padding:24px 22px}}@media(max-width:620px){.portfolio-app{--portfolio-section-heading-gap:34px;--portfolio-section-heading-gap-compact:24px;--portfolio-hero-intro-padding-top:22svh;--portfolio-hero-intro-padding-bottom:8svh;--portfolio-hero-statement-padding-top:10svh;--portfolio-hero-statement-padding-bottom:10svh;--portfolio-content-padding-top:168px;--portfolio-content-padding-bottom:88px}.portfolio-app .standalone-software__exit{top:auto;left:auto}.portfolio-nav{grid-template-columns:minmax(34px,1fr) minmax(0,auto) minmax(max-content,1fr);gap:8px;width:calc(100% - 24px);min-height:50px;padding:0 10px;top:18px}.portfolio-nav__brand-title{font-size:.84rem}.portfolio-nav__utilities,.portfolio-nav__socials{gap:6px}.portfolio-app .standalone-software__exit{justify-content:center;width:34px;min-width:34px;min-height:34px;padding:0}.portfolio-nav__action{width:34px;height:34px}.portfolio-app .standalone-software__exit-label{display:none}.portfolio-nav__quick-links-menu{min-width:160px;padding:7px;top:calc(100% + 10px);right:-4px}.portfolio-nav__quick-links-menu a{padding:8px 10px;font-size:.78rem}.portfolio-credential-card{grid-template-columns:auto;max-width:min(330px,86vw);height:260px;padding:10px}.portfolio-detail-hero{padding:148px 0 74px}.portfolio-detail-hero__eyebrow{letter-spacing:.18em;font-size:.74rem}.portfolio-detail-hero__summary{font-size:.98rem;line-height:1.72}.portfolio-detail-card,.portfolio-detail-download{border-radius:22px}.portfolio-detail-card__copy{padding:24px 20px}.portfolio-detail-card__copy p,.portfolio-detail-download p{font-size:.94rem}.portfolio-detail-card__action{width:100%;min-width:0}.portfolio-detail-download__copy{gap:14px}.portfolio-detail-download__icon{width:28px;height:28px}.portfolio-detail-download__icon img{width:18px;height:18px}.portfolio-detail-card__media img{min-height:240px}.portfolio-link.portfolio-credential-card__verify{top:14px;right:14px}.portfolio-hero{min-height:auto;padding-bottom:0}.portfolio-hero__intro{gap:8px}.portfolio-hero__lead{font-size:3.05rem}.portfolio-hero__sublead{font-size:.92rem}.portfolio-hero__sublead--secondary{font-size:.8rem}.portfolio-hero__title{font-size:3.05rem}.portfolio-roadmap__heading h2,.portfolio-section-heading h2,.portfolio-close h2{font-size:2.35rem}.portfolio-experience__title{font-size:2.12rem}.portfolio-close h2{font-size:1.7rem}.portfolio-roadmap__heading h2:after,.portfolio-section-heading h2:after,.portfolio-close h2:after{width:min(92px,34%)}.portfolio-card__visual{min-height:250px}.portfolio-video-frame{border-radius:22px;width:calc(100% - 18px)}.portfolio-video-section__link{margin-top:12px}.portfolio-experience-step{grid-template-columns:44px minmax(0,1fr);gap:14px}.portfolio-experience-step__node{width:28px;height:28px}.portfolio-experience-step__node span{width:10px;height:10px}.portfolio-experience-step__line{min-height:64px}.portfolio-experience-step__copy{padding-bottom:24px}.portfolio-experience-step__copy strong{font-size:1.06rem}.portfolio-experience-step__copy small{font-size:.88rem}.portfolio-experience-detail{gap:18px;padding:22px}.portfolio-experience-detail__header h3{font-size:1.28rem}.portfolio-tech-stack__heading,.portfolio-tech-stack__actions{width:min(100% - 32px,760px);margin-bottom:22px}.portfolio-tech-stack__token{width:56px;height:56px}.portfolio-social-cta__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;padding:10px 0 0;display:grid}.portfolio-social-cta__card{border-radius:18px;width:100%;min-width:0;min-height:284px;margin-bottom:0;transform:none}.portfolio-social-cta__card:hover,.portfolio-social-cta__card:focus-visible{transform:translateY(-6px)}.portfolio-social-cta__banner{min-height:176px}.portfolio-social-cta__copy{padding:18px 18px 20px}.portfolio-social-cta__copy strong{font-size:1.04rem}.portfolio-social-cta__copy span{font-size:.88rem}.portfolio-card p,.portfolio-surface figcaption{display:grid}.portfolio-link--quiet{margin-left:0}.portfolio-dotted-surface-host{opacity:.68;top:-110px;bottom:-100px}}@media(pointer:coarse){.portfolio-credential-card:hover,.portfolio-credential-card:focus-within{transform:none}}@media(prefers-reduced-motion:reduce){.portfolio-app{scroll-behavior:auto;scroll-snap-type:none}.portfolio-hero__intro,.portfolio-hero__intro-copy,.portfolio-hero__lead,.portfolio-hero__title{text-shadow:none;will-change:auto}.portfolio-hero__intro-copy{animation:none}.portfolio-section-shell--roadmap{opacity:1;transform:none}.portfolio-app.is-progression-ready [data-portfolio-reveal],.portfolio-app.is-progression-ready [data-portfolio-reveal].is-visible,.portfolio-app.is-progression-ready [data-portfolio-reveal].is-before,.portfolio-app.is-progression-ready [data-portfolio-reveal].is-after{opacity:1;will-change:auto;transform:none}.portfolio-progress span,.portfolio-card__visual,.portfolio-link,.portfolio-hero__chip,.portfolio-hero__chip:before,.portfolio-nav__action,.portfolio-app .standalone-software__exit,.portfolio-roadmap__rail-item,.portfolio-tech-stack__track{transition:none}.portfolio-hero__chip,.portfolio-hero__chip:before{opacity:1;animation:none;transform:none}.portfolio-tech-stack__track,.portfolio-tech-stack__lane.is-reverse .portfolio-tech-stack__track{flex-wrap:wrap;justify-content:center;width:100%;animation:none}.portfolio-experience__resume:after{animation:none}.portfolio-experience__resume:hover,.portfolio-experience__resume:focus-visible,.portfolio-experience__resume:hover:before,.portfolio-experience__resume:focus-visible:before{transform:none}}body.blog-body,.blog-app{--blog-bg:#000;--blog-panel:#201f1de0;--blog-panel-strong:#2a2825f0;--blog-surface-container:#f5f1e809;--blog-surface-container-high:#f5f1e80f;--blog-surface-container-highest:#f5f1e81a;--blog-line:#f5f1e829;--blog-ink:#f7f3ea;--blog-text:#f7f3ead1;--blog-muted:#f7f3ea8f;--blog-accent:#ff4d8d;--blog-accent-2:#70e1ff;--blog-focus:#f5f1e8b8;--blog-hover-line:#f5f1e852;--blog-hover-surface:#f5f1e812;--blog-shadow-soft:0 18px 56px #00000047;--blog-reveal-color:var(--blog-accent);--motion-luxury:1s;--motion-ultra-luxury:1.5s;--blog-backdrop-primary:#ff4d8d38;--blog-backdrop-secondary:#70e1ff33;--blog-backdrop-tertiary:#5ed68629;--blog-backdrop-quaternary:#ad6bff24;--blog-backdrop-quinary:#ffcd7021;--blog-backdrop-senary:#5070ff1f;--blog-backdrop-toplight:#ffffff09;--blog-backdrop-side-mask:#0000002e;--blog-backdrop-vignette-start:#0a0b0c2e;--blog-backdrop-vignette-end:#000000fa;--blog-backdrop-blur:84px;--blog-backdrop-before:radial-gradient(circle 46vw at 8% 12%, var(--blog-backdrop-primary), transparent 72%), radial-gradient(circle 42vw at 92% 16%, var(--blog-backdrop-secondary), transparent 74%), radial-gradient(circle 34vw at 54% 72%, var(--blog-backdrop-tertiary), transparent 76%), radial-gradient(circle 32vw at 16% 88%, var(--blog-backdrop-quaternary), transparent 74%), radial-gradient(circle 28vw at 78% 88%, var(--blog-backdrop-quinary), transparent 76%), radial-gradient(circle 30vw at 48% 20%, var(--blog-backdrop-senary), transparent 78%);--blog-backdrop-after:radial-gradient(ellipse 126vw 98vh at 50% 44%, var(--blog-backdrop-vignette-start), var(--blog-backdrop-vignette-end) 78%), radial-gradient(ellipse 74vw 38vh at 50% -4%, var(--blog-backdrop-toplight), transparent 74%), linear-gradient(90deg, var(--blog-backdrop-side-mask), transparent 16%, transparent 84%, var(--blog-backdrop-side-mask));background:var(--blog-bg);color:var(--blog-text);font-family:DM Sans,system-ui,sans-serif}body.blog-body{isolation:isolate;scrollbar-width:none;-ms-overflow-style:none;min-height:100%;position:relative;overflow-x:clip}body.blog-body::-webkit-scrollbar{width:0;height:0;display:none}.blog-app{z-index:1;isolation:isolate;background:0 0;min-height:100vh;position:relative;overflow-x:clip}body.blog-body:before,body.blog-body:after{z-index:0;pointer-events:none;content:"";position:fixed;inset:0}body.blog-body:before{background:var(--blog-backdrop-before);filter:blur(var(--blog-backdrop-blur));opacity:1}body.blog-body:after{background:var(--blog-backdrop-after)}body.blog-body,.blog-index,.blog-reader{--blog-backdrop-primary:#ff4a844d;--blog-backdrop-secondary:#57d7ff3b;--blog-backdrop-tertiary:#5bebae30;--blog-backdrop-quaternary:#b468ff30;--blog-backdrop-quinary:#ffca682e;--blog-backdrop-senary:#4e70ff29;--blog-backdrop-septenary:#ff70d82b;--blog-backdrop-octonary:#58ffcd1f;--blog-backdrop-toplight:#ffffff0b;--blog-backdrop-side-mask:#00000012;--blog-backdrop-vignette-start:#0c0c0e0f;--blog-backdrop-vignette-end:#000000f3;--blog-backdrop-blur:104px;--blog-backdrop-before:radial-gradient(circle 62vw at -10% 10%, var(--blog-backdrop-primary), transparent 72%), radial-gradient(circle 48vw at 22% 72%, var(--blog-backdrop-quaternary), transparent 74%), radial-gradient(circle 42vw at -4% 96%, var(--blog-backdrop-quinary), transparent 76%), radial-gradient(circle 34vw at 26% 28%, var(--blog-backdrop-septenary), transparent 76%), radial-gradient(circle 50vw at 106% 18%, var(--blog-backdrop-secondary), transparent 76%), radial-gradient(circle 42vw at 78% 68%, var(--blog-backdrop-tertiary), transparent 78%), radial-gradient(circle 34vw at 48% 14%, var(--blog-backdrop-senary), transparent 80%), radial-gradient(circle 30vw at 62% 104%, var(--blog-backdrop-octonary), transparent 78%), radial-gradient(ellipse 38vw 24vh at 54% 4%, #ffffff07, transparent 76%);--blog-backdrop-after:radial-gradient(ellipse 134vw 102vh at 50% 42%, var(--blog-backdrop-vignette-start), var(--blog-backdrop-vignette-end) 82%), radial-gradient(ellipse 88vw 38vh at 50% 2%, var(--blog-backdrop-toplight), transparent 78%), linear-gradient(180deg, #ffffff04, transparent 420px), linear-gradient(90deg, var(--blog-backdrop-side-mask), transparent 10%, transparent 90%, var(--blog-backdrop-side-mask))}.blog-app>*{z-index:1;position:relative}.blog-app :where(a,button,summary):focus-visible{outline:2px solid var(--blog-focus);outline-offset:3px}.blog-back-link,.blog-link{background:var(--blog-surface-container);min-height:44px;color:var(--blog-ink);transition:background var(--motion-ultra-luxury) var(--ease-standard),color var(--motion-ultra-luxury) var(--ease-standard),box-shadow var(--motion-ultra-luxury) var(--ease-standard),transform var(--motion-ultra-luxury) var(--ease-standard);border:0;border-radius:12px;align-items:center;gap:8px;padding:0 20px;text-decoration:none;display:inline-flex}.blog-back-link:hover,.blog-back-link:focus-visible,.blog-link:hover,.blog-link:focus-visible{background:var(--blog-surface-container-highest);color:#fff;transform:translateY(-1px)}.blog-back-link{z-index:8;background:var(--blog-surface-container-high);box-shadow:var(--blog-shadow-soft);border-radius:999px;position:fixed;top:22px;left:22px}.blog-nav{z-index:32;-webkit-backdrop-filter:blur(10px)saturate(102%);backdrop-filter:blur(10px)saturate(102%);background:#1c1b1d70;border:0;border-radius:999px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:14px;width:min(100% - 48px,1180px);min-height:58px;padding:4px 14px;display:grid;position:fixed;top:26px;left:50%;transform:translate(-50%)translateZ(0);box-shadow:inset 0 1px #ffffff05,0 8px 22px #0000001f}.blog-nav--reader{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr)}.blog-nav__back{isolation:isolate;color:#f7f3eae0;min-height:38px;transition:background var(--motion-ultra-luxury) var(--ease-standard),color var(--motion-ultra-luxury) var(--ease-standard),box-shadow var(--motion-ultra-luxury) var(--ease-standard);background:#f5f1e80b;border:0;border-radius:999px;justify-self:start;align-items:center;gap:9px;padding:0 18px 0 14px;text-decoration:none;display:inline-flex;position:relative}.blog-nav__back:hover,.blog-nav__back:focus-visible{background:var(--blog-surface-container-high);color:#fff}.blog-nav__back-icon{flex:none;justify-content:center;align-items:center;display:inline-flex}.blog-nav__brand{min-width:0;display:grid}.blog-nav__brand--centered{text-align:center;justify-items:center}.blog-nav__brand--reader{justify-self:center;justify-items:center}.blog-nav__brand-title{text-overflow:ellipsis;white-space:nowrap;color:#f7f3eaeb;letter-spacing:.01em;text-align:center;width:100%;font-size:.92rem;font-weight:600;overflow:hidden}.blog-nav__back-label{white-space:nowrap}.blog-nav__socials{justify-self:end;align-items:center;gap:8px;display:flex}.blog-nav__action{isolation:isolate;color:#f7f3eabd;width:36px;height:36px;transition:background var(--motion-ultra-luxury) var(--ease-standard),color var(--motion-ultra-luxury) var(--ease-standard),box-shadow var(--motion-ultra-luxury) var(--ease-standard);background:#f5f1e80a;border:0;border-radius:999px;justify-self:end;place-items:center;text-decoration:none;display:grid;position:relative}.blog-nav__action:hover,.blog-nav__action:focus-visible{background:var(--blog-surface-container-high);color:#fff}.blog-nav__action--menu{display:none}.blog-nav__action--placeholder{visibility:hidden;pointer-events:none}.blog-nav__icon{width:18px;height:18px;-webkit-mask-image:var(--icon-url);mask-image:var(--icon-url);background-color:currentColor;-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.blog-nav__menu-icon{justify-content:center;align-items:center;display:inline-flex}.blog-reader-mobile-nav{z-index:31;display:none;position:relative}.blog-mobile-toc-panel{z-index:31;-webkit-backdrop-filter:blur(16px)saturate(108%);backdrop-filter:blur(16px)saturate(108%);width:min(320px,100vw - 48px);clip-path:circle(0px at var(--blog-toc-origin-x, calc(100% - 28px) ) var(--blog-toc-origin-y,28px));opacity:0;pointer-events:none;background:#1c1b1dd1;border:0;border-radius:24px;transition:clip-path .42s cubic-bezier(.22,1,.36,1),opacity .42s cubic-bezier(.22,1,.36,1),transform .42s cubic-bezier(.22,1,.36,1);position:fixed;top:92px;right:max(24px,50vw - 590px);overflow:hidden;transform:translateY(-4px)scale(.985);box-shadow:inset 0 1px #ffffff05,0 18px 48px #00000047}.blog-mobile-toc-panel[data-state=open],.blog-mobile-toc-panel:not([hidden]):not([data-state=closing]){pointer-events:auto;clip-path:circle(var(--blog-toc-radius,520px) at var(--blog-toc-origin-x, calc(100% - 28px) ) var(--blog-toc-origin-y,28px))!important;opacity:1!important;transform:translateY(0)scale(1)!important}.blog-mobile-toc-panel[data-state=closing]{pointer-events:none;transition-duration:.32s,.32s,.32s;opacity:0!important;clip-path:circle(0px at var(--blog-toc-origin-x, calc(100% - 28px) ) var(--blog-toc-origin-y,28px))!important;transform:translateY(-4px)scale(.985)!important}.blog-index{padding:224px max(24px,50vw - 590px) 96px}.blog-index__hero{grid-template-columns:minmax(0,1.4fr) minmax(260px,.6fr);align-items:end;gap:64px;min-height:240px;padding:96px 0 54px;display:grid;position:relative}.blog-index__hero:after{content:"";opacity:.28;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1000 24' fill='none'%3E%3Cpath d='M0 12 C 20 2, 40 22, 60 12 C 80 2, 100 22, 120 12 C 140 2, 160 22, 180 12 C 200 2, 220 22, 240 12 C 260 2, 280 22, 300 12 C 320 2, 340 22, 360 12 C 380 2, 400 22, 420 12 C 440 2, 460 22, 480 12 C 500 2, 520 22, 540 12 C 560 2, 580 22, 600 12 C 620 2, 640 22, 660 12 C 680 2, 700 22, 720 12 C 740 2, 760 22, 780 12 C 800 2, 820 22, 840 12 C 860 2, 880 22, 900 12 C 920 2, 940 22, 960 12 C 980 2, 1000 22, 1020 12' stroke='%23f5f1e8' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:repeat-x;background-size:1000px 24px;height:24px;position:absolute;bottom:0;left:0;right:0}.blog-reader-kicker{color:var(--blog-accent);letter-spacing:.18em;text-transform:uppercase;margin:0 0 16px;font-size:.74rem;font-weight:850}.blog-index__hero h1,.blog-reader__header h1{background:linear-gradient(135deg,var(--blog-ink) 30%,var(--blog-ink));width:fit-content;max-width:900px;margin:0;display:inline-block;position:relative}@supports (color:color-mix(in lab,red,red)){.blog-index__hero h1,.blog-reader__header h1{background:linear-gradient(135deg,var(--blog-ink) 30%,color-mix(in srgb,var(--blog-ink) 60%,var(--blog-accent)))}}.blog-index__hero h1,.blog-reader__header h1{color:#0000;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:3.5rem;font-weight:850;line-height:1.05}.blog-hero-serif{font-family:Georgia,Times New Roman,serif;font-style:italic;font-weight:400}.blog-index__hero h1 em{font-style:italic;font-weight:400}.blog-reader__header--title h1{padding-bottom:.42em}.blog-prose h2:after,.blog-prose h3:after,.blog-prose h4:after{content:"";pointer-events:none;opacity:.92;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 18' preserveAspectRatio='none'%3E%3Cpath d='M2 10 C58 3 108 3 151 9 S245 16 298 8' fill='none' stroke='%23f5f1e8' stroke-width='3.2' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:100% 100%;width:calc(100% + .54em);max-width:calc(100vw - 32px);height:.22em;min-height:8px;max-height:15px;position:absolute;bottom:.02em;left:0}.blog-prose h1:after{content:"";pointer-events:none;background:linear-gradient(90deg,var(--blog-accent-2),#ffffff1f);border-radius:999px;width:min(132px,38%);height:2px;position:absolute;bottom:.08em;left:0}@supports (color:color-mix(in lab,red,red)){.blog-prose h1:after{background:linear-gradient(90deg,color-mix(in srgb,var(--blog-accent-2) 72%,#fff),#ffffff1f)}}.blog-prose h1:after{opacity:.9}.blog-index__hero>p,.blog-reader__header>p{color:var(--blog-muted);margin:0;font-size:1rem;line-height:1.7}.blog-index__hero>p{max-width:34ch;font-size:.94rem;line-height:1.6}.blog-reader{--blog-backdrop-primary:#ff4a842e;--blog-backdrop-secondary:#57d7ff24;--blog-backdrop-tertiary:#5bebae1c;--blog-backdrop-quaternary:#b468ff1c;--blog-backdrop-quinary:#ffca681a;--blog-backdrop-senary:#4e70ff1a;--blog-backdrop-septenary:#ff70d814;--blog-backdrop-octonary:#58ffcd14;--blog-backdrop-toplight:#ffffff07;--blog-backdrop-side-mask:#0000001f;--blog-backdrop-vignette-start:#0c0c0e2e;--blog-backdrop-vignette-end:#000000f9;--blog-backdrop-blur:96px}.blog-entry-board{grid-template-columns:repeat(3,minmax(0,1fr));gap:26px;margin-top:0;padding:10px;display:grid}.blog-entry-card{--entry-accent:var(--blog-accent);--entry-accent-2:var(--blog-accent-2);--entry-hover-motion:.7s;background:var(--blog-surface-container);height:500px;box-shadow:var(--blog-shadow-soft);transition:opacity .52s var(--ease-enter),background var(--motion-luxury) var(--ease-standard),box-shadow var(--entry-hover-motion) var(--ease-standard),transform var(--entry-hover-motion) var(--ease-standard);transform-origin:50%;border:0;border-radius:32px;overflow:hidden}.blog-entry-card.is-blog-reveal-ready:not(.is-blog-reveal-visible){opacity:0;transform:translateY(18px)scale(.985)}.blog-entry-card.is-blog-reveal-visible{opacity:1}.blog-entry-card--essay{--entry-accent:#ff4d8d;--entry-accent-2:#70e1ff}.blog-entry-card--writeup{--entry-accent:#70e1ff;--entry-accent-2:#fd7}.blog-entry-card--lab{--entry-accent:#9fef00;--entry-accent-2:#70e1ff}.blog-entry-card--note{--entry-accent:#fd7;--entry-accent-2:#ff8ad1}.blog-entry-card:hover,.blog-entry-card:focus-within{background:var(--blog-surface-container-high);transform:scale(1.018);box-shadow:0 24px 68px #00000057}.blog-entry-card a{height:100%;color:inherit;grid-template-rows:minmax(180px,220px) minmax(0,1fr);text-decoration:none;display:grid}.blog-entry-card__cover-img{object-fit:cover;border-radius:inherit;z-index:0;width:100%;height:100%;position:absolute;inset:0}.blog-entry-card__preview--has-cover:before{display:none}.blog-entry-card__preview--has-cover:after{z-index:1;content:"";opacity:1;border-radius:inherit;background:linear-gradient(#0000 40%,#000000b8);transition:none;position:absolute;inset:0;transform:none}.blog-entry-card:hover .blog-entry-card__preview--has-cover:after,.blog-entry-card:focus-within .blog-entry-card__preview--has-cover:after{opacity:1;transform:none}.blog-entry-card__preview--has-cover strong{z-index:2}.blog-controls{grid-template-columns:minmax(320px,1.4fr) auto auto;align-items:center;gap:16px;margin-top:24px;margin-bottom:18px;padding:0;display:grid}.blog-toggle,.blog-sort,.blog-search{isolation:isolate;position:relative}.blog-toggle:after,.blog-sort:after,.blog-search:after{content:"";z-index:5;pointer-events:none;background:radial-gradient(300px circle at var(--mouse-x,-999px) var(--mouse-y,-999px),#ffffff1a,transparent 60%);opacity:0;transition:opacity .4s var(--ease-standard);border-radius:inherit;position:absolute;inset:0}.blog-toggle:hover:after,.blog-sort:hover:after,.blog-search:hover:after,.blog-search:focus-within:after{opacity:1}.blog-toggle{background:var(--blog-surface-container);border:0;border-radius:999px;gap:0;padding:4px;display:inline-flex}.blog-toggle__btn{z-index:1;min-height:32px;color:var(--blog-muted);cursor:pointer;transition:color var(--motion-luxury) var(--ease-standard),background var(--motion-luxury) var(--ease-standard);background:0 0;border:0;border-radius:999px;align-items:center;padding:0 16px;font-family:inherit;font-size:.82rem;font-weight:750;display:inline-flex;position:relative}.blog-toggle__btn.is-active{color:var(--blog-ink);background:var(--blog-surface-container-highest)}.blog-toggle__btn:hover:not(.is-active),.blog-toggle__btn:focus-visible:not(.is-active){color:var(--blog-ink);background:var(--blog-surface-container-high)}.blog-sort{background:var(--blog-surface-container);border:0;border-radius:999px;gap:0;padding:4px;display:inline-flex}.blog-sort__btn{min-height:32px;color:var(--blog-muted);cursor:pointer;transition:color var(--motion-luxury) var(--ease-standard),background var(--motion-luxury) var(--ease-standard);background:0 0;border:0;border-radius:999px;align-items:center;padding:0 14px;font-family:inherit;font-size:.78rem;font-weight:750;display:inline-flex}.blog-sort__btn.is-active{color:var(--blog-ink);background:var(--blog-surface-container-highest)}.blog-sort__btn:hover:not(.is-active),.blog-sort__btn:focus-visible:not(.is-active){color:var(--blog-ink);background:var(--blog-surface-container-high)}.blog-search{background:var(--blog-surface-container-high);min-width:0;min-height:42px;transition:background var(--motion-luxury) var(--ease-standard),box-shadow var(--motion-luxury) var(--ease-standard),transform var(--motion-luxury) var(--ease-standard);border:0;border-radius:999px;grid-template-columns:20px minmax(0,1fr) 32px;align-items:center;padding:3px 5px 3px 14px;display:grid;position:relative}.blog-search:hover{background:var(--blog-surface-container-highest)}.blog-search:focus-within{background:var(--blog-surface-container-highest);box-shadow:0 0 0 1px var(--blog-hover-line)}.blog-search__icon{border:2px solid var(--blog-muted);border-radius:50%;width:12px;height:12px;position:relative}.blog-search__icon:after{background:var(--blog-muted);content:"";width:7px;height:2px;position:absolute;transform:translate(9px,10px)rotate(45deg)}.blog-search input{min-width:0;color:var(--blog-ink);font:inherit;background:0 0;border:0;outline:0;padding:0 8px;font-size:.84rem}.blog-search input::placeholder{color:var(--blog-muted)}.blog-search__clear{width:30px;height:30px;color:var(--blog-muted);cursor:pointer;background:0 0;border:0;border-radius:999px;justify-content:center;align-items:center;display:inline-flex;position:relative}.blog-search__clear:hover,.blog-search__clear:focus-visible{color:var(--blog-ink);background:#f5f1e814}.blog-search__clear span,.blog-search__clear span:after{content:"";background:currentColor;border-radius:999px;width:12px;height:2px;position:absolute}.blog-search__clear span{transform:rotate(45deg)}.blog-search__clear span:after{transform:rotate(90deg)}.blog-entry-card__preview{background:radial-gradient(ellipse 68% 80% at 22% 20%,var(--entry-accent),transparent 64%),radial-gradient(ellipse 58% 72% at 92% 6%,var(--entry-accent-2),transparent 68%),linear-gradient(180deg,#ffffff14,transparent 68%),#161514c7;border:0;border-radius:32px 32px 0 0;margin:0;position:relative;overflow:hidden}@supports (color:color-mix(in lab,red,red)){.blog-entry-card__preview{background:radial-gradient(ellipse 68% 80% at 22% 20%,color-mix(in srgb,var(--entry-accent) 14%,transparent),transparent 64%),radial-gradient(ellipse 58% 72% at 92% 6%,color-mix(in srgb,var(--entry-accent-2) 10%,transparent),transparent 68%),linear-gradient(180deg,#ffffff14,transparent 68%),#161514c7}}.blog-entry-card__preview{transition:transform var(--motion-luxury) var(--ease-standard),background var(--motion-luxury) var(--ease-standard)}.blog-entry-card__preview:before,.blog-entry-card__preview:after{display:none}.blog-entry-card__preview>span{background:var(--entry-accent);border-radius:999px;display:block;position:absolute}@supports (color:color-mix(in lab,red,red)){.blog-entry-card__preview>span{background:color-mix(in srgb,var(--entry-accent) 72%,#fff)}}.blog-entry-card__preview>span{opacity:.22;filter:blur(16px);transition:opacity .22s var(--ease-standard),transform .22s var(--ease-standard)}.blog-entry-card__preview strong{z-index:2;color:#f7f3eac7;letter-spacing:0;text-transform:lowercase;transition:color .22s var(--ease-standard),transform .22s var(--ease-standard);align-items:center;gap:12px;padding:0;font-family:inherit;font-size:.78rem;font-weight:500;line-height:1.2;display:inline-flex;position:absolute;bottom:23px;left:27px}.blog-entry-card__preview strong>span{background:var(--entry-accent);opacity:.45;filter:none;border-radius:0;width:6px;height:34px;display:block}.blog-entry-card__preview>span:first-child{width:84px;height:84px;transition-delay:80ms;bottom:24%;right:22%}.blog-entry-card__preview>span:nth-child(2){background:var(--entry-accent-2);width:48px;height:48px;bottom:14%;right:10%}@supports (color:color-mix(in lab,red,red)){.blog-entry-card__preview>span:nth-child(2){background:color-mix(in srgb,var(--entry-accent-2) 68%,#fff)}}.blog-entry-card__preview>span:nth-child(2){transition-delay:.14s}.blog-entry-card__preview>span:nth-child(3){opacity:.12;width:62px;height:62px;transition-delay:.19s;bottom:12%;left:14%}.blog-entry-card:hover .blog-entry-card__preview,.blog-entry-card:focus-within .blog-entry-card__preview{background:radial-gradient(ellipse 68% 80% at 18% 16%,var(--entry-accent),transparent 66%),radial-gradient(ellipse 58% 72% at 90% 10%,var(--entry-accent-2),transparent 70%),linear-gradient(180deg,#ffffff1a,transparent 70%),#1c1b19e0}@supports (color:color-mix(in lab,red,red)){.blog-entry-card:hover .blog-entry-card__preview,.blog-entry-card:focus-within .blog-entry-card__preview{background:radial-gradient(ellipse 68% 80% at 18% 16%,color-mix(in srgb,var(--entry-accent) 18%,transparent),transparent 66%),radial-gradient(ellipse 58% 72% at 90% 10%,color-mix(in srgb,var(--entry-accent-2) 13%,transparent),transparent 70%),linear-gradient(180deg,#ffffff1a,transparent 70%),#1c1b19e0}}.blog-entry-card:hover .blog-entry-card__preview,.blog-entry-card:focus-within .blog-entry-card__preview{transform:scale(1.006)}.blog-entry-card:hover .blog-entry-card__preview:before,.blog-entry-card:focus-within .blog-entry-card__preview:before{background:linear-gradient(135deg,#ffffff29,#0000),#0b0b0a3d;transform:scale(1.012)}.blog-entry-card:hover .blog-entry-card__preview strong,.blog-entry-card:focus-within .blog-entry-card__preview strong{color:var(--blog-ink);transform:translateY(-1px)}.blog-entry-card:hover .blog-entry-card__preview>span,.blog-entry-card:focus-within .blog-entry-card__preview>span{opacity:.26;transform:scale(1.08)}.blog-entry-card__body{grid-template-rows:auto auto auto auto;align-content:start;gap:14px;min-height:0;padding:24px;display:grid}.blog-entry-card__meta{color:var(--blog-muted);flex-wrap:wrap;gap:8px;display:flex}@supports (color:color-mix(in lab,red,red)){.blog-entry-card__meta{color:color-mix(in srgb,var(--blog-muted) 85%,#fff 15%)}}.blog-entry-card__meta{text-transform:uppercase;font-size:.74rem;font-weight:750}.blog-entry-card__meta span{background:var(--blog-surface-container-high);min-height:24px;color:var(--blog-muted);transition:background var(--motion-luxury) var(--ease-standard),color var(--motion-luxury) var(--ease-standard);border:0;border-radius:8px;align-items:center;padding:0 10px;font-size:.72rem;font-weight:650;display:inline-flex}.blog-entry-card:hover .blog-entry-card__meta span{background:var(--entry-accent)}@supports (color:color-mix(in lab,red,red)){.blog-entry-card:hover .blog-entry-card__meta span{background:color-mix(in srgb,var(--entry-accent) 15%,var(--blog-surface-container-high))}}.blog-entry-card:hover .blog-entry-card__meta span{color:var(--blog-ink)}.blog-entry-card h2,.blog-entry-card__title{color:var(--blog-ink);letter-spacing:0;-webkit-line-clamp:2;transition:color .22s var(--ease-standard);-webkit-box-orient:vertical;margin:0;font-size:1.62rem;line-height:1.08;display:-webkit-box;overflow:hidden}.blog-entry-card p,.blog-entry-card__description{color:var(--blog-muted);margin:0}@supports (color:color-mix(in lab,red,red)){.blog-entry-card p,.blog-entry-card__description{color:color-mix(in srgb,var(--blog-muted) 88%,#fff 12%)}}.blog-entry-card p,.blog-entry-card__description{-webkit-line-clamp:2;-webkit-box-orient:vertical;max-height:3.04em;font-size:.9rem;line-height:1.52;display:-webkit-box;overflow:hidden}.blog-entry-card--dense-tags .blog-entry-card__description{-webkit-line-clamp:2;max-height:3.04em}.blog-entry-card .blog-card__tags{opacity:.82;max-height:calc(3.698rem + 10px);transition:opacity .22s var(--ease-standard);align-self:end;margin-top:0;overflow:hidden;-webkit-mask-image:linear-gradient(#000 78%,#0000 100%);mask-image:linear-gradient(#000 78%,#0000)}.blog-entry-card:hover h2,.blog-entry-card:focus-within h2{color:var(--blog-ink)}.blog-entry-card:hover .blog-card__tags,.blog-entry-card:focus-within .blog-card__tags{opacity:1}.blog-style-nav{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:28px 0 34px;display:grid}.blog-style-nav a{background:var(--blog-surface-container);min-height:66px;color:var(--blog-text);transition:background var(--motion-luxury) var(--ease-standard),transform var(--motion-luxury) var(--ease-standard);border:0;border-radius:12px;justify-content:space-between;align-items:center;gap:14px;padding:14px 18px;text-decoration:none;display:flex}.blog-style-nav a:hover,.blog-style-nav a:focus-visible{background:var(--blog-surface-container-highest);transform:translateY(-1px)}.blog-style-nav strong,.blog-style-nav span{display:block}.blog-style-nav strong{color:var(--blog-ink);font-size:.9rem}.blog-style-nav span{color:var(--blog-accent-2);font-size:1.25rem;font-weight:850}.blog-feature,.blog-empty{background:var(--blog-surface-container);box-shadow:var(--blog-shadow-soft);border:0;border-radius:24px;gap:24px;padding:32px;display:grid}.blog-empty--filtered{margin-top:8px}.blog-feature__meta,.blog-card__meta,.blog-reader__meta{color:var(--blog-muted);text-transform:uppercase;flex-wrap:wrap;gap:8px;font-size:.76rem;font-weight:750;display:flex}.blog-feature__meta span,.blog-card__meta span,.blog-reader__meta span{background:var(--blog-surface-container-high);border:0;border-radius:999px;align-items:center;min-height:24px;padding:0 10px;display:inline-flex}.blog-feature h2,.blog-empty h2,.blog-archive__group h2,.blog-reader__end h2{color:var(--blog-ink);margin:0;font-size:1.75rem;line-height:1.1}.blog-feature h2 a{text-decoration:none}.blog-feature h2 a:hover,.blog-feature h2 a:focus-visible,.blog-card a:hover h3,.blog-card a:focus-visible h3{color:var(--blog-accent-2)}.blog-feature p,.blog-empty p,.blog-archive__group header p{max-width:760px;color:var(--blog-muted);margin:10px 0 0;line-height:1.7}.blog-archive{gap:46px;margin-top:54px;display:grid}.blog-archive__group{scroll-margin-top:96px}.blog-archive__group header{border:0;grid-template-columns:minmax(0,.82fr) minmax(0,1.18fr);align-items:end;gap:28px;margin-bottom:18px;padding-top:24px;display:grid}.blog-archive__group h2{grid-area:1/1}.blog-archive__group header p{grid-area:1/2;margin:0}.blog-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.blog-card{background:var(--blog-surface-container);min-height:260px;transition:background var(--motion-luxury) var(--ease-standard),transform var(--motion-luxury) var(--ease-standard),box-shadow var(--motion-luxury) var(--ease-standard);border:0;border-radius:20px}.blog-card:hover,.blog-card:focus-within{background:var(--blog-surface-container-high);box-shadow:var(--blog-shadow-soft);transform:translateY(-2px)}.blog-card a{min-height:inherit;color:inherit;align-content:start;gap:16px;padding:24px;text-decoration:none;display:grid}.blog-card h3{color:var(--blog-ink);transition:color var(--motion-luxury) var(--ease-standard);margin:0;font-size:1.25rem;line-height:1.2}.blog-card p{color:var(--blog-muted);margin:0;line-height:1.65}.blog-card,.blog-entry-card,.blog-toggle,.blog-sort,.blog-search,.blog-link,.blog-back-link,[data-blog-glow]{isolation:isolate;position:relative}.blog-card:before,.blog-entry-card:before,.blog-toggle:before,.blog-sort:before,.blog-search:before,.blog-link:before,.blog-back-link:before,[data-blog-glow]:before{content:"";z-index:10;border-radius:inherit;background:radial-gradient(360px circle at var(--mouse-x,-999px) var(--mouse-y,-999px),var(--blog-reveal-color),var(--blog-reveal-color) 40%,transparent 68%);padding:1px;position:absolute;inset:0}@supports (color:color-mix(in lab,red,red)){.blog-card:before,.blog-entry-card:before,.blog-toggle:before,.blog-sort:before,.blog-search:before,.blog-link:before,.blog-back-link:before,[data-blog-glow]:before{background:radial-gradient(360px circle at var(--mouse-x,-999px) var(--mouse-y,-999px),color-mix(in srgb,var(--blog-reveal-color) 66%,white 16%),color-mix(in srgb,var(--blog-reveal-color) 31%,transparent) 40%,transparent 68%)}}.blog-card:before,.blog-entry-card:before,.blog-toggle:before,.blog-sort:before,.blog-search:before,.blog-link:before,.blog-back-link:before,[data-blog-glow]:before{pointer-events:none;opacity:0;transition:opacity .3s var(--ease-standard);-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.blog-card:after,.blog-entry-card:after,.blog-toggle:after,.blog-sort:after,.blog-search:after,.blog-link:after,.blog-back-link:after,[data-blog-glow]:after{content:"";z-index:5;pointer-events:none;background:radial-gradient(720px circle at var(--mouse-x,-999px) var(--mouse-y,-999px),var(--blog-reveal-color),var(--blog-reveal-color) 32%,transparent 54%);position:absolute;inset:0}@supports (color:color-mix(in lab,red,red)){.blog-card:after,.blog-entry-card:after,.blog-toggle:after,.blog-sort:after,.blog-search:after,.blog-link:after,.blog-back-link:after,[data-blog-glow]:after{background:radial-gradient(720px circle at var(--mouse-x,-999px) var(--mouse-y,-999px),color-mix(in srgb,var(--blog-reveal-color) 20%,transparent),color-mix(in srgb,var(--blog-reveal-color) 10%,transparent) 32%,transparent 54%)}}.blog-card:after,.blog-entry-card:after,.blog-toggle:after,.blog-sort:after,.blog-search:after,.blog-link:after,.blog-back-link:after,[data-blog-glow]:after{opacity:0;transition:opacity .3s var(--ease-standard);border-radius:inherit;filter:saturate(1.04)contrast(1.01)}.blog-card:hover:before,.blog-entry-card:hover:before,.blog-toggle:hover:before,.blog-sort:hover:before,.blog-search:hover:before,.blog-link:hover:before,.blog-back-link:hover:before,.blog-card:focus-within:before,.blog-entry-card:focus-within:before,.blog-toggle:focus-within:before,.blog-sort:focus-within:before,.blog-search:focus-within:before,.blog-link:focus-visible:before,.blog-back-link:focus-visible:before,.blog-card.is-blog-glow-active:before,.blog-entry-card.is-blog-glow-active:before,.blog-toggle.is-blog-glow-active:before,.blog-sort.is-blog-glow-active:before,.blog-search.is-blog-glow-active:before,.blog-link.is-blog-glow-active:before,.blog-back-link.is-blog-glow-active:before,[data-blog-glow]:hover:before,[data-blog-glow]:focus-within:before,[data-blog-glow].is-blog-glow-active:before,.blog-card:hover:after,.blog-entry-card:hover:after,.blog-toggle:hover:after,.blog-sort:hover:after,.blog-search:hover:after,.blog-link:hover:after,.blog-back-link:hover:after,.blog-card:focus-within:after,.blog-entry-card:focus-within:after,.blog-toggle:focus-within:after,.blog-sort:focus-within:after,.blog-search:focus-within:after,.blog-link:focus-visible:after,.blog-back-link:focus-visible:after,.blog-card.is-blog-glow-active:after,.blog-entry-card.is-blog-glow-active:after,.blog-toggle.is-blog-glow-active:after,.blog-sort.is-blog-glow-active:after,.blog-search.is-blog-glow-active:after,.blog-link.is-blog-glow-active:after,.blog-back-link.is-blog-glow-active:after,[data-blog-glow]:hover:after,[data-blog-glow]:focus-within:after,[data-blog-glow].is-blog-glow-active:after{opacity:1}.blog-card:hover,.blog-card:focus-within,.blog-card.is-blog-glow-active,.blog-entry-card:hover,.blog-entry-card:focus-within,.blog-entry-card.is-blog-glow-active,.blog-toggle:hover,.blog-toggle:focus-within,.blog-toggle.is-blog-glow-active,.blog-sort:hover,.blog-sort:focus-within,.blog-sort.is-blog-glow-active,.blog-search:hover,.blog-search:focus-within,.blog-search.is-blog-glow-active,.blog-link:hover,.blog-link:focus-visible,.blog-link.is-blog-glow-active,.blog-back-link:hover,.blog-back-link:focus-visible,.blog-back-link.is-blog-glow-active,[data-blog-glow]:hover,[data-blog-glow]:focus-within,[data-blog-glow].is-blog-glow-active{filter:saturate(1.03)}.blog-mobile-toc-panel[data-blog-glow]{position:fixed;left:auto}.blog-card__tags{flex-wrap:wrap;gap:10px;display:flex}.blog-hashtag{--tag-bg:#f5f1e81a;--tag-ink:var(--blog-muted);background:var(--tag-bg);min-height:2.15em;color:var(--tag-ink);letter-spacing:.02em;text-transform:lowercase;white-space:nowrap;vertical-align:middle;transition:background var(--motion-luxury) var(--ease-standard),color var(--motion-luxury) var(--ease-standard),filter var(--motion-luxury) var(--ease-standard);border:0;border-radius:999px;justify-content:center;align-items:center;gap:.42em;padding:.42em .9em .44em .72em;font-size:.86rem;font-weight:740;line-height:1.05;display:inline-flex}.blog-hashtag:before{content:"";background:currentColor;flex:none;width:1em;height:1em;transform:translateY(.01em);-webkit-mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 22s8-3.5 8-10V5.5L12 2 4 5.5V12c0 6.5 8 10 8 10Zm0-2.25C9.8 18.6 6 15.85 6 12V6.8l6-2.65 6 2.65V12c0 3.85-3.8 6.6-6 7.75Z'/%3E%3C/svg%3E") 50%/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 22s8-3.5 8-10V5.5L12 2 4 5.5V12c0 6.5 8 10 8 10Zm0-2.25C9.8 18.6 6 15.85 6 12V6.8l6-2.65 6 2.65V12c0 3.85-3.8 6.6-6 7.75Z'/%3E%3C/svg%3E") 50%/contain no-repeat}.blog-hashtag--gray-subtle{--tag-bg:#f5f1e81f;--tag-ink:#d8d8d8}.blog-hashtag--blue-subtle{--tag-bg:#0075ff33;--tag-ink:#55a9ff}.blog-hashtag--purple-subtle{--tag-bg:#9c3ddc38;--tag-ink:#c77dff}.blog-hashtag--amber-subtle{--tag-bg:#ffa50030;--tag-ink:#ffad1f}.blog-hashtag--red-subtle{--tag-bg:#ff2f4038;--tag-ink:#ff626d}.blog-hashtag--pink-subtle{--tag-bg:#eb2a823b;--tag-ink:#ff5d9d}.blog-hashtag--green-subtle{--tag-bg:#00be502e;--tag-ink:#15d96c}.blog-hashtag--teal-subtle{--tag-bg:#0fb4a538;--tag-ink:#1ed0c5}.blog-hashtag--gray{--tag-bg:#989898;--tag-ink:#fff}.blog-hashtag--blue{--tag-bg:#0878ff;--tag-ink:#fff}.blog-hashtag--purple{--tag-bg:#9b3ee6;--tag-ink:#fff}.blog-hashtag--amber{--tag-bg:#ffad13;--tag-ink:#16110a}.blog-hashtag--red{--tag-bg:#ff3144;--tag-ink:#fff}.blog-hashtag--pink{--tag-bg:#eb2a82;--tag-ink:#fff}.blog-hashtag--green{--tag-bg:#00ba4f;--tag-ink:#fff}.blog-hashtag--teal{--tag-bg:#16aa9b;--tag-ink:#fff}.blog-hashtag--inverted{--tag-bg:#eee;--tag-ink:#262626}.blog-hashtag--trial{--tag-bg:linear-gradient(135deg, #7467ff, #df2fd0);--tag-ink:#fff}.blog-hashtag--turborepo{--tag-bg:linear-gradient(135deg, #f1426d, #e368a7 52%, #48a7ff);--tag-ink:#fff}.blog-card:hover .blog-hashtag,.blog-card:focus-within .blog-hashtag{filter:saturate(1.14)brightness(1.05)}.blog-prose .blog-hashtag{margin:0 .08em;font-size:.9em}.blog-card--writeup,.blog-reader--writeup{--blog-accent:#70e1ff;--blog-accent-2:#fd7}.blog-card--lab,.blog-reader--lab{--blog-accent:#9fef00;--blog-accent-2:#70e1ff}.blog-card--note,.blog-reader--note{--blog-accent:#fd7;--blog-accent-2:#ff8ad1}.blog-reader{padding:104px 28px 110px}.blog-progress{z-index:11;background:#f5f1e814;height:3px;position:fixed;top:0;left:0;right:0}.blog-progress span{background:linear-gradient(90deg,var(--blog-accent),var(--blog-accent-2));transform-origin:0;width:100%;height:100%;display:block;transform:scaleX(0)}.blog-reader__shell{width:min(1700px,100%);margin:0 auto}.blog-reader__header{width:100%;margin:0}.blog-reader__header--title{margin-bottom:-10px;padding:52px 0 0}.blog-reader__header--meta{padding:0 0 12px}.blog-reader__header h1{letter-spacing:-.03em;text-wrap:balance;margin-bottom:0;font-family:Cormorant Garamond,Georgia,Times New Roman,serif;font-size:clamp(3.8rem,5vw,4.5rem);font-weight:600;line-height:.98}.blog-reader__intro-card{-webkit-backdrop-filter:blur(12px)saturate(102%);backdrop-filter:blur(12px)saturate(102%);background:linear-gradient(#ffffff08,#ffffff04),#14141685;border-radius:24px;gap:24px;margin-top:16px;padding:26px 28px;display:grid;box-shadow:0 20px 48px #0000002e}.blog-reader__summary{color:var(--blog-text);margin:0}@supports (color:color-mix(in lab,red,red)){.blog-reader__summary{color:color-mix(in srgb,var(--blog-text) 88%,#fff 12%)}}.blog-reader__summary{font-size:1.02rem;line-height:1.78}.blog-reader__meta-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.blog-reader__meta-group{gap:10px;min-width:0;display:grid}.blog-reader__meta-label,.blog-sibling-links__kicker,.blog-reader__end-kicker{color:var(--blog-muted);letter-spacing:.14em;text-transform:uppercase;margin:0;font-size:.72rem;font-weight:850}.blog-reader__meta-cluster{flex-wrap:wrap;gap:8px;display:flex}.blog-reader__meta-cluster span,.blog-reader__meta span{background:var(--blog-surface-container-high);min-height:28px;color:var(--blog-ink);border-radius:999px;align-items:center;padding:0 12px;display:inline-flex}.blog-reader__meta-cluster span{white-space:normal;text-transform:none;font-size:.82rem;line-height:1.45}.blog-reader__meta,.blog-reader__header .blog-card__tags{margin-top:18px}.blog-reader__cover{background:var(--blog-surface-container);border:0;border-radius:12px;width:100%;margin:0;overflow:hidden}.blog-reader__cover--banner{border-radius:24px;margin-bottom:0;box-shadow:0 24px 64px #0000004d}.blog-reader__cover img{object-fit:cover;width:100%;max-height:520px;display:block}.blog-reader__layout{grid-template-columns:minmax(180px,1fr) minmax(0,3fr) minmax(220px,1fr);align-items:start;gap:44px;display:grid}.blog-reader__sibling-nav{align-content:start;align-self:start;gap:18px;min-width:0;display:grid;position:sticky;top:104px}.blog-reader .blog-back-link{width:fit-content;max-width:100%;position:static}.blog-reader__sibling-nav-inner{will-change:transform;transition:transform .18s var(--ease-standard);align-content:start;gap:10px;padding:2px;display:grid}.blog-sibling-links{gap:8px;display:grid}.blog-sibling-links__item{background:var(--blog-surface-container);min-width:0;color:var(--blog-text);transition:background var(--motion-ultra-luxury) var(--ease-standard),color var(--motion-ultra-luxury) var(--ease-standard),box-shadow var(--motion-ultra-luxury) var(--ease-standard),transform var(--motion-ultra-luxury) var(--ease-standard);border:0;border-radius:18px;gap:5px;padding:14px 18px;text-decoration:none;display:grid}.blog-sibling-links__item:hover,.blog-sibling-links__item:focus-visible{background:var(--blog-surface-container-highest);color:var(--blog-ink)}.blog-sibling-links__item strong{min-width:0;color:var(--blog-ink);text-overflow:ellipsis;white-space:nowrap;font-size:.92rem;font-weight:700;line-height:1.22;overflow:hidden}.blog-sibling-links__item span{color:var(--blog-muted);text-overflow:ellipsis;white-space:nowrap;text-transform:uppercase;font-size:.7rem;font-weight:700;overflow:hidden}.blog-reader__content{align-content:start;gap:18px;min-width:0;padding:0;display:grid}.blog-prose{min-width:0;color:var(--blog-text);font-size:1rem;line-height:1.75}.blog-reader .blog-prose :where(p,li,blockquote){letter-spacing:.01em;font-family:Playwrite GB J,cursive;font-weight:300}.blog-reader .blog-prose p,.blog-reader .blog-prose li{font-size:.98rem;line-height:1.82}.blog-prose>:first-child{margin-top:0}.blog-prose h1,.blog-prose h2,.blog-prose h3,.blog-prose h4{width:fit-content;max-width:100%;color:var(--blog-ink);letter-spacing:-.01em;scroll-margin-top:92px;line-height:1.2;position:relative}.blog-prose h1{letter-spacing:-.03em;margin:4rem 0 1.75rem;padding:0 0 .42em;font-size:clamp(2.4rem,4vw,3.35rem);line-height:1.04}.blog-prose h2{margin:3.5rem 0 1.5rem;padding:0 0 .48em;font-size:1.6rem}.blog-prose h3{margin:2.5rem 0 1rem;padding-bottom:.48em;font-size:1.25rem}.blog-prose h4{margin:2rem 0 .85rem;padding-bottom:.48em;font-size:1.08rem}.blog-prose p,.blog-prose ul,.blog-prose ol,.blog-prose blockquote,.blog-prose pre,.blog-prose table{margin:0 0 24px}.blog-prose hr{opacity:1;background:linear-gradient(90deg,#f5f1e805,#f5f1e838 18% 82%,#f5f1e805);border:0;height:1px;margin:3rem 0}.blog-prose a:not(.blog-preview-card){color:var(--blog-accent-2);text-decoration:underline;text-decoration-thickness:1px;-webkit-text-decoration-color:var(--blog-accent-2);text-decoration-color:var(--blog-accent-2);position:relative}@supports (color:color-mix(in lab,red,red)){.blog-prose a:not(.blog-preview-card){-webkit-text-decoration-color:color-mix(in srgb,var(--blog-accent-2) 42%,transparent);text-decoration-color:color-mix(in srgb,var(--blog-accent-2) 42%,transparent)}}.blog-prose a:not(.blog-preview-card){text-underline-offset:.22em;-webkit-text-decoration-skip-ink:auto;text-decoration-skip-ink:auto;text-shadow:0 0 #0000;transition:color var(--motion-luxury) var(--ease-standard),text-decoration-color var(--motion-luxury) var(--ease-standard),text-underline-offset var(--motion-luxury) var(--ease-standard),text-shadow var(--motion-luxury) var(--ease-standard)}.blog-prose a:not(.blog-preview-card):after{content:"";background:linear-gradient(90deg,var(--blog-accent-2),var(--blog-accent-2) 18%,var(--blog-accent-2) 52%,var(--blog-accent-2));border-radius:999px;height:.9em;position:absolute;bottom:-.12em;left:-.08em;right:-.08em}@supports (color:color-mix(in lab,red,red)){.blog-prose a:not(.blog-preview-card):after{background:linear-gradient(90deg,color-mix(in srgb,var(--blog-accent-2) 0%,transparent),color-mix(in srgb,var(--blog-accent-2) 12%,transparent) 18%,color-mix(in srgb,var(--blog-accent-2) 18%,transparent) 52%,color-mix(in srgb,var(--blog-accent-2) 8%,transparent))}}.blog-prose a:not(.blog-preview-card):after{opacity:0;transform-origin:50%;pointer-events:none;transition:opacity var(--motion-luxury) var(--ease-standard),transform var(--motion-luxury) var(--ease-standard);transform:scaleX(.92)}.blog-prose a:not(.blog-preview-card):hover,.blog-prose a:not(.blog-preview-card):focus-visible{color:#fff4de;-webkit-text-decoration-color:var(--blog-accent-2);text-decoration-color:var(--blog-accent-2)}@supports (color:color-mix(in lab,red,red)){.blog-prose a:not(.blog-preview-card):hover,.blog-prose a:not(.blog-preview-card):focus-visible{-webkit-text-decoration-color:color-mix(in srgb,var(--blog-accent-2) 78%,#fff);text-decoration-color:color-mix(in srgb,var(--blog-accent-2) 78%,#fff)}}.blog-prose a:not(.blog-preview-card):hover,.blog-prose a:not(.blog-preview-card):focus-visible{text-underline-offset:.28em;text-shadow:0 0 16px var(--blog-accent-2)}@supports (color:color-mix(in lab,red,red)){.blog-prose a:not(.blog-preview-card):hover,.blog-prose a:not(.blog-preview-card):focus-visible{text-shadow:0 0 16px color-mix(in srgb,var(--blog-accent-2) 22%,transparent)}}.blog-prose a:not(.blog-preview-card):hover:after,.blog-prose a:not(.blog-preview-card):focus-visible:after{opacity:1;transform:scaleX(1)}.blog-prose a:not(.blog-preview-card):focus-visible{outline:0}.blog-prose a:not(.blog-preview-card):focus-visible:before{content:"";border:1px solid var(--blog-accent-2);position:absolute;inset:-.08em -.18em}@supports (color:color-mix(in lab,red,red)){.blog-prose a:not(.blog-preview-card):focus-visible:before{border:1px solid color-mix(in srgb,var(--blog-accent-2) 45%,#fff)}}.blog-prose a:not(.blog-preview-card):focus-visible:before{opacity:.8;pointer-events:none;border-radius:.45em}.blog-prose code a:not(.blog-preview-card),.blog-prose pre a:not(.blog-preview-card){text-shadow:none}.blog-prose code a:not(.blog-preview-card):after,.blog-prose pre a:not(.blog-preview-card):after,.blog-prose code a:not(.blog-preview-card):before,.blog-prose pre a:not(.blog-preview-card):before{display:none}.blog-prose code a:not(.blog-preview-card):hover,.blog-prose code a:not(.blog-preview-card):focus-visible,.blog-prose pre a:not(.blog-preview-card):hover,.blog-prose pre a:not(.blog-preview-card):focus-visible{color:#fff}.blog-prose a.blog-preview-card{background:0 0}.blog-prose a.blog-preview-card:hover,.blog-prose a.blog-preview-card:focus-visible{color:inherit}.blog-prose code{color:var(--blog-accent-2);background:#f5f1e814;border:1px solid #f5f1e81f;border-radius:5px;padding:.12em .34em;font-size:.92em}.blog-prose pre{box-shadow:var(--blog-shadow-soft);border:1px solid #ffffff14;border-radius:22px;padding:3rem 1.25rem 1.25rem;font-family:Cascadia Code,JetBrains Mono,Fira Code,monospace;line-height:1.32;position:relative;overflow-x:auto;background:linear-gradient(#181c24f5,#10131bf5)!important}.blog-prose pre:before{content:attr(data-code-language);color:#f7f3eabd;letter-spacing:.12em;text-transform:uppercase;background:#ffffff0f;border-radius:999px;align-items:center;min-height:24px;padding:0 10px;font-size:.68rem;font-weight:850;display:inline-flex;position:absolute;top:.85rem;left:1rem}.blog-prose pre[data-code-language=bash]:before,.blog-prose pre[data-code-language=sh]:before,.blog-prose pre[data-code-language=zsh]:before,.blog-prose pre[data-code-language=shell]:before{color:#cbff73;background:#9fef0024}.blog-prose pre[data-code-language=ts]:before,.blog-prose pre[data-code-language=typescript]:before,.blog-prose pre[data-code-language=js]:before,.blog-prose pre[data-code-language=javascript]:before{color:#9eeeff;background:#70e1ff29}.blog-prose pre code{color:inherit;font-family:inherit;font-size:.92rem;line-height:inherit;background:0 0;border:0;padding:0}.blog-prose pre .line{display:block}.blog-prose pre .line:before{content:none}.blog-copy-btn{background:var(--blog-surface-container-high);width:32px;height:32px;color:var(--blog-text);cursor:pointer;opacity:0;z-index:2;border:0;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:opacity .2s,background .2s;display:flex;position:absolute;top:.7rem;right:.7rem}.blog-prose pre:hover .blog-copy-btn{opacity:1}.blog-copy-btn:hover{background:var(--blog-surface-container-highest)}.blog-copy-btn:focus-visible{opacity:1}.blog-prose blockquote{border-left:3px solid var(--blog-accent);background:linear-gradient(180deg,#ffffff08,transparent),var(--blog-surface-container);color:var(--blog-ink);border-radius:0 16px 16px 0;margin:2.5rem 0;padding:2rem 2.5rem;font-size:1.1rem;font-style:italic;line-height:1.6}.blog-prose blockquote p:last-child{margin-bottom:0}.blog-prose ul{padding-left:1.5rem;list-style:none}.blog-prose ul li{margin-bottom:.75rem;position:relative}.blog-prose ul li:before{content:"";background:var(--blog-accent);opacity:.72;border-radius:50%;width:6px;height:6px;position:absolute;top:.65em;left:-1.5rem}.blog-prose ol{counter-reset:blog-counter;padding-left:1.5rem;list-style:none}.blog-prose ol li{counter-increment:blog-counter;margin-bottom:.75rem;position:relative}.blog-prose ol li:before{content:counter(blog-counter) ".";color:var(--blog-accent);font-family:inherit;font-size:.9em;font-weight:850;position:absolute;left:-1.5rem}.blog-prose table{border-collapse:separate;border-spacing:0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);width:100%;max-width:100%;color:var(--blog-text);background:linear-gradient(145deg,#ffffff08,#ffffff03);border:1px solid #ffffff0f;border-radius:12px;margin:2.5rem auto;font-family:inherit;display:table;overflow-x:auto;box-shadow:0 12px 40px #00000026}.blog-prose th{color:var(--blog-ink);text-align:left;white-space:nowrap;background:#ffffff08;border-bottom:1px solid #ffffff0f;padding:14px 20px;font-size:.9em;font-weight:600}.blog-prose td{text-align:left;border-bottom:1px solid #ffffff0a;padding:14px 20px;font-size:.9em}.blog-prose tr:last-child td{border-bottom:none}.blog-preview-card{--preview-accent-rgb:245, 190, 63;border:1px solid var(--blog-line);gap:10px;margin:0 0 20px;display:grid}@supports (color:color-mix(in lab,red,red)){.blog-preview-card{border:1px solid color-mix(in srgb,var(--blog-line) 92%,#ffffff0a)}}.blog-preview-card{background:linear-gradient(180deg,#ffffff09,#ffffff03),linear-gradient(120deg,rgba(var(--preview-accent-rgb),.045),transparent 34%),var(--blog-surface-container);border-radius:22px}@supports (color:color-mix(in lab,red,red)){.blog-preview-card{background:linear-gradient(180deg,#ffffff09,#ffffff03),linear-gradient(120deg,rgba(var(--preview-accent-rgb),.045),transparent 34%),color-mix(in srgb,var(--blog-surface-container) 94%,#080a0eb8)}}.blog-preview-card{color:var(--blog-text);-webkit-backdrop-filter:blur(20px)saturate(1.08);backdrop-filter:blur(20px)saturate(1.08);transition:border-color var(--motion-luxury) var(--ease-standard),transform var(--motion-luxury) var(--ease-standard),box-shadow var(--motion-luxury) var(--ease-standard),background var(--motion-luxury) var(--ease-standard);padding:14px 16px 15px;text-decoration:none;box-shadow:0 16px 36px #0000002e,inset 0 1px #ffffff0b}.blog-preview-card:hover,.blog-preview-card:focus-visible{border-color:rgba(var(--preview-accent-rgb),.24);color:var(--blog-ink);box-shadow:0 22px 54px #0000003d,0 0 0 1px rgba(var(--preview-accent-rgb),.08),inset 0 1px #ffffff0f;transform:translateY(-1px)}.blog-preview-card--youtube{--preview-accent-rgb:255, 47, 47}.blog-preview-card--github{--preview-accent-rgb:242, 245, 247}.blog-preview-card__body{gap:6px;display:grid}.blog-preview-card__top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.blog-preview-card__mark{align-items:center;gap:9px;min-width:0;display:flex}.blog-preview-card__icon-tile{background:linear-gradient(#ffffff14,#ffffff05),#0a0c12b8;border:1px solid #ffffff17;border-radius:11px;flex:none;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex;box-shadow:inset 0 1px #ffffff0a,0 6px 14px #00000029}.blog-preview-card__icon-tile svg{width:18px;height:18px}.blog-preview-card__icon-tile--youtube{color:#ff3131}.blog-preview-card__icon-tile--github{color:#f5f1e8}.blog-preview-card__label{color:var(--blog-ink);letter-spacing:.1em;text-transform:uppercase;font-size:.79rem;font-weight:800}.blog-preview-card__launch{color:#f5f1e8ad;letter-spacing:.12em;text-transform:uppercase;transition:border-color var(--motion-luxury) var(--ease-standard),color var(--motion-luxury) var(--ease-standard),transform var(--motion-luxury) var(--ease-standard),background var(--motion-luxury) var(--ease-standard);background:#f5f1e806;border:1px solid #ffffff14;border-radius:999px;align-self:flex-start;align-items:center;gap:5px;padding:6px 10px;font-size:.64rem;font-weight:800;display:inline-flex}.blog-preview-card:hover .blog-preview-card__launch,.blog-preview-card:focus-visible .blog-preview-card__launch{border-color:rgba(var(--preview-accent-rgb),.28);background:rgba(var(--preview-accent-rgb),.08);color:#fff4de;transform:translate(1px)}.blog-preview-card__body h3{color:var(--blog-ink);text-wrap:balance;max-width:30ch;margin:0;font-size:clamp(1rem,.98rem + .3vw,1.18rem);line-height:1.12}.blog-preview-card__body p{margin:0}.blog-preview-card__meta{color:var(--blog-muted);font-size:.79rem;font-weight:650}.blog-preview-card__description{color:#f5f1e8b8;max-width:48ch;font-size:.92rem;line-height:1.42}.blog-reader__rail{align-content:start;align-self:start;min-width:0;display:grid;position:sticky;top:104px}.blog-reader__rail-inner{will-change:transform;transition:transform .18s var(--ease-standard);align-content:start;gap:12px;padding:2px;display:grid}.blog-toc{background:var(--blog-surface-container);border:0;border-radius:24px;padding:24px}.blog-toc__links{gap:4px;display:grid;position:relative}.blog-toc__marker{background:linear-gradient(90deg,var(--blog-accent-2),transparent 72%);border-radius:0 14px 14px 0;width:100%;position:absolute;left:0}@supports (color:color-mix(in lab,red,red)){.blog-toc__marker{background:linear-gradient(90deg,color-mix(in srgb,var(--blog-accent-2) 16%,transparent),transparent 72%)}}.blog-toc__marker{border-left:2px solid var(--blog-accent-2)}@supports (color:color-mix(in lab,red,red)){.blog-toc__marker{border-left:2px solid color-mix(in srgb,var(--blog-accent-2) 72%,#fff 10%)}}.blog-toc__marker{opacity:0;transition:transform .32s var(--ease-standard),height .32s var(--ease-standard),opacity .22s var(--ease-standard);pointer-events:none;transform:translateY(0)}[data-blog-toc]:has(.blog-toc__link[aria-current=true]) .blog-toc__marker{opacity:1}.blog-toc p,.blog-mobile-toc p{color:var(--blog-muted);letter-spacing:.01em;text-transform:none;margin:0 0 12px;font-family:Cormorant Garamond,Georgia,Times New Roman,serif;font-size:1.18rem;font-weight:600}.blog-toc__link{z-index:1;color:var(--blog-muted);transition:background var(--motion-ultra-luxury) var(--ease-standard),color var(--motion-ultra-luxury) var(--ease-standard),border-color var(--motion-ultra-luxury) var(--ease-standard);border-left:2px solid #0000;border-radius:0 12px 12px 0;padding:8px 12px;font-size:.84rem;line-height:1.45;text-decoration:none;display:block;position:relative}.blog-toc__link--depth-3{padding-left:24px;font-size:.78rem}.blog-toc__link:hover,.blog-toc__link:focus-visible,.blog-toc__link[aria-current=true]{background:var(--blog-surface-container-high)}@supports (color:color-mix(in lab,red,red)){.blog-toc__link:hover,.blog-toc__link:focus-visible,.blog-toc__link[aria-current=true]{background:color-mix(in srgb,var(--blog-surface-container-high) 84%,#ffffff08)}}.blog-toc__link:hover,.blog-toc__link:focus-visible,.blog-toc__link[aria-current=true]{color:var(--blog-ink);border-color:var(--blog-accent-2)}.blog-mobile-toc{scrollbar-width:none;gap:12px;max-height:min(60vh,420px);padding:18px;display:grid}.blog-mobile-toc::-webkit-scrollbar{display:none}.blog-mobile-toc p{margin:0}.blog-mobile-toc .blog-toc__links{scrollbar-width:none;max-height:min(46vh,320px);padding-right:2px;overflow-y:auto}.blog-mobile-toc .blog-toc__links::-webkit-scrollbar{display:none}.blog-mobile-toc .blog-toc__link{isolation:isolate;color:#f7f3ead6;background:#f5f1e808;border-left-width:1px;border-radius:999px;position:relative}.blog-mobile-toc .blog-toc__link:hover,.blog-mobile-toc .blog-toc__link:focus-visible{color:#fff;background:#f5f1e814;border-color:#f5f1e824}.blog-mobile-toc .blog-toc__link[aria-current=true]{color:#f7f3eaf5;background:#f5f1e80e;border-color:#f5f1e81f}.blog-reader__end{isolation:isolate;border-top:0;align-items:start;gap:28px;width:100%;min-height:360px;margin:34px 0 0;padding:104px 0 112px;display:grid;position:relative;overflow:visible}.blog-reader__end-copy{gap:18px;max-width:940px;display:grid}.blog-reader__end h2{width:fit-content;max-width:100%;color:var(--blog-ink);letter-spacing:-.03em;margin:0;padding-bottom:.42em;font-size:clamp(2.8rem,5vw,3.35rem);line-height:1.02;position:relative}.blog-reader__end h2:after{content:"";pointer-events:none;background:linear-gradient(90deg,var(--blog-accent-2),#ffffff1f);border-radius:999px;width:min(132px,38%);height:2px;position:absolute;bottom:.08em;left:0}@supports (color:color-mix(in lab,red,red)){.blog-reader__end h2:after{background:linear-gradient(90deg,color-mix(in srgb,var(--blog-accent-2) 72%,#fff),#ffffff1f)}}.blog-reader__end h2:after{opacity:.9}.blog-reader__related{gap:12px;display:grid}.blog-reader__related span{color:var(--blog-muted);letter-spacing:.14em;text-transform:uppercase;margin:16px 0 10px;font-size:.72rem;font-weight:850;display:block}.blog-reader__related-links{gap:10px;display:grid}.blog-reader__related-link{background:var(--blog-surface-container-high);width:fit-content;max-width:100%;color:var(--blog-ink);transition:background var(--motion-ultra-luxury) var(--ease-standard),color var(--motion-ultra-luxury) var(--ease-standard),transform var(--motion-ultra-luxury) var(--ease-standard);border-radius:999px;align-items:center;padding:10px 14px;text-decoration:none;display:inline-flex}.blog-reader__related-link:hover,.blog-reader__related-link:focus-visible{background:var(--blog-surface-container-highest);color:#fff;transform:translateY(-1px)}.blog-reader__end>:not(.blog-dotted-surface-host){z-index:1;position:relative}.blog-reader__end-actions{flex-wrap:wrap;gap:10px;display:flex}.blog-link--quiet{color:var(--blog-muted)}.blog-dotted-surface-host{z-index:0;opacity:.86;pointer-events:none;isolation:isolate;width:100vw;position:absolute;top:-170px;bottom:-160px;left:50%;overflow:hidden;transform:translate(-50%);-webkit-mask-image:linear-gradient(#0000 0%,#000 18% 84%,#0000 100%);mask-image:linear-gradient(#0000,#000 18% 84%,#0000)}.blog-dotted-surface{pointer-events:none;position:absolute;inset:0;overflow:hidden}.blog-dotted-surface:after{display:none}.blog-dotted-surface__canvas{z-index:1;display:block;position:absolute;inset:0;width:100%!important;height:100%!important}@media(max-width:980px){.blog-nav{width:min(100% - 32px,760px)}.blog-index,.blog-reader{padding-left:18px;padding-right:18px}.blog-index__hero{grid-template-columns:1fr;gap:24px;min-height:auto;padding-top:76px}.blog-controls{grid-template-columns:minmax(0,1fr) auto}.blog-sort{justify-self:end}.blog-index__hero h1,.blog-reader__header h1{font-size:2.2rem}.blog-style-nav,.blog-entry-board{grid-template-columns:repeat(2,minmax(0,1fr))}.blog-card-grid,.blog-archive__group header,.blog-reader__layout,.blog-reader__end{grid-template-columns:1fr}.blog-reader__end-copy{max-width:100%}.blog-reader__intro-card,.blog-reader__meta-grid{grid-template-columns:1fr}.blog-archive__group h2,.blog-archive__group header p{grid-area:auto}.blog-reader__layout{gap:34px}.blog-reader__sibling-nav,.blog-reader__rail{display:none}.blog-reader__sibling-nav-inner,.blog-reader__rail-inner{transition:none;transform:none!important}.blog-reader-mobile-nav{display:block}.blog-reader-mobile-nav .blog-nav--reader{grid-template-columns:42px minmax(0,1fr) 42px;gap:8px;width:min(420px,100% - 24px);min-height:54px;padding-left:8px;padding-right:8px;top:16px}.blog-reader-mobile-nav .blog-nav__action--menu{display:grid}.blog-reader-mobile-nav .blog-nav__back{justify-content:center;width:38px;min-width:38px;min-height:38px;padding:0}.blog-reader-mobile-nav .blog-nav__back-label{display:none}.blog-reader-mobile-nav .blog-nav__brand{width:100%;max-width:100%}.blog-reader-mobile-nav .blog-nav__brand-title{max-width:100%;font-size:.84rem}.blog-reader-mobile-nav .blog-nav__action--menu,.blog-reader-mobile-nav .blog-nav__action--placeholder{width:38px;height:38px}.blog-mobile-toc-panel{-webkit-backdrop-filter:blur(16px)saturate(110%);backdrop-filter:blur(16px)saturate(110%);background:#1c1b1de6;border-radius:20px;width:clamp(208px,46vw,272px);top:78px;right:max(14px,50vw - 210px);box-shadow:inset 0 1px #ffffff05,0 22px 58px #00000057}.blog-mobile-toc{gap:8px;max-height:min(48vh,360px);padding:14px}.blog-mobile-toc .blog-toc__link{padding:9px 12px;font-size:.78rem;line-height:1.35}.blog-mobile-toc .blog-toc__link--depth-3{padding-left:18px;font-size:.74rem}.blog-reader__related{display:grid}.blog-reader__end>div:last-child{justify-content:flex-start}.blog-reader__end{min-height:320px;padding:78px 0 92px}.blog-reader .blog-back-link{display:none}.blog-preview-card{padding:14px}}@media(max-width:620px){.blog-nav{gap:10px;width:calc(100% - 24px);min-height:50px;padding:0 10px;top:18px}.blog-nav__brand-title{font-size:.84rem}.blog-nav__socials{gap:6px}.blog-nav__back{min-height:34px;padding:0 15px 0 11px}.blog-nav__action{width:34px;height:34px}.blog-reader-mobile-nav .blog-nav{width:calc(100% - 24px)}.blog-reader-mobile-nav .blog-nav__brand{max-width:min(100%,46vw)}.blog-reader-mobile-nav .blog-nav__brand-title{font-size:.8rem}.blog-mobile-toc-panel{width:clamp(198px,50vw,252px);top:76px;right:12px}.blog-index,.blog-reader{padding:156px 14px 76px}.blog-reader__shell{padding-top:0}.blog-dotted-surface-host{opacity:.72;top:-120px;bottom:-110px}.blog-index__hero{padding-top:56px;padding-bottom:34px}.blog-index__hero h1,.blog-reader__header h1{font-size:2.5rem;line-height:1.1}.blog-index__hero>p,.blog-reader__header>p,.blog-prose{font-size:.94rem}.blog-reader .blog-prose p,.blog-reader .blog-prose li{font-size:.88rem;line-height:1.5}.blog-prose ul li,.blog-prose ol li{margin-bottom:.25rem}.blog-style-nav,.blog-entry-board,.blog-controls{grid-template-columns:1fr}.blog-toggle,.blog-sort{justify-self:stretch}.blog-toggle__btn,.blog-sort__btn{flex:1;justify-content:center}.blog-search{grid-area:auto}.blog-entry-card{border-radius:26px;height:auto;min-height:500px}.blog-entry-card__preview{border-radius:26px 26px 0 0;min-height:160px;margin:0}.blog-entry-card__preview strong{font-size:.76rem;bottom:20px;left:18px}.blog-feature,.blog-empty,.blog-card a{padding:18px}.blog-entry-card__body{gap:12px;padding:18px}.blog-entry-card__description{-webkit-line-clamp:2;max-height:2.96em;font-size:.88rem;line-height:1.48}.blog-feature h2,.blog-empty h2,.blog-archive__group h2,.blog-reader__end h2,.blog-prose h2{font-size:1.45rem}.blog-card h3,.blog-prose h3,.blog-entry-card h2{font-size:1.15rem}.blog-reader__header{padding-top:28px}.blog-reader__intro-card{gap:18px;padding:20px}.blog-reader__summary{font-size:.94rem;line-height:1.7}.blog-prose pre{padding:2.8rem 14px 14px}.blog-prose th,.blog-prose td{padding:12px 14px;font-size:.84rem}.blog-preview-card__top{align-items:flex-start}.blog-preview-card__launch{align-self:flex-start}}@media(pointer:coarse){.blog-entry-card{--entry-hover-motion:.26s}}@media(prefers-reduced-motion:reduce){.blog-app *,.blog-app :before,.blog-app :after{scroll-behavior:auto!important}.blog-back-link,.blog-link,.blog-entry-card,.blog-entry-card__preview,.blog-entry-card__preview>span,.blog-entry-card__preview strong,.blog-toggle__btn,.blog-sort__btn,.blog-search,.blog-search__clear,.blog-preview-card,.blog-preview-card__launch,.blog-toc__link,.blog-copy-btn,.blog-mobile-toc-panel{transition:none}.blog-mobile-toc-panel[data-state=open],.blog-mobile-toc-panel[data-state=opening]{clip-path:none;opacity:1;pointer-events:auto;transform:none}.blog-entry-card:hover,.blog-entry-card:focus-within,.blog-back-link:hover,.blog-back-link:focus-visible,.blog-link:hover,.blog-link:focus-visible{transform:none}.blog-entry-card.is-blog-reveal-ready{opacity:1;transform:none}}.resume-viewer{contain:layout paint;min-height:100%;display:grid}.resume-viewer__frame{width:100%;min-height:540px;box-shadow:none;contain:layout paint;background:#0b111ff5;border:0;border-radius:0;margin:0;overflow:auto}.resume-viewer__sheet{justify-content:center;align-items:flex-start;min-height:100%;padding:0;display:flex}.resume-viewer__image{width:100%;height:auto;box-shadow:none;background:#f8fafc;border-radius:0;display:block}.resume-viewer h3,.browser-view h3,.project-grid h3{color:var(--ink);margin:8px 0}.resume-viewer p,.browser-view p,.project-grid p{color:var(--muted);line-height:1.6}.primary-link{background:var(--accent);color:#fff;border-radius:6px;justify-content:center;align-items:center;min-height:42px;padding:0 16px;font-weight:800;text-decoration:none;transition:background .18s,transform .18s;display:inline-flex}.primary-link:hover,.primary-link:focus-visible{background:#005a9e;transform:translateY(-1px)}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.project-grid span{color:var(--accent);font-weight:900}.project-link{color:var(--accent);margin-top:14px;font-size:.88rem;font-weight:800;text-decoration:none;display:inline-flex}.certification-gallery{background:#1f2635;min-height:100%;padding:0;display:grid;position:relative;overflow:hidden;container:certifications/inline-size}.certification-gallery:before{pointer-events:none;content:"";background:linear-gradient(#ffffff05,#0000 18% 82%,#ffffff03);position:absolute;inset:0}.certification-gallery__strip{z-index:1;gap:14px;height:100%;min-height:100%;padding:0;display:flex;position:relative}.certification-gallery__panel{min-width:0;color:inherit;isolation:isolate;contain:layout paint;background:#2a3140;border:0;border-radius:14px;flex:1 1 0;justify-content:flex-start;align-items:flex-end;transition:flex-grow .8s cubic-bezier(.2,.8,.2,1),transform .22s;display:flex;position:relative;overflow:hidden;transform:translateZ(0)}.certification-gallery__strip:hover .certification-gallery__panel,.certification-gallery__strip:focus-within .certification-gallery__panel{flex-grow:.42}.certification-gallery__strip:hover .certification-gallery__panel:hover,.certification-gallery__strip:hover .certification-gallery__panel:focus-visible,.certification-gallery__strip:focus-within .certification-gallery__panel:focus-visible{flex-grow:4.8}.certification-gallery__panel:focus-visible{outline-offset:-2px;outline:2px solid #d7e9ffb3}.certification-gallery__panel:hover,.certification-gallery__panel:focus-visible{transform:translateY(-1px)translateZ(0)}.certification-gallery__panel-media{border-radius:inherit;position:absolute;inset:0;overflow:hidden}.certification-gallery__panel-media img{object-fit:cover;width:100%;height:100%;transition:transform .42s cubic-bezier(.2,.8,.2,1);display:block;transform:scale(1)}.certification-gallery__panel:hover .certification-gallery__panel-media img,.certification-gallery__panel:focus-visible .certification-gallery__panel-media img{transform:scale(1.024)}.certification-gallery__panel-tint{background:linear-gradient(#141a220a,#141a221a 54%,#141a2285);position:absolute;inset:0}.certification-gallery__panel-grid{display:none}.certification-gallery__panel-content{z-index:1;opacity:.82;gap:8px;width:100%;padding:16px;transition:transform .36s cubic-bezier(.2,.8,.2,1),opacity .36s cubic-bezier(.2,.8,.2,1);display:grid;position:relative;transform:translateY(8px)}.certification-gallery__panel:hover .certification-gallery__panel-content,.certification-gallery__panel:focus-visible .certification-gallery__panel-content{opacity:1;transform:translateY(0)}.certification-gallery__panel-order{color:#f1f6fceb;letter-spacing:.12em;text-transform:uppercase;background:#2b3546b8;border:0;border-radius:999px;justify-content:center;align-items:center;width:fit-content;padding:.42rem .68rem;font-size:.56rem;font-weight:700;display:inline-flex}.certification-gallery__panel-text{gap:6px;display:grid}.certification-gallery__panel-text strong{color:#f4f7fb;letter-spacing:-.03em;font-size:clamp(.98rem,1.24vw,1.12rem);font-weight:650;line-height:1.02}.certification-gallery__panel-text span{color:#e2e9f2d1;letter-spacing:.16em;text-transform:uppercase;font-size:.62rem;font-weight:700}@media(max-width:980px){.certification-gallery__strip{min-height:100%;padding:0}}@media(max-width:760px){.certification-gallery__strip{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;min-height:auto;padding:0;display:grid}.certification-gallery__panel{aspect-ratio:.88;border-radius:12px;min-height:220px;flex-grow:1!important}}@media(max-width:560px){.certification-gallery__strip{grid-template-columns:1fr}.certification-gallery__panel{aspect-ratio:1.25}}@media(prefers-reduced-motion:reduce){.certification-gallery__panel,.certification-gallery__panel-content,.certification-gallery__panel-media img{transition:none}}.lab-showcase{gap:18px;display:grid}.lab-showcase__hero,.lab-showcase__panel,.lab-showcase__metric{background:var(--window-panel-bg);border:1px solid #ffffff1a;border-radius:10px}.lab-showcase__hero{background:radial-gradient(circle at top left,#60cdff24,transparent 34%),var(--window-panel-bg);grid-template-columns:minmax(220px,300px) minmax(0,1fr);gap:20px;padding:20px;display:grid}.lab-showcase--thm .lab-showcase__hero{background:radial-gradient(circle at top left,#ff525229,transparent 34%),var(--window-panel-bg)}.lab-showcase--htb .lab-showcase__hero{background:radial-gradient(circle at top left,#9fef0029,transparent 34%),var(--window-panel-bg)}.lab-showcase__portrait{background:linear-gradient(#ffffff14,#0000002e);border-radius:10px;min-height:280px;overflow:hidden}.lab-showcase__portrait img{object-fit:cover;width:100%;height:100%;display:block}.lab-showcase__intro{align-content:start;gap:10px;display:grid}.lab-showcase__eyebrow{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.lab-showcase__eyebrow span,.lab-showcase__eyebrow strong{border-radius:999px;align-items:center;min-height:28px;padding:0 12px;font-size:.78rem;font-weight:750;display:inline-flex}.lab-showcase__eyebrow span{color:var(--ink);background:#ffffff14}.lab-showcase__eyebrow strong{color:#06101f;background:linear-gradient(135deg,#60cdffeb,#2d7dffeb)}.lab-showcase--thm .lab-showcase__eyebrow strong{background:linear-gradient(135deg,#ff5e5ef5,#ff996beb)}.lab-showcase--htb .lab-showcase__eyebrow strong{background:linear-gradient(135deg,#9fef00f2,#14b88ceb)}.lab-showcase h3,.lab-showcase h4,.lab-showcase p{margin:0}.lab-showcase h3{color:var(--ink);font-size:clamp(1.8rem,2vw,2.5rem);line-height:1}.lab-showcase__tagline{color:var(--accent);letter-spacing:.04em;text-transform:uppercase;font-size:.92rem;font-weight:800}.games-dashboard{--games-panel:#111824f5;--games-panel-strong:#182130fa;--games-line:#ffffff14;--games-line-strong:#ffffff24;--games-ink:#f6f8ff;--games-text:#e4ebf7d1;--games-muted:#abb8d0b8;--games-accent:#79f2c7;--games-accent-2:#4d8dff;color:var(--games-text);gap:18px;font-family:Segoe UI Variable Text,Segoe UI,system-ui,sans-serif;display:grid}.games-dashboard__hero,.games-dashboard__metric,.games-dashboard__note,.games-dashboard__profile,.games-dashboard__game{border:1px solid var(--games-line);background:linear-gradient(180deg,#ffffff0b,transparent 22%),var(--games-panel);border-radius:24px;box-shadow:inset 0 1px #ffffff0a,0 24px 60px #00000047}.games-dashboard__hero{background:radial-gradient(circle at 12% 12%,#79f2c724,transparent 28%),radial-gradient(circle at 84% 10%,#4d8dff29,transparent 32%),var(--games-panel);grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr);gap:18px;padding:24px;display:grid}.games-dashboard__eyebrow,.games-dashboard__game-head p{color:var(--games-muted);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:.78rem;font-weight:850}.games-dashboard__hero-copy{gap:14px;display:grid}.games-dashboard__hero-copy h2,.games-dashboard__game-head h3,.games-dashboard__profile strong{color:var(--games-ink);margin:0}.games-dashboard__hero-copy h2{max-width:15ch;font-size:clamp(2rem,3.2vw,3.2rem);line-height:1.02}.games-dashboard__hero-copy>p:last-child,.games-dashboard__note p,.games-dashboard__game-copy>p{margin:0;line-height:1.7}.games-dashboard__metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.games-dashboard__metric{background:linear-gradient(180deg,#ffffff0d,transparent 24%),var(--games-panel-strong);align-content:end;gap:8px;min-height:120px;padding:18px;display:grid}.games-dashboard__metric span,.games-dashboard__game-stats dt{color:var(--games-muted);text-transform:uppercase;font-size:.78rem;font-weight:760}.games-dashboard__metric strong,.games-dashboard__game-stats dd,.games-dashboard__game-head strong{color:var(--games-ink)}.games-dashboard__metric strong{font-size:1.4rem;line-height:1.1}.games-dashboard__note{gap:8px;padding:20px 24px;display:grid}.games-dashboard__note strong{color:var(--games-ink);font-size:1rem}.games-dashboard__profiles{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.games-dashboard__profile{color:inherit;gap:6px;padding:18px 22px;text-decoration:none;display:grid}.games-dashboard__profile span{color:var(--games-muted);letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;font-weight:850}.games-dashboard__library{gap:18px;display:grid}.games-dashboard__game{grid-template-columns:220px minmax(0,1fr);gap:22px;padding:20px;display:grid}.games-dashboard__game-thumb{border:1px solid var(--games-line-strong);background:#ffffff0a;border-radius:18px;min-height:160px;position:relative;overflow:hidden}.games-dashboard__game-thumb img{object-fit:cover;width:100%;height:100%;display:block}.games-dashboard__game-thumb span{min-width:40px;min-height:32px;color:var(--games-ink);background:#040b16d1;border-radius:999px;justify-content:center;align-items:center;font-size:.78rem;font-weight:850;display:inline-flex;position:absolute;top:12px;left:12px}.games-dashboard__game-copy{align-content:center;gap:16px;display:grid}.games-dashboard__game-head{flex-wrap:wrap;justify-content:space-between;align-items:start;gap:16px;display:flex}.games-dashboard__game-head strong{font-size:1.2rem;line-height:1.1}.games-dashboard__game-stats{grid-template-columns:repeat(2,minmax(0,180px));gap:16px;margin:0;display:grid}.games-dashboard__game-stats div{gap:4px;display:grid}.games-dashboard__game-stats dd{margin:0;font-size:1.1rem;font-weight:760}@media(max-width:980px){.games-dashboard__hero,.games-dashboard__profiles,.games-dashboard__game{grid-template-columns:1fr}.games-dashboard__metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.games-dashboard__metrics,.games-dashboard__game-stats{grid-template-columns:1fr}}.htb-dashboard{--htb-ink:#f7faf2;--htb-text:#e1ebd9d1;--htb-muted:#b8cab0a8;--htb-line:#9fef003d;--htb-green:#9fef00;min-height:100%;color:var(--htb-text);font-family:Segoe UI Variable Text,Segoe UI,system-ui,sans-serif;display:grid;position:relative;overflow:hidden}.htb-dashboard__surface-host{z-index:0;opacity:.86;pointer-events:none;position:absolute;inset:-120px;overflow:hidden;-webkit-mask-image:linear-gradient(#0000 0%,#000 14% 86%,#0000 100%);mask-image:linear-gradient(#0000,#000 14% 86%,#0000)}.htb-dashboard__surface{pointer-events:none;position:absolute;inset:0}.htb-dashboard__surface .blog-dotted-surface__canvas{z-index:0}.htb-profile-card{z-index:1;grid-template-columns:190px minmax(0,1fr);align-items:center;gap:22px;min-height:100%;padding:18px 20px 20px;display:grid;position:relative}.htb-profile-card__visual{place-items:center;min-height:100%;display:grid;position:relative}.htb-profile-card__platform-mark{opacity:.18;filter:drop-shadow(0 0 30px #9fef0029)saturate(1.15);width:220px;height:auto;position:absolute;left:-42px}.htb-profile-card__portrait{z-index:1;aspect-ratio:1;clip-path:polygon(25% 4%,75% 4%,100% 50%,75% 96%,25% 96%,0 50%);filter:drop-shadow(0 16px 36px #00000047);background:linear-gradient(135deg,#9fef00e0,#ffffff2e);width:126px;padding:5px;position:relative}.htb-profile-card__portrait img{object-fit:cover;width:100%;height:100%;clip-path:inherit;display:block}.htb-profile-card__content{align-content:center;gap:12px;max-width:480px;display:grid}.htb-profile-card__brand span,.htb-profile-card__rank span{color:var(--htb-muted);letter-spacing:0;text-transform:uppercase;font-size:.72rem;font-weight:800;display:block}.htb-profile-card__brand strong{color:var(--htb-ink);margin-top:4px;font-size:1.6rem;line-height:1.02;display:block}.htb-profile-card__rank{gap:4px;display:grid}.htb-profile-card__rank strong{color:var(--htb-ink);letter-spacing:0;font-size:3.8rem;font-weight:850;line-height:.9}.htb-profile-card__rank p{color:var(--htb-ink);opacity:.82;margin:0;font-size:.94rem;font-weight:600}.htb-profile-card__badges{flex-wrap:wrap;gap:8px;display:flex}.htb-profile-card__badges em{border:1px solid var(--htb-line);width:fit-content;color:var(--htb-green);background:#101f12b8;border-radius:999px;padding:6px 10px;font-size:.76rem;font-style:normal;font-weight:800}.htb-profile-card__note{max-width:30rem;color:var(--htb-muted);margin:0;font-size:.86rem;line-height:1.45}.htb-profile-card__link{width:fit-content;min-height:38px;color:var(--htb-ink);background:#9fef0014;border:1px solid #9fef003d;border-radius:999px;align-items:center;gap:8px;padding:0 14px;text-decoration:none;transition:background .18s,border-color .18s,color .18s;display:inline-flex}.htb-profile-card__link svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px;width:16px;height:16px}.htb-profile-card__link:hover,.htb-profile-card__link:focus-visible{color:#fff;background:#9fef0029;border-color:#9fef0075}@media(max-width:860px){.htb-profile-card{grid-template-columns:1fr;gap:14px;padding:16px}.htb-profile-card__visual{min-height:160px}.htb-profile-card__platform-mark{width:210px;left:50%;transform:translate(-50%)}.htb-profile-card__content{max-width:none}.htb-profile-card__brand strong{font-size:1.4rem}.htb-profile-card__rank strong{font-size:3rem}}.thm-dashboard{--thm-ink:#f8fbff;--thm-text:#e2e8f1d6;--thm-muted:#a9bacfad;--thm-panel-line:#ffffff0f;--thm-red:#ff6b6b;--thm-gold:#ffc45c;--thm-violet:#d7a7ff;--thm-orange:#ff981f;--thm-blue:#7aa0ff;min-height:100%;color:var(--thm-text);font-family:Segoe UI Variable Text,Segoe UI,system-ui,sans-serif;display:grid;position:relative;overflow:hidden}.thm-dashboard__surface-host{z-index:0;opacity:.86;pointer-events:none;position:absolute;inset:-120px;overflow:hidden;-webkit-mask-image:linear-gradient(#0000 0%,#000 14% 86%,#0000 100%);mask-image:linear-gradient(#0000,#000 14% 86%,#0000)}.thm-dashboard__surface{pointer-events:none;position:absolute;inset:0}.thm-dashboard__surface .blog-dotted-surface__canvas{z-index:0}.thm-profile-card{z-index:1;grid-template-columns:190px minmax(0,1fr);align-items:center;gap:22px;min-height:100%;padding:18px 20px 20px;display:grid;position:relative}.thm-profile-card__visual{place-items:center;min-height:100%;display:grid;position:relative}.thm-profile-card__platform-mark{opacity:.16;filter:drop-shadow(0 0 28px #ff686824)saturate(1.08);width:236px;height:auto;position:absolute;left:-48px}.thm-profile-card__portrait{z-index:1;aspect-ratio:1;clip-path:polygon(25% 4%,75% 4%,100% 50%,75% 96%,25% 96%,0 50%);filter:drop-shadow(0 16px 36px #00000047);background:linear-gradient(135deg,#ff6868cc,#7ab1ff47);width:126px;padding:5px;position:relative}.thm-profile-card__portrait img{object-fit:cover;width:100%;height:100%;clip-path:inherit;display:block}.thm-profile-card__content{align-content:center;gap:14px;width:min(100%,620px);min-width:0;display:grid}.thm-profile-card__brand span,.thm-profile-card__stat-top span{color:var(--thm-muted);letter-spacing:0;text-transform:uppercase;font-size:.72rem;font-weight:800;display:block}.thm-profile-card__brand strong{color:var(--thm-ink);margin-top:4px;font-size:1.55rem;line-height:1.02;display:block}.thm-profile-card__stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;width:100%;min-width:0;display:grid}.thm-profile-card__stat{border:1px solid var(--thm-panel-line);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#151f3194;border-radius:16px;align-content:space-between;gap:14px;min-height:112px;padding:14px 16px 16px;display:grid;overflow:hidden}.thm-profile-card__stat-top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.thm-profile-card__stat-top em{color:var(--thm-gold);background:#475d8657;border-radius:999px 999px 999px 14px;padding:6px 10px;font-size:.72rem;font-style:normal;font-weight:800}.thm-profile-card__stat-value{justify-content:space-between;align-items:center;gap:12px;min-width:0;display:flex}.thm-profile-card__stat-value strong{color:var(--thm-ink);text-align:right;font-size:2.4rem;font-weight:800;line-height:.94}.thm-profile-card__stat-icon{border-radius:14px;flex:none;place-items:center;width:46px;height:46px;display:grid}.thm-profile-card__stat svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.7px;width:28px;height:28px}.thm-profile-card__stat--rank .thm-profile-card__stat-icon{background:#f5a94a24}.thm-profile-card__stat--rank svg{stroke:var(--thm-gold)}.thm-profile-card__stat--badges .thm-profile-card__stat-icon{background:#d7a7ff1f}.thm-profile-card__stat--badges svg{stroke:var(--thm-violet)}.thm-profile-card__stat--streak .thm-profile-card__stat-icon{background:#ff981f1f}.thm-profile-card__stat--streak svg{stroke:var(--thm-orange)}.thm-profile-card__stat--rooms .thm-profile-card__stat-icon{background:#7aa0ff1f}.thm-profile-card__stat--rooms svg{stroke:var(--thm-blue)}.thm-profile-card__link{width:fit-content;min-height:38px;color:var(--thm-ink);background:#ff686814;border:1px solid #ff686838;border-radius:999px;align-items:center;gap:8px;padding:0 14px;text-decoration:none;transition:background .18s,border-color .18s,color .18s;display:inline-flex}.thm-profile-card__link svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px;width:16px;height:16px}.thm-profile-card__link:hover,.thm-profile-card__link:focus-visible{color:#fff;background:#ff686824;border-color:#ff686870}@media(max-width:860px){.thm-profile-card{grid-template-columns:1fr;gap:14px;padding:16px}.thm-profile-card__visual{min-height:160px}.thm-profile-card__platform-mark{width:220px;left:50%;transform:translate(-50%)}.thm-profile-card__content{width:100%}}@media(max-width:720px){.thm-profile-card__stats{grid-template-columns:1fr}.thm-profile-card__stat-value strong{font-size:2.1rem}}@media(prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media(max-width:980px){.desktop{padding:116px 18px 82px}.menu-bar{min-height:56px;-webkit-backdrop-filter:var(--blur-mobile);backdrop-filter:var(--blur-mobile);padding:8px 12px;box-shadow:0 -12px 34px #00000047}.app-drawer,.notification-centre__panel{-webkit-backdrop-filter:var(--blur-mobile);backdrop-filter:var(--blur-mobile);box-shadow:inset 0 1px #ffffff1f,inset 0 -1px #ffffff08,0 28px 34px #00000047}.menu-brand strong{display:none}.menu-brand{width:auto}.menu-launcher{flex:1;justify-content:flex-start;gap:4px;min-width:0;position:static;transform:none}.desktop-shortcuts{grid-template-columns:repeat(4,minmax(0,82px));grid-auto-flow:initial;justify-content:start;gap:10px 8px;top:18px;left:16px;right:16px}.desktop-shortcut{width:76px;padding:7px 4px 8px}.desktop-shortcut img{width:30px;height:30px}.desktop-shortcut span{font-size:.7rem}.app-drawer{width:auto;height:min(720px,100vh - 92px);animation:app-drawer-enter-mobile .22s var(--ease-enter);bottom:70px;left:16px;right:16px;transform:none}.app-drawer__body{padding:18px 30px 22px}.window-layer{inset:108px 14px 76px}.app-window{resize:none;border-radius:10px;min-width:0;min-height:0}.menu-socials__label{display:none}}@media(max-width:620px){.desktop{padding:104px 10px 74px}.menu-bar{gap:6px;min-height:52px;padding:7px 10px}.app-drawer{border-radius:14px;max-height:calc(100dvh - 90px);bottom:62px;left:14px;right:14px;overflow:auto}.app-drawer__search{gap:9px;min-height:38px;margin:12px 12px 6px;padding:0 11px}.app-drawer__search input::placeholder{font-size:.78rem}.app-drawer__body{padding:10px 12px 14px}.app-drawer__view{gap:16px}.app-drawer__view--pinned{grid-template-rows:auto auto}.app-drawer__section{gap:14px}.app-drawer__grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px 3px}.app-drawer__section-head h2{font-size:.84rem}.app-drawer__section-action{min-height:22px;padding:0 8px;font-size:.72rem}.app-drawer__section-head--all-apps{padding-bottom:8px}.app-drawer__item strong{font-size:.64rem}.app-drawer__letter-group{grid-template-columns:24px minmax(0,1fr);gap:10px}.app-drawer__letter-heading{font-size:.76rem}.app-drawer__all-apps-scroll{padding:2px 6px 4px 0}.app-drawer__app-row{grid-template-columns:30px auto;gap:10px;max-width:min(100%,440px);min-height:40px;padding:5px 12px 5px 6px}.app-drawer__app-row img{width:26px;height:26px}.app-drawer__app-row span{font-size:.78rem}.app-drawer__item{gap:5px;min-height:58px;padding:4px 2px}.app-drawer__item img{width:24px;height:24px}.app-drawer__section--developer{align-self:stretch}.app-drawer__developer-card{grid-template-columns:56px minmax(0,1fr);gap:12px;padding:10px 11px}.app-drawer__developer-card img{border-radius:50%;width:56px;height:56px}.app-drawer__developer-card strong{font-size:.78rem}.app-drawer__developer-card span{margin-top:2px;font-size:.64rem}.app-drawer__developer-card p{-webkit-line-clamp:2;margin-top:6px;font-size:.68rem}.app-drawer__footer{min-height:54px;padding:9px 12px}.app-drawer__user{gap:10px;font-size:.74rem}.app-drawer__user img{width:30px;height:30px}.desktop-shortcuts{grid-template-columns:repeat(auto-fit,minmax(68px,1fr));gap:8px 6px;top:12px;left:10px;right:10px}.desktop-shortcut{border-radius:8px;width:100%;min-width:0;padding:7px 2px 8px}.desktop-shortcut img{width:28px;height:28px}.desktop-shortcut span{font-size:.66rem;line-height:1.15}.menu-brand strong{font-size:.8rem}.menu-icon{border-radius:8px;width:34px;height:34px}.menu-icon img{width:19px;height:19px}.menu-socials{gap:2px}.menu-socials a:nth-of-type(n+4){display:none}.menu-clock{min-width:0;padding:0 1px;font-size:.74rem}.menu-icon--tray{gap:0;min-width:0;height:34px;margin-left:3px;margin-right:2px;padding:0 4px}.tray-icon,.tray-icon__svg{width:16px;height:16px}.window-content{padding:14px;font-size:10px}.window-titlebar{grid-template-columns:58px 1fr 58px;min-height:42px;padding:0 8px 0 12px}.window-titlebar h2{font-size:.76rem}}@media(max-width:420px){.app-drawer__grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px 2px}.app-drawer__developer-card{grid-template-columns:48px minmax(0,1fr);gap:10px}.app-drawer__developer-card img{width:48px;height:48px}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{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-outline-style{syntax:"*";inherits:false;initial-value:solid}@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-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}
