:root{--primary-accent: #1a1a1a;--primary-hover: #444444;--secondary-accent: #f0f0f0;--active-accent: #000000;--hover-bg: #f8f8f8;--hover-border: #cccccc;--bg-border: var(--hover-border);--text-dark: #1a1a1a;--text-main: #333;--text-muted: #666;--text-subtle: #888;--text-description: #444;--bg-white: #ffffff;--border-color: #dddddd;--shadow-light: rgba(0, 0, 0, .05);--shadow-medium: rgba(0, 0, 0, .1);--shadow-heavy: rgba(0, 0, 0, .1);--shadow-accent: rgba(0, 0, 0, .1);--tag-bg: #f0f0f0}*{margin:0;padding:0;box-sizing:border-box}.center{display:flex;justify-content:center;align-items:center}*::-webkit-scrollbar{display:none}*{-ms-overflow-style:none;scrollbar-width:none}body{font-family:Poppins,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:var(--text-main);background-image:linear-gradient(180deg,transparent 0%,#ffffff 70%);background-attachment:fixed;min-height:100vh;animation:backgroundCycle 20s ease infinite}@keyframes backgroundCycle{0%{background-color:#f0f7ff}20%{background-color:#fff5f5}40%{background-color:#f2fff9}60%{background-color:#f8f4ff}80%{background-color:#fffcf2}to{background-color:#f0f7ff}}.navbar{background-color:transparent;position:relative;display:flex;flex-direction:column}.navbar.navbar--menu-open{background-color:var(--bg-white)}.nav-container{max-width:800px;margin:0 auto;position:relative;display:flex;align-items:center;justify-content:center}.nav-links{display:flex;justify-content:center;gap:40px;padding:25px 0}.nav-links a{text-decoration:none;color:var(--text-muted);transition:color .3s ease;position:relative;padding-bottom:4px}.nav-links a:hover{color:var(--hover-border)}.main-content{max-width:1000px;margin:0 auto 100px;min-height:calc(100vh - 80px)}.hero-section{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:60px}.headline{font-size:2.5rem;font-weight:700;color:var(--text-dark);margin-bottom:30px;letter-spacing:-.5px}.map-container{width:500px;height:200px;margin-bottom:20px;border-radius:15px 15px 0 0;overflow:hidden}#map{width:100%;height:100%}.map-row{width:100%;display:flex;flex-direction:column;align-items:center;margin:40px 0 0}.map-title{font-size:1.1rem;font-weight:600;color:var(--text-dark);margin-bottom:12px;letter-spacing:.5px;text-transform:lowercase}.map-row .map-container{order:1;margin-bottom:0}.location-details-panel{order:2;width:500px;max-height:200px;background:var(--bg-white);padding:14px;display:flex;flex-direction:column;-webkit-mask-image:linear-gradient(to bottom,black 60%,transparent 100%);mask-image:linear-gradient(to bottom,black 60%,transparent 100%);overflow:auto;position:relative;transition:max-height .5s cubic-bezier(.4,0,.2,1)}.location-details-panel.expanded{max-height:250px}.panel-content-fade{animation:panelFadeIn .4s ease-out forwards;display:flex;flex-direction:column}@keyframes panelFadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.panel-view{display:flex;flex-direction:column}.section p{text-align:center;color:var(--text-muted);font-size:1rem;width:100%;margin:0 auto 30px}.location-back{appearance:none;color:var(--text-dark);text-align:left;border:1px solid var(--border-color);padding:.3rem .5rem;background:transparent;cursor:pointer;font-size:.9rem;position:relative;transition:color .2s ease}.location-back:after{content:"";position:absolute;width:100%;height:1px;bottom:-1px;left:0;background-color:var(--bg-border);transform:scaleX(0);transform-origin:bottom right;transition:transform .3s ease-out}.location-back:hover:after{transform:scaleX(1);transform-origin:bottom left}.location-details-header{display:flex;justify-content:space-between;align-items:flex-start}.location-details-title{font-size:1.05rem;font-weight:700;color:var(--text-dark);margin:0 0 4px}.location-details-subtitle{font-size:.85rem;color:var(--text-muted);margin-bottom:10px}.locations-list{display:flex;flex-direction:column;gap:8px;overflow:auto;padding-right:2px}.location-item{appearance:none;background:transparent;border:none;color:var(--primary-accent);text-align:left;padding:5px 10px;cursor:pointer;font-weight:400;transition:background-color .2s ease,border-color .2s ease,transform .05s ease}.location-item:hover{background:var(--secondary-accent);border-color:var(--bg-border)}.location-item:active{transform:translateY(1px)}.location-item.active{background:var(--secondary-accent);border-color:var(--primary-accent);color:var(--active-accent)}.location-details-body{margin-top:12px;text-align:left;padding-right:2px}.location-selected-name{font-size:1.05rem;font-weight:800;color:var(--text-dark);margin-bottom:6px}.location-selected-subtitle{font-size:.9rem;color:var(--text-muted);margin-bottom:10px}.location-selected-description{font-size:.95rem;color:var(--text-description);line-height:1.5;margin-bottom:12px}.location-images{column-count:2;column-gap:8px}.location-images img{width:100%;height:auto;display:block;break-inside:avoid;-webkit-column-break-inside:avoid;margin:0 0 8px}@media(min-width:900px){.location-images{column-count:3}}@media(max-width:480px){.location-images{column-count:1}}.location-muted{color:var(--text-subtle)}.profile-section{display:flex;flex-direction:row;padding:1.5rem;align-items:center;gap:2rem;width:100%;max-width:600px;margin:0 auto}.profile-intro{display:flex;flex-direction:column;align-items:start;text-align:left;flex:1;gap:.2rem}.profile-name{color:var(--text-dark);font-size:2rem;font-weight:700;line-height:1.2}.profile-role{font-size:1.2rem;color:var(--primary-accent);font-weight:500}.profile-desc{font-size:1rem;color:var(--text-muted);line-height:1.6;margin-bottom:1rem}.profile-contact{display:flex;align-items:flex-start;gap:1rem;width:100%}.profile-contact a{display:flex;align-items:center;text-decoration:none;color:var(--text-muted);transition:all .3s ease;line-height:1}.profile-contact a:hover{color:var(--bg-border);transform:translateY(-2px)}.profile-contact a svg{display:block}.avatar{width:180px;height:180px;border-radius:50%;object-fit:cover;box-shadow:0 4px 10px #00000026;border:none}.outline-button{display:inline-block;padding:2px 0;color:var(--primary-accent);text-decoration:none;font-weight:500;position:relative;transition:color .3s ease}.outline-button:after{content:"";position:absolute;width:100%;height:2px;bottom:-2px;left:0;background-color:var(--bg-border);transform:scaleX(0);transform-origin:bottom right;transition:transform .3s ease-out}.outline-button:hover{background-color:transparent;color:var(--primary-accent)}.outline-button:hover:after{transform:scaleX(1);transform-origin:bottom left}.outline-button.resume{border:1px solid var(--border-color);padding:.3rem .5rem}button.outline-button.resume{appearance:none;background:transparent;cursor:pointer;font:inherit}.resume-overlay{position:fixed;inset:0;background:#ffffffb8;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:24px 16px}.resume-menu{width:min(350px,calc(100vw - 30px));border:1px solid var(--border-color);background:var(--bg-white);box-shadow:#64646f2e 0 14px 40px;padding:14px;border-radius:14px}.resume-menu-title{font-size:.95rem;font-weight:600;color:var(--text-dark);margin-bottom:10px;text-transform:lowercase;letter-spacing:-.2px}.resume-menu-options{display:grid;grid-template-columns:1fr;gap:10px}.resume-option{display:inline-flex;align-items:center;justify-content:center;padding:10px 12px;border:1px solid var(--border-color);color:var(--text-main);text-decoration:none;background:transparent;transition:all .15s ease;text-transform:lowercase;font-weight:500}.resume-option:hover{border-color:var(--bg-border);color:var(--primary-accent);background:color-mix(in srgb,var(--bg-white) 80%,var(--hover-bg));transform:translateY(-2px)}.resume-option:active{transform:translateY(0)}.project-link{text-decoration:none;font-weight:500;font-size:.9rem;color:var(--primary-accent);position:relative;transition:color .3s ease}.project-link:not(.primary){padding:2px 0}.project-link:not(.primary):after{content:"";position:absolute;width:100%;height:2px;bottom:-2px;left:0;background-color:var(--bg-border);transform:scaleX(0);transform-origin:bottom right;transition:transform .3s ease-out}.project-link:not(.primary):hover{background-color:transparent;color:var(--primary-accent)}.project-link:not(.primary):hover:after{transform:scaleX(1);transform-origin:bottom left}.project-link.primary{background-color:var(--primary-accent);color:var(--bg-white);padding:8px 16px;border-radius:6px}.project-link.primary:hover{background-color:var(--primary-hover)}.experiences-timeline{margin-top:20px;position:relative;width:100%}:root{--exp-work: #2d7ff9;--exp-swe: #a855f7;--exp-volunteer: #22c55e}.experiences-type-legend{width:fit-content;display:flex;justify-content:flex-start;gap:12px;margin:1.5rem 0 0;align-self:flex-start;border:1px solid var(--border-color);border-radius:12px;padding:.45rem .8rem}.experiences-type-pill{appearance:none;background:transparent;border:0;padding:0;cursor:pointer;font-size:.95rem;font-weight:500;display:inline-flex;align-items:center;gap:5px;opacity:.65;position:relative}.experiences-type-pill:before{content:"";width:10px;height:10px;border-radius:999px;background:currentColor;display:inline-block}.experiences-type-pill.all{color:var(--text-muted)}.experiences-type-pill.work{color:var(--exp-work)}.experiences-type-pill.swe{color:var(--exp-swe)}.experiences-type-pill.volunteer{color:var(--exp-volunteer)}.experiences-type-pill:hover,.experiences-type-pill.active{opacity:1}.experience-role h3.position{display:inline-block}.experience-card{background-color:transparent;border-radius:0;box-shadow:none;padding:0 0 10px 30px;margin-bottom:0;margin-left:0;position:relative;border-left:1px solid var(--border-color)}.experience-card--reveal{opacity:0;transform:translate(-18px);transition:opacity .65s ease,transform .65s cubic-bezier(.22,1,.36,1);will-change:opacity,transform}.experience-card--reveal.is-inview{opacity:1;transform:translate(0)}.experience-card--reveal.is-inview:before{transform:translate(-50%) translateZ(0)}.experience-card:last-child{padding-bottom:0}.experience-card:before{content:"";position:absolute;left:0;top:5px;border-radius:50%;background-color:var(--exp-work);width:10px;height:10px;border:1px solid var(--border-color);transform:translate(-50%);box-shadow:none;z-index:1}.experience-card.swe:before{background-color:var(--exp-swe)}.experience-card.volunteer:before{background-color:var(--exp-volunteer)}.experience-header{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:10px;gap:4px}.experience-role h3{font-size:1.1rem;font-weight:600;color:var(--text-dark);margin-bottom:2px}.experience-role h4{font-size:.95rem;color:var(--text-muted);font-weight:400}.experience-meta{text-align:left;color:var(--text-subtle);font-size:.85rem}.duration,.location{display:inline}.location:before{content:" • "}.experience-description{color:var(--text-muted);line-height:1.5;margin-bottom:15px;font-size:.9rem;text-align:left}.section .experience-description{text-align:left}.experience-achievements h5{font-size:.9rem;font-weight:600;color:var(--text-dark);margin-bottom:8px}.experience-achievements ul{list-style-type:none;padding:0}.experience-achievements li{color:var(--text-muted);line-height:1.4;margin-bottom:6px;position:relative;padding-left:15px;font-size:.85rem}.experience-achievements li:before{content:"-";position:absolute;left:0;color:var(--text-subtle)}.experience-tech{display:flex;flex-wrap:wrap;gap:6px;margin-top:15px}.contact-content{text-align:center;width:100%;margin:1.5rem 0 0}.contact-info p{font-size:1rem;color:var(--text-muted);line-height:1.6;margin-bottom:25px}.contact-methods{display:flex;flex-direction:row;gap:14px;justify-content:center;flex-wrap:wrap;text-align:center;width:100%}.contact-info a{color:var(--text-muted);text-decoration:none;border-bottom:1px solid transparent;transition:all .2s ease}.contact-info a:hover{color:var(--hover-border)}.contact-social{display:inline-flex;align-items:center;gap:5px;padding:10px 14px;background:transparent;box-shadow:none;color:var(--text-muted);border:0;cursor:pointer;font:inherit}.contact-social-label{font-size:.92rem;font-weight:500;letter-spacing:-.2px}.navbar--dark{background-color:#0a0a0c}.navbar--dark .nav-links a{color:#ffffff8c}.navbar--dark .nav-links a:hover,.navbar--dark .nav-links a.active{color:#ffffffe6}.navbar--dark .nav-links a:after{background-color:#fff6}.navbar--dark .nav-hamburger-label{color:#ffffffa6}.nav-links a.active{color:var(--text-muted);text-decoration:none}.nav-links a:after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background-color:var(--bg-border);transform:scaleX(0);transform-origin:bottom right;transition:transform .25s ease}.nav-links a:hover:after{transform:scaleX(1);transform-origin:bottom left}.nav-links a.active:after{transform:scaleX(1);transform-origin:bottom left}.nav-hamburger{display:none;appearance:none;background:transparent;border:0;padding:10px 12px;margin-left:auto;cursor:pointer;gap:10px;align-items:center}.nav-hamburger-label{font-size:2rem;color:var(--text-muted);letter-spacing:-.2px;text-transform:lowercase}.nav-hamburger:hover .nav-hamburger-label{color:var(--primary-accent)}.nav-dropdown{display:none}.section{width:100%;max-width:500px;margin:0 auto;display:flex;flex-direction:column;align-items:center;min-height:calc(100vh - 120px);justify-content:flex-start}.section h2{font-size:2rem;font-weight:600;color:var(--text-dark);margin-bottom:25px;text-align:center;letter-spacing:-.5px;text-transform:lowercase}.projects-grid{display:grid;grid-template-columns:1fr;gap:20px;width:100%;margin-top:20px}.section.projects-section{max-width:1100px;width:95%;padding:0}.projects-filter-row{width:100%;display:flex;justify-content:flex-start;margin:0;margin-top:1.5rem}.projects-loading-hint{width:100%;text-align:left;color:var(--text-muted);font-size:.9rem;margin-top:10px}.projects-filter{position:relative;display:inline-flex;align-items:center}.projects-filter-trigger{appearance:none;background-color:transparent;color:var(--text-main);border:1px solid var(--border-color);border-radius:10px;padding:.45rem .8rem;font-size:.95rem;font-weight:400;box-shadow:#64646f1f 0 6px 18px;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem}.projects-filter-caret{display:inline-block;font-size:.8rem;opacity:.8;line-height:1;transition:transform .15s ease}.projects-filter-trigger[aria-expanded=true] .projects-filter-caret{transform:rotate(-90deg)}.projects-filter-menu{position:absolute;top:50%;left:calc(100% + 10px);transform:translateY(-50%);display:flex;flex-direction:row;gap:.5rem;background-color:transparent;z-index:20;white-space:nowrap}.projects-filter-option{appearance:none;background:transparent;border:1px solid transparent;color:var(--text-main);border-radius:999px;padding:.35rem .7rem;font-size:.9rem;cursor:pointer}.projects-filter-option:hover{border-color:var(--bg-border);color:var(--primary-accent)}.projects-filter-option.active{color:var(--primary-accent)}@media(min-width:1025px){.projects-section .projects-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}}@media(min-width:769px)and (max-width:1024px){.projects-section .projects-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}}@media(max-width:768px){.projects-section .projects-grid{grid-template-columns:1fr}}.project-card{background-color:var(--bg-white);border-radius:0;padding:1.4em 1.1em;text-align:center;border:0;display:flex;flex-direction:column;height:100%;border:1px solid var(--border-color);position:relative;overflow:hidden;transition:transform .2s linear;transform-style:preserve-3d;backface-visibility:hidden;-webkit-backface-visibility:hidden}.project-card-anim-wrap{perspective:1200px;transform:translateZ(0);transition:transform .2s linear}.project-card-anim-wrap.has-image:not(.is-loaded){opacity:0}.project-card-anim-wrap.is-loaded .project-card{animation:projectCardFlipIn .65s cubic-bezier(.22,1,.36,1) both;animation-delay:0ms;will-change:transform,opacity}@keyframes projectCardFlipIn{0%{opacity:0;transform:rotateY(90deg)}to{opacity:1;transform:rotateY(0)}}@media(prefers-reduced-motion:reduce){.project-card-anim-wrap .project-card{animation:none}}.project-card-anim-wrap:hover{transform:translateY(-7px)}.project-image{width:100%;height:auto;overflow:hidden;margin-bottom:1em;border-radius:0;background-color:transparent}.project-image img{width:100%;height:auto;display:block;object-fit:cover;backface-visibility:hidden;-webkit-backface-visibility:hidden;transform:translateZ(0)}.project-content{padding:0;display:flex;flex-direction:column;flex:1}.project-title-container{display:flex;flex-direction:column;gap:4px;margin-bottom:.6rem}.project-title{font-size:1.2rem;font-weight:700;color:var(--text-dark);margin:0;letter-spacing:-.3px}.project-subtitle{font-size:.9rem;font-weight:300;opacity:.8;color:var(--text-muted)}.project-description{color:var(--text-muted);line-height:1.5;font-size:1rem;text-align:center;flex:0 0 auto}.section .project-description{margin:0;font-size:.9rem;line-height:1.5;color:var(--text-muted)}.project-tech{display:flex;flex-wrap:wrap;gap:0;margin:.9em 0 0;justify-content:center}.tech-tag{background-color:transparent;border:1px solid var(--bg-border);color:var(--text-muted);border-radius:.5rem;font-size:.75rem;font-weight:500;margin:.35em;padding:.35em .7em}.project-links{display:flex;gap:15px;justify-content:center;margin-top:.8em}.project-link-icon{color:var(--text-muted);transition:all .2s ease;display:flex;align-items:center;justify-content:center;opacity:1;padding:0}.project-link-icon:hover{color:var(--bg-border)}.skills-section{margin-top:2rem;width:100%}.skills-section h3{font-size:1.1rem;font-weight:600;color:var(--text-dark);margin-bottom:15px;text-align:left}.skills-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start;width:100%;margin-bottom:30px}.skill-tag{background-color:transparent;color:var(--text-main);padding:4px 10px;border-radius:4px;font-size:.85rem;font-weight:400;border:1px solid var(--border-color);transition:all .2s ease}.skill-tag:hover{background-color:var(--text-dark);color:var(--bg-white);transform:none}.skills-bubbles-section{justify-content:center;margin-top:1.5rem;max-width:1100px;width:95%;min-height:auto}.skills-bubbles-stage{position:relative;width:min(800px,92vw);height:min(520px,62vh);overflow:hidden;background:transparent;--mx: 50%;--my: 50%;--mactive: 0}.skills-bubbles-stage:after{content:"";position:absolute;left:var(--mx);top:var(--my);width:44px;height:44px;border-radius:999px;border:1px solid color-mix(in srgb,var(--bg-border) 85%,transparent);background:color-mix(in srgb,var(--bg-white) 88%,transparent);transform:translate(-50%,-50%);opacity:calc(var(--mactive) * .85);pointer-events:none;transition:opacity .12s ease;mix-blend-mode:multiply}.skills-bubble{position:absolute;left:0;top:0;display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:999px;border:1px solid var(--border-color);background:color-mix(in srgb,var(--bg-white) 88%,transparent);color:var(--text-main);font-size:.92rem;font-weight:450;letter-spacing:-.2px;white-space:nowrap;-webkit-user-select:none;user-select:none;pointer-events:auto;will-change:transform}.skills-bubble:hover{border-color:var(--bg-border)}@media(max-width:768px){.skills-bubbles-stage{height:min(560px,72vh);width:calc(100% - 30px);margin-left:15px;margin-right:15px;box-sizing:border-box}.skills-bubble{padding:6px 10px;font-size:.82rem}}@media(max-width:420px){.skills-bubbles-stage{height:min(520px,70vh)}.skills-bubble{padding:5px 9px;font-size:.78rem}}.main-content.main-content--full{max-width:none;margin-bottom:0;padding:0}@media(max-width:768px){.main-content.main-content--full{padding:0;margin:0}.App:has(.hackathons-section),body:has(.hackathons-section){background:#0a0a0c}}.hackathons-section{height:calc(100vh - 80px);max-width:none;min-height:unset;align-items:stretch;overflow:hidden;background:#0a0a0c}.hackathons-sticky{height:calc(100vh - 80px);display:flex;flex-direction:column;overflow:clip;position:relative}.hackathons-bg-number{position:absolute;top:50%;left:3vw;transform:translateY(-50%);font-size:48vw;font-weight:900;line-height:.82;background:linear-gradient(125deg,#ffffff61,#ffffff29 30%,#ffffff75 50%,#ffffff24 68%,#ffffff52);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:blur(1.5px);pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0;opacity:0;transition:opacity .45s ease}.hackathons-viewport{flex:1;position:relative;overflow:hidden;perspective:1000px;perspective-origin:50% 50%}.hackathon-intro{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:0 12vw;opacity:0;pointer-events:none;transition:opacity .45s ease;z-index:1}.hackathon-intro.active{opacity:1;pointer-events:auto}.hackathon-intro-body{display:flex;flex-direction:column;align-items:center;gap:32px;text-align:center}.hackathon-intro-quote{font-size:clamp(1.8rem,3.2vw,2.8rem);font-style:italic;font-weight:400;color:#fffc;line-height:1.65;margin:0}.hackathon-intro-hint{font-size:3rem;font-style:italic;letter-spacing:.12em;color:#ffffff38;margin:0}.hackathon-wheel-wrap{position:absolute;left:100%;top:50%;transform:translate(-50%,-50%);width:min(92vh,82vw);height:min(92vh,82vw);opacity:0;transition:opacity .5s ease;pointer-events:none;z-index:0}.hackathon-wheel-wrap.visible{opacity:1}.hackathon-wheel{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(255,255,255,.09);background:radial-gradient(circle at center,rgba(255,255,255,.03) 0%,rgba(255,255,255,.008) 50%,transparent 100%);box-shadow:0 0 120px #ffffff0a,inset 0 0 100px #ffffff05;transform:rotate(270deg);transition:transform .65s cubic-bezier(.25,.46,.45,.94);transform-origin:center center}.hackathon-wheel-tick{position:absolute;inset:0;transform:rotate(var(--angle, 0deg));transform-origin:center center}.hackathon-wheel-label{position:absolute;top:calc(6% + 14px);left:50%;transform:translate(-50%);writing-mode:vertical-lr;font-size:.65rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:#ffffff47;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none}.hackathon-wheel-tick:after{content:"";position:absolute;top:6px;left:50%;transform:translate(-50%);width:2px;height:6%;background:#ffffff47;border-radius:1px}.hackathon-wheel-notch{position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:22px;border-radius:2px;background:#ffffffe6;box-shadow:0 0 6px #fffc,0 0 18px #ffffff73,0 0 40px #fff3;z-index:2}@keyframes card-emerge{0%{transform:translateY(-50%) translate(44vw) scale(.74);opacity:0;filter:blur(6px)}55%{opacity:1;filter:blur(0)}to{transform:translateY(-50%) translate(0) scale(1);opacity:1;filter:blur(0)}}@keyframes card-recede{0%{transform:translateY(-50%) translate(0) scale(1);opacity:1;filter:blur(0)}45%{opacity:0;filter:blur(4px)}to{transform:translateY(-50%) translate(44vw) scale(.74);opacity:0;filter:blur(6px)}}.hackathon-slide{position:absolute;right:4vw;top:50%;width:58vw;height:calc(100vh - 284px);transform:translateY(-50%);opacity:0;pointer-events:none;z-index:1}.hackathon-slide.active{opacity:1;pointer-events:auto}.hackathon-slide.card-emerge{animation:card-emerge .32s cubic-bezier(.22,.61,.36,1) forwards}.hackathon-slide.card-recede{animation:card-recede .18s ease-in forwards;pointer-events:none}.hackathon-slide:before{content:"";position:absolute;top:0;left:10%;right:10%;height:220px;background:radial-gradient(ellipse at top,rgba(255,255,255,.13) 0%,transparent 68%);pointer-events:none;z-index:2;opacity:0;transition:opacity .35s ease}.hackathon-slide:has(.hackathon-slide-content.focused):before{opacity:1}@keyframes hackathon-idle-pulse{0%,to{opacity:.4}50%{opacity:.9}}.hackathon-slide-content{position:relative;height:100%;padding:28px 36px;overflow-y:auto;overflow-x:hidden;background:#0e0e12e0;backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%);border:1px dashed rgba(255,255,255,.55);box-shadow:0 8px 32px #0009,0 2px 6px #0000004d;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent;cursor:pointer;animation:none;transition:border .25s ease,box-shadow .3s ease;z-index:1}.hackathon-slide.active .hackathon-slide-content:not(.focused){animation:hackathon-idle-pulse 1.2s ease-in-out infinite}.hackathon-slide-content.focused{opacity:1;border:1px solid rgba(255,255,255,.4);cursor:auto;animation:none;box-shadow:inset 0 80px 60px -30px #ffffff0f,inset 0 1.5px #ffffff2e,0 8px 32px #0009,0 2px 6px #0000004d}.hackathon-slide-content::-webkit-scrollbar{width:3px}.hackathon-slide-content::-webkit-scrollbar-track{background:transparent}.hackathon-slide-content::-webkit-scrollbar-thumb{background:#ffffff2e;border-radius:2px}.hackathon-slide-content .hackathon-name{font-size:2.2rem;font-weight:600;color:#ffffffeb;margin-bottom:10px;line-height:1.2;text-align:left!important}.hackathon-slide-content .hackathon-award{display:inline-flex;align-items:center;gap:5px;font-size:.7rem;font-weight:600;letter-spacing:.06em;color:#ffdc50e6;background:#ffc8281a;border:1px solid rgba(255,200,40,.25);border-radius:4px;padding:3px 8px;margin-bottom:10px;text-transform:uppercase}.hackathon-slide-content .hackathon-highlight{font-size:1.05rem;color:#ffffff7a;line-height:1.65;text-align:left!important;margin:0}.hackathon-slide-content .hackathon-highlight+.hackathon-highlight{margin-top:1em}.hackathon-preview-label{position:absolute;left:calc(100% - (min(92vh,82vw)/2) + 22px);top:50%;transform:translateY(-56%);font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#ffffffbf;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .18s ease;z-index:3;-webkit-user-select:none;user-select:none}.hackathon-preview-label.visible{opacity:1}.hackathon-cursor-tip{position:absolute;pointer-events:none;transform:translate(-50%,calc(-100% - 10px));background:#ffffff1f;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);color:#ffffffd9;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:4px;white-space:nowrap;opacity:0;transition:opacity .15s ease;z-index:10}.hackathon-cursor-tip.visible{opacity:1}.hackathon-slide-images{columns:3;column-gap:6px;margin-top:2em}.hackathon-slide-image{width:100%;break-inside:avoid;margin-bottom:6px;border-radius:3px;overflow:hidden;filter:brightness(.45) saturate(.7);transition:filter .3s ease;cursor:default}.hackathon-slide-content.focused .hackathon-slide-image{filter:brightness(1) saturate(1)}.hackathon-slide-image img{width:100%;height:auto;display:block}.hackathons-nav-row{display:flex;align-items:center;justify-content:center;gap:16px;padding:14px 0 12px;flex-shrink:0;position:relative;z-index:10}.hackathon-nav-arrow{appearance:none;border:none;background:none;color:#ffffff73;font-size:1.1rem;cursor:pointer;padding:4px 8px;line-height:1;transition:color .2s ease;flex-shrink:0}.hackathon-nav-arrow:hover:not(:disabled){color:#ffffffe0}.hackathon-nav-arrow:disabled{color:#ffffff1f;cursor:default}.hackathons-nav-dots{display:flex;align-items:center;gap:8px}.hackathon-dot-nav{appearance:none;border:none;padding:0;cursor:pointer;width:6px;height:6px;border-radius:50%;background:#ffffff38;transition:background .25s ease,transform .25s ease;flex-shrink:0}.hackathon-dot-nav:hover{background:#ffffff8c;transform:scale(1.3)}.hackathon-dot-nav.active{background:#ffffffe6;transform:scale(1.4)}.hackathon-mobile-name,.hackathon-mobile-hint,.hackathon-mobile-return,.hackathon-mobile-quote{display:none}@media(max-width:768px){.hackathon-wheel-wrap{left:50%;top:58%;transform:translate(-50%,-50%);width:min(76vw,48vh);height:min(76vw,48vh);opacity:1;pointer-events:auto;transition:opacity .4s ease}.hackathons-viewport.mobile-card-view .hackathon-wheel-wrap{opacity:0;pointer-events:none}.hackathons-bg-number{left:50%;top:58%;transform:translate(-50%,-50%);font-size:30vw;transition:opacity .4s ease;z-index:1}.hackathon-intro{display:none}.hackathon-mobile-quote{display:flex;align-items:center;justify-content:center;position:absolute;left:0;right:0;top:0;height:calc(58% - (min(76vw,48vh)/2) - 10px);padding:50px 8vw 10px;text-align:center;font-size:clamp(.72rem,2.2vw,.9rem);font-style:italic;font-weight:400;color:#fff9;line-height:1.65;pointer-events:none;-webkit-user-select:none;user-select:none;transition:opacity .3s ease;z-index:2;margin:0}.hackathons-viewport.mobile-card-view .hackathon-mobile-quote{opacity:0;pointer-events:none}.hackathon-mobile-name{display:block;position:absolute;left:50%;top:calc(58% + min(76vw,48vh)/2 + 22px);transform:translate(-50%);text-align:center;font-size:1rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:#fffc;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;transition:opacity .3s ease;z-index:2}.hackathon-mobile-hint{display:block;position:absolute;left:50%;top:calc(58% + min(76vw,48vh)/2 + 56px);transform:translate(-50%);text-align:center;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:#ffffff38;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;transition:opacity .4s ease;z-index:2;margin:0}.hackathons-viewport.mobile-card-view .hackathon-mobile-name,.hackathons-viewport.mobile-card-view .hackathon-mobile-hint{opacity:0;pointer-events:none}.hackathon-mobile-return{display:block;position:absolute;top:14px;left:14px;background:#ffffff12;border:1px solid rgba(255,255,255,.18);color:#ffffffb8;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;padding:8px 14px;border-radius:4px;cursor:pointer;z-index:10;opacity:0;pointer-events:none;transition:opacity .3s ease}.hackathons-viewport.mobile-card-view .hackathon-mobile-return{opacity:1;pointer-events:auto}.hackathons-section,.hackathons-sticky{height:calc(100dvh - 80px)}.hackathon-slide{right:5vw;left:5vw;width:auto;top:54px;bottom:0;height:auto;transform:none}.hackathon-slide:before{display:none}.hackathon-slide-content{padding:16px 18px 28px;overflow-y:scroll;-webkit-overflow-scrolling:touch}.hackathon-slide-content .hackathon-name{font-size:1.65rem}.hackathon-slide-content .hackathon-highlight{font-size:.9rem}.hackathon-slide-image{filter:brightness(1) saturate(1)}.hackathon-cursor-tip{display:none}@keyframes card-emerge-mobile{0%{opacity:0;transform:scale(.94);filter:blur(4px)}to{opacity:1;transform:scale(1);filter:blur(0)}}@keyframes card-recede-mobile{0%{opacity:1;transform:scale(1);filter:blur(0)}to{opacity:0;transform:scale(.94);filter:blur(4px)}}.hackathon-slide.card-emerge{animation:card-emerge-mobile .32s cubic-bezier(.22,.61,.36,1) forwards}.hackathon-slide.card-recede{animation:card-recede-mobile .2s ease-in forwards}.hackathon-wheel-label,.hackathons-nav-row{display:none}}@media(max-width:768px){.profile-section{flex-direction:column;text-align:center;align-items:center;gap:1.5rem}.main-content{padding:12px 20px 20px;margin-bottom:60px}.profile-intro{align-items:center;text-align:center}.nav-links{display:none}.nav-container{max-width:none;width:100%;margin:0;justify-content:flex-start}.nav-hamburger{display:inline-flex;margin-left:0;margin-right:auto}.nav-dropdown{display:flex;flex-direction:column;gap:0;position:static;width:100%;background-color:var(--bg-white);border-top:1px solid var(--border-color);z-index:50}.nav-dropdown a{text-decoration:none;color:var(--text-muted);padding:14px 20px;width:100%;display:block}.nav-dropdown a:hover{color:var(--primary-accent)}.nav-dropdown a+a{border-top:1px solid rgba(0,0,0,.06)}.map-container{height:150px;width:100%}.map-row{flex-direction:column}.location-details-panel{width:100%;max-height:100px}.profile-contact{justify-content:center}.location-details-panel.expanded{max-height:150px}.locations-list{max-height:120px}.avatar{width:120px;height:120px}.project-links{flex-direction:row;justify-content:center}}@media(max-width:480px){.projects-filter-row{padding:0 15px;margin-top:.75rem}.projects-filter{width:100%}.projects-filter-menu{position:fixed;transform:translateY(-50%);max-width:calc(100vw - 30px);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding:.35rem;border:0;border-radius:0;box-sizing:border-box}.projects-filter-menu{gap:.25rem}.projects-filter-option{border:0;font-size:.82rem;padding:.25rem .5rem}.projects-grid{padding:0 15px}.experiences-type-legend{margin-left:15px;margin-right:15px;margin-top:.75rem}.experiences-timeline{padding:0 15px}.contact-content{padding:0 15px;box-sizing:border-box}.nav-links{gap:15px}.nav-links a{font-size:.85rem}}
