@import "https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=Syne:wght@400;700&family=Press+Start+2P&family=VT323&display=swap";:root{--bg:#0a0a0a;--accent:#00b4d8;--text:#fff;--muted:#888;--border:#ffffff14}html{scroll-behavior:smooth;scroll-snap-type:y mandatory}*{box-sizing:border-box}body{color:var(--text);background:#000;margin:0;font-family:DM Mono,monospace;overflow-x:hidden}#root{min-height:100vh}h1,h2,h3{color:var(--text);font-family:Syne,sans-serif}.snap-section{scroll-snap-align:start;scroll-snap-stop:always}.terrain-canvas{z-index:0;pointer-events:none;display:block;position:fixed;top:0;left:0}.background-canvas{z-index:1;pointer-events:none;background:0 0;border:none;border-radius:0;outline:none;width:100vw;height:100vh;position:fixed;top:0;left:0}.journey-spacer{pointer-events:none;height:600vh}.journey-panel{z-index:2;flex-direction:column;align-items:center;width:100%;height:100%;transition:opacity .4s;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.journey-panel .site-section{width:min(1100px,92vw)}.level-tag{color:#00d9ff;letter-spacing:.08em;text-transform:uppercase;text-shadow:0 0 8px #00d9ffe6,0 0 20px #00d9ff73,0 0 40px #00b4ff33;margin-bottom:1.4rem;font-family:"Press Start 2P",monospace;font-size:clamp(1.4rem,2.8vw,2.2rem);line-height:1.4}.level-tag:before{content:"> ";opacity:.6}.level-tag--hero:before{content:""}.scanlines{z-index:10;pointer-events:none;mix-blend-mode:multiply;background-image:repeating-linear-gradient(0deg,#0000,#0000 3px,#0000000f 3px 4px);width:100%;height:100%;position:fixed;top:0;left:0}.site-section{padding:5rem 0}#projects,#experience,#skills,#contact{padding-top:5vh}#personal{padding-top:15vh}.hero-section{flex-direction:column;justify-content:flex-start;align-items:flex-start;min-height:100vh;padding-top:clamp(2rem,10vh,6rem);display:flex}.hero-section h1{margin:0;font-size:clamp(3rem,7vw,6rem)}.hero-rotating-wrap{align-self:flex-start;width:max-content;min-width:26ch;max-width:100%;min-height:1.35em;margin-top:1rem}.hero-rotating-role{color:#00d9ff;text-shadow:0 0 8px #00d9ffe6,0 0 20px #00d9ff73,0 0 40px #00b4ff33;margin:0;font-family:"Press Start 2P",monospace;font-size:1.1rem;line-height:1.6}.hero-rotating-role--in{opacity:1;transition:opacity .4s ease-out}.hero-rotating-role--out{opacity:0;transition:opacity .4s ease-in}.hero-cta{flex-wrap:wrap;align-items:center;gap:.65rem;margin-top:1.25rem;display:flex}.section-title-fade{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(20px)}.section-title-fade.section-title-visible{opacity:1;transform:translateY(0)}@keyframes heroTextFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-intro-item.section-title-fade.section-title-visible{animation:.85s both heroTextFadeIn}h2{text-shadow:0 0 30px #00b4ff40;margin:0 0 2rem;font-size:clamp(1.8rem,3vw,2.5rem)}h3{margin:0 0 .75rem;font-family:Syne,sans-serif}h4{margin:0 0 .5rem;font-size:1rem;font-weight:500}.cards-wrap{flex-direction:column;gap:2rem;display:flex}@property --angle{syntax:"<angle>";inherits:false;initial-value:0deg}@keyframes rotate-angle{to{--angle:360deg}}.projects-circles-wrap{opacity:0;pointer-events:none;transition:opacity .4s}.projects-circles-wrap.branch-visible{opacity:1;pointer-events:auto;transition-delay:.15s}.projects-row-label{text-align:center;color:var(--muted);letter-spacing:.15em;text-transform:uppercase;margin:0 0 1rem;font-family:DM Mono,monospace;font-size:11px}.featured-circles-row{flex-wrap:wrap;justify-content:center;gap:40px;display:flex}.featured-circle{text-align:center;cursor:pointer;background:transparent padding-box, conic-gradient(from var(--angle,var(--fallback-angle,0deg)), #0096c7, #00b4d8, #023e8a, #0096c7) border-box;border:2.5px solid #0000;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:220px;height:220px;padding:1.2rem;transition:all .3s;animation:8s linear infinite rotate-angle;display:flex;position:relative;overflow:hidden;transform:scale(1);box-shadow:0 0 35px #00b4d873,inset 0 0 60px #00b4d812}.featured-circle:hover{transform:scale(1.04);box-shadow:0 0 35px #00b4d8b8,inset 0 0 60px #00b4d81d}.featured-circle--0:before{content:"";pointer-events:none;z-index:0;opacity:.07;clip-path:circle(50%);background-image:repeating-radial-gradient(circle,#fffc 0 1px,#0000 1px 28px);border-radius:50%;position:absolute;inset:0;overflow:hidden}.featured-circle--1:before{content:"";pointer-events:none;z-index:0;opacity:.07;clip-path:circle(50%);background-image:repeating-linear-gradient(0deg,#fffc 0 1px,#0000 1px 22px),repeating-linear-gradient(90deg,#fffc 0 1px,#0000 1px 22px);border-radius:50%;position:absolute;inset:0;overflow:hidden}.featured-circle--2:before{content:"";pointer-events:none;z-index:0;opacity:.07;clip-path:circle(50%);background-image:repeating-linear-gradient(45deg,#fffc 0 1px,#0000 1px 20px),repeating-linear-gradient(-45deg,#fffc 0 1px,#0000 1px 20px);border-radius:50%;position:absolute;inset:0;overflow:hidden}.featured-circle-labels{z-index:1;text-align:center;flex-direction:column;align-items:center;gap:.55rem;display:flex;position:relative}.featured-circle-name{color:#fff;font-family:Syne,sans-serif;font-size:13px;line-height:1.25}.featured-circle-award{color:#888;font-family:DM Mono,monospace;font-size:10px}.featured-circle--0:before,.featured-circle--1:before,.featured-circle--2:before{opacity:0!important;background-image:none!important}.other-projects-label{margin-top:32px}.other-circles-row{flex-wrap:wrap;justify-content:center;gap:24px;margin-top:0;display:flex}.other-circle{text-align:center;cursor:pointer;background:0 0;border:1.5px solid #00b4d840;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:110px;height:110px;padding:.7rem;transition:transform .3s,box-shadow .3s;display:flex;position:relative;overflow:hidden;transform:scale(1)}.other-circle-orbit{pointer-events:none;z-index:0;border:1px dashed #00b4d81f;border-radius:50%;position:absolute;inset:6px}.other-circle:hover{transform:scale(1.03);box-shadow:0 0 16px #00b4d852}.other-circle-name{z-index:1;color:#fff;font-family:Syne,sans-serif;font-size:11px;line-height:1.2;position:relative}.other-circle-award{z-index:1;color:#888;margin-top:.25rem;font-family:DM Mono,monospace;font-size:9px;line-height:1.3;position:relative}.project-expand-panel{opacity:0;background:#000a14bf;border:1px solid #00d9ff59;border-radius:4px;width:100%;max-height:0;margin-top:1.2rem;padding:0 40px;transition:max-height .4s,opacity .3s 50ms,padding .4s;overflow:hidden;box-shadow:0 0 18px #00b4ff1a}.project-expand-panel.expanded{opacity:1;max-height:320px;padding:32px 40px}.project-expand-content{justify-content:space-between;gap:2rem;display:flex}.project-expand-left{flex:1}.project-expand-left h3{margin-bottom:.75rem;font-size:22px;font-weight:700}.project-expand-left p{color:var(--muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:1rem;font-size:13px;line-height:1.6;display:-webkit-box;overflow:hidden}.award-pill{color:#fff;background:#00b4d833;border:1px solid #00b4d8;border-radius:999px;margin-bottom:.9rem;padding:.25rem .65rem;font-family:DM Mono,monospace;font-size:11px;display:inline-flex}.project-expand-right{flex-direction:column;align-items:flex-end;gap:.8rem;min-width:180px;display:flex}.ghost-btn{color:#fff;background:0 0;border:1px solid #00b4d880;border-radius:8px;padding:.6rem 1rem;font-family:DM Mono,monospace;text-decoration:none}.content-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;pointer-events:none;background:#000a14b3;border:1px solid #00d9ff59;border-radius:4px;width:35%;min-width:290px;padding:2rem;transition:opacity .4s;position:relative;box-shadow:0 0 18px #00b4ff1f,inset 0 0 20px #0078c80a}.content-card:before,.content-card:after{content:"";opacity:.7;border-style:solid;border-color:#00d9ff;width:10px;height:10px;position:absolute}.content-card:before{border-width:2px 0 0 2px;top:-1px;left:-1px}.content-card:after{border-width:0 2px 2px 0;bottom:-1px;right:-1px}.content-card.branch-visible{opacity:1;pointer-events:auto;transition-delay:.15s}.card-left{margin-left:10%}.card-right{margin-left:55%}.pill-row{flex-wrap:wrap;gap:.55rem;margin-bottom:1rem;display:flex}.pill{color:var(--text);background:#00b4ff0f;border:1px solid #00d9ff4d;border-radius:2px;padding:.32rem .75rem;font-size:.8rem}.content-card p{color:var(--muted);margin-bottom:1.25rem;line-height:1.55}.date-range{color:var(--muted);margin-bottom:.9rem;font-size:.85rem;display:inline-block}.primary-btn{color:#fff;cursor:pointer;background:#00b4d8;border:1px solid #00b4d8;border-radius:8px;justify-content:center;align-items:center;padding:.6rem 1rem;font-family:DM Mono,monospace;text-decoration:none;display:inline-flex}.skills-group{opacity:0;gap:1.75rem;transition:opacity .6s;display:grid}.skills-group>div{background:#000a1480;border:1px solid #00d9ff33;border-radius:4px;padding:1.25rem 1.5rem;position:relative;box-shadow:0 0 12px #00b4ff12}.skills-group>div:before{content:"";opacity:.7;border-top:2px solid #00d9ff;border-left:2px solid #00d9ff;width:8px;height:8px;position:absolute;top:-1px;left:-1px}.skills-group.skills-visible{opacity:1;transition-delay:.15s}.skills-group .pill-row{margin-bottom:0}.personal-section-heading{color:var(--text);flex-wrap:wrap;justify-content:center;align-items:baseline;gap:0;margin:0 0 2rem;font-family:Syne,sans-serif;font-size:clamp(1.8rem,3vw,2.5rem);display:flex}.personal-heading-md{color:#ffffff40;font-family:DM Mono,monospace;font-size:18px;font-weight:400}.personal-wrap{opacity:0;text-align:center;max-width:600px;margin:0 auto;transition:opacity .6s}.personal-wrap.personal-visible{opacity:1;transition-delay:.15s}.personal-bio{max-width:480px;color:var(--muted);margin:0 auto;font-family:DM Mono,monospace;font-size:13px;line-height:1.65}.personal-interests{flex-wrap:wrap;justify-content:center;gap:.7rem;margin-top:1.2rem;display:flex}.personal-interest-pill{padding:10px 18px}.currently-block{justify-content:center;align-items:stretch;margin-top:1.4rem;display:flex}.currently-item{flex-direction:column;align-items:center;gap:.35rem;min-width:150px;font-family:DM Mono,monospace;display:flex}.currently-label{color:var(--muted);letter-spacing:.15em;font-size:9px}.currently-value{color:#fff;font-size:13px}.currently-listening-row{align-items:center;gap:.5rem;display:inline-flex}.currently-album-thumb{vertical-align:middle;object-fit:cover;border-radius:4px;flex-shrink:0;width:32px;height:32px}.currently-reading-link{color:#fff;font-size:13px;text-decoration:underline}.personal-also{color:var(--muted);margin-top:1.5rem;font-family:DM Mono,monospace;font-size:13px;line-height:1.65}#personal .personal-bio,#personal .personal-interest-pill,#personal .currently-value,#personal .currently-reading-link,#personal .personal-also{text-shadow:0 1px 12px #000000e6,0 0 4px #000c}.currently-divider{background:#ffffff1a;width:1px;margin:0 1rem}.contact-section{padding-bottom:6rem}.contact-links{opacity:0;pointer-events:none;align-items:center;gap:1rem;transition:opacity .4s;display:flex}.contact-links.contact-visible{opacity:1;pointer-events:auto;transition-delay:.15s}.contact-links a{color:var(--text);transition:filter .25s;display:inline-flex}.contact-links a:hover{filter:drop-shadow(0 0 6px #00b4d8cc)}.contact-links svg{fill:currentColor;width:28px;height:28px}.dot-nav{z-index:3;flex-direction:column;gap:.65rem;display:flex;position:fixed;top:50%;right:24px;transform:translateY(-50%)}.dot{cursor:pointer;background:0 0;border:1px solid #fff6;border-radius:50%;width:10px;height:10px;padding:0}.dot-active{background:#00b4d8;border-color:#00b4d8}@media (width<=900px){.content-card,.card-left,.card-right{width:100%;min-width:0;margin-left:0}.dot-nav{right:12px}}@media (width<=768px){.hero-section{padding-top:clamp(1.5rem,8vh,4rem)}.featured-circle{width:160px;height:160px}.other-circle{width:90px;height:90px}.other-circle-orbit{inset:5px}.project-expand-panel.expanded{max-height:420px;padding:24px 20px}.project-expand-panel{padding:0 20px}.project-expand-content{flex-direction:column}.project-expand-right{align-items:flex-start}.currently-block{flex-direction:column;gap:.9rem}.currently-divider{width:100%;height:1px;margin:0}}
