@import"https://fonts.googleapis.com/css2?family=Geist:wght@100..900&family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap";.liquid-ether-container{position:absolute!important;top:0;left:0;min-width:100vw!important;height:100vh;overflow:hidden}.liquid-ether-container canvas{position:absolute;width:100%!important;height:100%!important;display:block;-o-object-fit:cover;object-fit:cover;pointer-events:none}*{margin:0;padding:0;box-sizing:border-box}html,body{background-color:#000;color:#fff;font-family:Montserrat,sans-serif;width:100%;height:100vh;overflow-x:hidden}body{display:flex;justify-content:center;align-items:flex-start;overflow-y:auto;background-color:#000!important;scrollbar-width:none}.portfolio-container{display:flex;flex-direction:column;align-items:center;position:relative;width:100%;padding-top:100px;pointer-events:none}.content-container{display:flex;flex-direction:column;align-items:flex-start;position:relative;z-index:10}.header nav{display:flex;gap:16px;margin-bottom:48px}.header a{color:#fff;text-decoration:none;font-size:.9rem;opacity:.9;transition:opacity .2s}.header a:hover{opacity:1}.portfolio-title{font-size:1.4rem;font-weight:500;margin-bottom:16px}.portfolio-description{font-size:1rem;line-height:1.6;opacity:.9;margin-bottom:32px;letter-spacing:-.5px}.portfolio-posts p{font-size:.95rem;opacity:.9;margin:6px 0}.portfolio-links{display:flex;gap:16px;margin-top:28px;font-size:.8rem;pointer-events:all}.portfolio-links a{color:#fff;text-decoration:none;opacity:.85;transition:opacity .2s}.portfolio-links a:hover{opacity:1}.portfolio-footer{font-size:.7rem;opacity:.7;margin-top:48px}.date{opacity:.7}.hyperlink{color:#e8e9f9;text-decoration:none;opacity:1;transition:text-shadow .2s;cursor:pointer;pointer-events:all}.hyperlink:hover{text-shadow:#c8cae6 0px 0px 8px;text-decoration:underline}.projects-container{width:800px}.projects-grid{display:flex;flex-direction:column;gap:48px;margin-top:32px}.project-card{background:rgba(255,255,255,.02);border:1.5px solid rgba(255,255,255,.05);border-radius:12px;padding:24px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden;transition:all .3s ease}.project-card.clickable{cursor:pointer;pointer-events:all}.project-card.clickable:hover{background:rgba(255,255,255,.05);transform:scale(1.01);border-radius:40px}.project-image-placeholder{width:100%;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:24px;overflow:hidden}.placeholder-content{display:flex;flex-direction:column;align-items:center;gap:12px}.placeholder-icon{font-size:3rem}.placeholder-text{font-size:.9rem;letter-spacing:.5px}.project-content{display:flex;flex-direction:column;gap:20px}.project-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.project-title{font-size:1.3rem;font-weight:500;line-height:1.3}.project-date{font-size:.75rem;opacity:.6;white-space:nowrap;margin-top:4px}.project-description{font-size:.95rem;line-height:1.6;opacity:.85;letter-spacing:-.3px}.project-highlights{margin-top:8px}.highlights-title{font-size:.85rem;font-weight:500;margin-bottom:12px}.highlights-list{list-style:none;display:flex;flex-direction:column;gap:8px}.highlights-list li{font-size:.85rem;opacity:.8;position:relative;line-height:1.5}.project-tech{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.tech-tag{font-size:.7rem;padding:4px 12px;background:rgba(170,174,207,.1);border-radius:12px;opacity:.9}.read-more{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.05)}.read-more-text{font-size:.8rem;color:#aaaecf;opacity:.9;font-weight:500}.project-links{display:flex;gap:16px;margin-top:8px}.project-link{font-size:.8rem;color:#e8e9f9;text-decoration:none;opacity:.85;transition:opacity .2s,text-shadow .2s}.project-link:hover{opacity:1;text-shadow:#c8cae6 0px 0px 4px}.project-detail{max-width:800px;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.back-button{display:flex;align-items:center;gap:5px;color:#fff;font-size:1rem;cursor:pointer;transition:all .2s;margin-bottom:32px;letter-spacing:-.5px;pointer-events:all;width:100%;border-bottom:1.5px solid rgba(151,151,174,.2);padding-bottom:10px}.project-date-detail{font-size:.85rem;opacity:.6;display:block;margin-bottom:32px}.project-detail-image-placeholder{width:100%;border-radius:12px;display:flex;align-items:center;justify-content:center}.project-quick-info{margin-bottom:48px;padding-bottom:32px;border-bottom:2px solid rgba(255,255,255,.05)}.project-description-detail{font-size:1.15rem;line-height:1.7;opacity:.9;margin-bottom:32px}.project-tech-detail{margin-bottom:28px}.tech-title{font-size:.9rem;font-weight:500;margin-bottom:12px;color:#fff}.tech-tags-container{display:flex;flex-wrap:wrap;gap:8px}.project-highlights-detail{margin-bottom:28px}.project-highlights-detail .highlights-list li{font-size:.9rem}.project-links-detail{display:flex;gap:20px;margin-top:24px}.project-detail-sections{display:flex;flex-direction:column;gap:48px}.detail-section-title{font-size:1.25rem;font-weight:500;margin-bottom:10px;color:#e8e9f9;line-height:1.4;letter-spacing:-1px}.detail-section-content-hyperlink{font-size:1rem;line-height:1.8;margin-bottom:20px;letter-spacing:-.75px;color:#d8dcff;text-decoration:underline;cursor:pointer;pointer-events:all}.about-image-placeholder{width:300px;height:300px;display:flex;align-items:center;justify-content:center;margin:32px auto}.about-section{margin-bottom:40px}.section-title{font-size:1.2rem;font-weight:500;margin-bottom:16px;color:#e8e9f9}.section-text{font-size:.95rem;line-height:1.7;opacity:.85;margin-bottom:16px;letter-spacing:-.3px}.contact-link{font-size:.9rem;color:#e8e9f9;text-decoration:none;opacity:.85;transition:opacity .2s,text-shadow .2s;display:inline-block;width:-moz-fit-content;width:fit-content}.contact-link:hover{opacity:1;text-shadow:#c8cae6 0px 0px 4px}@media (max-width: 850px){.portfolio-container,.projects-container,.about-container,.project-detail{width:90%;max-width:720px}.detail-section{padding:24px}}@media (max-width: 600px){body{padding-top:40px}.portfolio-title{font-size:1.2rem}.portfolio-description{font-size:.9rem}.project-title,.section-title,.detail-section-title{font-size:1.1rem}.detail-section{padding:20px}.detail-section-content{font-size:.9rem}}.portfolio-wrapper{display:flex;align-items:center;justify-content:center;position:relative;min-width:100vw;color:#fff;background-color:#000}.pixel-canvas{position:fixed!important;top:0;left:0;width:100vw!important;height:100vh!important;pointer-events:auto!important;z-index:10;opacity:.5;mix-blend-mode:screen}.header-glass{transition:all .2s}.header-glass:hover{scale:1.15;border-radius:5px!important}.header-glass.active{scale:.9}.main-container{max-width:700px;margin-bottom:60px}.header{max-width:700px;pointer-events:all}.carousel-container{position:relative;display:flex;align-items:center;justify-content:center;gap:20px;margin:30px 0}.carousel-button{background:rgba(255,255,255,.05);color:#ffffffca;font-size:30px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0;pointer-events:all}.carousel-button:hover{background:rgba(255,255,255,.2);transform:scale(1.1)}.carousel-button:active{transform:scale(.95)}.carousel-button.prev{margin-right:10px}.carousel-button.next{margin-left:10px}.project-detail-image-placeholder{width:100%;max-width:800px;height:auto;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}.project-detail-image-placeholder img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;display:block}.project-detail-image-placeholder .placeholder-content{width:100%;display:flex;align-items:center;justify-content:center}.project-detail-image-placeholder .placeholder-text{font-size:24px;color:#ffffff80}.project-detail-sections{margin-top:40px}.detail-section{margin-bottom:0}.detail-section-title{font-size:28px;margin-bottom:24px;color:#fff}.detail-section-content{font-size:1rem;line-height:1.8;color:#ffffffbf;margin-bottom:20px;letter-spacing:-.75px}.detail-section-content-list{font-size:1rem;line-height:1.8;color:#ffffffd9;margin-bottom:7px;letter-spacing:-.75px;margin-left:30px}.detail-section-content:last-child{margin-bottom:0}.portfolio-intro-title{font-size:1.5rem;font-weight:600;margin-bottom:16px;letter-spacing:-1px}.image-caption{position:absolute;bottom:12px;left:0;text-align:center;font-size:.85rem;color:#ffffffd9;background:rgba(0,0,0,.4);padding:6px;border-top:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);letter-spacing:-.3px;margin:8px 8px 0;border-radius:6px;width:calc(100% - 16px)}.project-detail-image-placeholder{position:relative}.detail-section-subtitle{font-size:1.3rem;font-weight:500;margin-top:16px;margin-bottom:12px;color:#e8e9f9}.home-project-link:hover{text-decoration:underline;cursor:pointer}.home-project-link{pointer-events:all}*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}:root{--background: 0 0% 100%;--foreground: 0 0% 3.9%;--card: 0 0% 100%;--card-foreground: 0 0% 3.9%;--popover: 0 0% 100%;--popover-foreground: 0 0% 3.9%;--primary: 0 0% 9%;--primary-foreground: 0 0% 98%;--secondary: 0 0% 96.1%;--secondary-foreground: 0 0% 9%;--muted: 0 0% 96.1%;--muted-foreground: 0 0% 45.1%;--accent: 0 0% 96.1%;--accent-foreground: 0 0% 9%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 0 0% 98%;--border: 0 0% 89.8%;--input: 0 0% 89.8%;--ring: 0 0% 3.9%;--chart-1: 12 76% 61%;--chart-2: 173 58% 39%;--chart-3: 197 37% 24%;--chart-4: 43 74% 66%;--chart-5: 27 87% 67%;--radius: .5rem}*{border-color:hsl(var(--border))}body{background-color:hsl(var(--background));color:hsl(var(--foreground))}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.visible{visibility:visible}.invisible{visibility:hidden}.relative{position:relative}.block{display:block}.flex{display:flex}.hidden{display:none}.resize{resize:both}.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)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}.running{animation-play-state:running}:root{font-family:Montserrat,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#000;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;letter-spacing:-.7px}::-moz-selection{background-color:#ffffff4d;color:#fff}::selection{background-color:#ffffff4d;color:#fff}h1{font-size:3.2em;line-height:1.1}
