canvas{position:fixed;top:0;left:0}:root{--bg-color: #060608;--text-main: #f4f4f5;--text-muted: #71717a;--text-muted-soft: #a1a1aa;--border-color: rgba(255, 255, 255, .08);--section-gap-vertical: clamp(1.25rem, 3vw, 2rem);--section-gap-large: clamp(3rem, 8vw, 72px);--accent-snow: #ffffff;--accent-ice: #e0f2fe;--accent-ice-rgb: 224, 242, 254;--accent-mint: #ecfdf5;--accent-mint-rgb: 236, 253, 245;--accent-secondary: #bae6fd;--accent-secondary-rgb: 186, 230, 253;--accent-hover: #e0f2fe;--accent-hover-rgb: 224, 242, 254;--font-main: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-serif: "Source Serif 4", Georgia, serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--spacing: 56px;--section-gap: 1.5rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition: .25s cubic-bezier(.4, 0, .2, 1);--text-dim: var(--text-muted);--bg-card: rgba(255, 255, 255, .04);--border-panel: rgba(255, 255, 255, .06)}*{box-sizing:border-box;margin:0;padding:0}html,body{overflow:hidden;height:100%;width:100%}.transition-fade{transition:opacity .4s ease-in-out,backdrop-filter .4s ease-in-out;opacity:1;-webkit-backdrop-filter:blur(0px)}html.is-animating .transition-fade{opacity:0;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px)}@media(prefers-reduced-motion:reduce){.transition-fade,html.is-animating .transition-fade{transition:none}}.skip-link{position:absolute;top:-100px;left:0;padding:.75rem 1.5rem;background:var(--accent-ice);color:var(--bg-color);font-weight:600;text-decoration:none;z-index:1000;transition:top .2s ease}.skip-link:focus{top:0}a:focus-visible,button:focus-visible{outline:2px solid var(--accent-ice);outline-offset:2px}.card-links a.read-more:focus-visible,.action-btn:focus-visible,.lightbox-close:focus-visible{outline:2px solid var(--accent-ice);outline-offset:2px}body{background-color:var(--bg-color);color:var(--text-main);font-family:var(--font-main);font-size:16px;line-height:1.6;height:100dvh;overflow:hidden;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative}.site-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:.875rem 0;background:transparent;border:none;pointer-events:none;display:flex;justify-content:center}.site-header-inner{width:min(92%,1520px);max-width:1520px;margin:0 auto;padding:0 var(--spacing);display:flex;align-items:center;justify-content:space-between;pointer-events:auto;position:relative}.site-header-inner:after{content:"";position:absolute;left:0;right:0;bottom:-.875rem;height:1px;background:linear-gradient(90deg,transparent,var(--border-color) 15%,var(--border-color) 85%,transparent);opacity:.6}.site-logo{font-weight:600;font-size:1.05rem;letter-spacing:-.02em;color:var(--text-main);text-decoration:none;transition:color var(--transition)}.site-logo:hover{color:var(--accent-ice)}.site-nav{display:flex;align-items:center;gap:2rem}.site-nav a{font-size:.9rem;font-weight:500;color:var(--text-muted-soft);text-decoration:none;transition:color var(--transition)}.site-nav a:hover{color:var(--text-main)}body:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;opacity:.28;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:-1}body:after{content:"";position:absolute;top:-40%;left:-40%;width:180%;height:180%;background:radial-gradient(circle at 40% 30%,rgba(var(--accent-mint-rgb),.06),rgba(var(--accent-ice-rgb),.05) 20%,rgba(255,255,255,.02) 45%,transparent 60%);pointer-events:none;z-index:-2;animation:pulseLight 30s infinite alternate}@keyframes pulseLight{0%{transform:scale(1);opacity:.35}to{transform:scale(1.08);opacity:.65}}.grid-container{width:min(92%,1520px);max-width:1520px;height:100dvh;max-height:100dvh;display:grid;grid-template-columns:1.5fr 1fr;grid-template-rows:1fr 1fr auto;gap:0;border-left:1px solid var(--border-panel);border-right:1px solid var(--border-panel);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent;background:linear-gradient(180deg,#0a0a0ceb,#060608f2);margin:0 auto}.grid-container::-webkit-scrollbar{width:6px}.grid-container::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:3px}.back{padding:var(--spacing);border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color);background:linear-gradient(180deg,#080808e6,#060606eb);box-shadow:0 0 0 1px #ffffff0a,inset 0 1px #ffffff05}.grid-item{padding:var(--spacing);border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color);display:flex;flex-direction:column;justify-content:center;position:relative;background:linear-gradient(180deg,#080808e6,#060606eb);box-shadow:0 0 0 1px #ffffff0a,inset 0 1px #ffffff05}.name-section{grid-column:1 / 2;grid-row:1 / 3;justify-content:center}.name-section .profile-pic,.name-section .profile-image img{transform:none;-webkit-image-orientation:none;image-orientation:none}.profile-image{margin-bottom:12px;position:relative;width:clamp(140px,14vmin,280px);height:clamp(140px,14vmin,280px);display:inline-block}header.name-section .profile-image{width:clamp(120px,18vw,280px);height:clamp(120px,18vw,280px);max-width:min(280px,90%);max-height:min(280px,45vmin)}.profile-image:before{content:"";position:absolute;inset:-6px;border:3px dashed rgba(255,255,255,.15);border-radius:50%;transition:transform .8s cubic-bezier(.4,0,.2,1);pointer-events:none}.profile-image:hover:before{transform:rotate(180deg);border-color:#fff6}.profile-pic{width:100%;height:100%;border-radius:50%;object-fit:cover;box-shadow:0 10px 40px #0006;display:block;image-rendering:auto;image-rendering:-webkit-optimize-contrast}h1{font-size:clamp(2.75rem,5.5vw,5rem);font-weight:700;letter-spacing:-.03em;line-height:1.1;color:var(--text-main)}.subtitle{font-size:1.05rem;font-weight:500;color:var(--text-muted-soft);margin-top:var(--section-gap);letter-spacing:.02em}.bio-section{grid-column:2 / 3;grid-row:1 / 2;color:var(--text-muted-soft);font-size:1.05rem;line-height:1.7}strong{color:var(--text-main);font-weight:500}.nav-section{grid-column:2 / 3;grid-row:2 / 3;padding:0}.link-list{list-style:none;height:100%;display:flex;flex-direction:column}.link-list li{flex:1;border-bottom:1px solid var(--border-color);display:flex;transition:background .28s ease}.link-list li:last-child{border-bottom:none}.nav-link{text-decoration:none;color:var(--text-main);width:100%;display:flex;justify-content:space-between;align-items:center;padding:0 var(--spacing);transition:all .36s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;border-left:3px solid transparent}.nav-link:hover{background:linear-gradient(90deg,rgba(var(--accent-mint-rgb),.04),rgba(var(--accent-ice-rgb),.035));border-left-color:var(--accent-ice)}.nav-link:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.03),transparent);transform:translate(-100%);transition:transform .6s ease}.nav-link:hover:before{transform:translate(100%)}.main-link{font-size:1.5rem;font-weight:500;letter-spacing:-.02em}.nav-link:hover .link-text{transform:translate(10px);color:#fff;text-shadow:0 0 12px rgba(255,255,255,.25)}.link-text{transition:transform .3s ease}.nav-link:hover .arrow,.nav-link:hover .arrow-small{color:var(--accent-hover);transform:translate(5px) scale(1.04)}.arrow{font-size:1.2rem;transition:all .3s ease;color:var(--text-muted)}.social-row{display:flex;flex-direction:row}.social-link{flex:1;text-decoration:none;color:var(--text-muted);font-size:.9rem;font-family:var(--font-mono);display:flex;justify-content:center;align-items:center;gap:8px;transition:all .3s ease;border-right:1px solid var(--border-color);border-left:3px solid transparent;background:transparent}.social-link:last-child{border-right:none}.social-link:hover{background:linear-gradient(90deg,rgba(var(--accent-ice-rgb),.04),rgba(var(--accent-mint-rgb),.03));color:var(--accent-hover);border-left-color:var(--accent-hover)}.arrow-small{font-size:.8rem;transition:transform .3s ease}.footer-section{grid-column:1 / 3;grid-row:3 / 4;border-bottom:none;border-right:none;border-top:1px solid var(--border-panel);display:flex;flex-direction:row;justify-content:flex-start;align-items:center;font-size:.85rem;font-family:var(--font-mono);color:var(--text-muted);gap:12px;padding:var(--spacing)}.status-dot{width:6px;height:6px;background-color:var(--accent-snow);border-radius:50%;box-shadow:0 0 8px #ffffffd9;animation:blink 3s infinite ease-in-out}@keyframes blink{0%,to{opacity:.8}50%{opacity:.35}}.fade-in{opacity:0;animation:fadeIn 1s ease forwards}.fade-in-delay{opacity:0;animation:fadeIn 1s ease .3s forwards}@keyframes fadeIn{to{opacity:1}}.grid-container:has(.home-page){clip-path:inset(0 0 100% 0);animation:revealVertical 2.5s cubic-bezier(.22,1,.36,1) forwards}@keyframes revealVertical{to{clip-path:inset(0 0 0 0)}}.widget-fade{opacity:0;animation:fadeInUp 1.4s cubic-bezier(.22,1,.36,1) forwards}.home-page .subtitle.widget-fade{animation-delay:.3s}.home-page .tagline.widget-fade{animation-delay:.5s}.home-page .opportunities.widget-fade{animation-delay:.7s}.home-page .capabilities.widget-fade{animation-delay:.9s}.home-page .bio-section.widget-fade{animation-delay:1.1s}.home-page .nav-section.widget-fade{animation-delay:1.3s}.projects-page .back-link.widget-fade{animation-delay:.2s}.projects-page .projects-header h1.widget-fade{animation-delay:.4s}.projects-page .intro.widget-fade{animation-delay:.6s}.projects-page .divider-frost.widget-fade{animation-delay:.8s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.grid-container:has(.home-page){clip-path:none;animation:none}.widget-fade{animation:none;opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.fade-in,.fade-in-delay{animation:none;opacity:1}.status-dot{animation:none}}.projects-wrapper{--accent-secondary: var(--accent-snow);--accent-secondary-rgb: 255, 255, 255;position:absolute;top:0;left:0;width:100%;height:100dvh;overflow-y:auto;padding:64px var(--spacing) 80px;display:flex;flex-direction:column;align-items:center;z-index:10;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.projects-wrapper::-webkit-scrollbar{width:6px}.projects-wrapper::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:3px}.not-found{text-align:center;padding:4rem 2rem;position:relative}.not-found h1{font-size:clamp(4rem,15vw,8rem);font-weight:700;color:var(--text-muted);margin-bottom:.5rem}.not-found .not-found-tagline{color:var(--text-muted-soft);font-size:1.1rem;margin-bottom:2rem}.not-found p{color:var(--text-muted-soft);margin-bottom:2rem}.not-found .back-link{display:inline-flex;align-items:center;gap:.5rem}.not-found-snow{position:absolute;inset:0;pointer-events:none;overflow:hidden}.not-found-snow span{position:absolute;width:4px;height:4px;background:#fff6;border-radius:50%;animation:snowFloat 12s linear infinite}.not-found-snow span:nth-child(1){left:10%;animation-delay:0s;animation-duration:14s}.not-found-snow span:nth-child(2){left:25%;animation-delay:-2s;animation-duration:11s}.not-found-snow span:nth-child(3){left:40%;animation-delay:-4s;animation-duration:15s}.not-found-snow span:nth-child(4){left:60%;animation-delay:-1s;animation-duration:13s}.not-found-snow span:nth-child(5){left:75%;animation-delay:-3s;animation-duration:12s}.not-found-snow span:nth-child(6){left:90%;animation-delay:-5s;animation-duration:16s}@keyframes snowFloat{0%{transform:translateY(-10vh) scale(1);opacity:.4}to{transform:translateY(100vh) scale(.8);opacity:.2}}@media(prefers-reduced-motion:reduce){.not-found-snow span{animation:none;opacity:.2}}.breadcrumbs{margin-bottom:1rem}.breadcrumb-list{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;list-style:none;padding:.5rem 0;margin:0;font-size:.9rem;color:var(--text-muted-soft)}.breadcrumb-item{display:flex;align-items:center;gap:.35rem}.breadcrumb-item a{color:var(--text-muted-soft);text-decoration:none;padding:.2em .4em;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition)}.breadcrumb-item a:hover{color:var(--accent-ice);background:rgba(var(--accent-ice-rgb),.06)}.breadcrumb-item:last-child span{color:var(--text-muted);font-weight:500}.breadcrumb-sep{color:var(--text-muted);opacity:.7;user-select:none}.divider-frost{height:1px;width:100%;margin:var(--section-gap-vertical) 0;background:linear-gradient(90deg,transparent,rgba(var(--accent-ice-rgb),.2) 20%,rgba(var(--accent-ice-rgb),.15) 50%,rgba(var(--accent-ice-rgb),.2) 80%,transparent);border:none;filter:blur(.5px)}.projects-header{width:100%;max-width:1200px;margin-bottom:var(--section-gap-large);position:relative}.projects-header h1{margin-top:16px;letter-spacing:-.03em;font-weight:700;color:var(--text-main)}.projects-header .intro{margin-top:12px;font-size:1rem;color:var(--text-muted-soft);max-width:560px;line-height:1.6}.back-link{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;font-weight:500;color:var(--text-muted-soft);text-decoration:none;transition:color var(--transition),transform var(--transition);position:relative}.back-link:after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:linear-gradient(90deg,var(--accent-ice),transparent);transition:width var(--transition)}.back-link:hover,.back-link:focus-visible{color:var(--accent-ice);transform:translate(-3px)}.back-link:hover:after,.back-link:focus-visible:after{width:100%}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;width:100%;max-width:1200px;padding-bottom:120px}@media(max-width:1100px){.projects-grid{grid-template-columns:repeat(2,1fr)}}.project-card-reveal{opacity:0;transform:translateY(18px);min-height:420px;display:flex}.project-card-reveal.in-view{animation:fadeInUp .8s cubic-bezier(.22,1,.36,1) forwards}.project-card-reveal.in-view:nth-child(1){animation-delay:0s}.project-card-reveal.in-view:nth-child(2){animation-delay:.2s}.project-card-reveal.in-view:nth-child(3){animation-delay:.4s}.project-card-reveal.in-view:nth-child(n+4){animation-delay:0s}@media(prefers-reduced-motion:reduce){.project-card-reveal{opacity:1;transform:none;animation:none}.project-card-reveal.in-view{animation:none;opacity:1}}.project-card{background:#0a0a0ce0;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 0 0 1px #ffffff08,0 4px 24px #0006;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:0;display:flex;flex-direction:column;justify-content:space-between;flex:1;min-height:420px;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);position:relative;overflow:hidden}.project-card:hover{transform:translateY(-4px);border-color:rgba(var(--accent-ice-rgb),.25);box-shadow:0 0 0 1px rgba(var(--accent-ice-rgb),.08),0 20px 48px #00000080}.project-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(255,255,255,.035),transparent);transform:translate(-100%);transition:transform .7s ease;pointer-events:none}.project-card:hover:before{transform:translate(100%)}.card-thumbnail{width:100%;aspect-ratio:16 / 9;overflow:hidden;background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0;text-decoration:none;color:inherit;display:block}.card-thumbnail img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}.project-card:hover .card-thumbnail img{transform:scale(1.05)}.card-thumbnail-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(var(--accent-secondary-rgb),.08),#ffffff05)}.card-thumbnail-label{font-family:var(--font-mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent-secondary);opacity:.85}.card-content{padding:30px 30px 22px;display:flex;flex-direction:column;flex:1}.card-content h3{font-size:1.35rem;font-weight:600;color:var(--text-main);margin-bottom:12px;letter-spacing:-.02em}.card-content p{font-size:.95rem;line-height:1.7;color:var(--text-muted-soft);margin-bottom:24px}.tech-stack{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:32px}.tech-stack span{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted-soft);border:1px solid rgba(var(--accent-secondary-rgb),.25);padding:6px 14px;border-radius:999px;background:rgba(var(--accent-secondary-rgb),.05);transition:all .25s ease}.project-card:hover .tech-stack span{border-color:rgba(var(--accent-hover-rgb),.45);color:var(--accent-hover)}.card-links{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding:22px 30px 30px;border-top:1px solid rgba(255,255,255,.05);gap:20px}.card-links a.read-more{display:flex;align-items:center;gap:10px;border:1px solid rgba(var(--accent-secondary-rgb),.4);border-radius:10px;padding:10px 18px;font-family:var(--font-mono);font-size:.72rem;font-weight:600;color:var(--accent-secondary);text-decoration:none;text-transform:uppercase;letter-spacing:.08em;transition:all .25s ease}.card-links a.read-more:hover{border-color:var(--accent-hover);color:var(--text-main);background:rgba(var(--accent-hover-rgb),.12)}.card-links .arrow-icon{color:var(--accent-secondary);transition:transform .3s ease,color .3s ease}.card-links a.read-more:hover .arrow-icon{color:var(--accent-hover);transform:translate(4px)}.github-icon{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid rgba(var(--accent-secondary-rgb),.3);border-radius:50%;color:var(--text-muted);transition:all .3s cubic-bezier(.16,1,.3,1)}.github-icon :global(svg){width:20px;height:20px;transition:transform .3s ease}.github-icon:hover{border-color:var(--accent-hover);color:var(--accent-hover);background:rgba(var(--accent-hover-rgb),.1)}.github-icon:hover :global(svg){transform:rotate(12deg) scale(1.05)}#swup{width:100%;height:100%;margin:0 auto}.lightbox{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:2rem;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.lightbox.is-open{opacity:1;visibility:visible}.lightbox-backdrop{position:absolute;inset:0;background:#0c0c0ee6;backdrop-filter:blur(6px);cursor:pointer}.lightbox-img{position:relative;z-index:1;max-width:92vw;max-height:88vh;object-fit:contain;border-radius:10px;box-shadow:0 30px 80px #000000a6;border:1px solid rgba(var(--accent-ice-rgb),.12);box-shadow:0 30px 80px #000000a6,0 0 0 1px rgba(var(--accent-ice-rgb),.08)}.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;z-index:2;width:44px;height:44px;border:1px solid rgba(255,255,255,.12);background:#ffffff14;color:#fff;font-size:1.4rem;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s ease,transform .2s ease,border-color .2s ease}.lightbox-close:hover{background:rgba(var(--accent-ice-rgb),.15);border-color:rgba(var(--accent-ice-rgb),.35);transform:rotate(90deg)}.detail-container{width:100%;max-width:1100px;margin:0 auto;padding:0 24px 100px}.content-grid{display:grid;grid-template-columns:2fr 1fr;gap:clamp(2rem,5vw,72px);margin-top:var(--section-gap-vertical)}.detail-header{border-bottom:1px solid var(--border-color);padding-bottom:40px}.detail-header h1{font-size:clamp(2.25rem,4vw,3.25rem);margin-top:20px;margin-bottom:12px;letter-spacing:-.03em;font-weight:700;color:var(--text-main)}.tagline{font-size:1.1rem;color:var(--text-muted-soft);font-family:var(--font-main);max-width:720px;line-height:1.65}.project-hero-image{cursor:pointer;width:100%;aspect-ratio:16 / 9;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;margin-bottom:56px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;box-shadow:0 20px 60px #00000073,0 0 0 1px #ffffff0a;transition:transform .3s ease,box-shadow .3s ease}.project-hero-image:hover{transform:translateY(-4px);box-shadow:0 30px 80px #0009,0 0 0 1px #ffffff14}.project-hero-image img{cursor:pointer;border-radius:10px;width:100%;height:100%;object-fit:cover}.placeholder-overlay{color:#fff6;font-family:var(--font-mono);font-size:.85rem;text-transform:uppercase;letter-spacing:.12em}.text-content h3{font-size:1.75rem;color:var(--text-main);margin-top:3rem;margin-bottom:1.25rem;font-weight:600;letter-spacing:-.02em}.text-content h3:first-child{margin-top:0}.text-content p{font-size:1.075rem;line-height:1.8;color:var(--text-muted-soft);margin-bottom:1.5rem;font-family:var(--font-serif)}.text-content code{font-family:var(--font-mono);font-size:.9em;padding:.2em .45em;background:#ffffff14;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--accent-ice)}.text-content ul{list-style:none;margin-bottom:2rem;padding-left:0}.text-content li{position:relative;padding-left:1.5rem;margin-bottom:.75rem;color:var(--text-muted);line-height:1.6}.text-content li:before{content:"→";position:absolute;left:0;color:var(--accent-ice);font-weight:700;font-size:.9em}.project-sidebar{position:sticky;top:2rem;height:fit-content;padding:1.75rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 8px 32px -8px #00000073}.meta-block{margin-bottom:2rem}.meta-label{display:block;font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;color:var(--accent-ice);margin-bottom:.5rem;letter-spacing:.1em}.meta-value{display:block;font-size:1rem;color:var(--text-main);font-weight:500}.tech-stack-wrap{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{font-family:var(--font-mono);font-size:.7rem;padding:4px 10px;border-radius:4px;border:1px solid var(--border-color);color:var(--text-muted);background:#ffffff08;transition:var(--transition)}.tech-tag:hover{color:var(--text-main);border-color:var(--accent-ice);background:rgba(var(--accent-ice-rgb),.12)}.action-buttons{display:flex;flex-direction:column;gap:12px;margin-top:2.5rem}.action-btn{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;padding:.8rem 1.5rem;border-radius:8px;font-family:var(--font-mono);font-size:.8rem;font-weight:600;text-decoration:none;text-transform:uppercase;transition:var(--transition)}.action-btn.outline{border:1px solid var(--border-color);color:var(--text-main);background:transparent}.action-btn.outline:hover{border-color:var(--accent-ice);color:var(--accent-ice);background:rgba(var(--accent-ice-rgb),.08);transform:translateY(-1px)}.detail-footer{margin-top:6rem;padding:3rem 0;border-top:1px solid var(--border-color)}.next-project-link{text-decoration:none;display:inline-block;transition:var(--transition)}.next-project-link .label{display:block;font-family:var(--font-mono);font-size:.7rem;color:var(--text-dim);text-transform:uppercase}.next-project-link .title{font-size:1.5rem;font-weight:600;color:var(--text-main)}.next-project-link:hover{transform:translate(8px)}header.name-section{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px}h1{font-size:clamp(2.5rem,5vw,4rem);font-weight:600;letter-spacing:-1px}.subtitle{font-size:clamp(.9rem,1vw,1.15rem);font-weight:400;color:var(--text-muted);max-width:500px}.dynamic-line{margin-top:18px;font-family:var(--font-mono);font-size:.9rem;color:var(--accent-ice);letter-spacing:.5px;min-height:22px}.cursor{animation:cursor-blink 1s infinite;opacity:.7}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}.link-list{list-style:none;padding:0;margin:0}.tagline{margin-top:14px;font-size:clamp(.95rem,1.05vw,1.2rem);color:var(--text-muted-soft);line-height:1.5}.opportunities{margin-top:12px;font-size:clamp(.85rem,.95vw,1.05rem);color:var(--accent-ice);font-weight:500}.capabilities{margin-top:20px;display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.capabilities span{font-size:clamp(.72rem,.85vw,.95rem);font-weight:500;padding:6px 14px;border-radius:999px;background:#ffffff0d;border:1px solid var(--border-color);color:var(--text-muted-soft);letter-spacing:.02em}.main-wrapper{display:contents}.main-wrapper::-webkit-scrollbar{width:6px}.main-wrapper::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:3px}.customback,.mobile-buffer{display:contents}@media(max-width:768px){html,body{margin:0;padding:0;overflow-x:hidden}*{max-width:100vw;box-sizing:border-box}.site-header{padding:.75rem 0}.site-header-inner{width:100%;max-width:100%;padding:0 24px}.site-logo{font-size:.95rem}.site-nav{gap:1.25rem}.site-nav a{font-size:.85rem}.project-sidebar{position:relative;top:0;margin-bottom:2rem}.action-buttons{flex-direction:row}.grid-container{width:100vw;max-width:100vw;grid-template-columns:1fr;grid-template-rows:auto auto auto auto;border:none;overflow:visible;box-sizing:border-box;margin:0;padding:0}#swup{width:100%;max-width:100vw;grid-template-columns:1fr;grid-template-rows:auto auto auto auto;border:none;padding:0}.name-section{grid-column:1 / 2;grid-row:1 / 2;padding:48px 24px;border-right:none}.name-section h1{font-size:2rem}.bio-section{grid-column:1 / 2;grid-row:2 / 3;border-right:none}.nav-section{grid-column:1 / 2;grid-row:3 / 4;border-right:none}.nav-link{padding:28px 24px}.footer-section{grid-column:1 / 2;grid-row:4 / 5;padding:28px 24px}.social-link{padding:24px 0;border-bottom:1px solid var(--border-color)}.mainpage-wrapper{width:100vw;max-width:100vw;min-height:100dvh}.projects-wrapper{padding:60px 24px;width:100vw;max-width:100vw;min-height:100dvh;box-sizing:border-box;margin:0}.projects-grid{grid-template-columns:1fr}.project-card-reveal,.project-card{min-height:380px}.projects-header h1{font-size:3rem;letter-spacing:-.02em}.card-links{gap:18px}.read-more{padding:16px 26px;font-size:.95rem;color:#ffffffd9;font-weight:600;border-radius:8px}.github-icon{width:56px;height:56px;color:#ffffffd9}.github-icon :global(svg){width:28px;height:28px}.project-card h3{font-size:1.5rem;letter-spacing:-.01em}.project-card p{font-size:1.05rem;line-height:1.65;color:#ffffffc7}.tech-stack span{font-size:.8rem;padding:6px 12px;border-radius:20px}.detail-container{padding:1rem;overflow-x:hidden;width:100vw;max-width:100vw;min-height:100dvh;box-sizing:border-box;margin:0}.content-grid{display:flex;flex-direction:column;gap:2rem;width:100%;max-width:100%}.project-body,.project-sidebar{width:100%;max-width:100%;margin:0}.project-sidebar{order:2;border-top:1px solid rgba(255,255,255,.1);padding-top:2rem}.project-hero-image img{max-width:100%;width:100%;height:auto;border-radius:8px}.tech-stack-wrap{display:flex;flex-wrap:wrap;gap:8px}h1,p,li{overflow-wrap:break-word;word-wrap:break-word}.action-btn{display:flex;justify-content:center;width:100%;box-sizing:border-box}.profile-image{width:clamp(100px,28vw,160px);height:clamp(100px,28vw,160px);margin:0 auto;display:block}.profile-image:before{inset:-5px;border-width:2px;animation:slowSpin 10s linear infinite}.main-wrapper{--accent-secondary: var(--accent-snow);--accent-secondary-rgb: 255, 255, 255;top:0;left:0;width:100%;min-height:100dvh;overflow-y:auto;z-index:10;scrollbar-width:thin;scrollbar-color:transparent;display:block}.main-wrapper::-webkit-scrollbar{width:6px}.main-wrapper::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:3px}.grid-item{background:none}.customback,.back{border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color);background:linear-gradient(180deg,#08080887,#06060687);box-shadow:0 0 0 1px #ffffff0a,inset 0 1px #ffffff05}.mobile-buffer{display:block}}.nav-link-underline{position:relative;text-decoration:none}.nav-link-underline:after{content:"";position:absolute;left:0;bottom:-.2em;width:100%;height:1px;background-color:var(--accent-ice);transform-origin:left;transform:scaleX(0);opacity:0;transition:transform var(--transition),opacity var(--transition)}.nav-link-underline:hover:after,.nav-link-underline:focus-visible:after{transform:scaleX(1);opacity:1}.site-logo-mark{font-size:1.15rem;letter-spacing:.08em;text-transform:uppercase;padding:.15rem .5rem;border:1px solid var(--border-panel);border-radius:var(--radius-sm);color:var(--text-main)}.site-logo-text{font-size:1rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-main);white-space:nowrap}.detail-title{font-size:clamp(2.75rem,4vw,3.75rem);margin-top:20px;margin-bottom:12px;letter-spacing:-.03em;font-weight:700;color:var(--text-main)}.detail-kicker{font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted)}.detail-deck{font-size:1.05rem;color:var(--text-muted-soft);max-width:720px;line-height:1.8;margin-bottom:1.5rem}.detail-rule{border:0;border-top:1px solid var(--border-panel);margin:0 0 .75rem}.detail-meta-line{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);display:inline-flex;gap:.75rem;flex-wrap:wrap}.masthead-kicker{font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted);margin:0}.masthead-subtitle{margin-bottom:.75rem}.masthead-capabilities{font-size:1rem;color:var(--text-muted-soft);line-height:1.6;margin:0}.bio-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted);margin-bottom:.5rem;display:block}.home-project-preview{list-style:none;padding:0;margin:.75rem 0 0;display:flex;flex-direction:column;gap:.4rem}.home-project-preview li{font-size:.85rem;color:var(--text-muted);padding-left:.75rem;border-left:1px solid var(--border-panel);border-bottom:none;line-height:1.4;font-weight:400;flex:none;display:block}.nav-link-subtext{display:block;font-size:.9rem;color:var(--text-muted);margin-top:.5rem;line-height:1.6;font-weight:400}.projects-list{width:100%;padding-bottom:120px;gap:0;border-left:none}.project-row{display:grid;grid-template-columns:96px 56px 1fr auto;column-gap:1.5rem;padding:1.5rem 0 1.5rem .75rem;border-bottom:1px solid var(--border-panel);border-left:none;align-items:start;transition:border-color .35s cubic-bezier(.22,1,.36,1),box-shadow .35s cubic-bezier(.22,1,.36,1),padding-left .35s cubic-bezier(.22,1,.36,1),transform .35s cubic-bezier(.22,1,.36,1);width:100%;cursor:pointer}.project-row:hover{box-shadow:inset 3px 0 0 var(--accent-ice);border-bottom-color:var(--accent-ice)}.project-row:hover .project-row-title{color:var(--accent-ice)}.project-row-meta{grid-area:meta;font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.16em;display:flex;align-items:flex-start;padding-top:0}.project-row-main{grid-area:main;display:flex;flex-direction:column;gap:.5rem}.project-row-title{font-size:1.6rem;letter-spacing:-.03em;color:var(--text-main);margin:0;transition:color var(--transition)}.project-row-title-link{color:inherit;text-decoration:none}.project-row-tagline{margin:0;font-size:.98rem;line-height:1.7;color:var(--text-muted-soft)}.project-row-stack{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.35rem}.stack-tag{font-size:.72rem;padding:.18rem .6rem;border-radius:3px;border:1px solid var(--border-panel);color:var(--text-muted-soft);text-transform:uppercase;letter-spacing:.14em}.project-row-cta{grid-column:4;grid-row:1;display:flex;flex-direction:row;align-items:center;gap:.75rem;justify-content:flex-end}.project-row-read{font-size:.8rem;text-transform:uppercase;letter-spacing:.18em;color:var(--text-muted);text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap;transition:color var(--transition)}.project-row-read:hover{color:var(--text-main)}.project-row-github{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;border:1px solid var(--border-panel);color:var(--text-muted);transition:border-color var(--transition),color var(--transition),background-color var(--transition),transform var(--transition)}.project-row-github:hover{border-color:var(--accent-ice);color:var(--accent-ice);background-color:rgba(var(--accent-ice-rgb),.1);transform:translateY(-1px)}.project-row-link{display:grid;grid-column:1 / 4;grid-template-columns:96px 56px 1fr;grid-template-areas:"thumb meta main";column-gap:1.5rem;align-items:start;color:inherit;text-decoration:none;cursor:pointer}.project-row-thumb{grid-area:thumb;position:relative;width:80px;height:80px;flex-shrink:0}.project-row-thumb:before{content:"";position:absolute;inset:-4px;border:2px dashed rgba(var(--accent-ice-rgb),.35);border-radius:8px;transition:border-color .4s ease,box-shadow .4s ease;pointer-events:none}.project-row:hover .project-row-thumb:before{border-color:rgba(var(--accent-ice-rgb),.6);box-shadow:0 0 16px rgba(var(--accent-ice-rgb),.12)}.project-row-thumb-img{width:100%;height:100%;object-fit:cover;object-position:center;border-radius:4px;display:block;border:1px solid var(--border-panel)}.project-row-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:700;color:var(--text-muted);background:linear-gradient(135deg,rgba(var(--accent-ice-rgb),.08),#ffffff08);border:1px solid var(--border-panel);border-radius:4px}@media(max-width:768px){.project-row{grid-template-columns:1fr;row-gap:.75rem;padding:1rem 0}.project-row-link{grid-column:1;grid-template-columns:1fr;grid-template-areas:"thumb" "meta" "main";row-gap:.75rem}.project-row-thumb{width:72px;height:72px;justify-self:start}.project-row-cta{grid-column:1;grid-row:2;justify-content:flex-start;align-items:center}.project-row-read{padding:.5rem 0}}
