@import"https://fonts.googleapis.com/css2?family=Rubik:wght@400;500;700&display=swap";@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}body{min-height:100vh;line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6,p,blockquote,figure,dl,dd{margin:0;font:inherit}a{color:inherit;text-decoration:none}a:hover{text-decoration:none}ul,ol,menu{list-style:none}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}input,button,textarea,select{font:inherit;color:inherit;background:transparent;border:none;outline:none}button{cursor:pointer}textarea{resize:vertical}table{border-collapse:collapse;border-spacing:0}th,td{padding:0;text-align:left;font:inherit}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:""}fieldset{border:0;margin:0;padding:0}legend{padding:0}button,input[type=button],input[type=submit],input[type=reset]{-webkit-appearance:none;appearance:none}article,aside,footer,header,nav,section,main{display:block}:focus{outline:none}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:root{--portfolio-color-page: #EAF2FA;--portfolio-color-page-soft: #F3F8FC;--portfolio-color-surface: #FFFFFF;--portfolio-color-subsurface: #F6FAFD;--portfolio-color-border: #D7E5F3;--portfolio-color-border-strong: #BED4EA;--portfolio-color-text: #3C4754;--portfolio-color-text-muted: #627286;--portfolio-color-text-subtle: #8A99AB;--portfolio-color-accent: #78A8D8;--portfolio-color-accent-strong: #5F96CB;--portfolio-color-accent-soft: #DDECF8;--portfolio-color-hover-surface: #F4F9FD;--portfolio-color-hover-border: #BED4EA;--portfolio-color-hover-text: #5F96CB;--game-color-background-dark: #050F20;--game-color-background: #071224;--game-color-surface: #101B31;--game-color-subsurface: #18233C;--game-color-border: #3A4663;--game-color-text: #F5F7FB;--game-color-text-muted: #A5B3CA;--game-color-accent: #2F66F5;--game-color-accent-hover: #4276FF;--game-color-glow: rgba(47, 102, 245, .18);--game-color-shadow: rgba(0, 0, 0, .45);--game-card-border: #E6EBf4;--game-color-gradient: radial-gradient(circle at center, rgba(47, 102, 245, .12), transparent 55%), #050F20;--game-text: #F2F2F2;--game-text-muted: #C7C7C7;--game-text-subtle: #9A9A9A;--game-background: #212121;--game-surface: #2C2C2C;--game-surface-alt: #2F3136;--game-border: #3A3A3A;--game-accent-red: #C94F4F;--game-accent-blue: #4F7AC9;--game-accent-green: #4FA06D;--game-accent-yellow: #D8B24C;--game-accent-rainbow: linear-gradient( 135deg, var(--game-accent-red), var(--game-accent-yellow), var(--game-accent-green), var(--game-accent-blue) );--color-type-frontend-background: #DCEEFF;--color-type-frontend-text: #1D4ED8;--color-type-backend-background: #DCF5E4;--color-type-backend-text: #166534;--color-type-full-stack-background: #E8E0FF;--color-type-full-stack-text: #6D28D9;--color-type-framework-background: #DCF5F0;--color-type-framework-text: #0F766E;--color-type-database-background: #FFE8D1;--color-type-database-text: #B45309;--color-type-markup-background: #FFE0E0;--color-type-markup-text: #B91C1C;--color-type-styling-background: #DCF2FF;--color-type-styling-text: #0369A1;--color-type-design-background: #FFE1ED;--color-type-design-text: #BE185D;--code-keyword: #B45F06;--code-function: #8A6D00;--code-component: #3574F0;--code-key: #871094;--code-value: #067D17;--code-punctuation: #606366;--code-identifier: #000000;--code-comment: #6A737D;--mac-red: #FF5F57;--mac-yellow: #FEBC2E;--mac-green: #28C840}body.page-portfolio{--color-background: var(--portfolio-color-page);--color-border: var(--portfolio-color-border);--color-surface: var(--portfolio-color-surface);--color-subsurface: var(--portfolio-color-subsurface);--color-text: var(--portfolio-color-text);--color-text-muted: var(--portfolio-color-text-muted);--color-text-subtle: var(--portfolio-color-text-subtle);--color-accent: var(--portfolio-color-accent);--color-accent-hover: var(--portfolio-color-accent-strong);--color-accent-soft: var(--portfolio-color-accent-soft);--color-hover-surface: var(--portfolio-color-hover-surface);--color-hover-border: var(--portfolio-color-hover-border);--color-hover-text: var(--portfolio-color-hover-text)}body.page-game{--color-background: var(--game-color-background-dark);--color-surface: var(--game-color-surface);--color-border: var(--game-color-border);--color-text: var(--game-color-text);--color-text-subtle: var(--game-color-text-muted);--color-text-muted: var(--game-color-text-muted)}@font-face{font-family:InterVariable;font-style:normal;font-weight:100 900;font-display:swap;src:url(/assets/InterVariable-DiVDrmQJ.woff2) format("woff2")}@font-face{font-family:InterVariable;font-style:italic;font-weight:100 900;font-display:swap;src:url(/assets/InterVariable-Italic-FCBEiFp6.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:100;font-display:swap;src:url(/assets/Inter-Thin-DzN99i8q.woff2) format("woff2")}@font-face{font-family:Inter;font-style:italic;font-weight:100;font-display:swap;src:url(/assets/Inter-ThinItalic-DxehbPeK.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:200;font-display:swap;src:url(/assets/Inter-ExtraLight-7kXoOaX_.woff2) format("woff2")}@font-face{font-family:Inter;font-style:italic;font-weight:200;font-display:swap;src:url(/assets/Inter-ExtraLightItalic-Ox17i_b0.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(/assets/Inter-Light-14LG-y7V.woff2) format("woff2")}@font-face{font-family:Inter;font-style:italic;font-weight:300;font-display:swap;src:url(/assets/Inter-LightItalic-iBr7p6CH.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/assets/Inter-Regular-COLGFB3M.woff2) format("woff2")}@font-face{font-family:Inter;font-style:italic;font-weight:400;font-display:swap;src:url(/assets/Inter-Italic-Bm_w1qmz.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(/assets/Inter-Medium-CDhBSFyE.woff2) format("woff2")}@font-face{font-family:Inter;font-style:italic;font-weight:500;font-display:swap;src:url(/assets/Inter-MediumItalic-BqDObnQN.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(/assets/Inter-SemiBold-BAEEcJ4E.woff2) format("woff2")}@font-face{font-family:Inter;font-style:italic;font-weight:600;font-display:swap;src:url(/assets/Inter-SemiBoldItalic-B7KOJJiL.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(/assets/Inter-Bold-BOs3KVhN.woff2) format("woff2")}@font-face{font-family:Inter;font-style:italic;font-weight:700;font-display:swap;src:url(/assets/Inter-BoldItalic-Cabj1n7x.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(/assets/Inter-ExtraBold-BUaDDWMS.woff2) format("woff2")}@font-face{font-family:Inter;font-style:italic;font-weight:800;font-display:swap;src:url(/assets/Inter-ExtraBoldItalic-efVpd_pq.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:900;font-display:swap;src:url(/assets/Inter-Black-BJbWHna9.woff2) format("woff2")}@font-face{font-family:Inter;font-style:italic;font-weight:900;font-display:swap;src:url(/assets/Inter-BlackItalic-D3PIgx41.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:normal;font-weight:100;font-display:swap;src:url(/assets/InterDisplay-Thin-BT9qaRpT.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:italic;font-weight:100;font-display:swap;src:url(/assets/InterDisplay-ThinItalic-DtFR0WUP.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:normal;font-weight:200;font-display:swap;src:url(/assets/InterDisplay-ExtraLight-B3-UpUq4.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:italic;font-weight:200;font-display:swap;src:url(/assets/InterDisplay-ExtraLightItalic-C8b3Z3Tc.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:normal;font-weight:300;font-display:swap;src:url(/assets/InterDisplay-Light-DQj7ly9y.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:italic;font-weight:300;font-display:swap;src:url(/assets/InterDisplay-LightItalic-Bbt9QreW.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:normal;font-weight:400;font-display:swap;src:url(/assets/InterDisplay-Regular-CHKdHLF4.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:italic;font-weight:400;font-display:swap;src:url(/assets/InterDisplay-Italic-Pk5cUfHi.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:normal;font-weight:500;font-display:swap;src:url(/assets/InterDisplay-Medium-CYGNL_ty.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:italic;font-weight:500;font-display:swap;src:url(/assets/InterDisplay-MediumItalic-hd-DtBFz.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:normal;font-weight:600;font-display:swap;src:url(/assets/InterDisplay-SemiBold--Mm3ZPsY.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:italic;font-weight:600;font-display:swap;src:url(/assets/InterDisplay-SemiBoldItalic-KqvXNdTp.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:normal;font-weight:700;font-display:swap;src:url(/assets/InterDisplay-Bold-BpCEuk9N.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:italic;font-weight:700;font-display:swap;src:url(/assets/InterDisplay-BoldItalic-2f5-4TWO.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:normal;font-weight:800;font-display:swap;src:url(/assets/InterDisplay-ExtraBold-CTk6ni5a.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:italic;font-weight:800;font-display:swap;src:url(/assets/InterDisplay-ExtraBoldItalic-7uYEMdJ3.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:normal;font-weight:900;font-display:swap;src:url(/assets/InterDisplay-Black--Thh5XZM.woff2) format("woff2")}@font-face{font-family:InterDisplay;font-style:italic;font-weight:900;font-display:swap;src:url(/assets/InterDisplay-BlackItalic-CeOspfgx.woff2) format("woff2")}@font-feature-values InterVariable{@character-variant{cv01:1;cv02:2;cv03:3;cv04:4;cv05:5;cv06:6;cv07:7;cv08:8;cv09:9;cv10:10;cv11:11;cv12:12;cv13:13;alt-1:1;alt-3:9;open-4:2;open-6:3;open-9:4;lc-l-with-tail:5;simplified-u:6;alt-double-s:7;uc-i-with-serif:8;uc-g-with-spur:10;single-story-a:11;compact-lc-f:12;compact-lc-t:13}@styleset{ss01:1;ss02:2;ss03:3;ss04:4;ss05:5;ss06:6;ss07:7;ss08:8;open-digits:1;disambiguation:2;disambiguation-except-zero:4;round-quotes-and-commas:3;square-punctuation:7;square-quotes:8;circled-characters:5;squared-characters:6}}@font-feature-values Inter{@character-variant{cv01:1;cv02:2;cv03:3;cv04:4;cv05:5;cv06:6;cv07:7;cv08:8;cv09:9;cv10:10;cv11:11;cv12:12;cv13:13;alt-1:1;alt-3:9;open-4:2;open-6:3;open-9:4;lc-l-with-tail:5;simplified-u:6;alt-double-s:7;uc-i-with-serif:8;uc-g-with-spur:10;single-story-a:11;compact-lc-f:12;compact-lc-t:13}@styleset{ss01:1;ss02:2;ss03:3;ss04:4;ss05:5;ss06:6;ss07:7;ss08:8;open-digits:1;disambiguation:2;disambiguation-except-zero:4;round-quotes-and-commas:3;square-punctuation:7;square-quotes:8;circled-characters:5;squared-characters:6}}@font-feature-values InterDisplay{@character-variant{cv01:1;cv02:2;cv03:3;cv04:4;cv05:5;cv06:6;cv07:7;cv08:8;cv09:9;cv10:10;cv11:11;cv12:12;cv13:13;alt-1:1;alt-3:9;open-4:2;open-6:3;open-9:4;lc-l-with-tail:5;simplified-u:6;alt-double-s:7;uc-i-with-serif:8;uc-g-with-spur:10;single-story-a:11;compact-lc-f:12;compact-lc-t:13}@styleset{ss01:1;ss02:2;ss03:3;ss04:4;ss05:5;ss06:6;ss07:7;ss08:8;open-digits:1;disambiguation:2;disambiguation-except-zero:4;round-quotes-and-commas:3;square-punctuation:7;square-quotes:8;circled-characters:5;squared-characters:6}}:root{--font-portfolio: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-squirrel: "Amatic SC", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-weight-light: 300;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--font-weight-black: 900;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-base-lg: 1.125rem;--font-size-md: 1.25rem;--font-size-lg: 1.5rem;--font-size-xl: 2rem;--font-size-xl-lg: 2.5rem;--font-size-2xl: 3rem;--font-size-2xl-lg: 3.5rem;--font-size-3xl: 4.5rem;--type-page-title-size: var(--font-size-3xl);--type-page-title-weight: var(--font-weight-bold);--type-page-title-line-height: 1.1;--type-page-title-letter-spacing: 0;--type-page-text-size: var(--font-size-md);--type-page-text-weight: var(--font-weight-semibold);--type-page-text-line-height: 1.6;--type-page-text-letter-spacing: 0;--type-page-eyebrow-size: var(--font-size-base);--type-page-eyebrow-weight: var(--font-weight-semibold);--type-page-eyebrow-line-height: 1.3;--type-page-eyebrow-letter-spacing: .04em;--type-section-page-title-size: var(--font-size-2xl-lg);--type-section-page-title-weight: var(--font-weight-bold);--type-section-page-title-line-height: 1.1;--type-section-page-title-letter-spacing: 0;--type-section-title-size: var(--font-size-2xl);--type-section-title-weight: var(--font-weight-semibold);--type-section-title-line-height: 1.1;--type-section-title-letter-spacing: 0;--type-section-subtitle-size: var(--font-size-md);--type-section-subtitle-weight: var(--font-weight-semibold);--type-section-subtitle-line-height: 1.6;--type-section-subtitle-letter-spacing: 0;--type-section-text-size: var(--font-size-base);--type-section-text-weight: var(--font-weight-medium);--type-section-text-line-height: 1.6;--type-section-text-letter-spacing: 0;--type-card-title-size: var(--font-size-md);--type-card-title-weight: var(--font-weight-semibold);--type-card-title-line-height: 1.3;--type-card-title-letter-spacing: 0;--type-card-subtitle-size: var(--font-size-base);--type-card-subtitle-weight: var(--font-weight-semibold);--type-card-subtitle-line-height: 1.3;--type-card-subtitle-letter-spacing: 0;--type-card-body-size: var(--font-size-sm);--type-card-body-weight: var(--font-weight-medium);--type-card-body-line-height: 1.6;--type-card-body-letter-spacing: 0;--type-label-size: var(--font-size-sm);--type-label-weight: var(--font-weight-semibold);--type-label-line-height: 1.3;--type-label-letter-spacing: .04em;--type-badge-size: var(--font-size-sm);--type-badge-weight: var(--font-weight-semibold);--type-badge-line-height: 1.3;--type-badge-letter-spacing: 0;--type-eyebrow-size: var(--font-size-sm);--type-eyebrow-weight: var(--font-weight-semibold);--type-eyebrow-line-height: 1.3;--type-eyebrow-letter-spacing: .04em;--type-button-size: var(--font-size-base);--type-button-weight: var(--font-weight-semibold);--type-button-line-height: 1;--type-button-letter-spacing: 0;--type-link-size: var(--font-size-base);--type-link-weight: var(--font-weight-semibold);--type-link-line-height: 1.3;--type-link-letter-spacing: 0;--type-nav-logo-size: var(--font-size-base);--type-nav-logo-weight: var(--font-weight-bold);--type-nav-logo-line-height: 1.3;--type-nav-logo-letter-spacing: 0;--type-nav-subtitle-size: var(--font-size-base);--type-nav-subtitle-weight: var(--font-weight-medium);--type-nav-subtitle-line-height: 1.3;--type-nav-subtitle-letter-spacing: 0;--type-nav-link-size: var(--font-size-sm);--type-nav-link-weight: var(--font-weight-semibold);--type-nav-link-line-height: 1.3;--type-nav-link-letter-spacing: 0;--type-nav-link-subtitle-size: var(--font-size-sm);--type-nav-link-subtitle-weight: var(--font-weight-regular);--type-nav-link-subtitle-line-height: 1.3;--type-nav-link-subtitle-letter-spacing: 0}.type-page-title{font-size:var(--type-page-title-size);font-weight:var(--type-page-title-weight);line-height:var(--type-page-title-line-height);letter-spacing:var(--type-page-title-letter-spacing);color:var(--color-text)}.type-page-text{font-size:var(--type-page-text-size);font-weight:var(--type-page-text-weight);line-height:var(--type-page-text-line-height);letter-spacing:var(--type-page-text-letter-spacing);color:var(--color-text)}.type-page-eyebrow{font-size:var(--type-page-eyebrow-size);font-weight:var(--type-page-eyebrow-weight);line-height:var(--type-page-eyebrow-line-height);letter-spacing:var(--type-page-eyebrow-letter-spacing);text-transform:uppercase;color:var(--color-accent)}.type-section-page-title{font-size:var(--type-section-page-title-size);font-weight:var(--type-section-page-title-weight);line-height:var(--type-section-page-title-line-height);letter-spacing:var(--type-section-page-title-letter-spacing);color:var(--color-text)}.type-section-title{font-size:var(--type-section-title-size);font-weight:var(--type-section-title-weight);line-height:var(--type-section-title-line-height);letter-spacing:var(--type-section-title-letter-spacing);color:var(--color-text)}.type-section-subtitle{font-size:var(--type-section-subtitle-size);font-weight:var(--type-section-subtitle-weight);line-height:var(--type-section-subtitle-line-height);letter-spacing:var(--type-section-subtitle-letter-spacing);color:var(--color-text)}.type-section-text{font-size:var(--type-section-text-size);font-weight:var(--type-section-text-weight);line-height:var(--type-section-text-line-height);letter-spacing:var(--type-section-text-letter-spacing);color:var(--color-text-muted)}.type-card-title{font-size:var(--type-card-title-size);font-weight:var(--type-card-title-weight);line-height:var(--type-card-title-line-height);letter-spacing:var(--type-card-title-letter-spacing);color:var(--color-text)}.type-card-subtitle{font-size:var(--type-card-subtitle-size);font-weight:var(--type-card-subtitle-weight);line-height:var(--type-card-subtitle-line-height);letter-spacing:var(--type-card-subtitle-letter-spacing);color:var(--color-text)}.type-card-body{font-size:var(--type-card-body-size);font-weight:var(--type-card-body-weight);line-height:var(--type-card-body-line-height);letter-spacing:var(--type-card-body-letter-spacing);color:var(--color-text-muted)}.type-label{font-size:var(--type-label-size);font-weight:var(--type-label-weight);line-height:var(--type-label-line-height);letter-spacing:var(--type-label-letter-spacing);color:var(--color-accent)}.type-badge{font-size:var(--type-badge-size);font-weight:var(--type-badge-weight);line-height:var(--type-badge-line-height);letter-spacing:var(--type-badge-letter-spacing);color:var(--color-text)}.type-eyebrow{font-size:var(--type-eyebrow-size);font-weight:var(--type-eyebrow-weight);line-height:var(--type-eyebrow-line-height);letter-spacing:var(--type-eyebrow-letter-spacing);text-transform:uppercase;color:var(--color-accent)}.type-button{font-size:var(--type-button-size);font-weight:var(--type-button-weight);line-height:var(--type-button-line-height);letter-spacing:var(--type-button-letter-spacing);color:var(--color-text)}.type-back-link{font-size:var(--type-link-size);font-weight:var(--type-link-weight);line-height:var(--type-link-line-height);letter-spacing:var(--type-link-letter-spacing);color:var(--color-accent)}.type-nav-logo{font-size:var(--type-nav-logo-size);font-weight:var(--type-nav-logo-weight);line-height:var(--type-nav-logo-line-height);letter-spacing:var(--type-nav-logo-letter-spacing);color:var(--color-text)}.type-nav-subtitle{font-size:var(--type-nav-subtitle-size);font-weight:var(--type-nav-subtitle-weight);line-height:var(--type-nav-subtitle-line-height);letter-spacing:var(--type-nav-subtitle-letter-spacing);color:var(--color-text-muted)}.type-nav-link{font-size:var(--type-nav-link-size);font-weight:var(--type-nav-link-weight);line-height:var(--type-nav-link-line-height);letter-spacing:var(--type-nav-link-letter-spacing);color:var(--color-text)}.type-nav-link-subtitle{font-size:var(--type-nav-link-subtitle-size);font-weight:var(--type-nav-link-subtitle-weight);line-height:var(--type-nav-link-subtitle-line-height);letter-spacing:var(--type-nav-link-subtitle-letter-spacing);color:var(--color-text-muted)}@supports (font-variation-settings: "cv11" 1){.h0,.heading-xxl,.heading-xl,.heading-lg,header,footer{font-family:InterVariable,sans-serif;font-feature-settings:"cv11" 1}}@media(max-width:768px){:root{--type-page-title-size: var(--font-size-2xl-lg);--type-page-text-size: var(--font-size-base-lg);--type-page-eyebrow-size: var(--font-size-sm);--type-section-title-size: var(--font-size-xl-lg);--type-section-page-title-size: var(--font-size-2xl);--type-section-subtitle-size: var(--font-size-base-lg);--type-button-size: var(--font-size-sm);--type-button-weight: var(--font-weight-bold);--type-card-title-size: var(--font-size-base-lg);--type-label-size: var(--font-size-xs)}}@media(max-width:480px){:root{--type-page-title-size: var(--font-size-2xl);--type-section-subtitle-size: var(--font-size-base);--type-section-page-title-size: var(--font-size-xl-lg);--type-section-text-size: var(--font-size-sm);--type-badge-size: var(--font-size-xs)}}:root{--bp-mobile: 480px;--bp-tablet: 768px;--bp-desktop: 1200px;--nav-height: 88px;--section-spacing: 7.5rem;--nav-section-spacing: 1rem;--page-margin: 10rem;--nav-margin: 3rem;--grid-gutter: 2rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-xxl: 3rem}.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--grid-gutter)}.section{padding-block:var(--section-spacing)}.nav-section{padding-block:var(--nav-section-spacing)}.page-margin{margin-inline:var(--page-margin)}.nav-page-margin{margin-inline:var(--nav-margin)}@media(min-width:1700px){:root{--page-margin: 20rem}}@media(max-width:1024px){:root{--page-margin: 5rem;--nav-margin: 2rem;--grid-gutter: 2rem}.grid{grid-template-columns:repeat(8,1fr)}}@media(max-width:768px){:root{--section-spacing: 5rem}}@media(max-width:480px){:root{--nav-height: 72px;--section-spacing: 4rem;--page-margin: 1.5rem;--nav-margin: 1.5rem;--grid-gutter: 1rem}.grid{grid-template-columns:repeat(4,1fr)}}:root{--radius-xs: 6px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-pill: 999px;--surface-card: 0 4px 10px rgba(15, 23, 42, .06), inset 0 1px 0 rgba(255, 255, 255, .65);--surface-icon: 0 2px 6px rgba(15, 23, 42, .04), inset 0 1px 0 rgba(255, 255, 255, .8), inset 0 -1px 0 rgba(15, 23, 42, .03);--surface-icon-wrapper: 0 8px 18px rgba(15, 23, 42, .1), inset 0 1px 0 rgba(255, 255, 255, .8), inset 0 -1px 0 rgba(15, 23, 42, .04);--surface-header: 0 1px 0 var(--color-border), 0 2px 6px rgba(15, 23, 42, .04)}body{background:var(--color-background);color:var(--color-text);font-family:var(--font-portfolio),serif;min-height:100vh;overflow-x:hidden}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media(hover:hover)and (pointer:fine){.interactive-lift:hover{transform:translateY(-2px);cursor:pointer}.interactive-text:hover{color:var(--color-interactive-hover);cursor:pointer}.interactive-surface:hover{background-color:var(--color-interactive-hover);cursor:pointer}}.site-header{position:sticky;z-index:100;top:0;background:var(--color-background);border-bottom:2px solid var(--color-border)}.site-main{background:var(--color-background)}.nav-container{grid-column:1/-1;display:flex;justify-content:space-between}.nav-brand{display:flex;align-items:center;gap:var(--space-md);transition:color .2s ease}.nav-name-full{white-space:nowrap;transition:color .2s ease}.nav-name-full{white-space:nowrap}.nav-logo-mark{width:36px;height:36px;background-color:var(--color-surface);border-radius:var(--radius-sm);box-shadow:var(--surface-icon-wrapper);font-weight:var(--font-weight-bold);font-size:var(--font-size-md);color:var(--color-accent);display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.nav-divider{width:2px;height:100%;background-color:var(--color-border)}.nav-overlay{z-index:90;position:fixed;inset:0;opacity:0;transition:opacity .2s ease-in-out;pointer-events:none}.nav-overlay.open{opacity:1;pointer-events:auto}.projects-nav{position:relative}.nav-menu-button{transition:color .2s ease}.nav-menu-button-mobile{display:none}.nav-menu-button-desktop-container{display:flex}@media(hover:hover)and (pointer:fine){.nav-brand:hover>.nav-name-full,.nav-menu-button:hover{color:var(--color-hover-text)}.nav-brand:hover>.nav-logo-mark{background-color:var(--color-accent-soft)}}@media(max-width:600px){.nav-menu-button-mobile{display:block}.nav-menu-button-desktop-container{display:none}.nav-logo-mark{width:32px;height:32px}.nav-subtitle,.nav-divider{display:none}}.desktop-nav-menu{z-index:100;position:absolute;right:10px;min-width:420px;max-height:calc(100dvh - (var(--space-xl) * 2));padding:var(--space-md);overflow:hidden;overflow-y:auto;background-color:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--surface-card);opacity:0;display:flex;pointer-events:none;flex-direction:column;gap:var(--space-sm);overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;transition:opacity .3s ease-in-out}.desktop-nav-divider{flex-shrink:0;width:100%;height:1px;background-color:var(--color-border)}.desktop-nav-section{display:flex;flex-direction:column}.desktop-nav-menu.is-open{opacity:1;pointer-events:auto}.desktop-nav-section-button{all:unset;width:100%;display:block;cursor:pointer}.desktop-nav-submenu{position:relative;min-height:0;max-height:0;padding:0 var(--space-md);overflow:hidden;background:var(--color-subsurface);border-radius:var(--radius-md);display:flex;flex-direction:column;transition:max-height .3s ease-in-out}.desktop-nav-submenu.is-open{max-height:1000px}.desktop-nav-submenu:before{content:"";position:absolute;inset:0;border:1px solid var(--color-border);border-radius:var(--radius-md);opacity:0;transition:opacity .6s ease-in-out}.desktop-nav-submenu.is-open:before{opacity:1}.desktop-nav-submenu>li{position:relative}.desktop-nav-submenu>li:not(:last-child):after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background-color:var(--color-border)}@media(hover:hover)and (pointer:fine){.desktop-nav-link:hover .nav-menu-item-title{color:var(--color-hover-text)}.desktop-nav-link:hover .nav-menu-item-trailing-icon{transform:translate(4px)}}.nav-menu-item{position:relative;padding:var(--space-md) 0;display:flex;align-items:center;gap:var(--space-md)}.nav-menu-item-icon{flex:0 0 48px;width:48px;height:48px;background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-accent);display:flex;align-items:center;justify-content:center}.nav-menu-item-content{flex:1;display:flex;flex-direction:column}.nav-menu-item-trailing-icon{margin-right:var(--space-sm);transition:transform .3s ease}.nav-menu-item-trailing-icon.open{transform:rotate(90deg)}.mobile-nav-menu{z-index:100;position:fixed;max-height:calc(100dvh - (var(--page-margin) * 2));padding:var(--space-md);overflow:hidden;background-color:var(--color-surface);box-shadow:var(--surface-card);bottom:var(--page-margin);left:var(--page-margin);right:var(--page-margin);border-radius:var(--radius-md);transform:translateY(calc(100% + var(--page-margin)));display:flex;flex-direction:column;gap:var(--space-sm);overflow-y:auto;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;transition:transform .3s ease-in-out}.mobile-nav-menu.is-open{transform:translateY(0)}.mobile-nav-section{display:flex;flex-direction:column}.mobile-nav-submenu{position:relative;min-height:0;max-height:0;padding:0 var(--space-md);overflow:hidden;background:var(--color-subsurface);border-radius:var(--radius-md);display:flex;flex-direction:column;transition:max-height .3s ease-in-out}.mobile-nav-submenu.is-open{max-height:1000px}.mobile-nav-submenu:before{content:"";position:absolute;inset:0;border:1px solid var(--color-border);border-radius:var(--radius-md);opacity:0;transition:opacity .6s ease-in-out}.mobile-nav-submenu.is-open:before{opacity:1}.mobile-nav-submenu>li{position:relative}.mobile-nav-submenu>li:not(:last-child):after{content:"";position:absolute;width:100%;height:1px;bottom:0;background-color:var(--color-border)}.mobile-nav-divider{flex-shrink:0;width:100%;height:1px;background-color:var(--color-border)}.mobile-nav-section-button{all:unset;width:100%;display:block;cursor:pointer}.mobile-nav-grab-handle-button{all:unset;padding-block:var(--space-sm);display:flex;justify-content:center;cursor:pointer}.mobile-nav-grab-handle{width:30px;height:4px;background:var(--color-accent);border-radius:999px}.mobile-nav-link{transition:color .2s ease}@media(hover:hover)and (pointer:fine){.mobile-nav-link:hover .nav-menu-item-title{color:var(--color-hover-text)}.mobile-nav-link:hover .nav-menu-item-trailing-icon{transform:translate(4px)}}.footer-section{padding-block:1rem;background:var(--color-background);box-shadow:var(--surface-card);color:var(--color-text)}.footer-content{grid-column:1/-1;display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.footer-icon{width:28px;height:28px;color:var(--color-accent)}.footer-email{transition:color .2s ease}@media(hover:hover)and (pointer:fine){.footer-email:hover{color:var(--color-accent-hover)}}.hero-section{position:relative;min-height:100vh;padding-top:var(--space-xxl);padding-bottom:var(--section-spacing)}.hero-intro-wrapper,.hero-links-wrapper{grid-column:1 / 7}.hero-code-editor-wrapper{grid-column:7/-1;grid-row:1/3;display:flex;align-items:center}@media(max-width:1150px){.hero-intro-wrapper,.hero-links-wrapper{grid-column:1 / -1}.hero-code-editor-wrapper{grid-column:1/-1;grid-row:auto}}@media(max-width:768px){.hero-section{padding-top:var(--space-xl)}.hero-code-editor-body{font-size:var(--font-size-xs)}}@media(max-width:480px){.hero-section{padding-top:var(--space-lg)}}.hero-intro{z-index:10;display:flex;flex-direction:column;gap:var(--space-md)}.hero-intro-title{display:flex;flex-direction:column}.hero-intro-line{white-space:nowrap}.hero-intro-name{color:var(--color-accent)}.hero-intro-description{max-width:50ch}.hero-code-editor{width:100%;max-width:640px;min-width:500px;background-color:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--surface-card);overflow:hidden;display:flex;flex-direction:column}.hero-code-editor-title{display:flex;align-items:center;gap:var(--space-sm)}.hero-code-editor-title-text{font-weight:var(--font-weight-medium)}.hero-code-editor-body{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium );font-family:JetBrains Mono,monospace;overflow:auto;scrollbar-color:var(--color-border) transparent;scrollbar-width:thin;display:flex;align-items:stretch}.code-cursor{display:inline-block;width:2px;height:1em;margin-left:.15em;background:var(--color-accent);vertical-align:-2px;animation:blink 1s steps(1) infinite}@keyframes blink{50%{opacity:0}}.hero-code-editor-code{flex:0 0 auto;padding:var(--space-sm) var(--space-md);min-width:max-content;margin:0}.hero-code-editor-title-logo{width:32px;height:32px;padding:var(--space-xs);background-color:var(--color-accent);border-radius:var(--radius-sm);color:var(--color-surface);display:flex;align-items:center;justify-content:center}.hero-code-editor-titlebar{padding:var(--space-md);border-bottom:1px solid var(--color-border);font-weight:var(--font-weight-semibold);display:flex;align-items:center;justify-content:space-between}.hero-code-editor-sidebar{padding:var(--space-sm) var(--space-md);color:var(--color-text-subtle);display:flex;flex-direction:column}.hero-code-editor-dots{display:flex;gap:var(--space-sm)}.hero-code-editor-dot{width:12px;height:12px;border-radius:50%}.hero-code-editor-dot.red{background-color:var(--mac-red)}.hero-code-editor-dot.yellow{background-color:var(--mac-yellow)}.hero-code-editor-dot.green{background-color:var(--mac-green)}.code-editor-comment{color:var(--code-comment)}.code-editor-punctuation{color:var(--code-punctuation)}.code-editor-component{color:var(--code-component)}.code-editor-key{color:var(--code-key)}.code-editor-value{color:var(--code-value)}.code-editor-function{color:var(--code-function)}.code-editor-keyword{color:var(--code-keyword)}@media(max-width:768px){.hero-code-editor{aspect-ratio:4/3;min-width:0}}.hero-links{display:flex;flex-wrap:wrap;gap:var(--space-md);z-index:10}.hero-link{padding:var(--space-md);width:fit-content;height:fit-content;border-radius:var(--radius-md);box-shadow:var(--surface-icon-wrapper);background-color:var(--portfolio-color-surface);display:flex;align-items:center;justify-content:center;gap:var(--space-sm);transition:background-color .2s ease}.hero-link-icon{flex-shrink:0;width:28px;height:28px}.hero-link-label{align-self:center}@media(hover:hover)and (pointer:fine){.hero-link:hover{background-color:var(--color-accent-soft)}}.projects-section-header,.projects-section-carousel{grid-column:1/-1}.projects-section-track{display:grid;grid-auto-flow:column;grid-auto-columns:300px;gap:var(--space-sm)}.project-card{height:100%;overflow:hidden;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--surface-card);user-select:none;-webkit-user-select:none;-moz-user-select:none;display:flex;flex-direction:column;transition:transform .2s ease-in-out;cursor:pointer;scroll-snap-align:start;scroll-margin-left:var(--space-sm)}.project-card-top{width:100%;aspect-ratio:16 / 9;overflow:hidden}.project-card-image{width:100%;height:100%;object-position:top}.project-card-badges{padding:var(--space-md);border-top:1px solid var(--color-border);display:flex;gap:var(--space-md)}.project-card-badge-icon{width:28px;height:28px}.project-card-type{align-self:flex-start;padding:var(--space-xs) var(--space-md);background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-pill)}.project-card-body{flex:1;padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}@media(hover:hover)and (pointer:fine){.project-card:hover{transform:translateY(-4px)}}.sliding-carousel{position:relative}.sliding-carousel-viewport{border-right:2px solid var(--color-border);border-left:2px solid var(--color-border)}.sliding-carousel-track{padding:var(--space-sm);overflow-x:auto;scrollbar-width:none;scroll-behavior:smooth;scroll-snap-type:x mandatory;--webkit-overflow-scrolling: touch}.sliding-carousel-track::-webkit-scrollbar{display:none}.sliding-carousel-button{height:42px;width:42px;border-radius:50%;cursor:pointer;color:var(--color-accent);font-size:var(--font-size-2xl);background:var(--color-surface);box-shadow:var(--surface-icon-wrapper);position:absolute;top:50%;transform:translateY(-50%);transition:background .2s ease-in-out,opacity .2s ease-in-out;display:flex;align-items:center;justify-content:center}.sliding-carousel-button:disabled{cursor:default;opacity:0}.sliding-carousel-button-left{left:-50px}.sliding-carousel-button-right{right:-50px}.sliding-carousel-icon{height:32px;width:32px}.sliding-carousel-icon-left{transform:rotate(180deg)}@media(hover:hover)and (pointer:fine){.sliding-carousel-button:not(:disabled){opacity:1}.sliding-carousel-button:hover{background:var(--color-accent-soft)}}@media(max-width:480px){.sliding-carousel-button{display:none}}.section-header{display:flex;flex-direction:column;gap:var(--space-md)}.section-header-heading{line-height:1;display:flex;flex-direction:column;gap:var(--space-xs)}.section-header-divider{width:48px;height:5px;background:var(--color-accent);border-radius:10px}.section-header-description{max-width:50ch}.about-intro{grid-column:1 / 7;grid-row:1 / 3;display:flex;flex-direction:column;gap:var(--space-lg)}.about-profile{max-width:700px;grid-column:7 / -1}.about-highlights{grid-column:7 / -1;height:100%;display:flex;flex-direction:column;gap:var(--space-md)}.about-highlights>li{flex:1;display:flex}.about-divider{width:100%;height:2px;background-color:var(--color-border)}.about-description{display:flex;flex-direction:column;gap:var(--space-md)}.about-text-emphasis{font-weight:var(--font-weight-bold);color:var(--color-text)}@media(max-width:1200px){.about-intro{grid-column:1 / -1}.about-profile{grid-column:1 / 7;width:100%}.about-highlights{grid-column:7 / -1}}@media(max-width:1024px){.about-profile{grid-column:1 / 5}.about-highlights{grid-column:5 / -1}}@media(max-width:900px){.about-profile{grid-column:1 / -1;justify-self:flex-start}.about-highlights{grid-column:1 / -1;flex-direction:column}}.about-highlight-card{flex:1;padding:var(--space-md);background-color:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--surface-card);display:flex;gap:var(--space-md);text-align:center}.about-highlight-card-content{display:flex;flex-direction:column;gap:var(--space-xs);text-align:left}.about-highlight-card-icon-wrapper{flex-shrink:0;width:50px;height:50px;border-radius:50%;border:1px solid var(--color-border);background-color:var(--color-subsurface);display:flex;align-items:center;justify-content:center}.about-highlight-card-icon{width:28px;height:28px;color:var(--color-accent)}.about-profile-card{padding:var(--space-lg);height:100%;box-shadow:var(--surface-card);background-color:var(--color-surface);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-md)}.about-profile-avatar-icon{flex-shrink:0;align-self:center;width:64px;height:64px;color:var(--color-accent)}.about-profile-list{display:flex;flex-direction:column;gap:var(--space-md)}.about-profile-list>li:not(:last-child){padding-bottom:var(--space-md);border-bottom:2px solid var(--color-border)}.about-profile-item{display:flex;gap:var(--space-md)}.about-profile-item-icon-wrapper{flex-shrink:0;width:50px;height:50px;border:1px solid var(--color-border);background-color:var(--color-subsurface);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.about-profile-item-icon{width:28px;height:28px;color:var(--color-accent)}.stack-section-header,.stack-section-carousel{grid-column:1/-1}.stack-section-track{display:grid;grid-auto-flow:column;grid-auto-columns:auto;gap:var(--space-sm)}.stack-card{min-width:180px;min-height:200px;height:100%;padding:var(--space-md);background-color:var(--color-surface);box-shadow:var(--surface-icon);border-radius:var(--radius-md);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--space-md);text-align:center;scroll-snap-align:start;scroll-margin-left:var(--space-sm)}.stack-card-image-container{padding:var(--space-md);background-color:var(--color-background);border-radius:var(--radius-md);box-shadow:var(--surface-icon-wrapper)}.stack-card-image{width:48px;height:48px}.stack-card-type{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-pill);box-shadow:var(--surface-icon-wrapper)}.section-divider{display:block;position:relative;border:none;height:2px;width:100%;margin:0;background:var(--color-border)}.section-divider-dot{width:30px;height:5px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-accent);border-radius:var(--radius-sm);z-index:1}.project-hero-left-side{grid-column:1 / 7}.project-hero-right-side{grid-column:7 / -1;display:flex;flex-direction:column;gap:var(--space-lg)}.project-hero-section{padding-top:var(--space-xxl);padding-bottom:var(--section-spacing)}@media(max-width:1250px){.project-hero-right-side,.project-hero-left-side{grid-column:1 / -1}}@media(max-width:768px){.project-hero-section{padding-top:var(--space-xl)}}@media(max-width:480px){.project-hero-section{padding-top:var(--space-lg)}}.project-hero-intro{display:flex;flex-direction:column;gap:var(--space-lg)}.project-hero-back-link{display:flex;gap:var(--space-xs);align-items:center}.project-hero-back-link-text{transition:color .2s ease-in-out}.project-hero-back-icon{color:var(--color-accent);transition:transform .2s ease-in-out}.project-hero-heading{display:flex;flex-direction:column;gap:var(--space-md)}.project-hero-type{align-self:flex-start;padding:var(--space-sm) var(--space-md);background-color:var(--color-subsurface);border-radius:var(--radius-pill);box-shadow:var(--surface-icon-wrapper);color:var(--color-text-muted)}.project-hero-description{display:flex;flex-direction:column;gap:var(--space-md)}@media(hover:hover)and (pointer:fine){.project-hero-back-link:hover .project-hero-back-link-text{color:var(--color-hover-text)}.project-hero-back-link:hover .project-hero-back-icon{transform:translate(-4px)}}.project-quick-links{display:flex;flex-direction:column;gap:var(--space-md)}.project-quick-links-header{display:flex;gap:var(--space-sm);align-items:center}.project-quick-links-icon-wrapper{padding:var(--space-xs);background-color:var(--color-subsurface);border:1px solid var(--color-border);border-radius:var(--radius-xs);color:var(--color-accent)}.project-hero-links-icon{width:20px;height:20px}.project-quick-links-list{display:flex;flex-wrap:wrap;gap:var(--space-md)}.project-quick-links-divider{width:100%;height:2px;background-color:var(--color-border)}.project-quick-link{width:fit-content;height:fit-content;padding:var(--space-md);background:var(--color-surface);border-radius:var(--radius-sm);box-shadow:var(--surface-icon-wrapper);display:flex;align-items:center;gap:var(--space-md);transition:background-color .2s ease}.project-quick-link-arrow-icon{margin-left:auto}.project-quick-link-icon{border-radius:50%;transition:color .2s ease,transform .2s ease}@media(hover:hover)and (pointer:fine){.project-quick-link:hover{background-color:var(--color-accent-soft)}}.project-technologies{display:flex;flex-direction:column;gap:var(--space-md)}.project-technologies-header{display:flex;gap:var(--space-sm);align-items:center}.project-technologies-icon-wrapper{flex-shrink:0;padding:var(--space-xs);background-color:var(--color-subsurface);border:1px solid var(--color-border);border-radius:var(--radius-xs);color:var(--color-accent)}.project-hero-technologies-icon{width:20px;height:20px}.project-technologies-badge-list{display:flex;flex-wrap:wrap;gap:var(--space-md)}.project-technologies-badge{padding:var(--space-sm);width:120px;background-color:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--surface-icon-wrapper);display:flex;flex-direction:column;align-items:center}.project-technologies-badge-wrapper{padding:var(--space-sm);border-radius:var(--radius-md)}.project-technologies-badge-wrapper>img{width:48px;height:48px}.project-screenshot-section-header,.project-screenshot-section-carousel-wrapper{grid-column:1 / -1}@media(max-width:768px){.project-screenshot-section-carousel-wrapper{margin-inline:16px}}@media(max-width:480px){.project-screenshot-section-carousel-wrapper{margin-inline:12px}}.project-screenshot-carousel{position:relative;max-width:1100px;display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.project-screenshot-carousel-button{position:absolute;top:45%;width:56px;height:56px;background:var(--color-surface);border-radius:50%;box-shadow:var(--surface-icon-wrapper);display:grid;place-items:center;transform:translateY(-50%);transition:background-color .2s ease-in-out;cursor:pointer}.project-screenshot-carousel-previous-button{left:-28px}.project-screenshot-carousel-next-button{right:-28px}.project-screenshot-carousel-icon{width:40px;height:40px;color:var(--color-accent);font-weight:var(--font-weight-semibold);stroke-width:2.4}.project-screenshot-carousel-dots{display:flex;gap:var(--space-md)}.project-screenshot-carousel-dot{width:12px;height:12px;background-color:var(--color-border);border-radius:9999px}.project-screenshot-carousel-dot.active{background-color:var(--color-accent)}@media(hover:hover)and (pointer:fine){.project-screenshot-carousel-button:hover{background:var(--color-accent-soft)}}@media(max-width:1024px){.project-screenshot-carousel{width:100%}}@media(max-width:768px){.project-screenshot-carousel-button{height:40px;width:40px}.project-screenshot-carousel-icon{height:30px;width:30px}.project-screenshot-carousel-previous-button{left:24px}.project-screenshot-carousel-next-button{right:24px}}@media(max-width:480px){.project-screenshot-carousel-button{height:34px;width:34px}.project-screenshot-carousel-icon{height:24px;width:24px}}.project-screenshot-slide{width:100%;overflow:hidden;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--surface-card);display:flex;flex-direction:column}.project-screenshot-details{width:100%;padding:var(--space-md);display:flex;align-items:center;gap:var(--space-md)}.project-screenshot-icon-wrapper{width:50px;height:50px;flex-shrink:0;background-color:var(--color-subsurface);border:1px solid var(--color-border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.project-screenshot-icon{width:28px;height:28px;color:var(--color-accent)}.project-screenshot-text{flex:1;min-width:0;display:flex;flex-direction:column}.project-screenshot-title,.project-screenshot-description{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-screenshot-counter{min-width:60px;margin-left:auto;padding:var(--space-xs);background-color:var(--color-subsurface);border:1px solid var(--color-border);border-radius:var(--radius-pill);display:flex;align-items:center;justify-content:center}@media(max-width:768px){.project-screenshot-icon-wrapper{width:40px;height:40px;border-radius:var(--radius-sm)}.project-screenshot-icon{width:20px;height:20px}.project-screenshot-title{font-size:var(--font-size-base)}}@media(max-width:600px){.project-screenshot-details{padding:var(--space-sm)}}.project-screenshot-card{width:100%;aspect-ratio:16/9;overflow:hidden}.project-screenshot-card img{width:100%;height:100%;object-fit:cover;object-position:top}.project-features-section-header,.project-features-section-features-wrapper{grid-column:1/-1}.project-features-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-md)}.project-features-list>li{height:100%}@media(max-width:768px){.project-features-list{grid-template-columns:1fr}}.project-feature-card{height:100%;background-color:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--surface-card);display:flex;padding:var(--space-md);gap:var(--space-md)}.project-feature-card-icon-wrapper{flex-shrink:0;width:72px;height:72px;background-color:var(--color-subsurface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.project-feature-card-icon{width:32px;height:32px;color:var(--color-accent)}.project-feature-card-content{display:flex;flex-direction:column;gap:var(--space-xs)}@media(max-width:1200px){.project-feature-card-icon-wrapper{width:64px;height:64px}.project-feature-card-icon{width:28px;height:28px}.project-feature-card-title{font-size:var(--font-size-base-lg)}}@media(max-width:480px){.project-feature-card-icon-wrapper{width:50px;height:50px;border-radius:var(--radius-sm)}.project-feature-card-icon{width:24px;height:24px}.project-feature-card-title{font-size:var(--font-size-base)}}.word-search-page{display:flex;flex-direction:column}.word-search-game{display:flex;align-content:center;justify-content:center;padding:20px 10px}.word-search-game-card{display:flex;flex-direction:column;width:min(600px,100%)}.word-search-game-header{width:100%;margin-bottom:var(--space-md);padding:var(--space-sm)}.word-search-board-wrapper{grid-area:board;width:100%;border:1px solid var(--color-border);background-color:var(--color-surface);margin-bottom:var(--space-md);border-radius:var(--radius-sm);cursor:pointer}.word-search-board{touch-action:none}.word-search-title{font-size:var(--font-size-md)}.word-search-progress{font-size:var(--font-size-sm);color:var(--color-text-subtle)}.word-search-word-list{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);color:var(--color-text-muted);font-size:var(--font-size-sm)}.word-search-word-list-item{transition:color .25s ease,opacity .25s ease}.word-search-word-check{opacity:0;padding:var(--space-sm);transition:opacity .25s ease}.found{color:var(--color-text)}.word-search-word-list-item.found-item .word-search-word-check{opacity:1}.word-search-word-list-item .found{color:var(--color-text-subtle);text-decoration:line-through}@media(max-width:768px){.word-search-word-list{grid-template-columns:repeat(3,1fr)}}.word-search-dropdown-select{position:relative;flex:1;display:flex;cursor:pointer}.word-search-dropdown-select:before{content:"";position:absolute;bottom:0;left:0;height:2px;width:100%;transform:scaleX(0);transform-origin:left;background-color:var(--color-border);text-decoration:none;transition:transform .2s ease}.word-search-dropdown-select:hover:before{transform:scaleX(1)}.word-search-dropdown-arrow{opacity:0;transition:opacity .3s ease-in-out}.word-search-dropdown-arrow.visible{opacity:1}.word-search-dropdown-button{cursor:pointer;font-size:var(--font-size-xl);font-weight:var(--font-weight-regular);overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.word-search-dropdown-button:hover .word-search-dropdown-arrow{opacity:1}.word-search-dropdown-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.word-search-dropdown-overlay{position:fixed;inset:0;z-index:9}.word-search-dropdown-menu{font-size:var(--font-size-sm);pointer-events:none;opacity:0;border-bottom-left-radius:var(--radius-sm);border-bottom-right-radius:var(--radius-sm);position:absolute;transition:opacity .3s ease-in-out;top:100%;left:0;z-index:10;border:1px solid var(--color-border);width:100%;background:var(--color-surface);overflow:hidden;color:var(--color-text-muted);display:flex;flex-direction:column}.word-search-dropdown-menu.open{pointer-events:auto;opacity:1}.word-search-dropdown-option{width:100%;text-align:left;padding:var(--space-sm)}.word-search-dropdown-option:hover{background:var(--color-border)}.word-search-dropdown-option.selected{border:1px solid var(--color-text)}.word-search-dropdown-menu li:last-child .word-search-dropdown-option.selected{border-bottom-left-radius:var(--radius-sm);border-bottom-right-radius:var(--radius-sm)}@media(max-width:768px){.word-search-dropdown-select{flex:1 1 0;min-width:0}}.game-toolbar{padding-top:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}.game-toolbar-content{margin-left:var(--nav-margin);margin-right:var(--nav-margin);display:flex;justify-content:space-between}.game-toolbar-actions{display:flex;gap:var(--space-md)}.game-toolbar-link,.game-toolbar-button{transition:color .2s ease}.game-toolbar-link:hover,.game-toolbar-button:hover{text-decoration:none;color:var(--color-text-subtle)}.uno-game-page{position:relative;min-height:100vh;display:flex;flex-direction:column;--uno-card-width: 80px;--uno-card-height: 100px;--uno-card-gap: var(--space-sm);--uno-card-gap-center: var(--space-md);--uno-card-font-size: var(--font-size-lg);--uno-player-font-size: var(--font-size-base);--uno-opponents-grid-columns: repeat(4, auto);--uno-opponent-badge-width: 100px;--uno-opponent-columns: 4}@media(max-width:768px){.uno-game-page{--uno-card-width: 60px;--uno-card-height: 80px;--uno-card-gap: var(--space-xs);--uno-card-gap-center: var(--space-sm);--uno-card-font-size: var(--font-size-md);--uno-card-font-size-corner: var(--font-size-sm);--uno-player-font-size: var(--font-size-sm);--uno-opponents-grid-columns: repeat(2, auto);--uno-opponent-columns: 2}}@media(max-width:480px){.uno-game-page{--uno-card-width: 46px;--uno-card-height: 58px;--uno-card-font-size: var(--font-size-sm);--uno-card-font-size-corner: var(--font-size-xs)}}.center-area{position:relative;display:flex;justify-content:center;gap:var(--uno-card-gap-center)}.uno-discard-pile{display:flex;flex-direction:column;position:relative;justify-content:center}.uno-card-face{width:var(--uno-card-width);height:var(--uno-card-height);border-radius:3px;border:var(--color-border) 1px solid;transition:transform .2s ease-in-out;position:relative;font-weight:700;user-select:none;-webkit-user-select:none;font-family:Rubik,Arial Rounded MT Bold,Trebuchet MS,Arial,sans-serif;display:flex;align-items:center;justify-content:center;text-align:center}.uno-card-center-value{font-size:var(--uno-card-font-size);-webkit-user-select:none;user-select:none}.uno-card-top-value{position:absolute;top:0;left:8px;font-size:var(--uno-card-font-size-corner);opacity:.5}.uno-card-bottom-value{position:absolute;bottom:0;right:8px;font-size:var(--uno-card-font-size-corner);opacity:.5}.uno-card-face.red{background-color:var(--game-accent-red)}.uno-card-face.blue{background-color:var(--game-accent-blue)}.uno-card-face.green{background-color:var(--game-accent-green)}.uno-card-face.yellow{background-color:var(--game-accent-yellow)}.uno-card-face.wild{background:var(--game-accent-rainbow)}@media(max-width:480px){.uno-card-bottom-value,.uno-card-top-value{display:none}}.uno-draw-pile{display:flex;flex-direction:column;align-items:center;position:relative;justify-content:center}.uno-draw-pile-card{width:var(--uno-card-width);height:var(--uno-card-height);border:var(--color-border) 1px solid;background-color:var(--color-surface);border-radius:3px;transition:transform .2s ease-in-out;transform-style:preserve-3d;cursor:pointer}.uno-draw-pile-card:hover{transform:translateY(-4px)}.action-area{position:absolute;top:50%;left:50%;transform:translate(calc(var(--uno-card-width) + 32px),-50%);z-index:1000}.action-area-message{animation:float-up 1.8s ease-in-out 1 forwards;font-weight:var(--font-weight-semibold)}.action-color.red{color:var(--game-accent-red)}.action-color.blue{color:var(--game-accent-blue)}.action-color.green{color:var(--game-accent-green)}.action-color.yellow{color:var(--game-accent-yellow)}@keyframes float-up{0%{transform:translateY(8px);opacity:0}15%{opacity:1}80%{opacity:1}to{transform:translateY(-30px);opacity:0}}.opponent-area-wrapper{display:flex;justify-content:center}.opponent-area{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-xl);margin-top:var(--space-xxl);width:calc((var(--uno-opponent-badge-width) * var(--uno-opponent-columns)) + (var(--space-xl) * (var(--uno-opponent-columns) - 1)))}.uno-player-badge{display:flex;background:transparent;flex-direction:column;width:var(--uno-opponent-badge-width);font-size:var(--uno-player-font-size);color:var(--color-text-muted);transition:transform .2s ease-in-out;align-items:flex-start;gap:5px;position:relative}.uno-player-label{white-space:nowrap;font-weight:700;width:100%;padding:10px;border-radius:3px;background:var(--color-surface);border:1px solid var(--color-border);letter-spacing:.02em;min-width:80px;text-align:center;transition:transform .2s ease-in-out,border .2s ease-in-out;cursor:default;position:relative;overflow:hidden;opacity:.8}.uno-player-label-text{position:relative;z-index:1}.uno-player-card-count{display:flex;gap:2px;align-items:center;position:relative}.uno-player-action-text{animation:float-up-player 1.4s ease-in-out 1 forwards;position:absolute;bottom:0;font-size:16px;pointer-events:none;width:100%;text-align:center;font-weight:var(--font-weight-semibold)}.uno-player-card-count-label{font-size:var(--uno-player-font-size);opacity:.6;position:absolute;left:100%;margin-left:6px}.uno-player-card-count-card{width:10px;height:18px;background-color:var(--color-border);border-radius:1px}.uno-player-label.uno-player-badge-has-action{animation:pulse-white 1s ease-in-out infinite}.uno-player-label.uno-player-badge-has-countdown:hover,.uno-player-label.uno-player-badge-has-action:hover{cursor:pointer;animation:none;transition:border .2s ease-in-out;border:var(--color-text-muted) 1px solid}.uno-player-label.uno-player-badge-has-countdown:before{content:"";position:absolute;background:var(--color-border);inset:0;z-index:0;transform-origin:left;animation:uno-countdown-drain 2s linear forwards}@keyframes pulse-white{0%{border:var(--color-border) 1px solid}50%{border:var(--color-text-muted) 1px solid}to{border:var(--color-border) 1px solid}}@keyframes float-up-player{0%{transform:translateY(8px);opacity:0}15%{opacity:1}80%{opacity:1}to{transform:translateY(-10px);opacity:0}}@keyframes uno-countdown-drain{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.uno-game-board{display:flex;flex-direction:column;width:100%;position:relative;gap:var(--space-xxl)}.uno-player-area{display:flex;flex-direction:column;align-items:center;gap:var(--space-xxl);padding-bottom:var(--space-xxl)}.uno-player-container{display:flex;gap:10px;width:100%;justify-content:center}.uno-player-hand{display:flex;width:calc(var(--uno-card-width) * 7 + var(--uno-card-gap) * 6);flex-wrap:wrap;gap:var(--uno-card-gap);align-content:start}.uno-hand-page-dots{display:flex;flex-direction:column;align-items:center;gap:10px}.uno-hand-page-dot{width:8px;height:8px;border-radius:50%;border:none;background:#ffffff4d;cursor:pointer}.uno-hand-page-dot.active{background:var(--color-text);box-shadow:0 0 8px #fffc,0 0 16px #fff6}.uno-hand-page-arrow{background:none;border:none;color:#ffffff80;font-size:1rem;line-height:1;padding:0;margin:0;cursor:pointer;transition:color .2s ease,transform .2s ease}.hand-page-arrow:hover:not(:disabled){color:#fff;transform:scale(1.1)}.hand-page-arrow:disabled{opacity:.15;cursor:default}@media(max-width:390px){.uno-player-hand{max-width:calc(100vw - 24px)}}.uno-hand-card{position:relative;-webkit-user-select:none;user-select:none;cursor:pointer}.uno-hand-card.uno-hand-card-is-hidden{opacity:0}.uno-hand-card.uno-hand-card-is-pending .uno-card-face{animation:pulse-white-card 1s infinite}@media(hover:hover)and (pointer:fine){.uno-hand-card .uno-card-face:hover{transform:translateY(-4px);transition:transform .2s ease-in-out}}.uno-hand-card.uno-hand-card-is-pending .uno-card-face:hover{border:var(--color-text) 1px solid;animation:none;transition:transform .2s ease-in-out}@keyframes pulse-white-card{0%{border:var(--color-border) 1px solid}50%{border:var(--color-text) 1px solid}to{border:var(--color-border) 1px solid}}.uno-flying-card{perspective:1000px;transform-style:preserve-3d;transform-origin:center center}.uno-flying-card-side{position:absolute;inset:0;backface-visibility:hidden}.uno-flying-card-side>*{width:100%;height:100%}.uno-flying-card-back{transform:rotateY(180deg)}.uno-card-face.uno-card-back{background-color:var(--color-surface)}.wild-color-modal{position:relative;display:flex;gap:10px}.wild-card{width:40px;height:50px;background-color:var(--color-surface);border:var(--color-border) 1px solid;border-radius:3px;opacity:0;animation:fadeIn .5s ease forwards;cursor:pointer}.wild-card:hover{transition:border .2s ease-in-out;border:var(--color-text) 1px solid}.wild-card.red{background-color:var(--game-accent-red)}.wild-card.blue{background-color:var(--game-accent-blue)}.wild-card.green{background-color:var(--game-accent-green)}.wild-card.yellow{background-color:var(--game-accent-yellow)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.current-player-dot{position:fixed;width:8px;height:8px;border-radius:50%;background:var(--color-text);box-shadow:0 0 8px #fffc,0 0 16px #fff6;pointer-events:none;transform:translate(-50%)}.uno-game-menu{display:flex;flex:1;justify-content:center;align-items:center}.uno-menu-content{display:flex;flex-direction:column;align-items:flex-start;gap:40px}.uno-game-title{font-size:32px}.uno-start-game-button{padding:10px;background-color:var(--color-surface);color:var(--color-text-muted);border:var(--color-border) 1px solid;transition:border .2s ease-in-out;cursor:pointer;font-size:16px;border-radius:3px;width:120px}.uno-start-game-button:hover{border:var(--color-text-muted) 1px solid}.uno-player-selection{display:flex;flex-direction:column;gap:10px}.uno-player-count-options{display:flex;position:relative}.uno-player-count{display:flex;flex-direction:column;align-items:center;width:48px;height:72px;border-radius:5px;gap:5px;justify-content:center;cursor:pointer}.uno-player-count:hover .uno-player-dot{background:var(--color-text);box-shadow:0 0 8px #fffc,0 0 16px #fff6}.uno-player-dot{width:8px;height:8px;border-radius:50%;border:none;background:#ffffff4d;cursor:pointer}.uno-player-dot.selected{background:var(--color-text);box-shadow:0 0 8px #fffc,0 0 16px #fff6}.uno-player-number,.uno-player-count-title{font-size:16px;color:var(--color-text-muted)}.corner{position:absolute;width:12px;height:2px;background-color:var(--color-border)}.corner.top-left{top:0;left:0}.corner.top-left:after{content:"";position:absolute;background-color:var(--color-border);height:12px;width:2px;top:0}.corner.top-right{top:0;right:0}.corner.top-right:after{content:"";position:absolute;background-color:var(--color-border);height:12px;width:2px;right:0}.corner.bottom-left{bottom:0;left:0}.corner.bottom-left:after{content:"";position:absolute;background-color:var(--color-border);height:12px;width:2px;bottom:0}.corner.bottom-right{bottom:0;right:0}.corner.bottom-right:after{content:"";position:absolute;background-color:var(--color-border);height:12px;width:2px;bottom:0;right:0}.uno-rules{border:1px solid var(--color-border);background:var(--color-background);font-weight:var(--font-weight-regular);border-radius:var(--radius-sm);width:100%;display:flex;flex-direction:column}.uno-rules-header{position:relative}.uno-rules-header,.uno-rules-section{padding:var(--space-md) var(--space-md);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);display:flex;flex-direction:column;gap:var(--space-md)}.uno-rules-section:last-child{border-bottom:none}.uno-rules-title{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.uno-gameplay-list{color:var(--color-text-muted)}.uno-gameplay-list li{padding-bottom:var(--space-sm);list-style-type:disc;list-style-position:inside}.uno-rules-title-secondary{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-muted)}.uno-action-rule-header{display:flex;align-items:flex-end;gap:var(--space-sm)}.uno-action-rule{padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-sm)}.uno-action-rule:last-child{border-bottom:none}.uno-action-rule-icon{display:inline-block;border:1px solid var(--color-text-subtle);width:32px;border-radius:2px;height:32px;padding:3px;text-align:center}.modal-backdrop{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:var(--padding-lg);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.modal-panel{max-width:calc(100vw - (2 * var(--padding-lg)));max-height:calc(100vh - (2 * var(--padding-lg)));overflow-y:auto;overflow-x:hidden;z-index:101;position:relative}.modal-panel::-webkit-scrollbar{width:8px}.modal-panel::-webkit-scrollbar-track{background:transparent}.modal-panel::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:999px}.modal-panel::-webkit-scrollbar-thumb:hover{background:var(--color-text-subtle)}.close-button{position:absolute;top:var(--padding-sm);right:var(--padding-sm);font-size:var(--font-size-lg);color:inherit;cursor:pointer;width:40px;height:40px;border-radius:var(--radius-sm);z-index:1;transition:background-color .2s ease,transform .2s ease}.close-button:hover{background:#0000000d}.game-over{width:min(400px,100%);background-color:var(--color-background);border:var(--color-border) 1px solid;box-shadow:var(--surface-card);border-radius:var(--radius-sm);margin-inline:auto;display:flex;flex-direction:column;justify-content:center;align-items:center}.game-menu-button{padding:10px;background-color:var(--color-surface);color:var(--color-text-muted);border:var(--color-border) 1px solid;transition:border .2s ease-in-out;cursor:pointer;font-size:16px;border-radius:3px;width:120px}.game-menu-button:hover{border:var(--color-text-muted) 1px solid}.game-over-header{width:100%;border-bottom:var(--color-border) 1px solid;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-lg)}.game-over-title{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.game-over-winner{color:var(--color-text-muted);font-size:var(--font-size-md)}.game-over-actions{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-lg)}.game-over-actions a{text-align:center}.game-over-actions a:hover{text-decoration:none}.game-layout{min-height:100vh}
