:root{--bg: #04040a;--panel: rgba(10, 12, 30, .86);--panel-border: rgba(172, 131, 230, .45);--purple: #ac83e6;--green: #69bf41;--orange: #ffa53d;--blue: #0096ff;--text: #f4f1fb;--muted: #b9b4d6;--mono: "Nanum Gothic Coding", monospace;--sans: "Space Grotesk", sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-user-select:none;-moz-user-select:none;user-select:none;scrollbar-width:thin;scrollbar-color:var(--purple) rgba(10,12,30,.6)}body{background:var(--bg);color:var(--text);font-family:var(--sans);overflow-x:hidden;line-height:1.6}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:#080a18b3}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--purple),var(--blue));border-radius:999px;border:3px solid rgba(8,10,24,.7);box-shadow:inset 0 0 6px #0006}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#c19cff,#38aaff)}::-webkit-scrollbar-corner{background:transparent}#bg{position:fixed;inset:0;width:100vw;height:100vh;z-index:-2;display:block}#scrim{position:fixed;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(120% 90% at 50% 0%,#04040a38,#04040a8c 55%,#04040acc),linear-gradient(90deg,#04040ab8,#04040a5c 30% 70%,#04040ab8)}#loader{position:fixed;inset:0;z-index:100;display:grid;place-items:center;background:radial-gradient(circle at 50% 40%,#ac83e61f,#04040a00 60%),var(--bg);transition:opacity .8s ease,visibility .8s ease}#loader.hidden{opacity:0;visibility:hidden}.loaderInner{display:flex;flex-direction:column;align-items:center;gap:1.4rem}.loaderRing{position:relative;width:96px;height:96px;display:grid;place-items:center}.loaderRingArc{position:absolute;inset:0;border-radius:50%;background:conic-gradient(from 0deg,rgba(172,131,230,0) 0deg,var(--purple) 140deg,var(--blue) 240deg,rgba(0,150,255,0) 360deg);-webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 4px),#000 calc(100% - 3px));mask:radial-gradient(farthest-side,transparent calc(100% - 4px),#000 calc(100% - 3px));animation:loaderSpin 1.1s linear infinite;filter:drop-shadow(0 0 10px rgba(172,131,230,.6))}.loaderLogo{width:48px;height:48px;object-fit:contain;filter:drop-shadow(0 0 12px rgba(172,131,230,.8));animation:loaderPulse 1.8s ease-in-out infinite}@keyframes loaderSpin{to{transform:rotate(360deg)}}@keyframes loaderPulse{0%,to{transform:scale(1);opacity:.92}50%{transform:scale(1.08);opacity:1}}.loaderName{font-family:var(--mono);font-size:clamp(1.5rem,5vw,3rem);letter-spacing:.6em;padding-left:.6em;background:linear-gradient(100deg,#fff 0%,var(--purple) 50%,var(--blue) 100%);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 24px rgba(172,131,230,.35);animation:loaderShine 2.6s linear infinite}@keyframes loaderShine{to{background-position:200% center}}.loaderBar{width:min(60vw,320px);height:4px;background:#ac83e626;border-radius:999px;overflow:hidden}.loaderBar span{display:block;height:100%;width:0%;background:linear-gradient(90deg,var(--purple),var(--blue),var(--green));box-shadow:0 0 14px #0096ffb3;transition:width .3s ease}.loaderHint{font-family:var(--mono);font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);opacity:.7;animation:loaderBlink 1.6s ease-in-out infinite}@keyframes loaderBlink{0%,to{opacity:.35}50%{opacity:.85}}.topNav{position:fixed;top:1rem;left:50%;transform:translate(-50%);width:calc(100% - 2rem);max-width:1200px;z-index:40;display:flex;align-items:center;justify-content:space-between;padding:.7rem clamp(1rem,3vw,1.6rem);border-radius:999px;border:1px solid rgba(172,131,230,.18);background:#0808128c;backdrop-filter:blur(8px);box-shadow:0 10px 40px #00000059;transition:background .4s ease,border-color .4s ease,transform .45s cubic-bezier(.4,0,.2,1),opacity .4s ease,box-shadow .4s ease}.topNav.scrolled{background:#04040ac7;border-color:#ac83e647;box-shadow:0 12px 48px #00000080}.topNav.hidden{transform:translate(-50%) translateY(-150%);opacity:0;pointer-events:none}.topNav:before{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;background:linear-gradient(120deg,#ac83e6b3,#0096ff80,#69bf4173,#ffa53d80,#ac83e6b3);background-size:300% 300%;-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;opacity:0;transition:opacity .5s ease;animation:navBorderFlow 8s linear infinite;pointer-events:none}.topNav.scrolled:before{opacity:1}@keyframes navBorderFlow{0%{background-position:0% 50%}to{background-position:300% 50%}}.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--mono);font-size:1.05rem;letter-spacing:.15em;color:var(--text);text-decoration:none;background:linear-gradient(100deg,#fff 10%,var(--purple) 55%,var(--blue) 90%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;transition:filter .3s ease,transform .3s ease}.brand:hover{filter:drop-shadow(0 0 14px rgba(172,131,230,.6));transform:translateY(-1px)}.brand img{width:34px;height:34px;object-fit:contain;filter:drop-shadow(0 0 8px rgba(172,131,230,.7));transition:transform .5s cubic-bezier(.34,1.56,.64,1),filter .3s ease}.brand:hover img{transform:rotate(-12deg) scale(1.08);filter:drop-shadow(0 0 14px rgba(0,150,255,.8))}.navLinks{display:flex;gap:.25rem}.navLinks a{position:relative;color:var(--muted);text-decoration:none;font-size:.92rem;letter-spacing:.04em;padding:.45rem .95rem;border-radius:999px;transition:color .25s ease,background .25s ease}.navLinks a:after{content:"";position:absolute;left:50%;bottom:.28rem;width:0;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--purple),var(--blue));box-shadow:0 0 8px #0096ffb3;transform:translate(-50%);transition:width .3s ease}.navLinks a:hover{color:var(--text)}.navLinks a:hover:after{width:55%}.navLinks a.active{color:#fff;background:linear-gradient(135deg,#ac83e647,#0096ff33);box-shadow:inset 0 0 0 1px #ac83e680,0 4px 18px #0096ff40}.navLinks a.active:after{width:0}.navToggle{display:none;background:none;border:1px solid rgba(172,131,230,.4);color:var(--text);border-radius:10px;padding:.4rem .6rem;font-size:1.2rem;cursor:pointer}.socialLinks{display:flex;align-items:center;gap:.55rem}.navSocial{margin-left:.4rem}.socialLink{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;color:var(--muted);border:1px solid rgba(172,131,230,.28);background:#ac83e60f;transition:color .25s ease,transform .25s ease,border-color .25s ease,background .25s ease,box-shadow .25s ease}.socialLink:hover{color:#fff;transform:translateY(-3px);border-color:#ac83e6b3;background:#ac83e62e;box-shadow:0 10px 24px #ac83e659}.iconGlyph,.iconGlyph svg{display:block;width:20px;height:20px}.contactSocial{margin-top:1.75rem;justify-content:flex-start;flex-wrap:wrap}.contactSocial .socialLink{width:44px;height:44px}.contactSocial .iconGlyph,.contactSocial .iconGlyph svg{width:22px;height:22px}main{position:relative;z-index:1;width:min(1080px,92vw);margin:0 auto;padding-bottom:2rem}section{min-height:100vh;padding:8rem 0 4rem;display:flex;flex-direction:column;justify-content:center;scroll-margin-top:5rem}section.compact{min-height:auto;padding:5rem 0}#about{text-align:center;align-items:center;justify-content:center;position:relative;min-height:100vh;min-height:100svh}#about:before{content:"";position:absolute;left:50%;top:50%;width:min(70rem,90vw);height:40rem;transform:translate(-50%,-50%);background:radial-gradient(ellipse at center,#04040ab3,#04040a59 45%,#04040a00 72%);z-index:-1;pointer-events:none}.heroGreeting{font-family:var(--mono);font-size:clamp(2.4rem,8vw,6rem);line-height:1.05;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.95),0 0 18px rgba(0,0,0,.8)}.heroGreeting .accent{color:var(--purple);text-shadow:0 0 36px rgba(172,131,230,.9),0 2px 24px rgba(0,0,0,.8)}.typedCaret{display:inline-block;width:.06em;min-width:3px;height:.92em;margin-left:.06em;vertical-align:-.06em;background:var(--purple);box-shadow:0 0 18px #ac83e6e6}.typedCaret.typedCaretBlink{animation:caretBlink 1.05s steps(1) infinite}@keyframes caretBlink{0%,49%{opacity:1}50%,to{opacity:0}}.heroSubtitle{margin-top:1.5rem;font-family:var(--mono);font-size:clamp(1.1rem,3.5vw,2.2rem);color:var(--green);text-shadow:0 0 24px rgba(105,191,65,.55),0 2px 18px rgba(0,0,0,.85)}.uwaterloo-highlight{display:inline-flex;align-items:center;gap:.4rem;font-size:.82em;color:gold;text-shadow:0 0 24px rgba(255,215,0,.7),0 2px 18px rgba(0,0,0,.85);background:linear-gradient(135deg,#ffd7001a,#ffd7000d);padding:.15rem .5rem;border-radius:8px;border:1px solid rgba(255,215,0,.3);box-shadow:0 0 20px #ffd70033}.uwaterloo-logo-inline{width:clamp(1rem,2.4vw,1.6rem);height:clamp(1rem,2.4vw,1.6rem);object-fit:contain;filter:drop-shadow(0 0 8px rgba(255,215,0,.6))}.highlight-fullstack{color:var(--blue);text-shadow:0 0 22px rgba(0,150,255,.75),0 2px 14px rgba(0,0,0,.85)}.highlight-ml{color:var(--purple);text-shadow:0 0 22px rgba(172,131,230,.85),0 2px 14px rgba(0,0,0,.85)}.heroBadges{margin-top:2rem;display:flex;gap:.7rem;flex-wrap:wrap;justify-content:center}.heroBadge{border:1px solid rgba(172,131,230,.4);background:#ac83e614;color:#d9c9f5;border-radius:999px;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;padding:.45rem 1rem}.scrollCue{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%);display:inline-flex;flex-direction:column;align-items:center;gap:.4rem;color:var(--muted);text-decoration:none;font-size:.85rem;letter-spacing:.2em;text-transform:uppercase}.scrollCue.reveal{transform:translate(-50%,32px)}.scrollCue.reveal.visible{transform:translate(-50%)}.scrollCue .arrow{font-size:1.6rem;animation:bob 1.6s ease-in-out infinite}@keyframes bob{0%,to{transform:translateY(0);opacity:.6}50%{transform:translateY(10px);opacity:1}}.sectionTitle{font-family:var(--mono);font-size:clamp(1.8rem,5vw,3.2rem);margin-bottom:.5rem;color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.9)}.sectionTitle .accent{color:var(--purple);text-shadow:0 0 30px rgba(172,131,230,.7)}.sectionSub{font-family:var(--mono);font-size:clamp(.95rem,2.2vw,1.4rem);color:var(--muted);margin-bottom:2.5rem;text-shadow:0 2px 18px rgba(0,0,0,.9)}.sectionSub .blue{color:var(--blue)}.sectionSub .orange{color:var(--orange)}.codeSnippet{display:inline-flex;align-items:baseline;flex-wrap:wrap;gap:.05em;font-family:var(--mono);font-size:clamp(.85rem,1.8vw,1.15rem);line-height:1.5;padding:.5rem .9rem;border-radius:10px;background:#080a188c;border:1px solid rgba(172,131,230,.22);box-shadow:inset 0 0 18px #00000059;white-space:pre-wrap}.sectionSnippet{margin-bottom:2.5rem}.cardSnippet{margin-bottom:1.4rem}#contact .card{display:flex;flex-direction:column;align-items:center;text-align:center}#contact .contactSocial{justify-content:center}.codePrompt{color:var(--green);margin-right:.5em;opacity:.8}.tok-kw{color:#c792ea}.tok-fn{color:var(--blue)}.tok-var{color:var(--text)}.tok-str{color:var(--green)}.tok-prop{color:var(--orange)}.tok-bool{color:#ff9d6c}.tok-punc{color:var(--muted)}.card{background:var(--panel);border:1px solid var(--panel-border);border-radius:24px;padding:clamp(1.5rem,4vw,2.6rem);backdrop-filter:blur(8px) saturate(120%);box-shadow:0 24px 60px #000000a6,inset 0 0 0 1px #ffffff0a;transition:transform .4s ease,border-color .4s ease,box-shadow .4s ease}.card:hover{transform:translateY(-6px);border-color:#ac83e6bf;box-shadow:0 30px 80px #000000b3,0 0 40px #ac83e638}.cardHeading{font-family:var(--mono);font-size:clamp(1.3rem,3vw,1.9rem);color:var(--orange);margin-bottom:1.1rem}.cardBody{font-size:clamp(1rem,2vw,1.15rem);color:var(--text)}.cardBody li{list-style:none;position:relative;padding-left:1.6rem;margin-bottom:1rem}.cardBody li:before{content:"▹";position:absolute;left:0;color:var(--green)}.cardGrid{display:grid;gap:1.5rem}.factGrid{margin-top:1.6rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.fact{display:flex;flex-direction:column;gap:.2rem;padding:.9rem 1.1rem;border:1px solid rgba(172,131,230,.25);border-radius:14px;background:#ac83e60f}.factLabel{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}.factValue{font-size:1rem;color:var(--text)}.projectStack{font-family:var(--mono);font-size:.85rem;color:var(--blue);letter-spacing:.02em}.projectGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.codeSelect{position:relative;display:inline-block;vertical-align:baseline;margin:0 .1em}.codeSelectTrigger{font-family:var(--mono);font-size:inherit;font-weight:700;color:var(--green);cursor:pointer;display:inline-flex;align-items:center;gap:.45em;padding:.05em .5em;border:none;border-bottom:1px dashed color-mix(in srgb,var(--green) 70%,transparent);border-radius:4px;background-color:color-mix(in srgb,var(--green) 12%,transparent);transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease}.codeSelectTrigger:hover{background-color:color-mix(in srgb,var(--green) 22%,transparent);border-bottom-color:var(--green)}.codeSelectTrigger:focus-visible{outline:none;border-bottom-color:var(--green);box-shadow:0 0 0 2px color-mix(in srgb,var(--green) 30%,transparent)}.codeSelectCaret{width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--green);transition:transform .25s ease}.codeSelect.open .codeSelectCaret{transform:rotate(180deg)}.codeSelectPanel{position:absolute;top:calc(100% + .5em);left:0;z-index:40;min-width:max(100%,9em);margin:0;padding:.35em;list-style:none;background:#0a0c1e;border:1px solid color-mix(in srgb,var(--green) 35%,transparent);border-radius:10px;box-shadow:0 14px 34px #00000073,0 0 0 1px #ffffff05 inset;opacity:0;transform:translateY(-6px) scale(.96);transform-origin:top left;pointer-events:none;will-change:opacity,transform;transition:opacity .2s ease,transform .22s cubic-bezier(.22,1,.36,1)}.codeSelect.open .codeSelectPanel{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.codeSelectOption{font-family:var(--mono);font-size:.95em;font-weight:400;color:var(--text);padding:.45em .7em;border-radius:6px;cursor:pointer;white-space:nowrap;transition:background-color .15s ease,color .15s ease}.codeSelectOption:hover{background-color:color-mix(in srgb,var(--green) 16%,transparent);color:var(--green)}.codeSelectOption.selected{color:var(--green);font-weight:700;background-color:color-mix(in srgb,var(--green) 12%,transparent)}@media (prefers-reduced-motion: reduce){.codeSelectPanel,.codeSelectCaret{transition:opacity .15s ease}}.projectCard.filteredOut{display:none}@keyframes cardFilterIn{0%{opacity:0;transform:translateY(24px) scale(.96);filter:blur(4px)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}.projectCard.filterIn{animation:cardFilterIn .45s cubic-bezier(.22,1,.36,1) backwards}#projects .projectsSnippet{position:relative;z-index:10}#projects .projectGrid{position:relative;z-index:1}.projectEmpty{font-family:var(--mono);color:var(--muted);text-align:center;padding:2rem 0}.projectCard{position:relative;overflow:hidden;text-align:left;cursor:pointer;font-family:inherit;color:var(--text);background:var(--panel);border:1px solid rgba(172,131,230,.25);border-radius:24px;padding:clamp(1.4rem,3vw,2rem);backdrop-filter:blur(8px) saturate(120%);box-shadow:0 18px 50px #0000008c;transition:transform .35s cubic-bezier(.2,.8,.2,1),border-color .35s ease,box-shadow .35s ease;display:flex;flex-direction:column;gap:.6rem}.projectCard:hover,.projectCard:focus-visible{transform:translateY(-8px) scale(1.02);border-color:var(--accent, var(--purple));box-shadow:0 28px 70px #0009,0 0 40px color-mix(in srgb,var(--accent, #ac83e6) 35%,transparent);outline:none}.projectCardGlow{position:absolute;top:-40%;right:-30%;width:70%;height:80%;background:radial-gradient(circle,color-mix(in srgb,var(--accent, #ac83e6) 45%,transparent) 0%,transparent 70%);opacity:.25;pointer-events:none;transition:opacity .4s ease,transform .4s ease}.projectCard:hover .projectCardGlow{opacity:.55;transform:scale(1.15)}.projectCardTitle{font-family:var(--mono);font-size:clamp(1.3rem,3vw,1.8rem);color:#fff}.projectCardMeta{display:flex;flex-direction:column;gap:.6rem;flex:1 1 auto}.projectCardTagline{font-size:1rem;color:var(--muted);line-height:1.5}.projectSkills{display:flex;flex-wrap:wrap;gap:.4rem}.projectCardMeta .projectSkills{margin-top:auto}.projectModalCard .projectSkills{margin-bottom:1.6rem}.skillTag{display:inline-flex;align-items:center;padding:.28rem .65rem;border-radius:999px;font-family:var(--mono);font-size:.72rem;letter-spacing:.03em;color:var(--text);background:color-mix(in srgb,var(--accent, #ac83e6) 12%,transparent);border:1px solid color-mix(in srgb,var(--accent, #ac83e6) 40%,transparent)}.timelineSkills{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.9rem}.projectCardCue{margin-top:.4rem;font-family:var(--mono);font-size:.82rem;color:var(--accent, var(--purple));letter-spacing:.04em;transition:transform .3s ease}.projectCard:hover .projectCardCue{transform:translate(5px)}.projectOverlay{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:1.5rem;background:#02020700;backdrop-filter:blur(0px);opacity:0;pointer-events:none;transition:opacity .35s ease,backdrop-filter .35s ease,background .35s ease}.projectOverlay.open{opacity:1;pointer-events:auto;background:#020207b8;backdrop-filter:blur(8px)}.projectModalCard{position:relative;width:min(720px,100%);max-height:86vh;overflow-y:auto;background:linear-gradient(180deg,color-mix(in srgb,var(--accent, #ac83e6) 12%,rgba(10,12,30,.96)),#0a0c1ef7);border:1px solid color-mix(in srgb,var(--accent, #ac83e6) 55%,transparent);border-radius:26px;padding:clamp(1.6rem,4vw,2.8rem);box-shadow:0 40px 100px #000000b3,0 0 60px color-mix(in srgb,var(--accent, #ac83e6) 30%,transparent);transform:scale(.82) translateY(20px);opacity:0;transition:transform .4s cubic-bezier(.2,.9,.2,1),opacity .4s ease}.projectOverlay.open .projectModalCard{transform:scale(1) translateY(0);opacity:1}.projectModalCard{scrollbar-width:thin;scrollbar-color:var(--accent, var(--purple)) transparent}.projectModalCard::-webkit-scrollbar{width:10px}.projectModalCard::-webkit-scrollbar-track{background:transparent;margin:18px 0}.projectModalCard::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--accent, var(--purple)),var(--blue));border-radius:999px;border:2px solid transparent;background-clip:padding-box}.projectModalCard::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#c19cff,#38aaff);background-clip:padding-box}.projectClose{position:absolute;top:1rem;right:1rem;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:#00000059;color:#fff;font-size:1rem;cursor:pointer;transition:background .25s ease,transform .25s ease}.projectClose:hover{background:var(--accent, var(--purple));transform:rotate(90deg)}.projectModalTitle{font-family:var(--mono);font-size:clamp(1.8rem,5vw,2.8rem);color:#fff;margin-top:.4rem}.projectModalTagline{font-size:1.1rem;color:var(--muted);margin-top:.4rem;margin-bottom:1.6rem}.projectOverviewLabel{font-family:var(--mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.18em;color:var(--accent, var(--purple));margin-bottom:.9rem}.timelineWrap{position:relative;margin-top:1rem;padding-left:.5rem}.timelineSpine{position:absolute;top:.6rem;bottom:.6rem;left:27px;width:2px;background:linear-gradient(180deg,#ac83e600,#ac83e6e6 10%,#0096ffe6,#69bf41e6 90%,#69bf4100);box-shadow:0 0 16px #ac83e680}.timeline{display:flex;flex-direction:column;gap:1.6rem}.timelineItem{position:relative;display:grid;grid-template-columns:56px 1fr;gap:1.2rem;align-items:start}.timelineNode{position:relative;z-index:2;width:56px;height:56px;border-radius:16px;display:grid;place-items:center;font-family:var(--mono);font-size:1.25rem;font-weight:700;color:#fff;background:#0a0c1eeb;border:2px solid var(--accent, var(--purple));box-shadow:0 0 0 5px #04040ae6,0 0 22px color-mix(in srgb,var(--accent, #ac83e6) 55%,transparent);transition:transform .3s ease,box-shadow .3s ease}.timelineNode img{width:70%;height:70%;object-fit:contain}.timelineNode img[src="/Images/be-edmonton-log.png"]{width:95%;height:95%}.timelineItem:hover .timelineNode{transform:scale(1.08);box-shadow:0 0 0 5px #04040ae6,0 0 32px color-mix(in srgb,var(--accent, #ac83e6) 80%,transparent)}.timelineBody{background:var(--panel);border:1px solid rgba(172,131,230,.22);border-left:3px solid var(--accent, var(--purple));border-radius:16px;padding:1.1rem 1.4rem;backdrop-filter:blur(8px) saturate(120%);box-shadow:0 18px 40px #00000080;transition:border-color .3s ease,transform .3s ease}.timelineItem:hover .timelineBody{transform:translate(4px);border-color:color-mix(in srgb,var(--accent, #ac83e6) 60%,transparent)}.timelinePeriod{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;font-family:var(--mono);font-size:.82rem;color:var(--muted);margin-bottom:.35rem}.timelineDates{color:var(--accent, var(--purple))}.timelineDot{opacity:.5}.timelineCompany{font-family:var(--mono);font-size:clamp(1.15rem,2.6vw,1.5rem);color:#fff;margin-top:.1rem}.timelineRole{font-size:.95rem;color:var(--green)}.timelineSummary{margin-top:.7rem;font-size:clamp(.95rem,1.9vw,1.08rem);color:var(--text);line-height:1.5}.contactRow{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.5rem}.contactChip{text-decoration:none;color:#04040a;background:linear-gradient(135deg,var(--purple),var(--blue));border-radius:999px;padding:.7rem 1.5rem;font-weight:600;letter-spacing:.03em;transition:transform .25s ease,box-shadow .25s ease}.contactChip:hover{transform:translateY(-3px);box-shadow:0 12px 30px #ac83e673}.contactForm{margin-top:1.75rem;margin-left:auto;margin-right:auto;display:flex;flex-direction:column;gap:1.4rem;max-width:540px;width:100%}.formField{position:relative}.formInput{width:100%;font-family:var(--mono);font-size:1rem;color:var(--text);background:#0a0a1299;border:1px solid rgba(172,131,230,.25);border-radius:12px;padding:1.15rem 1rem .5rem;transition:border-color .25s ease,box-shadow .25s ease,background .25s ease}.formTextarea{resize:vertical;min-height:7rem;line-height:1.5}.formInput:focus{outline:none;border-color:#ac83e6bf;background:#0e0e18d9;box-shadow:0 0 0 3px #ac83e62e}.formLabel{position:absolute;left:1rem;top:.95rem;font-family:var(--mono);font-size:1rem;color:var(--muted);pointer-events:none;transition:transform .2s ease,color .2s ease,font-size .2s ease}.formInput:focus+.formLabel,.formInput:not(:placeholder-shown)+.formLabel{transform:translateY(-.7rem);font-size:.72rem;color:var(--purple)}.formSubmit{align-self:center;border:none;cursor:pointer;font-family:var(--mono);font-size:1rem}.formStatus{font-family:var(--mono);font-size:.9rem;min-height:1.2rem;margin:0;color:var(--muted);text-align:center}.formStatus.ok{color:var(--green)}.formStatus.err{color:#ff7a7a}.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease;will-change:opacity,transform}.reveal.visible{opacity:1;transform:translateY(0);will-change:auto}.scrollProgress{position:fixed;top:0;left:0;height:3px;width:100%;transform:scaleX(0);transform-origin:left center;will-change:transform;background:linear-gradient(90deg,var(--purple),var(--blue),var(--green));z-index:50;box-shadow:0 0 12px #ac83e6b3}#toTop{position:fixed;bottom:1.5rem;right:1.5rem;width:48px;height:48px;border-radius:14px;border:1px solid rgba(172,131,230,.4);background:#080a20b3;backdrop-filter:blur(8px);color:var(--text);font-size:1.3rem;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .4s ease,transform .25s ease;z-index:45}#toTop.show{opacity:1;pointer-events:auto}#toTop:hover{transform:translateY(-3px);border-color:var(--purple)}footer{text-align:center;color:var(--muted);font-family:var(--mono);font-size:.8rem;padding:0;position:relative;z-index:1}footer:not(:empty){padding:2rem 0}@media (max-width: 760px){.card,.projectCard,.timelineBody{backdrop-filter:blur(8px) saturate(110%)}.topNav{backdrop-filter:blur(8px)}section{min-height:auto;padding:6rem 0 3rem}.factGrid{grid-template-columns:1fr}.timelineItem{grid-template-columns:44px 1fr;gap:.8rem}.timelineNode{width:44px;height:44px;font-size:1rem;border-radius:13px}.timelineSpine{left:21px}.navLinks{position:fixed;top:70px;right:1rem;left:1rem;flex-direction:column;background:#04040aeb;border:1px solid rgba(172,131,230,.25);border-radius:16px;padding:.8rem;backdrop-filter:blur(16px);transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity .3s ease,transform .3s ease}.navLinks.open{transform:translateY(0);opacity:1;pointer-events:auto}.navToggle{display:block}.navSocial{gap:.35rem;margin-left:0}.navSocial .socialLink{width:34px;height:34px}.navSocial .iconGlyph,.navSocial .iconGlyph svg{width:17px;height:17px}}@media (max-width: 460px){.navSocial{display:none}}@media (prefers-reduced-motion: reduce){*{animation:none!important;scroll-behavior:auto}.reveal{opacity:1;transform:none;filter:none}}
