.hero{width:100%;height:120svh;color:var(--text-primary);background:#2e3330;position:relative;overflow:hidden}.hero-header{text-align:center;z-index:5;background:#2e3330;flex-direction:column;justify-content:center;align-items:center;gap:1.25rem;width:100%;height:100svh;display:flex;position:absolute}.hero-socials{z-index:10;flex-direction:row;gap:1rem;display:flex;position:absolute;top:2rem;right:2rem}.hero-socials a{color:#fffc;justify-content:center;align-items:center;transition:color .3s;display:flex}.hero-socials a:hover{color:#fff}.hero-header h1{color:#fff;letter-spacing:-.04em;font-size:clamp(3.5rem,10vw,9rem);transition:opacity .3s}.hero-header.exploded h1{opacity:0;pointer-events:none;visibility:hidden}.hero-subtitle{color:#ffffffbf;font-family:var(--font-mono),"JetBrains Mono",monospace;text-transform:uppercase;letter-spacing:.3em;font-size:.9rem;font-weight:400}.hero-tagline{color:#ffffffb3;font-family:var(--font-heading),serif;text-transform:none;letter-spacing:.01em;font-size:clamp(1rem,1.8vw,1.35rem);font-style:italic;font-weight:300}.explosion-btn{z-index:10;color:#ffffffb3;font-family:var(--font-mono),monospace;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #ffffff4d;border-radius:0;margin-top:2rem;padding:.6rem 0;font-size:.75rem;transition:all .3s;position:relative}.explosion-btn:hover{color:#fff;border-bottom-color:#fffc}.explosion-btn.done{cursor:default;text-transform:none;letter-spacing:.05em;color:#ffffffbf;border-bottom:none;font-size:.85rem}.explosion-btn.done:hover{transform:none}.explosion-btn.done .arrow-down{animation:1.5s ease-in-out infinite bounce-down;display:inline-block}@keyframes bounce-down{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.letter{color:#fff;font-family:var(--font-heading),serif;letter-spacing:-.04em;cursor:grab;-webkit-user-select:none;user-select:none;z-index:4;font-size:clamp(3.5rem,10vw,9rem);position:absolute}.letter:active{cursor:grabbing}.hero-canvas{pointer-events:none;z-index:6;width:100%;height:100%;position:absolute;bottom:0}.hero-content{text-align:center;z-index:3;justify-content:center;align-items:center;width:100%;height:125svh;display:flex;position:absolute;bottom:0}.hero-content h2{color:#1a1a1a;width:75%;font-weight:400;line-height:1}
.experience{background:var(--bg-primary);color:#1a1a1a;padding:6rem 8% 10rem;position:relative;overflow:hidden}.experience:after{content:"";opacity:.025;pointer-events:none;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='grain'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23grain)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:512px 512px;position:absolute;inset:0}.experience-label{font-family:var(--font-mono),monospace;text-transform:uppercase;letter-spacing:.25em;color:#999;margin-bottom:1rem;font-size:.8rem}.experience-title{font-family:var(--font-heading),serif;letter-spacing:-.035em;color:#1a1a1a;margin-bottom:5rem;font-size:clamp(2.5rem,4.5vw,4.5rem);font-weight:400;line-height:1}.experience-grid{grid-template-columns:1.1fr .9fr;gap:6rem;max-width:1300px;margin:0 auto;display:grid;position:relative}.experience-grid:before{content:"";background:linear-gradient(#0000,#0000001f 10% 90%,#0000);width:1px;position:absolute;top:0;bottom:0;left:calc(55% + .5rem)}.experience-column-title{font-family:var(--font-mono),monospace;text-transform:uppercase;letter-spacing:.25em;color:#999;border-bottom:1px solid #00000014;margin-bottom:2.5rem;padding-bottom:.75rem;font-size:.85rem;position:relative}.experience-column-title:after{content:"";background:linear-gradient(90deg,#0000001f,#0000);width:100%;height:1px;position:absolute;bottom:-1px;left:0}.timeline{padding-left:3rem;position:relative}.timeline:before{content:"";background:linear-gradient(#1a1a1a26,#0000);width:1px;position:absolute;top:20px;bottom:0;left:5px}.timeline:hover .timeline-entry{opacity:.5;transition:opacity .3s,transform .4s}.timeline:hover .timeline-entry:hover{opacity:1}.timeline-entry{opacity:0;border-bottom:1px solid #0000000d;margin-bottom:.5rem;padding-bottom:3rem;transition:opacity .3s,transform .4s;animation:.6s forwards fadeInUp;position:relative;transform:translateY(16px)}.timeline-entry:last-child{border-bottom:none}.timeline-entry:first-child{animation-delay:.1s}.timeline-entry:nth-child(2){animation-delay:.25s}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.timeline-dot{background:var(--bg-primary);border:1.5px solid #1a1a1a;border-radius:50%;width:11px;height:11px;position:absolute;top:13px;left:-3rem;box-shadow:inset 0 0 0 2px #1a1a1a}.timeline-dot.current:after{content:"";border:1px solid #1a1a1a33;border-radius:50%;animation:4s ease-in-out infinite pulse;position:absolute;inset:-6px}@keyframes pulse{0%,to{opacity:0;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}.timeline-entry h3{font-family:var(--font-heading),serif;color:#1a1a1a;letter-spacing:-.01em;margin:0 0 .5rem;font-size:2rem;font-weight:400;line-height:1.3}.timeline-company{font-family:var(--font-body),serif;color:#444;margin-bottom:.35rem;font-size:1.2rem;line-height:1.5}.timeline-date{font-family:var(--font-mono),monospace;text-transform:uppercase;letter-spacing:.12em;color:#999;margin-bottom:1.25rem;font-size:.85rem}.timeline-entry ul{margin:0;padding:0;list-style:none}.timeline-entry ul li{font-family:var(--font-body),serif;color:#333;padding-left:1.2rem;font-size:1.18rem;line-height:1.85;position:relative}.timeline-entry ul li:before{content:"";background:#00000040;width:3px;height:1px;position:absolute;top:.75em;left:0}.timeline-expand{cursor:pointer;background:0 0;border:none;align-items:center;gap:1rem;margin-top:-.5rem;margin-bottom:2rem;padding:0 0 0 3rem;display:flex;position:relative}.expand-dot{background:var(--bg-primary);border:1.5px solid #888;border-radius:50%;justify-content:center;align-items:center;width:11px;height:11px;transition:border-color .3s,box-shadow .3s,transform .3s;display:flex;position:absolute;left:0}.expand-dot svg{stroke:#999;width:6px;height:6px;transition:stroke .3s,transform .3s}.timeline-expand:hover .expand-dot{border-color:#1a1a1a;box-shadow:0 0 0 3px #1a1a1a1f}.timeline-expand:hover .expand-dot svg{stroke:#1a1a1a}.timeline-expand.is-expanded .expand-dot svg{transform:rotate(45deg)}.expand-label{font-family:var(--font-mono),monospace;text-transform:uppercase;letter-spacing:.12em;color:#666;font-size:.9rem;transition:color .3s;position:relative}.expand-label:after{content:"";background:#1a1a1a;width:0;height:1px;transition:width .3s;position:absolute;bottom:-2px;left:0}.timeline-expand:hover .expand-label{color:#1a1a1a}.timeline-expand:hover .expand-label:after{width:100%}.timeline-extra{grid-template-rows:0fr;transition:grid-template-rows .5s cubic-bezier(.4,0,.2,1);display:grid}.timeline-extra.expanded{grid-template-rows:1fr}.timeline-extra-inner{overflow:hidden}.timeline-extra .timeline-entry{opacity:0;transition:opacity .4s,transform .4s;transform:translateY(12px)}.timeline-extra.expanded .timeline-entry{opacity:1;animation:none;transform:translateY(0)}.timeline-extra.expanded .timeline-entry:first-child{transition-delay:.15s}.timeline-extra.expanded .timeline-entry:nth-child(2){transition-delay:.25s}.timeline-extra.expanded .timeline-entry:nth-child(3){transition-delay:.35s}.timeline-extra.expanded .timeline-entry:nth-child(4){transition-delay:.45s}.timeline-dot.secondary{background:var(--bg-primary);box-shadow:none;border:1.5px solid #0003}.education-degree{font-family:var(--font-heading),serif;color:#1a1a1a;letter-spacing:-.01em;margin-bottom:.5rem;padding-left:1rem;font-size:2.1rem;font-weight:400;line-height:1.3;position:relative}.education-degree:before{content:"";background:#1a1a1a;width:2px;height:2rem;position:absolute;top:.15em;left:0}.education-school{font-family:var(--font-body),serif;color:#333;margin-bottom:.25rem;font-size:1.2rem;line-height:1.5}.education-date{font-family:var(--font-mono),monospace;text-transform:uppercase;letter-spacing:.12em;color:#999;margin-bottom:2.5rem;font-size:.85rem}.education-coursework-label{font-family:var(--font-mono),monospace;text-transform:uppercase;letter-spacing:.2em;color:#999;margin-bottom:1rem;font-size:.8rem}.coursework{flex-wrap:wrap;gap:.5rem;display:flex}.coursework-tag{font-family:var(--font-mono),monospace;letter-spacing:.01em;color:#555;white-space:nowrap;background:#00000006;border:1px solid #0000000f;border-radius:8px;padding:.45rem .85rem;font-size:.8rem;transition:background .25s,border-color .25s,color .25s;display:inline-block}.coursework-tag:hover{color:#1a1a1a;background:#0000000f;border-color:#0000001f}@media (max-width:900px){.experience{padding:6rem 6% 5rem}.experience-title{margin-bottom:3rem}.experience-grid{grid-template-columns:1fr;gap:4rem}.experience-grid:before{display:none}.timeline:hover .timeline-entry{opacity:1}}
.projects{background-color:var(--bg-primary);color:#1a1a1a;width:100vw;height:100vh;position:relative;overflow:hidden}.projects-header{z-index:2;margin:2em 2em 2em 8%;position:absolute}.projects-label{font-family:var(--font-mono),monospace;text-transform:uppercase;letter-spacing:.25em;color:#999;margin-bottom:1rem;font-size:.8rem;display:block}.projects-title{font-family:var(--font-heading),serif;letter-spacing:-.035em;color:#1a1a1a;margin:0 0 1.5rem;font-size:clamp(2.5rem,4.5vw,4.5rem);font-weight:400;line-height:1}.step-counter{flex-direction:column;display:flex}.count{clip-path:polygon(0 0,100% 0,100% 100%,0% 100%);width:200px;height:100px;position:relative;overflow:hidden}.count-container{will-change:transform;position:relative;transform:translateY(100px)}.step-counter h1{color:#1a1a1a;width:100%;font-family:var(--font-heading),serif;letter-spacing:-.04em;will-change:transform;font-size:clamp(4rem,7.5vw,6.25rem);font-weight:400;line-height:1;position:relative}.count h1{font-family:var(--font-heading),serif;color:#ccc}.cards{will-change:transform;width:150vw;height:600px;position:absolute;top:25%;left:50%;transform:translate(-50%,-50%)}.card{transform-origin:50%;will-change:transform;width:500px;height:550px;transition:border-color var(--transition-base),box-shadow var(--transition-base);background:#fff;border:1px solid #00000014;border-radius:1rem;flex-direction:column;justify-content:space-between;margin-left:-250px;padding:2.5em;display:flex;position:absolute;top:50%;left:50%;box-shadow:0 1px 3px #00000005}.card:hover{border-color:#00000026;box-shadow:0 8px 32px -8px #00000014}.card-number{font-family:var(--font-mono),"JetBrains Mono",monospace;color:#aaa;letter-spacing:.1em;margin-bottom:.5rem;font-size:.75rem}.card h3{font-family:var(--font-heading),serif;color:#1a1a1a;margin:0;font-size:1.75rem;font-weight:400;line-height:1.1}.card p{font-family:var(--font-body),serif;color:#555;flex-grow:1;margin:0;padding-top:1em;font-size:1rem;line-height:1.6}.tech-tags{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.tech-tag{color:#555;font-family:var(--font-mono),monospace;letter-spacing:.01em;white-space:nowrap;background:#00000006;border:1px solid #0000000f;border-radius:8px;padding:.45rem .85rem;font-size:.8rem;transition:background .25s,border-color .25s,color .25s,box-shadow .25s;display:inline-block}.card:hover .tech-tag{color:#1a1a1a;background:#0000000f;border-color:#0000001f}.empty{opacity:0}.projects-end{background-color:var(--bg-primary);width:100%;height:40vh}@media (max-width:900px){.projects-header{margin-left:6%}.projects-title{margin-bottom:1rem}.count{height:40px}.count h1{font-size:40px}.count-container{transform:translateY(40px)}.cards{top:27.5%}.card{width:300px;height:400px;margin-left:-150px;padding:1.5em}.card h3{font-size:1.25rem}.card p{font-size:.875rem}}
.tech-section{background-color:var(--bg-primary);color:#1a1a1a;width:100vw;height:120svh;position:relative;overflow:hidden}.tech-content{z-index:5;background-color:var(--bg-primary);flex-direction:column;justify-content:flex-start;gap:3.5rem;width:100%;height:100svh;padding:5vh 8% 6rem;display:flex;position:absolute}.tech-dissolve-canvas{pointer-events:none;z-index:6;width:100%;height:100%;position:absolute;bottom:0}.tech-left{max-width:600px}.tech-label{font-family:var(--font-mono),monospace;text-transform:uppercase;letter-spacing:.25em;color:#999;margin-bottom:1rem;font-size:.8rem;display:block}.tech-title{font-family:var(--font-heading),serif;letter-spacing:-.035em;color:#1a1a1a;margin:0 0 1.5rem;font-size:clamp(2.5rem,4.5vw,4.5rem);font-weight:400;line-height:1}.tech-description{font-family:var(--font-body),serif;color:#666;font-size:1.1rem;font-weight:300;line-height:1.8}.tech-right{grid-template-columns:repeat(4,1fr);gap:2.5rem;display:grid}.tech-category-title{font-family:var(--font-mono),monospace;text-transform:uppercase;letter-spacing:.2em;color:#aaa;margin-bottom:.85rem;font-size:.7rem;font-weight:500}.tech-skill-tags{flex-wrap:wrap;gap:.5rem;display:flex}.tech-skill-tag{font-family:var(--font-mono),monospace;color:#555;letter-spacing:.01em;cursor:default;opacity:0;background:#00000006;border:1px solid #0000000f;border-radius:8px;align-items:center;gap:.45rem;padding:.45rem .85rem;font-size:.8rem;transition:all .3s;display:inline-flex;transform:translateY(12px)}.tech-visible .tech-skill-tag{opacity:1;transition:opacity .5s cubic-bezier(.16,1,.3,1)calc(var(--stagger)*40ms),transform .5s cubic-bezier(.16,1,.3,1)calc(var(--stagger)*40ms),background .25s ease,color .25s ease,border-color .25s ease,box-shadow .25s ease;transform:translateY(0)}.tech-skill-tag svg{opacity:.6;flex-shrink:0;width:16px;height:16px;transition:opacity .25s}.tech-skill-tag:hover{color:#1a1a1a;background:#0000000f;border-color:#0000001f;box-shadow:0 2px 8px #0000000f}.tech-skill-tag:hover svg{opacity:1}@media (max-width:1000px){.tech-right{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.tech-content{gap:2.5rem;padding:4rem 6%}.tech-right{grid-template-columns:1fr;gap:2rem}.tech-description{font-size:1rem}.tech-skill-tag{padding:.4rem .7rem;font-size:.75rem}.tech-skill-tag svg{width:14px;height:14px}}
