:root{--bg: #000000;--bg-elevated: #0a0a0a;--text: #ffffff;--text-secondary: #a0a0a0;--text-tertiary: #666666;--border: rgba(255, 255, 255, .08);--border-hover: rgba(255, 255, 255, .2);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--shape-color: #ffffff;--shape-line-color: #ffffff;--logo-shadow: drop-shadow(0 4px 16px rgba(255, 255, 255, .35)) drop-shadow(0 1px 4px rgba(255, 255, 255, .2));--card-hover-shadow: 0 8px 40px rgba(255, 255, 255, .03);--nav-bg: rgba(0, 0, 0, .85);--nav-shadow: 0 1px 20px rgba(0, 0, 0, .3);--mobile-menu-bg: rgba(0, 0, 0, .97);--selection-bg: rgba(255, 255, 255, .15);--hamburger-color: #ffffff;--heading-color: #ffffff;--heading-glow: 0 0 4px rgba(212, 175, 55, 1), 0 0 10px rgba(212, 175, 55, 1), 0 0 20px rgba(212, 175, 55, .9), 0 0 40px rgba(212, 175, 55, .7), 0 0 80px rgba(212, 175, 55, .5)}[data-theme=light]{--bg: #ffffff;--bg-elevated: #f8f8f8;--text: #0a0a0a;--text-secondary: #555555;--text-tertiary: #888888;--border: rgba(0, 0, 0, .08);--border-hover: rgba(0, 0, 0, .18);--shape-color: #000000;--shape-line-color: #000000;--logo-shadow: drop-shadow(0 4px 16px rgba(0, 0, 0, .4)) drop-shadow(0 1px 4px rgba(0, 0, 0, .25));--card-hover-shadow: 0 8px 40px rgba(0, 0, 0, .06);--nav-bg: rgba(255, 255, 255, .85);--nav-shadow: 0 1px 20px rgba(0, 0, 0, .04);--mobile-menu-bg: rgba(255, 255, 255, .97);--selection-bg: rgba(0, 0, 0, .1);--hamburger-color: #0a0a0a;--heading-color: #000000;--heading-glow: 0 0 2px rgba(212, 175, 55, .4), 0 0 5px rgba(212, 175, 55, .4), 0 0 10px rgba(212, 175, 55, .3), 0 0 20px rgba(212, 175, 55, .2)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;transition:background .4s ease,color .4s ease}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}::selection{background:var(--selection-bg);color:var(--text)}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 clamp(1.5rem,5vw,4rem);height:72px;display:flex;align-items:center;justify-content:space-between;transition:background .4s ease,backdrop-filter .4s ease,border-color .4s ease,box-shadow .4s ease;border-bottom:1px solid transparent}.navbar.scrolled{background:var(--nav-bg);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border-bottom-color:var(--border);box-shadow:var(--nav-shadow)}.navbar__brand{display:flex;align-items:center;gap:.625rem}.navbar__logo{width:28px;height:28px;border-radius:6px;filter:var(--logo-shadow);transition:filter .4s ease}.navbar__brand-text{font-size:1.125rem;font-weight:700;letter-spacing:-.02em}.navbar__links{display:flex;gap:2.25rem;list-style:none}.navbar__link{font-size:.8125rem;font-weight:500;letter-spacing:.03em;color:var(--text-secondary);transition:color .3s ease;position:relative}.navbar__link:after{content:"";position:absolute;bottom:-4px;left:0;width:100%;height:1.5px;background:var(--text);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease-out-expo)}.navbar__link:hover{color:var(--text)}.navbar__link:hover:after{transform:scaleX(1);transform-origin:left}.navbar__actions{display:flex;align-items:center;gap:1.25rem}.theme-toggle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);color:var(--text-secondary);transition:color .3s ease,border-color .3s ease,background .3s ease;cursor:pointer;background:none;flex-shrink:0}.theme-toggle:hover{color:var(--text);border-color:var(--border-hover);background:var(--bg-elevated)}.theme-toggle svg{width:16px;height:16px;transition:transform .4s var(--ease-out-expo)}.theme-toggle:hover svg{transform:rotate(30deg)}.navbar__mobile-toggle{display:none;flex-direction:column;gap:5px;width:24px;padding:4px 0}.navbar__mobile-toggle span{display:block;height:1.5px;background:var(--hamburger-color);border-radius:1px;transition:transform .3s ease,opacity .3s ease,background .4s ease}.navbar__mobile-toggle.open span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}.navbar__mobile-toggle.open span:nth-child(2){opacity:0}.navbar__mobile-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}.floating-shapes{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.hero{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:72px clamp(1.5rem,5vw,4rem) 2rem;text-align:center}.hero__center{display:flex;flex-direction:column;align-items:center;gap:0}.hero__tag{font-size:1.125rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--heading-color);text-shadow:var(--heading-glow);margin-bottom:1.5rem;opacity:0}.hero__name{font-size:clamp(4rem,12vw,9rem);font-weight:900;letter-spacing:-.04em;line-height:.9;margin-bottom:1.5rem;color:var(--text);perspective:800px}.hero__name-inner{display:inline-flex}.hero__letter-wrap{display:inline-block;overflow:hidden;perspective:600px}.hero__letter{display:inline-block;transform-origin:center bottom;will-change:transform,opacity}.hero__typewriter-wrap{font-family:var(--font-mono);font-size:clamp(.85rem,1.5vw,1rem);font-weight:400;color:var(--text-secondary);margin-bottom:1.5rem;height:1.6em;display:flex;align-items:center;justify-content:center}.hero__typewriter-text{border-right:2px solid var(--text-tertiary);padding-right:2px;animation:blink 1s step-end infinite}@keyframes blink{50%{border-color:transparent}}.hero__description{font-size:1.0625rem;color:var(--text-secondary);line-height:1.7;max-width:480px;font-weight:400;margin-bottom:3rem}.hero__stats{display:flex;gap:2rem;margin-bottom:4rem;opacity:0}.hero__stat-item{display:flex;flex-direction:column;align-items:center}.hero__stat-value{font-size:1.5rem;font-weight:800;color:var(--text);letter-spacing:-.02em}.hero__stat-label{font-size:.75rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem}.hero__scroll-indicator{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;animation:float 3s ease-in-out infinite;cursor:pointer;padding:.5rem}.hero__mouse{width:22px;height:36px;border:2px solid var(--text-tertiary);border-radius:12px;position:relative;display:flex;justify-content:center}.hero__mouse-wheel{width:3px;height:8px;background:var(--text-tertiary);border-radius:2px;margin-top:6px;animation:scroll-wheel 2s ease-in-out infinite}@keyframes scroll-wheel{0%{opacity:1;transform:translateY(0)}50%{opacity:.3;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-8px)}}.hero__scroll-text{font-size:.625rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--text-tertiary)}.section{position:relative;z-index:1;padding:clamp(5rem,12vh,8rem) clamp(1.5rem,5vw,4rem);max-width:1600px;margin:0 auto;background:var(--bg)}.section__label{font-size:2rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--heading-color);text-shadow:var(--heading-glow);margin-bottom:3rem;display:flex;align-items:center;justify-content:center;gap:1.5rem}.section__label:before,.section__label:after{content:"";flex:1;height:1px;background:var(--heading-color);max-width:80px}.about__heading{font-size:clamp(2rem,4vw,2.75rem);font-weight:900;letter-spacing:-.03em;margin-bottom:.5rem;color:var(--heading-color);text-shadow:var(--heading-glow);text-align:center}.about__heading-accent{color:var(--text-tertiary)}.about__subtitle{font-size:.9375rem;color:var(--text-secondary);margin-bottom:3rem;text-align:center}.about__layout{display:grid;grid-template-columns:1fr 280px;gap:3rem;align-items:start}.about__paragraphs{display:flex;flex-direction:column;gap:1.25rem}.about__paragraphs p{font-size:.9375rem;line-height:1.8;color:var(--text-secondary)}.about__stats{display:flex;flex-direction:column;gap:1rem}.about__stat-card{padding:1.25rem 1.5rem;border:1px solid var(--border);border-radius:12px;display:flex;align-items:center;gap:1rem;transition:border-color .3s ease}.about__stat-card:hover{border-color:var(--border-hover)}.about__stat-number{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;min-width:3rem}.about__stat-label{font-size:.8125rem;color:var(--text-secondary);font-weight:500}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 #22c55e66}50%{opacity:.7;box-shadow:0 0 0 6px #22c55e00}}.work__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.work__desktop-layout{display:flex;flex-direction:column;gap:2.5rem}.work__desktop-card{max-width:820px;margin:0 auto;width:100%}.desktop-carousel__wrap{position:relative;width:100%;margin:-60px 0}.desktop-carousel__fade-left,.desktop-carousel__fade-right{position:absolute;top:0;bottom:0;width:18%;z-index:300;pointer-events:none}.desktop-carousel__fade-left{left:0;background:linear-gradient(to right,var(--bg) 0%,transparent 100%)}.desktop-carousel__fade-right{right:0;background:linear-gradient(to left,var(--bg) 0%,transparent 100%)}.desktop-carousel{position:relative;width:100%;height:480px;overflow:hidden;cursor:grab;-webkit-user-select:none;user-select:none}.desktop-carousel:active{cursor:grabbing}.desktop-carousel__viewport{position:absolute;inset:0;will-change:transform}.carousel-card{flex-shrink:0;height:288px;border-radius:18px;overflow:hidden;display:flex;flex-direction:column;position:relative;transform-origin:center bottom;will-change:transform,opacity;box-shadow:0 12px 48px #0000008c;transition:box-shadow .3s ease}.carousel-card--active{box-shadow:0 0 0 2px #d4af37b3,0 16px 64px #000000b3}.carousel-card__image{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.carousel-card__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}.carousel-card__num{font-family:var(--font-mono);font-size:5rem;font-weight:900;color:#ffffff1a;line-height:1;pointer-events:none;position:absolute;bottom:.5rem;right:.75rem}.carousel-card__footer{padding:.75rem 1rem;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:space-between;gap:.5rem}.carousel-card__title{font-size:.875rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.carousel-card__ext{font-size:1rem;color:#fff9;flex-shrink:0;transition:color .2s ease}.carousel-card__ext:hover{color:#fff}.project-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:2rem;position:relative;transition:border-color .4s ease,transform .1s ease,box-shadow .4s ease;transform-style:preserve-3d;cursor:default;display:flex;flex-direction:column}.project-card:hover{border-color:var(--border-hover);box-shadow:var(--card-hover-shadow)}.project-card__header-flex{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem}.project-card__number{font-size:3.5rem;font-weight:900;line-height:.8;color:var(--text-tertiary);opacity:.3;letter-spacing:-.04em}.project-card__name{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1rem}.project-card__link-icon{color:var(--text-tertiary);transition:color .3s ease,transform .3s ease;flex-shrink:0}.project-card:hover .project-card__link-icon{color:var(--text);transform:translate(2px,-2px)}.project-card__description{font-size:.9375rem;line-height:1.7;color:var(--text-secondary);margin-bottom:1.5rem}.project-card__highlights{background:#ffffff08;border:1px solid var(--border);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem;flex:1}[data-theme=light] .project-card__highlights{background:#00000008}.project-card__highlights-title{font-size:.8125rem;font-weight:700;margin-bottom:.75rem;color:var(--text)}.project-card__highlights-list{list-style:none;display:flex;flex-direction:column;gap:.625rem}.project-card__highlights-list li{position:relative;padding-left:1rem;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.project-card__highlights-list li:before{content:"▸";position:absolute;left:0;top:-1px;color:var(--text-tertiary)}.project-card__techs{display:flex;flex-wrap:wrap;gap:.5rem}.project-card__mobile-hero{position:relative;width:calc(100% + 4rem);margin:-2rem -2rem 1rem;height:200px;overflow:hidden;border-radius:12px 12px 0 0}.project-card__mobile-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.project-card__mobile-num{position:absolute;top:.75rem;left:.75rem;font-family:var(--font-mono);font-size:.75rem;font-weight:700;color:#fff;background:#00000073;padding:.2rem .5rem;border-radius:6px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.project-card__mobile-title-overlay{position:absolute;bottom:0;left:0;right:0;padding:2rem 1rem .75rem;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 100%);display:flex;align-items:flex-end;justify-content:space-between;gap:.5rem}.project-card__mobile-title{font-size:.9rem;font-weight:700;color:#fff;line-height:1.3;flex:1}.project-card__tech{font-family:var(--font-mono);font-size:.6875rem;font-weight:500;color:var(--text-tertiary);padding:.25rem .625rem;border:1px solid var(--border);border-radius:4px;transition:border-color .3s ease,color .3s ease}.project-card:hover .project-card__tech{border-color:var(--border-hover);color:var(--text-secondary)}.work__grid .project-card:last-child:nth-child(odd){grid-column:1 / -1}.stack__subtitle{font-size:1.0625rem;color:var(--text-secondary);margin-bottom:3rem;text-align:center}.stack__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.skill-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;padding:1.5rem;transition:border-color .3s ease;display:flex;flex-direction:column}.skill-card:hover{border-color:var(--border-hover)}.skill-card__header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;width:100%;text-align:left}.skill-card__icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;background:#ffffff0d;color:#3b82f6;font-family:var(--font-mono);font-weight:700;font-size:1rem}[data-theme=light] .skill-card__icon{background:#0000000d}.skill-card__title{font-size:1.125rem;font-weight:700;color:var(--text);flex:1}.skill-card__chevron{display:none;color:var(--text-tertiary);transition:transform .3s ease}.skill-card__chevron.rotated{transform:rotate(180deg)}.skill-card__content{overflow:hidden;transition:max-height .4s var(--ease-out-expo),opacity .4s ease}.skill-card__skills{display:flex;flex-direction:column;gap:.75rem}.skill-card__row{display:flex;flex-wrap:wrap;gap:.75rem}.skill-card__tag{font-size:.8125rem;font-weight:500;color:var(--text-secondary);background:#ffffff08;padding:.375rem .875rem;border-radius:6px;transition:color .3s ease,background .3s ease}[data-theme=light] .skill-card__tag{background:#00000008}.skill-card__tag:hover{color:var(--text);background:#ffffff14}[data-theme=light] .skill-card__tag:hover{background:#00000014}.contact{position:relative;z-index:1;background:var(--bg);text-align:center;padding:clamp(6rem,15vh,10rem) clamp(1.5rem,5vw,4rem);max-width:1200px;margin:0 auto}.contact__heading{font-size:clamp(2.5rem,6vw,5rem);font-weight:900;letter-spacing:-.04em;line-height:1;margin-bottom:1.5rem;color:var(--heading-color);text-align:center}.contact__subtext{font-size:1.0625rem;color:var(--text-secondary);margin-bottom:3rem;font-weight:400;text-align:center}.contact__links{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-bottom:3rem}.contact__link{font-size:.875rem;font-weight:500;color:var(--text-secondary);display:inline-flex;align-items:center;gap:.5rem;padding-bottom:2px;border-bottom:1px solid transparent;transition:color .3s ease,border-color .3s ease}.contact__link:hover{color:var(--text);border-bottom-color:var(--text-secondary)}.contact__badge{display:inline-flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);padding:.5rem 1.25rem;border:1px solid var(--border);border-radius:100px}.contact__badge-dot{width:6px;height:6px;background:#22c55e;border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}.contact__say-hello-btn{display:flex;width:fit-content;margin:2rem auto 0;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;background:linear-gradient(135deg,#0284c7,#06b6d4);color:#fff;font-weight:600;font-size:1rem;text-decoration:none;box-shadow:0 0 20px #06b6d466;transition:transform .3s ease,box-shadow .3s ease}.contact__say-hello-btn:hover{transform:translateY(-2px);box-shadow:0 0 30px #06b6d499;color:#fff}.footer{position:relative;z-index:1;background:var(--bg);padding:1.5rem clamp(1.5rem,5vw,4rem);border-top:1px solid var(--border);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;font-size:.75rem;color:var(--text-tertiary)}.footer__copy{justify-self:start}.footer__logo{justify-self:center}.footer__logo-img{width:34px;height:34px;border-radius:6px;filter:var(--logo-shadow);opacity:1;transition:filter .4s ease}.footer__links{justify-self:end;display:flex;gap:1.5rem}.footer__links a{color:var(--text-tertiary);transition:color .3s ease}.footer__links a:hover{color:var(--text)}@media(max-width:1024px){.stack__grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.navbar__links{position:absolute;top:100%;right:1.5rem;width:220px;height:auto;background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;padding:1.5rem;flex-direction:column;justify-content:flex-start;align-items:flex-start;gap:1.5rem;transform:translateY(-10px);opacity:0;pointer-events:none;transition:transform .3s ease,opacity .3s ease;z-index:999;box-shadow:var(--nav-shadow)}.navbar__links.open{transform:translateY(10px);opacity:1;pointer-events:auto}.navbar__link{font-size:1rem;letter-spacing:.02em}.navbar__actions{gap:1rem}.navbar__mobile-toggle{display:flex;z-index:1001}.hero__tag{font-size:.5625rem}.section__label{font-size:1rem}.about__heading{font-size:1.5rem}.work__grid{grid-template-columns:1fr}.work__mobile-layout{display:flex;flex-direction:column;gap:1.5rem}.wheel-selector-container{position:relative;width:100%;height:200px;overflow:hidden;display:flex;justify-content:center;align-items:flex-end;margin-top:1rem;touch-action:pan-y;border-radius:20px;-webkit-user-select:none;user-select:none;cursor:grab}.wheel-selector-container.dragging{cursor:grabbing}.wheel-pointer{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:4px;height:16px;background:var(--heading-color);border-radius:4px;z-index:10;box-shadow:var(--heading-glow)}.wheel-dial{position:absolute;bottom:-150px;width:300px;height:300px;border-radius:50%;border:1px dashed var(--border-hover)}.wheel-item{position:absolute;top:50%;left:50%;margin-top:-30px;margin-left:-40px;width:80px;height:60px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;transition:opacity .3s;opacity:.2;cursor:pointer}.wheel-item.active{opacity:1}.wheel-item-number{font-family:var(--font-mono);font-size:1.5rem;font-weight:900;color:var(--heading-color)}.wheel-item-name{font-size:.65rem;color:var(--text-secondary);margin-top:4px;white-space:nowrap}.stack__grid{grid-template-columns:1fr}.skill-card__chevron{display:block}@keyframes float-arrow{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.project-card__chevron-wrapper svg{animation:float-arrow 2s infinite ease-in-out}.project-card__chevron-wrapper svg.rotated{animation:none}.about__layout{grid-template-columns:1fr;gap:2rem}.about__stats{flex-direction:row;flex-wrap:wrap}.about__stat-card{flex:1;min-width:140px}.contact{padding-bottom:2rem}.contact__links{flex-direction:column;align-items:center;gap:1rem}.floating-socials{position:fixed;right:.5rem;top:72px;display:flex;flex-direction:column;gap:.5rem;z-index:900}.floating-social-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);border-radius:50%;transition:all .3s ease}.floating-social-btn:hover,.floating-social-btn:active{color:#000;background:#eab308;box-shadow:0 0 10px #eab30880}.footer{grid-template-columns:1fr;gap:1rem;text-align:center;justify-items:center}.footer__logo{order:-1}.footer__copy,.footer__links{justify-self:center}}@media(max-width:480px){.hero__name{font-size:3.5rem}.about__stats{flex-direction:column}}.mouse-particles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:-1}@media(max-width:768px){.mouse-particles{display:none}}
