.planet-container{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:20;pointer-events:none;transition:z-index 0s}.planet-container:hover{z-index:50}.planet-trigger{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;pointer-events:auto;cursor:pointer;z-index:10}.planet-label{position:absolute;font-family:var(--font-body);font-size:.85rem;color:var(--text-secondary);white-space:nowrap;opacity:1;transform:translateY(0);transition:all .3s ease;letter-spacing:.05em;pointer-events:none}.planet-container:hover .planet-label{opacity:1;color:var(--text-primary)}.planet-body-float{width:100%;height:100%}.planet-body{width:100%;height:100%;position:relative;border-radius:50%;cursor:pointer;pointer-events:auto;box-shadow:inset -10px -10px 25px #000c,inset 3px 3px 8px #ffffff26,0 0 20px rgba(var(--planet-color-rgb, 100, 181, 246),.2);background:radial-gradient(circle at 30% 30%,var(--planet-color),#111 90%);transition:box-shadow .4s ease,transform .8s ease-in-out}.planet-container:hover .planet-body{box-shadow:inset -10px -10px 25px #000c,inset 3px 3px 10px #ffffff40,0 0 40px rgba(var(--planet-color-rgb, 100, 181, 246),.4);transform:rotate(360deg) scale(1.05)}.planet-container:active .planet-body{transform:scale(.9);transition:transform .1s ease}.planet-atmosphere{position:absolute;top:-8%;left:-8%;width:116%;height:116%;border-radius:50%;background:radial-gradient(circle at 50% 50%,transparent 65%,var(--planet-color));opacity:.1;pointer-events:none;filter:blur(4px)}.planet-surface{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;overflow:hidden;opacity:.5}.planet-surface:before{content:"";position:absolute;top:15%;left:-15%;width:130%;height:20%;background:#00000040;border-radius:50%;filter:blur(4px);transform:rotate(-10deg)}.planet-surface:after{content:"";position:absolute;bottom:20%;right:-15%;width:70%;height:25%;background:#ffffff08;border-radius:50%;filter:blur(6px);transform:rotate(-10deg)}.planet-preview-content{z-index:1000;outline:none}.planet-preview-card{border-radius:16px;overflow:hidden;box-shadow:0 25px 50px #00000080,0 0 0 1px #ffffff1a}.preview-image-wrapper{position:relative;padding:4px;background:linear-gradient(145deg,#1e1e23f2,#0f0f14fa);border-radius:16px;cursor:pointer;transition:all .2s ease}.preview-image-wrapper:hover{background:linear-gradient(145deg,#28282df2,#141419fa)}.preview-image{width:280px;height:175px;object-fit:cover;border-radius:12px;display:block}.preview-label{position:absolute;bottom:12px;left:12px;font-family:var(--font-body);font-size:.75rem;font-weight:500;color:#ffffffe6;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px 10px;border-radius:6px;letter-spacing:.03em}.planet-special .planet-body{box-shadow:inset -10px -10px 25px #0009,inset 3px 3px 8px #fff3,0 0 20px #4dd0e140;animation:specialGlow 4s ease-in-out infinite}.planet-special .planet-atmosphere{background:radial-gradient(circle at 50% 50%,transparent 60%,rgba(77,208,225,.4));opacity:.15}.planet-special .planet-label{font-weight:600}.planet-special:hover .planet-body{box-shadow:inset -10px -10px 25px #00000080,inset 3px 3px 10px #ffffff4d,0 0 35px #4dd0e166}@keyframes specialGlow{0%,to{box-shadow:inset -10px -10px 25px #0009,inset 3px 3px 8px #fff3,0 0 20px #4dd0e140}50%{box-shadow:inset -10px -10px 25px #0009,inset 3px 3px 8px #fff3,0 0 30px #4dd0e159}}.planet-disabled{opacity:.5}.planet-disabled .planet-body,.planet-disabled .planet-trigger{cursor:default}.planet-disabled:hover .planet-body{transform:none}@media (max-width: 768px){.planet-preview-content{display:none}.planet-container{position:relative!important;top:auto!important;left:auto!important;width:70px!important;height:70px!important;pointer-events:auto}.planet-label{position:relative;font-size:.75rem;margin-top:.5rem}.planet-trigger{min-width:44px;min-height:44px}}@media (max-width: 480px){.planet-container{width:55px!important;height:55px!important}.planet-label{font-size:.7rem}}@media (hover: none) and (pointer: coarse){.planet-preview-content{display:none}.planet-container:hover .planet-body{transform:none}.planet-trigger{min-width:44px;min-height:44px}}.landing-page{height:100vh;width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;z-index:10;overflow:hidden}.top-left-buttons{position:fixed;top:1.5rem;left:1.5rem;z-index:100;display:flex;gap:.75rem}.top-btn{display:inline-block;padding:.7rem 1.2rem;background:#14141ed9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:50px;color:#ffffffe6;font-family:var(--font-body);font-size:.85rem;font-weight:500;letter-spacing:.02em;text-decoration:none;transition:all .3s ease}.top-btn:hover{background:#ffffff1a;border-color:#ffffff4d;color:#ffffffe6;transform:translateY(-2px);box-shadow:0 10px 30px #0000004d}.hero-content{display:flex;flex-direction:column;align-items:center;position:relative;z-index:2}.hero-name-container{display:flex;flex-direction:column;align-items:center;line-height:.9}.hero-line{font-family:var(--font-hero);font-size:clamp(4rem,10vw,8rem);font-weight:700;color:var(--text-primary);letter-spacing:-.03em;white-space:nowrap;cursor:default}.hero-line:nth-child(2){color:transparent;-webkit-text-stroke:1px var(--text-primary);opacity:.5}.hero-role{font-family:var(--font-body);font-size:clamp(.9rem,1.2vw,1rem);color:var(--text-secondary);letter-spacing:.1em;text-transform:lowercase;margin-top:1.5rem;font-weight:500;text-align:center}.uwaterloo-link{color:#d4a44c;text-decoration:none;transition:all .2s ease}.uwaterloo-link:hover{color:#e8c068;text-shadow:0 0 8px rgba(212,164,76,.4)}.typing-container{display:flex;justify-content:center;align-items:center;margin-top:1rem;min-height:1.5rem}.typing-text{font-family:var(--font-body);font-size:clamp(.85rem,1.1vw,.95rem);color:#ffffffb3;letter-spacing:.1em;font-weight:400}.typing-cursor{font-family:var(--font-body);font-size:clamp(.85rem,1.1vw,.95rem);color:#ffffffb3;margin-left:2px;opacity:0;transition:opacity .1s}.typing-cursor.visible{opacity:1}.solar-system{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;pointer-events:none}.orbit-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border:1px dashed rgba(255,255,255,.03);border-radius:50%;pointer-events:none}.landing-socials{position:absolute;bottom:1.5rem;display:flex;gap:2rem;z-index:50}.social-icon{color:var(--text-secondary);width:20px;height:20px;transition:color var(--transition-normal),transform .2s ease;position:relative}.social-icon:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--text-primary);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.social-icon:hover{color:var(--text-primary);transform:translateY(-2px)}.social-icon:hover:after{transform:scaleX(1)}.email-icon{position:relative;width:22px;height:22px;top:-.7px}.email-tooltip{position:absolute;top:-36px;left:50%;transform:translate(-50%);padding:6px 12px;background:#000;border:1px solid rgba(255,255,255,.15);border-radius:6px;font-family:var(--font-body);font-size:.75rem;color:#fff;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;pointer-events:none;z-index:100}.email-icon:hover .email-tooltip{opacity:1;visibility:visible}@media (max-width: 1024px){.solar-system{transform:translate(-50%,-50%) scale(.85)}}@media (max-width: 768px){.landing-page{height:auto;min-height:100vh;min-height:100dvh;justify-content:flex-start;padding-top:4rem;padding-bottom:5rem;overflow:visible}.hero-content{margin-bottom:var(--space-lg)}.hero-line{font-size:12vw}.hero-role{font-size:.65rem;letter-spacing:.1em}.top-left-buttons{top:1rem;left:1rem}.top-btn{font-size:.75rem;padding:.5rem .9rem;min-height:44px;display:inline-flex;align-items:center}.landing-socials{bottom:1rem;gap:1.5rem}.social-icon{width:18px;height:18px}.solar-system{position:relative;top:auto;left:auto;transform:none;width:100%;height:auto;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:1.5rem;padding:var(--space-lg);margin-top:var(--space-lg)}.orbit-ring{display:none}.typing-container{padding:0 var(--space-md)}}@media (max-width: 480px){.hero-line{font-size:14vw}.hero-role{font-size:.55rem;margin-top:1rem;padding:0 var(--space-sm)}.solar-system{gap:1rem;padding:var(--space-md)}.top-left-buttons{top:.75rem;left:.75rem;gap:.5rem}.top-btn{font-size:.7rem;padding:.4rem .75rem;min-height:44px}.landing-socials{bottom:.75rem;gap:1.25rem}.typing-text{font-size:.75rem}}.signature-container{position:fixed;top:.85rem;right:3rem;z-index:1000;mix-blend-mode:difference}.signature-text{font-family:Dancing Script,cursive;font-size:1.8rem;color:var(--paint-white);font-weight:600;letter-spacing:1px}@media (max-width: 768px){.signature-container{top:1.5rem;right:1.5rem}.signature-text{font-size:1.5rem}}.back-button{position:fixed;top:1.5rem;left:1.5rem;display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#0d0d0dcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);border-radius:12px;color:var(--text-primary);font-size:1.5rem;cursor:pointer;transition:var(--transition-normal);z-index:100}.back-button:hover{border-color:#ffffff4d;background:#ffffff1a}@media (max-width: 768px){.back-button{top:1rem;left:1rem}}@media (max-width: 480px){.back-button{top:.75rem;left:.75rem;width:44px;height:44px;font-size:1.25rem;border-radius:10px}}.about-page{padding-top:80px;--section-accent: #64B5F6}.about-content{min-height:calc(100vh - 80px)}.about-layout{display:grid;grid-template-columns:340px 1fr;gap:var(--space-2xl);align-items:start}.about-left{position:sticky;top:100px;display:flex;flex-direction:column;align-items:center;text-align:center}.photo-carousel{width:100%;max-width:300px}.photo-frame{position:relative;width:100%;aspect-ratio:3 / 4;border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 30px #0003,inset 0 1px #ffffff0d;background:#12121899;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.photo-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:var(--radius-lg)}.photo-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-top:var(--space-md)}.photo-arrow{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.photo-arrow:hover{background:#ffffff1a}.photo-arrow svg{width:18px;height:18px}.photo-dots{display:flex;gap:8px}.photo-dot{width:10px;height:10px;border-radius:50%;background:#ffffff40;cursor:pointer;transition:all .2s ease}.photo-dot.active{background:#fff;transform:scale(1.3)}.about-name-block{margin-top:var(--space-sm)}.about-name-block h2{font-family:var(--font-hero);font-size:1.8rem;color:var(--text-primary);text-transform:none;letter-spacing:-.02em;margin-bottom:var(--space-xs)}.about-tagline{font-size:1rem;color:var(--text-accent);letter-spacing:.02em}.about-right{display:flex;flex-direction:column;gap:var(--space-lg)}.about-block{text-align:left}.about-block h3{font-family:var(--font-hero);font-size:1.3rem;color:var(--text-primary);margin-bottom:var(--space-md);text-transform:none;letter-spacing:-.01em;text-shadow:0 0 20px rgba(100,181,246,.15)}.about-block p{color:var(--text-secondary);line-height:1.85;font-size:1rem}.about-built-list{list-style:disc;padding-left:1.5rem;margin:0 0 var(--space-md) 0;color:var(--text-secondary);line-height:1.85;font-size:1rem}.about-built-list li{margin-bottom:var(--space-xs)}.about-interests{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:var(--space-lg)}.interest-item{padding:6px 14px;background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:100px;color:var(--text-secondary);font-size:.85rem;letter-spacing:.02em;transition:all .2s ease}.interest-item:hover{border-color:#64b5f64d;color:var(--text-primary)}@media (max-width: 1024px){.about-layout{grid-template-columns:1fr}.about-left{position:static}.photo-carousel{max-width:260px;margin:0 auto}}@media (max-width: 768px){.about-block{padding:var(--space-lg)}.about-block p{font-size:.95rem;line-height:1.75;word-wrap:break-word;overflow-wrap:break-word}.about-block h3{font-size:1.15rem}.about-built-list{font-size:.95rem;padding-left:1.25rem}.about-right{gap:var(--space-md)}}@media (max-width: 640px){.photo-carousel{max-width:220px}.about-name-block h2{font-size:1.5rem}}@media (max-width: 480px){.about-block{padding:var(--space-md)}.about-block p{font-size:.9rem;line-height:1.7}.about-block h3{font-size:1.1rem;margin-bottom:var(--space-sm)}.about-built-list{font-size:.9rem;padding-left:1rem}.interest-item{font-size:.8rem;padding:5px 10px}}.about-page.scroll-mode{padding-top:0}.about-page.scroll-mode .about-content{min-height:auto}.about-layout.scroll-mode-layout{grid-template-columns:1fr;max-width:800px;margin:0 auto}.experience-page{padding-top:80px;--section-accent: #9575CD}.experience-content{min-height:calc(100vh - 80px)}.exp-list{display:flex;flex-direction:column;gap:var(--space-2xl);max-width:900px;margin:0 auto}.exp-card{border-left:3px solid var(--section-accent);position:relative;max-width:700px}.exp-card:nth-child(odd){margin-left:0;margin-right:auto}.exp-card:nth-child(2n){margin-left:auto;margin-right:0}.exp-card:hover{box-shadow:0 8px 40px #9575cd14,inset 0 1px #ffffff14}.exp-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.exp-number{font-family:var(--font-hero);font-size:2.5rem;font-weight:700;opacity:.5;letter-spacing:-.04em;line-height:1;color:var(--text-primary)}.exp-meta{display:flex;align-items:center;gap:var(--space-sm)}.exp-actions{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.exp-type-badge{padding:4px 12px;border-radius:100px;font-size:.75rem;font-weight:600;letter-spacing:.03em}.exp-period{color:var(--text-secondary);font-size:.85rem}.exp-heading{margin-bottom:var(--space-lg)}.exp-title{font-family:var(--font-hero);font-size:1.6rem;color:var(--text-primary);text-transform:none;letter-spacing:-.02em;margin-bottom:4px}.exp-company{font-size:1rem;font-weight:600;letter-spacing:.01em;color:var(--text-secondary)}.exp-story{color:var(--text-secondary);line-height:1.85;font-size:1rem;margin-bottom:var(--space-md)}.exp-toggle{background:none;border:none;font-family:var(--font-body);font-size:.85rem;font-weight:500;cursor:pointer;padding:0;transition:opacity .2s ease;color:var(--text-primary)}.exp-toggle:hover{opacity:.7}.exp-details{overflow:hidden}.exp-detail-list{list-style:none;padding:var(--space-md) 0;border-top:1px solid rgba(255,255,255,.06)}.exp-detail-list li{position:relative;padding-left:var(--space-lg);margin-bottom:var(--space-sm);color:var(--text-secondary);line-height:1.7;font-size:.95rem}.exp-detail-list li:before{content:"→";position:absolute;left:0;color:var(--text-primary);opacity:.5}.exp-reference-btn{display:inline-block;padding:6px 14px;border:1px solid rgba(255,255,255,.3);border-radius:100px;font-family:var(--font-body);font-size:.8rem;font-weight:500;text-decoration:none;background:#ffffff08;cursor:pointer;transition:all .2s ease;color:var(--text-primary)}.exp-reference-btn:hover{background:#ffffff14}.exp-pdf-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:center;padding:var(--space-lg);z-index:1100}.exp-pdf-modal{position:relative;width:100%;max-width:960px;max-height:95vh;display:flex;flex-direction:column;overflow:hidden;border-top:2px solid var(--section-accent)}.exp-pdf-header{padding:var(--space-lg) var(--space-xl);display:flex;flex-direction:column;gap:var(--space-sm)}.exp-pdf-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);font-family:var(--font-body);font-size:.85rem;font-weight:500;cursor:pointer;padding:0;transition:color .2s ease;align-self:flex-start}.exp-pdf-back:hover{color:var(--text-primary)}.exp-pdf-title{font-family:var(--font-hero);font-size:1.4rem;color:var(--text-primary);text-transform:none;letter-spacing:-.02em;margin:0}.exp-pdf-frame{flex:1;min-height:0;padding:0 var(--space-xl)}.exp-pdf-frame iframe{width:100%;height:65vh;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);background:#0a0a0f}.exp-pdf-desc{padding:var(--space-md) var(--space-xl) var(--space-lg);color:var(--text-secondary);font-size:.9rem;line-height:1.6}.exp-tech{display:flex;flex-wrap:wrap;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid rgba(255,255,255,.06)}.exp-tech-item{padding:6px 14px;border:1px solid rgba(255,255,255,.2);border-radius:20px;font-size:.8rem;color:var(--text-secondary);background:#ffffff08;transition:all .2s ease}.exp-tech-item:hover{background:#ffffff14;color:var(--text-primary)}@media (max-width: 768px){.exp-card{max-width:100%}.exp-card:nth-child(odd),.exp-card:nth-child(2n){margin-left:0;margin-right:0}.exp-list{gap:var(--space-lg)}.exp-number{font-size:2rem}.exp-title{font-size:1.3rem}.exp-story{font-size:.9rem}.exp-detail-list li{font-size:.85rem}.exp-pdf-overlay{padding:var(--space-sm)}.exp-pdf-header{padding:var(--space-md)}.exp-pdf-frame{padding:0 var(--space-md)}.exp-pdf-frame iframe{height:55vh}.exp-pdf-desc{padding:var(--space-sm) var(--space-md) var(--space-md)}.exp-pdf-title{font-size:1.2rem}.exp-toggle,.exp-reference-btn{min-height:44px;display:inline-flex;align-items:center}}@media (max-width: 480px){.exp-top{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.exp-number{font-size:1.6rem}.exp-title{font-size:1.15rem}.exp-company{font-size:.9rem}.exp-story{font-size:.85rem;line-height:1.7}.exp-tech-item{font-size:.7rem;padding:4px 10px}}.experience-page.scroll-mode{padding-top:0}.experience-page.scroll-mode .experience-content{min-height:auto}.projects-page{padding-top:80px;--section-accent: #81C784}.projects-content{min-height:calc(100vh - 80px)}.projects-page .click-hint{color:var(--text-primary);font-weight:700}.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}.proj-card{cursor:pointer;transition:all .3s ease;overflow:hidden;display:flex;flex-direction:column;padding:var(--space-md)}.proj-card:hover{box-shadow:0 8px 30px #0006}.proj-carousel{position:relative}.proj-carousel-frame{aspect-ratio:16 / 10;overflow:hidden;background:#0a0a0f;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.12);position:relative}.proj-carousel-frame:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0a0f;z-index:0}.proj-carousel-img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;display:block;position:absolute;top:0;right:0;bottom:0;left:0}.proj-carousel-frame--vertical .proj-carousel-img{object-fit:cover;filter:brightness(.85)}.proj-carousel-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) 0 var(--space-xs)}.proj-carousel-arrow{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:none;border-radius:50%;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.proj-carousel-arrow:hover{background:#ffffff1f}.proj-carousel-arrow svg{width:14px;height:14px}.proj-carousel-dots{display:flex;gap:5px;align-items:center}.proj-carousel-dot{width:6px;height:6px;border-radius:50%;background:#ffffff40;cursor:pointer;transition:all .2s ease}.proj-carousel-dot.active{background:#fff;transform:scale(1.3)}.proj-info{padding:var(--space-lg) 0 0;display:flex;flex-direction:column;flex:1}.proj-carousel:has(.proj-carousel-controls)+.proj-info{padding-top:var(--space-md)}.proj-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-sm)}.proj-title{font-family:var(--font-hero);font-size:1.25rem;color:#fff;margin:0 0 var(--space-md) 0;text-transform:none;letter-spacing:-.01em}.proj-badge{padding:4px 12px;font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border-radius:4px;color:#fff;white-space:nowrap;flex-shrink:0}.proj-description{color:#fff;font-size:.9rem;line-height:1.65;margin-bottom:var(--space-lg);flex:1;opacity:.85}.proj-footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.proj-links{display:flex;flex-wrap:wrap;gap:var(--space-md)}.proj-link{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:500;text-decoration:none;color:#fff;opacity:.7;transition:all .2s ease}.proj-link:hover{opacity:1}.proj-link svg{opacity:.8}.proj-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:var(--space-xl);z-index:1000}.proj-modal{position:relative;width:100%;max-width:720px;max-height:90vh;overflow-y:auto;border-top:2px solid var(--proj-color, #81C784)}.proj-modal-close{position:absolute;top:var(--space-md);right:var(--space-md);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);border-radius:50%;color:var(--text-primary);cursor:pointer;z-index:10;transition:all .2s ease}.proj-modal-close:hover{background:#e639464d;border-color:#e6394680}.proj-modal-close svg{width:18px;height:18px}.proj-modal-award{text-align:center;padding:8px var(--space-lg);font-size:.85rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase}.proj-modal .proj-carousel{padding:0 var(--space-xl)}.proj-modal .proj-carousel-frame{aspect-ratio:16 / 9;margin:0;border-radius:var(--radius-lg)}.proj-modal-body{padding:var(--space-xl)}.proj-modal-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-md);flex-wrap:wrap}.proj-modal-title{font-family:var(--font-hero);font-size:1.8rem;color:var(--text-primary);text-transform:none;letter-spacing:-.02em;margin:0}.proj-modal-tagline{font-size:1rem;font-weight:700;margin-bottom:var(--space-lg);color:var(--text-primary)}.proj-modal-desc{color:var(--text-secondary);line-height:1.8;font-size:.95rem;margin-bottom:var(--space-xl);white-space:pre-line}.proj-modal-details{margin-bottom:var(--space-xl);padding-top:var(--space-md);border-top:1px solid rgba(255,255,255,.06)}.proj-modal-details h4{font-family:var(--font-hero);font-size:1rem;color:var(--text-primary);text-transform:none;margin-bottom:var(--space-md);letter-spacing:-.01em}.proj-modal-details ul{list-style:none;padding:0}.proj-modal-details li{position:relative;padding-left:var(--space-lg);margin-bottom:var(--space-sm);color:var(--text-secondary);line-height:1.7;font-size:.9rem}.proj-modal-details li:before{content:"→";position:absolute;left:0;color:var(--text-primary);opacity:.5}.proj-modal-tech{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-lg);padding-top:var(--space-md);border-top:1px solid rgba(255,255,255,.06)}.proj-tech-item{padding:6px 14px;border:1px solid rgba(255,255,255,.2);border-radius:20px;font-size:.8rem;color:var(--text-secondary);background:#ffffff08;transition:all .2s ease}.proj-tech-item:hover{background:#ffffff14;color:var(--text-primary)}.pdf-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:center;padding:var(--space-lg);z-index:1100}.pdf-modal{position:relative;width:100%;max-width:960px;max-height:95vh;display:flex;flex-direction:column;overflow:hidden;border-top:2px solid var(--proj-color, #42A5F5)}.pdf-modal-header{padding:var(--space-lg) var(--space-xl);display:flex;flex-direction:column;gap:var(--space-sm)}.pdf-modal-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);font-family:var(--font-body);font-size:.85rem;font-weight:500;cursor:pointer;padding:0;transition:color .2s ease;align-self:flex-start}.pdf-modal-back:hover{color:var(--text-primary)}.pdf-modal-title{font-family:var(--font-hero);font-size:1.4rem;color:var(--text-primary);text-transform:none;letter-spacing:-.02em;margin:0}.pdf-modal-frame{flex:1;min-height:0;padding:0 var(--space-xl)}.pdf-modal-frame iframe{width:100%;height:65vh;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);background:#0a0a0f}.pdf-modal-desc{padding:var(--space-md) var(--space-xl) var(--space-lg);color:var(--text-secondary);font-size:.9rem;line-height:1.6}button.proj-link{background:none;border:none;cursor:pointer;font-family:var(--font-body);padding:0}@media (max-width: 1024px){.proj-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.proj-grid{grid-template-columns:1fr;gap:var(--space-md)}.proj-card{padding:var(--space-sm)}.proj-modal-overlay{padding:var(--space-sm);align-items:flex-start;overflow-y:auto}.proj-modal{max-height:none;margin:var(--space-md) 0}.proj-modal .proj-carousel{padding:0 var(--space-md)}.proj-modal-body{padding:var(--space-md)}.proj-modal-title{font-size:1.3rem}.proj-modal-desc{font-size:.9rem}.proj-header{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.proj-carousel-arrow{width:32px;height:32px;min-width:44px;min-height:44px}.pdf-modal-overlay{padding:var(--space-sm)}.pdf-modal-header{padding:var(--space-md)}.pdf-modal-frame{padding:0 var(--space-md)}.pdf-modal-frame iframe{height:55vh}.pdf-modal-desc{padding:var(--space-sm) var(--space-md) var(--space-md)}.pdf-modal-title{font-size:1.2rem}}@media (max-width: 480px){.proj-card{padding:var(--space-xs)}.proj-title{font-size:1.1rem}.proj-description{font-size:.85rem}.proj-links{flex-direction:column;gap:var(--space-sm)}.proj-modal .proj-carousel{padding:0 var(--space-sm)}.proj-modal .proj-carousel-frame{margin:0}.proj-modal-body{padding:var(--space-sm)}.proj-modal-title{font-size:1.15rem}.proj-modal-close{width:44px;height:44px}}.projects-page.scroll-mode{padding-top:0}.projects-page.scroll-mode .projects-content{min-height:auto}.awards-page{padding-top:80px;--section-accent: #FFD54F}.awards-content{min-height:calc(100vh - 80px)}.awards-list{display:flex;flex-direction:column;gap:var(--space-md);max-width:800px;margin:0 auto}.award-card{border-left:3px solid var(--section-accent);transition:box-shadow .2s ease}.award-card:hover{box-shadow:0 8px 40px #ffd54f0f,inset 0 1px #ffffff14}.award-card.expanded{box-shadow:0 12px 48px #ffd54f14,inset 0 1px #ffffff1a}.award-card-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);padding:0;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit}.award-card-left{display:flex;align-items:center;gap:var(--space-lg);flex:1;min-width:0}.award-number{font-family:var(--font-hero);font-size:2rem;font-weight:700;opacity:.5;line-height:1;flex-shrink:0;color:var(--text-primary)}.award-card-info{flex:1;min-width:0}.award-title{font-family:var(--font-hero);font-size:1.15rem;color:var(--text-primary);text-transform:none;letter-spacing:-.01em;line-height:1.3;margin-bottom:6px}.award-meta{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.award-org{color:var(--text-secondary);font-size:.85rem}.award-date{padding:3px 10px;border:1px solid rgba(255,255,255,.3);border-radius:100px;font-size:.75rem;font-weight:600;color:var(--text-primary)}.award-card-right{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.award-has-images{display:flex;align-items:center;justify-content:center;opacity:.6;color:var(--text-primary)}.award-has-images svg{width:18px;height:18px}.award-expand-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#ffffff0d;transition:background .2s ease;color:var(--text-primary)}.award-card-header:hover .award-expand-icon{background:#ffffff1a}.award-expand-icon svg{width:16px;height:16px}.award-card-content{overflow:hidden}.award-card-inner{padding-top:var(--space-lg);border-top:1px solid rgba(255,255,255,.06);margin-top:var(--space-lg)}.award-description{color:var(--text-secondary);font-size:.95rem;line-height:1.8;margin-bottom:var(--space-lg)}.award-images{display:flex;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-lg);overflow-x:auto;padding-bottom:var(--space-sm)}.award-image-wrapper{flex-shrink:0;width:280px;height:210px;border-radius:var(--radius-md);overflow:hidden;border:1px solid rgba(255,255,255,.08)}.award-image-wrapper img{width:100%;height:100%;object-fit:cover;display:block}.award-image-square{width:280px;height:210px}.award-link{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid rgba(255,255,255,.3);border-radius:100px;font-size:.85rem;font-weight:500;text-decoration:none;color:var(--text-primary);background:#ffffff08;transition:all .2s ease;margin-bottom:var(--space-lg)}.award-link:hover{background:#ffffff14}.award-accent-line{width:50px;height:3px;border-radius:2px;opacity:.5;background:var(--text-primary)}.click-hint{color:var(--section-accent);font-weight:600}@media (max-width: 768px){.award-card-left{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.award-number{font-size:1.5rem}.award-title{font-size:1.05rem}.award-description{font-size:.9rem}.award-images{flex-direction:column;align-items:stretch}.award-image-wrapper{width:100%;max-width:100%;height:auto;aspect-ratio:4 / 3}.award-image-square{width:100%;height:auto;aspect-ratio:4 / 3}.award-expand-icon{width:44px;height:44px}.award-card-header{gap:var(--space-md)}}@media (max-width: 480px){.award-card-header{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.award-card-right{align-self:flex-end}.award-meta{flex-direction:column;align-items:flex-start;gap:6px}.award-number{font-size:1.25rem}.award-title{font-size:.95rem}.award-description{font-size:.85rem}.award-link{font-size:.8rem;padding:6px 12px;min-height:44px;display:inline-flex;align-items:center}}.awards-page.scroll-mode{padding-top:0}.awards-page.scroll-mode .awards-content{min-height:auto}.resume-page{padding-top:80px;--section-accent: #F48FB1}.resume-content{min-height:calc(100vh - 80px)}.resume-viewer{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-md)}.resume-frame{border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(255,255,255,.1);background:#0a0a0f}.resume-frame iframe{width:100%;height:75vh;border:none;display:block}.resume-actions{display:flex;justify-content:flex-end}.resume-download-btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:.85rem;font-weight:500;color:#f48fb1;text-decoration:none;padding:8px 18px;border:1px solid rgba(244,143,177,.3);border-radius:100px;background:#f48fb10d;transition:all .2s ease}.resume-download-btn:hover{background:#f48fb11f;border-color:#f48fb180}@media (max-width: 768px){.resume-frame iframe{height:60vh}}@media (max-width: 480px){.resume-frame iframe{height:50vh}}.resume-page.scroll-mode{padding-top:0}.resume-page.scroll-mode .resume-content{min-height:auto}.summary-page{min-height:100vh;padding:2rem;position:relative}.back-button{position:fixed;top:1.5rem;left:1.5rem;background:#12121899;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);color:var(--text-primary);padding:.5rem 1rem;border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-body);font-size:.9rem;z-index:100;transition:all .2s ease;box-shadow:0 4px 20px #0003}.back-button:hover{background:#121218cc;border-color:#fff3}.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto;gap:1.25rem;max-width:1200px;margin:0 auto;padding-top:3rem}.bento-card{background:#12121899;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:1.5rem;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;box-shadow:0 4px 30px #0003,inset 0 1px #ffffff0d}.bento-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.bento-card:hover{border-color:#ffffff26;transform:translateY(-3px);box-shadow:0 8px 40px #0000004d,0 0 20px color-mix(in srgb,var(--card-section-color, #64B5F6) 10%,transparent)}.card-label{display:inline-block;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);margin-bottom:.75rem;padding:.25rem .6rem;background:#ffffff0a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.06);border-radius:100px}.highlight-label{background:#ffd54f1a;border-color:#ffd54f33;color:#ffd54f}.profile-card{grid-column:span 2;grid-row:span 2;cursor:default;border-left:2px solid transparent;border-image:linear-gradient(180deg,#64b5f6,#9575cd) 1}.profile-card:hover{box-shadow:0 8px 40px #0000004d,0 0 25px #64b5f614}.profile-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:1.25rem}.profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#64b5f6,#9575cd);display:flex;align-items:center;justify-content:center;font-family:var(--font-hero);font-style:italic;font-size:1.5rem;color:#fff;box-shadow:0 0 20px #64b5f633;flex-shrink:0}.profile-info h1{font-family:var(--font-hero);font-size:1.8rem;color:var(--text-primary);margin:0;letter-spacing:-.02em}.profile-title{color:var(--text-accent);font-size:.95rem;margin:.2rem 0}.profile-school{color:var(--text-secondary);font-size:.85rem;margin:0}.profile-bio{color:var(--text-secondary);font-size:.9rem;line-height:1.7;margin-bottom:1.25rem}.profile-links{display:flex;flex-wrap:wrap;gap:.75rem}.profile-links a{color:var(--text-secondary);font-size:.85rem;padding:.4rem .8rem;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:100px;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.profile-links a:hover{color:var(--text-primary);border-color:#64b5f64d;background:#64b5f614;box-shadow:0 0 12px #64b5f61a}.exp-card h3{font-family:var(--font-hero);font-size:1.05rem;color:var(--text-primary);margin-bottom:.25rem;letter-spacing:-.01em;text-transform:none}.exp-card .company{color:var(--text-accent);font-size:.85rem;margin-bottom:.15rem}.exp-card .period{display:inline-block;color:var(--text-secondary);font-size:.75rem;margin-bottom:.75rem;padding:.15rem .5rem;background:#ffffff0a;border-radius:100px}.exp-card:hover{border-color:#9575cd4d;box-shadow:0 8px 40px #0000004d,0 0 20px #9575cd1a}.project-card h3{font-family:var(--font-hero);font-size:1.05rem;color:var(--text-primary);margin-bottom:.5rem;letter-spacing:-.01em;text-transform:none}.project-card .description{color:var(--text-secondary);font-size:.85rem;line-height:1.5;margin-bottom:.75rem}.project-card:hover{border-color:#81c7844d;box-shadow:0 8px 40px #0000004d,0 0 20px #81c7841a}.tech-tags{display:flex;flex-wrap:wrap;gap:.4rem}.tech-tags span{font-size:.7rem;padding:.2rem .5rem;background:#64b5f61a;color:#64b5f6;border-radius:100px;border:1px solid rgba(100,181,246,.15)}.skills-card{grid-column:span 2}.skills-card:hover{border-color:#4dd0e14d;box-shadow:0 8px 40px #0000004d,0 0 20px #4dd0e11a}.skills-grid-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1rem}.skill-category-mini{display:flex;align-items:center;gap:.5rem;padding:.45rem .6rem;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-sm);font-size:.75rem;color:var(--text-secondary);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}.top-skills{display:flex;flex-wrap:wrap;gap:.4rem}.top-skills span{font-size:.75rem;padding:.3rem .6rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);color:var(--text-primary);border-radius:100px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.awards-summary-card:hover{border-color:#ffd54f4d;box-shadow:0 8px 40px #0000004d,0 0 20px #ffd54f1a}.awards-list{display:flex;flex-direction:column;gap:.7rem}.award-item{display:flex;align-items:center;gap:.7rem;font-size:.85rem;color:var(--text-secondary)}.award-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}.cta-card{text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center;background:#121218b3;border:1px solid rgba(100,181,246,.15)}.cta-card:hover{border-color:#64b5f64d;box-shadow:0 8px 40px #0000004d,0 0 25px #64b5f61a}.cta-card h3{font-family:var(--font-hero);font-size:1.15rem;color:var(--text-primary);margin-bottom:.3rem;letter-spacing:-.01em;text-transform:none}.cta-card p{color:var(--text-secondary);font-size:.85rem;margin-bottom:1rem}.cta-button{display:inline-block;padding:.6rem 1.4rem;background:linear-gradient(135deg,#64b5f6,#9575cd);color:#fff;border-radius:100px;font-size:.85rem;font-weight:500;transition:all .3s ease;box-shadow:0 4px 15px #64b5f633}.cta-button:hover{transform:scale(1.05);box-shadow:0 4px 25px #64b5f659}@media (max-width: 1024px){.bento-grid{grid-template-columns:repeat(2,1fr)}.profile-card,.skills-card{grid-column:span 2}}@media (max-width: 640px){.summary-page{padding:4rem 1rem 1rem}.bento-grid{grid-template-columns:1fr;gap:.75rem}.profile-card,.skills-card{grid-column:span 1}.skills-grid-mini{grid-template-columns:repeat(2,1fr)}.profile-links{gap:.5rem}}.mobile-notice-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--space-lg)}.mobile-notice-card{background:#14141ef2;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);padding:var(--space-xl) var(--space-lg);max-width:340px;width:100%;text-align:center;box-shadow:0 20px 60px #00000080}.mobile-notice-title{font-family:var(--font-hero);font-size:1.4rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-md)}.mobile-notice-body{font-family:var(--font-body);font-size:.95rem;line-height:1.6;color:var(--text-secondary);margin-bottom:var(--space-xl)}.mobile-notice-btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 40px;min-height:44px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:100px;color:var(--text-primary);font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.mobile-notice-btn:active{background:#ffffff26}.scroll-view{min-height:100vh;scroll-behavior:smooth}.scroll-back-btn{position:fixed;top:1.5rem;left:1.5rem;display:inline-block;padding:.7rem 1.2rem;background:#14141ed9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:50px;color:#ffffffe6;font-family:var(--font-body);font-size:.85rem;font-weight:500;letter-spacing:.02em;text-decoration:none;z-index:100;transition:all .3s ease;cursor:pointer}.scroll-back-btn:hover{background:#ffffff1a;border-color:#ffffff4d;color:#ffffffe6;transform:translateY(-2px);box-shadow:0 10px 30px #0000004d}.scroll-back-btn svg{width:16px;height:16px}.scroll-hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:var(--space-3xl) var(--space-2xl);position:relative}.scroll-hero-content{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);max-width:950px;margin:0 auto;width:100%}.scroll-hero-text{flex:1;max-width:550px}.scroll-hero-name{font-family:var(--font-hero);font-size:clamp(3rem,7vw,5rem);font-weight:700;letter-spacing:-.03em;line-height:1.1;margin-bottom:var(--space-md)}.scroll-hero-role{font-size:1.35rem;color:var(--text-secondary);margin-bottom:var(--space-sm)}.scroll-hero-role .uwaterloo-link{color:#d4a44c;text-decoration:none;font-weight:600;transition:all .2s ease}.scroll-hero-role .uwaterloo-link:hover{color:#e8c068;text-shadow:0 0 8px rgba(212,164,76,.4)}.scroll-typing-container{font-size:1.65rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-xl);height:2.5rem}.scroll-typing-text{color:var(--text-primary)}.scroll-typing-cursor{color:var(--text-primary);opacity:0;transition:opacity .1s ease}.scroll-typing-cursor.visible{opacity:1}.scroll-hero-socials{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg)}.scroll-social-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-primary);transition:all .2s ease}.scroll-social-icon:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-2px)}.scroll-social-icon svg{width:22px;height:22px}.scroll-resume-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:100px;color:var(--text-primary);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:var(--font-body)}.scroll-resume-btn:hover{background:#ffffff1f;border-color:#ffffff40}.scroll-resume-btn svg{width:18px;height:18px}.scroll-hero-media{flex-shrink:0}.scroll-photo-carousel{width:380px}.scroll-photo-frame{aspect-ratio:3 / 4;border-radius:var(--radius-lg);overflow:hidden;background:#12121899;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 30px #0003,inset 0 1px #ffffff0d;position:relative}.scroll-photo-img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-lg)}.scroll-photo-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) 0 0}.scroll-photo-arrow{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:50%;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.scroll-photo-arrow:hover{background:#ffffff1a}.scroll-photo-arrow svg{width:18px;height:18px}.scroll-photo-dots{display:flex;gap:8px;align-items:center}.scroll-photo-dot{width:10px;height:10px;border-radius:50%;background:#ffffff40;cursor:pointer;transition:all .2s ease}.scroll-photo-dot.active{background:#fff;transform:scale(1.3)}.scroll-indicator{position:absolute;bottom:var(--space-xl);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);color:var(--text-secondary);font-size:.8rem;font-family:var(--font-body);background:none;border:none;cursor:pointer;transition:color .2s ease;animation:bounce 2s infinite}.scroll-indicator:hover{color:var(--text-primary)}.scroll-indicator svg{width:20px;height:20px}@keyframes bounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(8px)}}.scroll-content{position:relative}.scroll-content>section{scroll-margin-top:20px}.section-divider{display:flex;align-items:center;justify-content:center;padding:var(--space-lg) 0;max-width:900px;margin:0 auto}.section-divider:before{content:"";width:100%;max-width:550px;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent)}.scroll-view .page-container{padding-top:var(--space-xl);min-height:auto}.scroll-view .page-container .section{padding-bottom:var(--space-2xl)}@media (max-width: 1024px){.scroll-hero-content{flex-direction:column-reverse;text-align:center}.scroll-hero-text{max-width:100%;display:flex;flex-direction:column;align-items:center}.scroll-photo-carousel{width:260px}.scroll-hero-role{font-size:1.15rem}}@media (max-width: 768px){.scroll-hero{min-height:100vh;min-height:100dvh;padding:calc(var(--space-3xl) + 1rem) var(--space-lg) calc(var(--space-3xl) + 4rem)}.scroll-hero-name{font-size:clamp(2.2rem,10vw,3.5rem)}.scroll-typing-container{font-size:1.1rem;height:auto;min-height:1.8rem}.scroll-hero-role{font-size:1rem}.scroll-photo-carousel{width:220px}.scroll-back-btn{top:var(--space-md);left:var(--space-md);padding:8px 14px;font-size:.8rem;min-height:44px}.scroll-resume-btn{padding:12px 22px;font-size:.9rem;margin-bottom:var(--space-xl)}.scroll-indicator{bottom:var(--space-lg)}.section-divider{padding:var(--space-md) 0}}@media (max-width: 480px){.scroll-hero{padding:calc(var(--space-2xl) + 1rem) var(--space-md) calc(var(--space-2xl) + 4rem)}.scroll-hero-name{font-size:clamp(1.8rem,12vw,2.8rem)}.scroll-hero-role{font-size:.85rem}.scroll-typing-container{font-size:.95rem}.scroll-hero-socials{gap:var(--space-sm)}.scroll-social-icon{width:40px;height:40px}.scroll-social-icon svg{width:18px;height:18px}.scroll-photo-carousel{width:180px}.scroll-resume-btn{padding:10px 20px;font-size:.85rem}.scroll-indicator{bottom:var(--space-md)}}.notfound-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-xl)}.notfound-content{text-align:center;max-width:400px}.notfound-planet{width:80px;height:80px;border-radius:50%;margin:0 auto var(--space-xl);background:radial-gradient(circle at 35% 35%,#555,#1a1a1a 70%);box-shadow:inset -10px -10px 20px #000c,inset 5px 5px 10px #ffffff0d,0 0 30px #64b5f61a;animation:float-404 4s ease-in-out infinite}@keyframes float-404{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.notfound-code{font-family:var(--font-hero);font-size:5rem;color:var(--text-primary);letter-spacing:-.03em;margin-bottom:var(--space-sm);opacity:.9}.notfound-message{font-size:1.1rem;color:var(--text-secondary);margin-bottom:var(--space-2xl);line-height:1.6}.notfound-btn{padding:.7rem 1.5rem;background:#12121899;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(100,181,246,.25);border-radius:100px;color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #0003}.notfound-btn:hover{border-color:#64b5f680;box-shadow:0 4px 25px #64b5f626}.digital-background{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1;background:transparent;pointer-events:none}.loader-container{position:fixed;top:0;left:0;width:100%;height:100vh;background-color:#0d0d0d;display:flex;justify-content:center;align-items:center;z-index:9999}.loader-content{display:flex;flex-direction:column;align-items:center;gap:2rem;width:300px}.hobby-text{font-family:var(--font-hero);font-size:2.5rem;color:var(--paint-white);font-weight:700;text-transform:lowercase;height:3rem;display:flex;align-items:center;justify-content:center;white-space:nowrap}.progress-bar-container{width:100%;height:2px;background-color:#ffffff1a;border-radius:4px;overflow:hidden}.progress-bar{height:100%;background-color:var(--paint-white);border-radius:4px;transition:width .03s linear}@media (max-width: 768px){.hobby-text{font-size:2rem}.loader-content{width:80%}}.cursor-dot{position:fixed;top:0;left:0;width:16px;height:16px;background:radial-gradient(circle,#fff,#fffc,#fff0);border-radius:50%;pointer-events:none;z-index:10000;mix-blend-mode:difference}.cursor-dot.hovering{background:radial-gradient(circle,#64b5f6,#64b5f6cc,#64b5f600);mix-blend-mode:normal}@media (hover: hover){html,body,#root{cursor:none!important}*,*:before,*:after{cursor:none!important}a,button,[role=button],input,textarea,select{cursor:none!important}}@media (hover: none) and (pointer: coarse){.cursor-dot,.cursor-ring{display:none}html,body,#root,*,*:before,*:after{cursor:auto!important}}.availability-badge{position:fixed;bottom:1.5rem;right:1.5rem;z-index:100;display:flex;align-items:center;padding:.6rem 1.2rem;background:#0f0f14d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:100px;box-shadow:0 4px 20px #0000004d;text-decoration:none;cursor:pointer;transition:all .25s ease}.availability-badge:hover{background:#19191ee6;border-color:#ffffff40;transform:translateY(-2px);box-shadow:0 6px 25px #0006}.pulse-dot{width:6px;height:6px;border-radius:50%;background:#81c784;margin-right:.5rem;flex-shrink:0;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 4px #81c78466;opacity:1}50%{box-shadow:0 0 10px #81c784cc;opacity:.7}}.badge-text{font-family:var(--font-body);font-size:.8rem;font-weight:500;color:#ffffffe6;letter-spacing:.03em}@media (max-width: 640px){.availability-badge{bottom:1rem;right:1rem;padding:.4rem .8rem}.badge-text{font-size:.65rem}.pulse-dot{width:5px;height:5px}}@media (max-width: 400px){.badge-text{display:none}.availability-badge{padding:.5rem;border-radius:50%}.pulse-dot{width:8px;height:8px}}.floating-dock{position:fixed;top:1rem;left:80px;display:flex;align-items:flex-end;gap:8px;padding:8px 12px 10px;background:#1e1e23cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;border:1px solid rgba(255,255,255,.1);z-index:100;height:auto}.dock-item-link{text-decoration:none}.dock-item{position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer}.dock-item.selected .dock-planet-orb{box-shadow:0 0 0 2px #64b5f6,0 0 10px #64b5f666!important}.dock-planet-orb{width:100%;height:100%;border-radius:50%;transition:box-shadow .2s ease}.dock-tooltip{position:absolute;bottom:-32px;left:50%;padding:4px 10px;background:#0f0f14f2;border:1px solid rgba(255,255,255,.1);border-radius:6px;font-family:var(--font-body);font-size:.7rem;font-weight:500;color:#e0e0e0;white-space:nowrap;pointer-events:none}@media (max-width: 768px){.floating-dock{top:auto;bottom:1rem;left:50%;transform:translate(-50%);padding:8px 16px;gap:10px;border-radius:50px}.dock-tooltip{bottom:auto;top:-32px}}@media (max-width: 480px){.floating-dock{gap:8px;padding:6px 12px}}.warp-transition{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:radial-gradient(ellipse at center,#080810,#000);display:flex;align-items:center;justify-content:center;overflow:hidden}.warp-streaks{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.warp-streak{position:absolute;top:50%;left:50%;width:2px;height:2px;background:#fff;border-radius:1px;transform-origin:center;transform:rotate(var(--angle)) translate(var(--offset));animation:warpStreak .8s ease-out var(--delay) forwards;opacity:0}@keyframes warpStreak{0%{opacity:0;height:2px;transform:rotate(var(--angle)) translate(var(--offset))}15%{opacity:.9;height:var(--length)}to{opacity:0;height:var(--length);transform:rotate(var(--angle)) translate(calc(var(--offset) + 400px))}}.warp-center{position:absolute;top:50%;left:50%;width:8px;height:8px;background:#fff;border-radius:50%;transform:translate(-50%,-50%);animation:centerFlash .8s ease-out forwards;box-shadow:0 0 20px #fffc,0 0 40px #fff6}@keyframes centerFlash{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}20%{opacity:1;transform:translate(-50%,-50%) scale(1)}60%{opacity:1;transform:translate(-50%,-50%) scale(3)}to{opacity:0;transform:translate(-50%,-50%) scale(50)}}@media (max-width: 768px){.warp-streak{--length: 80px}}:root{--color-bg: #0D0D0D;--color-surface: #151515;--color-border: rgba(255, 255, 255, .08);--text-primary: #E0E0E0;--text-secondary: #888888;--text-accent: #E0E0E0;--planet-about: #64B5F6;--planet-experience: #9575CD;--planet-projects: #81C784;--planet-skills: #4DD0E1;--planet-awards: #FFD54F;--font-hero: "Playfair Display", serif;--font-display: "Space Grotesk", -apple-system, BlinkMacSystemFont, sans-serif;--font-body: "Space Grotesk", -apple-system, BlinkMacSystemFont, sans-serif;--font-signature: "Playfair Display", serif;--font-handwritten: "Playfair Display", serif;--paint-white: #E0E0E0;--text-cyan: #4DD0E1;--neon-cyan: #4DD0E1;--neon-cyan-dim: rgba(77, 208, 225, .3);--neon-highlight: #64B5F6;--neon-purple: #9575CD;--void-deep: #0D0D0D;--void-light: #1E1E2E;--glow-cyan: 0 0 20px rgba(77, 208, 225, .15);--font-tech: "Space Grotesk", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "Space Grotesk", monospace;--glass-bg: rgba(15, 15, 18, .8);--glass-blur: blur(12px);--glass-shadow: 0 4px 30px rgba(0, 0, 0, .3);--ease-tech: cubic-bezier(.23, 1, .32, 1);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--radius-full: 50%;--transition-fast: .15s ease;--transition-normal: .3s ease;--ease-smooth: cubic-bezier(.23, 1, .32, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;background-color:var(--color-bg)}body{font-family:var(--font-body);background:var(--color-bg);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}.font-hero{font-family:var(--font-hero)}.font-tech{font-family:var(--font-tech)}.font-mono{font-family:var(--font-mono)}h1,h2,h3,h4,h5,h6{font-family:var(--font-hero);font-weight:700;line-height:1.1;letter-spacing:.05em}h1{font-size:clamp(2.5rem,5vw,4.5rem);text-shadow:var(--glow-cyan)}h2{font-size:clamp(2rem,4vw,3.5rem)}h3{font-size:clamp(1.5rem,3vw,2.5rem);color:var(--text-cyan)}a{color:var(--text-cyan);text-decoration:none;transition:all .2s var(--ease-tech)}a:hover{color:var(--neon-highlight);text-shadow:0 0 8px var(--neon-highlight)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-md) var(--space-xl);font-family:var(--font-tech);font-size:1.1rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;background:#00f3ff1a;border:1px solid var(--neon-cyan);color:var(--neon-cyan);border-radius:var(--radius-sm);cursor:pointer;transition:all .3s var(--ease-tech);position:relative;overflow:hidden;box-shadow:0 0 10px #00f3ff33}.btn:hover{background:var(--neon-cyan);color:var(--void-deep);box-shadow:0 0 20px var(--neon-cyan)}.card{background:#12121899;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:0 4px 30px #0003,inset 0 1px #ffffff0d;transition:transform .3s var(--ease-tech),border-color .3s ease,box-shadow .3s ease;position:relative}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.card:hover{transform:translateY(-4px);border-color:#ffffff26;box-shadow:0 8px 40px #0000004d,inset 0 1px #ffffff14}.section{width:100%;max-width:1400px;margin:0 auto;padding:var(--space-lg) var(--space-xl) var(--space-3xl)}.section-header{text-align:center;margin-bottom:var(--space-2xl)}.section-title{font-family:var(--font-hero);font-size:clamp(2.5rem,5vw,4rem);color:var(--text-primary);margin-bottom:var(--space-md);position:relative;display:inline-block;letter-spacing:-.02em;-webkit-text-stroke:1px rgba(255,255,255,.5);text-shadow:0 0 30px var(--section-accent, rgba(100, 181, 246, .2))}.section-title:after{content:"";display:block;width:60px;height:2px;background:var(--section-accent, var(--text-secondary));margin:10px auto 0;opacity:.6;box-shadow:0 0 10px var(--section-accent, transparent)}.section-subtitle{font-family:var(--font-body);font-size:1.1rem;color:var(--text-secondary);max-width:600px;margin:0 auto;letter-spacing:.02em}.grid{display:grid;gap:var(--space-xl)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-col{flex-direction:column}.w-full{width:100%}.h-full{height:100%}.relative{position:relative}.absolute{position:absolute}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--void-deep)}::-webkit-scrollbar-thumb{background:var(--void-light);border:1px solid var(--neon-cyan-dim)}::-webkit-scrollbar-thumb:hover{background:var(--neon-cyan)}::selection{background:var(--neon-cyan);color:var(--void-deep)}.page-container{min-height:100vh;width:100%}.gradient-text{background:linear-gradient(135deg,var(--neon-cyan) 0%,var(--neon-purple) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 5px rgba(0,243,255,.3))}:focus-visible{outline:1px solid rgba(100,181,246,.5);outline-offset:2px;border-radius:4px;box-shadow:0 0 12px #64b5f626}button:focus-visible,a:focus-visible{outline:1px solid rgba(100,181,246,.5);outline-offset:2px;box-shadow:0 0 12px #64b5f626}@media (max-width: 768px){:root{--space-xs: .25rem;--space-sm: .4rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem;--space-2xl: 2rem;--space-3xl: 3rem}.section{padding:var(--space-md) var(--space-lg) var(--space-2xl)}.section-title{font-size:clamp(1.8rem,5vw,3rem)}.section-subtitle{font-size:.95rem}}@media (max-width: 480px){:root{--space-xs: .2rem;--space-sm: .35rem;--space-md: .6rem;--space-lg: .85rem;--space-xl: 1.25rem;--space-2xl: 1.75rem;--space-3xl: 2.5rem}.section{padding:var(--space-sm) var(--space-md) var(--space-xl)}.section-title{font-size:clamp(1.5rem,6vw,2.5rem)}.section-subtitle{font-size:.85rem;padding:0 var(--space-sm)}.card{padding:var(--space-lg)}}
