@import "https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&family=Syne:wght@400;600;800&display=swap";#root{isolation:isolate}:root{--bg:#0a0a0f;--bg2:#111118;--surface:#16161f;--border:#252532;--accent:#7fffb2;--accent2:#5b8fff;--text:#e8e8f0;--muted:#8888a8;--fhead:"Syne", sans-serif;--fmono:"Space Mono", monospace;--r:6px;--nav-h:60px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--fmono), monospace;-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}body:after{content:"";pointer-events:none;z-index:999;opacity:.35;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");position:fixed;inset:0}nav{z-index:100;height:var(--nav-h);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#0a0a0fe0;justify-content:space-between;align-items:center;padding:0 2rem;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{font-family:var(--fhead), sans-serif;letter-spacing:-.03em;color:var(--accent);font-size:1.52rem;font-weight:800}.nav-logo span{color:var(--text)}.nav-links{align-items:center;gap:1.75rem;display:flex;position:absolute;left:50%;transform:translate(-50%)}.nav-link{color:var(--muted);font-family:var(--fmono), monospace;letter-spacing:.08em;font-size:.82rem;text-decoration:none;transition:color .15s}.nav-link--email:hover{color:#5b8fff}.nav-link--github:hover{color:#7fffb2}.nav-link--linkedin:hover{color:#ff7fb2}.nav-tabs{gap:2px;list-style:none;display:flex}.nav-btn{font-family:var(--fmono), monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);cursor:pointer;border-radius:var(--r);text-shadow:0 0 10px #ffffff40;background:0 0;border:none;padding:6px 14px;font-size:.86rem;transition:color .15s,background .15s,transform .15s}.nav-btn--home:hover,.nav-btn--home.active{color:#5b8fff}.nav-btn--resume:hover,.nav-btn--resume.active{color:#e34f26}.nav-btn--projects:hover,.nav-btn--projects.active{color:#7fffb2}.nav-btn--courses:hover,.nav-btn--courses.active{color:#ff7fb2}.nav-btn:hover{background:0 0}.nav-btn--home.active{background:#5b8fff12}.nav-btn--resume.active{background:#e34f2612}.nav-btn--projects.active{background:#7fffb212}.nav-btn--courses.active{background:#ff7fb212}main{padding-top:var(--nav-h);min-height:100vh}.page{max-width:900px;margin:0 auto;padding:3.5rem 2rem 5rem;animation:.35s both fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.page-header{margin-bottom:2.5rem}.page-header h2{font-family:var(--fhead), sans-serif;letter-spacing:-.04em;color:var(--text);margin-bottom:.4rem;font-size:2.2rem;font-weight:800}.page-header p{color:var(--muted);font-size:1.02rem;line-height:1.6}.hero{margin-bottom:3.5rem}.hero-tag{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;font-size:1.08rem}.hero-name{font-family:var(--fhead), sans-serif;letter-spacing:-.05em;color:var(--text);margin-bottom:1.2rem;font-size:clamp(3rem,8vw,5.5rem);font-weight:800;line-height:.95}.hero-sub{color:var(--muted);font-size:1.06rem;line-height:1.75}.progress-section{margin-bottom:5rem}.progress-header{justify-content:space-between;align-items:baseline;margin-bottom:.75rem;display:flex}.progress-label{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:1.03rem}.progress-pct-follow{font-family:var(--fhead), sans-serif;color:var(--accent);white-space:nowrap;pointer-events:none;font-size:2rem;font-weight:800;transition:left 4s cubic-bezier(.16,1,.3,1);position:absolute;top:calc(100% + 10px);transform:translate(-50%)}.progress-track{background:var(--surface);border:1px solid var(--border);border-radius:99px;height:8px;position:relative;overflow:visible}.progress-fill{background:linear-gradient(90deg,#3dffa0,#7fffb2);border-radius:99px;height:100%;transition:width 4s cubic-bezier(.16,1,.3,1);position:relative}.progress-glow{background:var(--accent);border-radius:50%;width:14px;height:14px;position:absolute;top:50%;right:-1px;transform:translateY(-50%);box-shadow:0 0 12px 4px #7fffb280}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;display:grid}.course-card{--cat-color:#7fffb2;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);flex-direction:column;gap:.5rem;padding:1rem 1.1rem;transition:border-color .15s,transform .15s;animation:.4s both fadeUp;display:flex}.course-card:hover{border-color:color-mix(in srgb, var(--cat-color) 45%, transparent);transform:translateY(-2px)}.course-remaining{opacity:.6;border-style:dashed}.course-term{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:.65rem}.course-name{color:var(--text);flex:1;font-size:.82rem;line-height:1.4}.course-footer{justify-content:space-between;align-items:center;margin-top:.25rem;display:flex}.course-cus{color:var(--muted);font-size:.68rem}.badge{letter-spacing:.08em;text-transform:uppercase;border-radius:99px;padding:2px 8px;font-size:.62rem;font-weight:700}.badge.pass{color:var(--accent);background:#7fffb21a}.badge.upcoming{color:var(--accent2);background:#5b8fff1a}.course-term[data-cat=Gen\ Ed]{color:#ffd97f}.course-term[data-cat=Core]{color:#7fffb2}.course-term[data-cat=Math]{color:#ff9f7f}.course-term[data-cat=Programming]{color:#5b8fff}.course-term[data-cat=Data]{color:#d97fff}.tech-section{margin-bottom:3rem}.tech-section-sub{color:#c8c8d8;text-align:center;margin-bottom:1.5rem;font-size:1.52rem;font-weight:700;line-height:1.75}.tech-section-label{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;font-size:.72rem}.tech-grid{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.tech-card{--icon-color:var(--accent);background:var(--surface);border:1px solid var(--border);border-radius:var(--r);flex-direction:column;align-items:center;gap:1rem;padding:2.2rem 1rem;transition:border-color .2s,transform .2s;animation:.4s both fadeUp;display:flex}.tech-card:hover{border-color:color-mix(in srgb, var(--icon-color) 45%, transparent);transform:translateY(-3px)}.tech-name{letter-spacing:.06em;color:var(--text);text-align:center;font-size:1rem}.back-btn{border:1px solid var(--accent);color:var(--accent);font-family:var(--fmono), monospace;letter-spacing:.08em;cursor:pointer;border-radius:var(--r);background:0 0;margin-bottom:2rem;padding:10px 24px;font-size:1rem;transition:background .15s,color .15s}.back-btn:hover{background:color-mix(in srgb, var(--accent) 10%, transparent)}.sim-nav-btn{letter-spacing:.08em;background:0 0;border:1px solid #2a2a3a;border-radius:4px;padding:8px 22px;font-family:Courier New,monospace;font-size:17px;transition:background .15s,color .15s}.sim-nav-btn:not(:disabled):hover{background:#ffffff2e}.sim-nav-btn:disabled{color:#2a2a3a;cursor:default;box-shadow:none}.sim-nav-btn:not(:disabled){color:#d0d0e0;cursor:pointer;box-shadow:0 0 8px #ffffff26,0 0 18px #ffffff12}.detail-title{font-family:var(--fhead), sans-serif;letter-spacing:-.04em;color:#fff;font-size:2rem;font-weight:800}.detail-body{flex-direction:column;display:flex}.detail-section{border-bottom:1px solid var(--border);padding:1.75rem 0}.detail-section:last-child{border-bottom:none}.detail-section-label{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;font-size:1.3rem;font-weight:700}.detail-section p{color:var(--muted);font-size:.88rem;line-height:1.75}.projects-list{flex-direction:column;gap:1.25rem;display:flex}.project-card{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent,#7fffb2);border-radius:var(--r);padding:1.5rem 1.6rem;transition:transform .15s,border-color .15s}.project-card:hover{transform:translate(4px)}.project-top{justify-content:space-between;align-items:flex-start;margin-bottom:.8rem;display:flex}.project-tag{letter-spacing:.1em;text-transform:uppercase;color:var(--accent,#7fffb2);margin-bottom:.3rem;font-size:.66rem}.project-title{font-family:var(--fhead), sans-serif;letter-spacing:-.03em;color:var(--text);font-size:1.25rem;font-weight:700}.project-num{font-family:var(--fhead), sans-serif;color:var(--border);-webkit-user-select:none;user-select:none;font-size:2rem;font-weight:800;line-height:1}.project-desc{color:var(--muted);margin-bottom:1rem;font-size:.82rem;line-height:1.7}.project-highlights{flex-wrap:wrap;gap:.5rem;list-style:none;display:flex}.project-highlights li{letter-spacing:.06em;border:1px solid var(--border);color:var(--muted);background:#ffffff0a;border-radius:99px;padding:3px 10px;font-size:.7rem}.reveal{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(28px)}.reveal.visible{opacity:1;transform:translateY(0)}.home-about{border-top:1px solid var(--border);margin-top:3rem}.home-footer{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:center;gap:2rem;margin-top:2rem;padding:2rem 0 1rem;display:flex}.about-block{border-bottom:1px solid var(--border);grid-template-columns:140px 1fr;align-items:start;gap:1.5rem;padding:2.5rem 0;display:grid}.about-block:last-child{border-bottom:none}.about-block-label{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);text-shadow:0 0 10px #7fffb28c,0 0 22px #7fffb240;padding-top:2px;font-size:1rem}.about-block p{color:var(--muted);font-size:1.02rem;line-height:1.75}.about-link{color:var(--text);border-bottom:1px solid var(--border);padding-bottom:1px;font-size:1.18rem;text-decoration:none;transition:color .15s,border-color .15s}.about-link:hover{color:var(--accent);border-color:var(--accent)}.resume-page .page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.resume-download-btn{font-family:var(--fmono), monospace;letter-spacing:.08em;color:var(--muted);border:1px solid var(--border);border-radius:4px;padding:.35rem .85rem;font-size:.82rem;text-decoration:none;transition:color .15s,border-color .15s}.resume-download-btn:hover{color:#e34f26;border-color:#e34f26}.resume-body{flex-direction:column;gap:2rem;margin-top:1.5rem;display:flex}.resume-section{flex-direction:column;gap:1rem;display:flex}.resume-section-title{font-family:var(--fmono), monospace;letter-spacing:.18em;text-transform:uppercase;color:#e34f26;border-bottom:1px solid var(--border);margin:0;padding-bottom:.5rem;font-size:1.5rem}.resume-entry{flex-direction:column;gap:.3rem;display:flex}.resume-entry-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.5rem;display:flex}.resume-entry-title{color:var(--fhead);font-size:1rem;font-weight:600}.resume-entry-location{color:var(--muted);font-size:.85rem}.resume-entry-date{color:var(--muted);font-size:.85rem;font-style:italic}.resume-entry-sub{color:var(--text);font-size:.9rem}.resume-entry-tags{font-family:var(--fmono), monospace;color:#e34f26;letter-spacing:.04em;font-size:.78rem}.resume-entry-detail{color:var(--muted);margin:0;font-size:.92rem;line-height:1.6}.resume-skills{color:var(--muted);flex-direction:column;gap:.4rem;font-size:.92rem;line-height:1.6;display:flex}.resume-skills strong,.resume-entry-detail strong{color:var(--text);font-weight:600}.resume-no-exp{font-style:italic}.email-toast{z-index:1000;background:var(--surface);border:1px solid var(--accent);border-radius:var(--r);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);text-align:center;min-width:290px;max-width:400px;padding:1.25rem 1.6rem;animation:.25s cubic-bezier(.16,1,.3,1) both toastUp;position:fixed;bottom:2.5rem;left:50%;transform:translate(-50%);box-shadow:0 0 28px #7fffb21f,0 8px 32px #00000080}.email-toast--top{bottom:unset;top:calc(var(--nav-h) + 1rem);animation:.25s cubic-bezier(.16,1,.3,1) both toastDown}.email-toast-title{font-family:var(--fmono), monospace;color:var(--accent);text-shadow:0 0 12px #7fffb273;margin-bottom:.45rem;font-size:1rem;font-weight:700}.email-toast-body{color:var(--muted);font-size:.82rem;line-height:1.65}@keyframes toastUp{0%{opacity:0;transform:translate(-50%)translateY(14px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toastDown{0%{opacity:0;transform:translate(-50%)translateY(-14px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;flex-shrink:0;justify-content:center;gap:5px;width:32px;height:32px;padding:4px;display:none}.hamburger span{background:var(--text);border-radius:2px;width:22px;height:2px;transition:transform .22s,opacity .22s;display:block}.hamburger.open span:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-menu-backdrop,.mobile-menu{display:none}@media (width<=600px){.page{padding:2rem 1.2rem 4rem}.nav-tabs{display:none}.hamburger{display:flex}nav{padding:0 1rem}.nav-logo{font-size:.99rem}.nav-links{display:none}.progress-pct-follow{font-size:1.5rem}.mobile-menu-backdrop{z-index:98;display:block;position:fixed;inset:0}.mobile-menu{top:var(--nav-h);z-index:99;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#0a0a0ff7;flex-direction:column;padding:.75rem 1.2rem 1.2rem;animation:.18s both menuDown;display:flex;position:fixed;left:0;right:0}@keyframes menuDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.mobile-menu-btn{font-family:var(--fmono), monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);cursor:pointer;text-align:left;border-radius:var(--r);background:0 0;border:none;padding:.85rem .5rem;font-size:1rem;transition:color .15s}.mobile-menu-btn.active,.mobile-menu-btn:hover{color:var(--accent)}.mobile-menu-divider{background:var(--border);height:1px;margin:.4rem .5rem}.mobile-menu-socials{flex-direction:row;justify-content:space-around;padding:.5rem .5rem .25rem;display:flex}.mobile-menu-link{color:var(--text);font-family:var(--fmono), monospace;letter-spacing:.08em;border-radius:var(--r);padding:.5rem .25rem;font-size:.88rem;text-decoration:none;transition:color .15s}.mobile-menu-link:hover{color:var(--accent)}.courses-grid{grid-template-columns:repeat(2,1fr)}.about-block{grid-template-columns:1fr;gap:.4rem}.tech-grid{grid-template-columns:repeat(2,1fr)}}
