@import url("https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Inter:wght@300;400;500;600;700;800;900&display=swap");:root{--black:#0a0a0a;--white:#fff;--off-white:#f0f0ee;--red:#e63020;--teal:#7dd9c8;--gray:#3a3a3a;--gray-light:#888;--border:hsla(0,0%,100%,.1);--font-sans:"Inter","Helvetica Neue",Helvetica,Arial,sans-serif;--font-serif:"DM Serif Display",Georgia,serif}*,:after,:before{margin:0;padding:0;box-sizing:border-box}html{background:var(--black);color:var(--white);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;cursor:auto}body,html{overflow-x:hidden}::-webkit-scrollbar{width:0}a{color:inherit;text-decoration:none;transition:color .25s ease}a,button{cursor:pointer}button{transition:all .25s ease}.scroll-counter{left:2.5rem;letter-spacing:.05em;color:hsla(0,0%,100%,.4);font-weight:400}.scroll-counter,.side-label{position:fixed;top:50%;transform:translateY(-50%);font-size:.7rem;z-index:50;writing-mode:vertical-rl}.side-label{right:2.5rem;letter-spacing:.08em;color:hsla(0,0%,100%,.5);text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:3rem}.side-label:before{content:"";width:1px;height:60px;background:hsla(0,0%,100%,.2)}.hero{position:relative;width:100%;height:100vh;background:var(--black);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end}.hero-blob{top:-10%;left:30%;width:55%;height:85%;background:radial-gradient(ellipse at 40% 30%,#c0170a 0,#8a0e0e 30%,#3d0505 60%,transparent 80%);filter:blur(60px);opacity:.85;border-radius:50%;transform:rotate(-10deg)}.hero-blob,.hero-blob-2{position:absolute;pointer-events:none}.hero-blob-2{top:20%;right:0;width:30%;height:50%;background:radial-gradient(ellipse,#2a0060 0,transparent 70%);filter:blur(80px);opacity:.6}.hero-tagline{position:absolute;top:3rem;left:3rem;font-size:.82rem;line-height:1.6;color:hsla(0,0%,100%,.75);font-weight:300}.hero-tagline em{font-style:italic;font-family:var(--font-serif)}.hero-name{position:relative;z-index:2;padding:0 2rem;display:flex;justify-content:center;align-items:baseline;gap:0;line-height:.9;width:100%;overflow:visible}.hero-name .char{display:inline-block;will-change:transform,opacity}.hero-first{font-family:var(--font-sans);font-weight:800;color:var(--white);letter-spacing:-.03em}.hero-first,.hero-last{font-size:clamp(7rem,18vw,18rem);flex-shrink:0}.hero-last{font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--teal);letter-spacing:-.02em;margin-left:1.2vw}.hero-scroll-text{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:6;text-align:center;white-space:nowrap;pointer-events:none;will-change:opacity,filter,transform}.hero-scroll-text--main{font-family:var(--font-sans);font-weight:900;font-size:clamp(2.2rem,6vw,7rem);letter-spacing:-.03em;color:var(--white);line-height:1}.hero-scroll-text--sub{font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:clamp(1.4rem,3.5vw,4rem);color:hsla(0,0%,100%,.7);letter-spacing:-.01em}.hero-bar{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:1.2rem 3rem;border-top:1px solid hsla(0,0%,100%,.15);margin-top:.5rem}.hero-bar-left{font-size:.75rem;letter-spacing:.1em;color:hsla(0,0%,100%,.6);font-weight:500}.hero-bar-center{display:flex;align-items:center;gap:1.5rem}.hero-bar-center a{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:hsla(0,0%,100%,.85);transition:color .2s}.hero-bar-center a:hover{color:var(--white)}.hero-bar-center span{color:hsla(0,0%,100%,.25);font-size:.7rem}.hero-bar-right{display:flex;gap:2rem}.hero-bar-right a{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:hsla(0,0%,100%,.85);transition:color .2s}.hero-bar-right a:hover{color:var(--white)}.video-section{position:relative;width:100%;height:100vh;overflow:hidden;background:var(--black)}.video-section .video-placeholder,.video-section video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(100%);opacity:.75}.video-placeholder{background:linear-gradient(135deg,#1a1a1a,#2d2d2d 50%,#111);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:hsla(0,0%,100%,.2);letter-spacing:.2em;text-transform:uppercase}.video-section:after,.video-section:before{content:"+";position:absolute;font-size:1.2rem;color:hsla(0,0%,100%,.6);z-index:5;font-weight:300;line-height:1}.video-section:before{top:2rem;left:2rem}.video-section:after{bottom:2rem;right:2rem}.video-corner-tr{top:2rem;right:2rem}.video-corner-bl,.video-corner-tr{position:absolute;font-size:1.2rem;color:hsla(0,0%,100%,.6);z-index:5;font-weight:300}.video-corner-bl{bottom:2rem;left:2rem}.video-tagline{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;font-family:var(--font-serif);font-style:italic;font-size:clamp(1.5rem,4vw,3rem);color:var(--white);white-space:nowrap;text-align:center}.about{position:relative;width:100%;min-height:100vh;background:var(--black);display:grid;grid-template-columns:minmax(0,1.08fr) minmax(420px,.92fr);align-items:center;padding:6rem 4rem;overflow:hidden;filter:blur(18px);opacity:.4;transition:filter .1s ease-out,opacity .1s ease-out}.about:before{content:"";position:absolute;top:-20%;left:20%;width:65%;height:90%;background:radial-gradient(ellipse at 40% 30%,#c0170a 0,#8a0e0e 30%,#3d0505 60%,transparent 80%);filter:blur(70px);opacity:.7;pointer-events:none;border-radius:50%;transform:rotate(-8deg);z-index:0}.about-left{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:flex-start;max-width:44rem}.about-heading{font-family:var(--font-sans);font-weight:700;font-size:clamp(2rem,4.5vw,4.5rem);line-height:1.1;color:var(--white)}.about-heading em{font-family:var(--font-serif);font-style:italic;font-weight:400}.about-age{font-size:.75rem;color:hsla(0,0%,100%,.35);margin-top:1.5rem;letter-spacing:.05em}.about-body{margin-top:3rem;margin-left:0;font-size:1rem;line-height:1.7;color:hsla(0,0%,100%,.65);max-width:480px;font-weight:300}.about-right{position:relative;z-index:1;display:flex;justify-content:flex-end;align-items:center;min-height:100vh;padding-left:2rem}.about-photo-frame{position:relative;width:min(100%,540px);aspect-ratio:4/5;border-radius:1.6rem;overflow:hidden;box-shadow:0 30px 120px rgba(0,0,0,.45);border:1px solid hsla(0,0%,100%,.06);background:#120808}.about-photo{object-fit:cover;object-position:center top;filter:saturate(1.02) contrast(1.04)}.about-right:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 58% 30%,rgba(180,20,20,.18) 0,transparent 58%);pointer-events:none}.intro-panel{position:fixed;top:0;width:51vw;height:100vh;background:var(--black);z-index:99999;pointer-events:none}.intro-panel.left{left:0;transform-origin:left center}.intro-panel.right{right:0;transform-origin:right center}.moving-blob{position:fixed;left:50%;top:35%;width:60vmax;height:60vmax;transform:translate(-50%,-50%);background:radial-gradient(ellipse at 30% 30%,rgba(230,48,32,.9) 0,rgba(200,30,20,.6) 30%,rgba(120,12,12,.25) 60%,transparent 80%);filter:blur(80px);opacity:.9;pointer-events:none;z-index:0}@media (max-width:900px){.about{grid-template-columns:1fr;padding:5rem 1.5rem 3rem}.about-left{max-width:none;padding-right:0}.about-right{min-height:auto;justify-content:center;padding:2rem 0 0}.about-photo-frame{width:min(100%,420px)}.about-side-label{right:1rem}}.about-side-label{position:absolute;right:2.5rem;top:50%;transform:translateY(-50%);font-size:.7rem;letter-spacing:.1em;color:hsla(0,0%,100%,.45);writing-mode:vertical-rl;text-transform:uppercase;z-index:5}.projects{position:relative;width:100%;min-height:100vh;background:var(--black);display:grid;grid-template-columns:1fr 1fr;align-items:start}.projects-list{padding:6rem 3rem 6rem 4rem}.projects-list-item{position:relative;border-top:1px solid hsla(0,0%,100%,.12);padding:1.8rem 0;cursor:none;display:block}.projects-list-item:last-child{border-bottom:1px solid hsla(0,0%,100%,.12)}.projects-list-item h3{font-family:var(--font-sans);font-weight:700;font-size:clamp(1.8rem,3.5vw,3.5rem);color:hsla(0,0%,100%,.25);transition:color .35s ease,transform .35s ease;letter-spacing:-.02em;line-height:1}.projects-list-item.is-active h3,.projects-list-item:hover h3{color:var(--white);transform:translateX(12px)}.projects-preview{position:-webkit-sticky;position:sticky;top:8rem;padding:6rem 4rem 4rem 2rem;display:flex;flex-direction:column;gap:1.5rem}.projects-preview-meta{display:flex;justify-content:space-between;align-items:center}.projects-preview-date{font-weight:500}.projects-preview-date,.projects-preview-label{font-size:.72rem;letter-spacing:.12em;color:hsla(0,0%,100%,.4)}.projects-preview-label{font-weight:700;text-transform:uppercase}.projects-preview-img{width:100%;aspect-ratio:16/10;background:#1a1a1a;overflow:hidden;position:relative}.projects-preview-img img,.projects-preview-placeholder{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.projects-preview-placeholder{background:linear-gradient(135deg,#1a1a1a,#333,#111);display:flex;align-items:center;justify-content:center;color:hsla(0,0%,100%,.1);font-size:.75rem;letter-spacing:.2em}.project-detail{min-height:100vh;background:var(--black);padding:2rem 2.5rem 2.5rem}.project-detail-back{display:inline-flex;align-items:center;gap:.6rem;font-size:.85rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:hsla(0,0%,100%,.7);margin-bottom:3rem;margin-top:1rem;padding:.75rem 1.25rem;background:hsla(0,0%,100%,.02);border:1px solid hsla(0,0%,100%,.12);border-radius:.5rem;transition:all .3s ease}.project-detail-back:hover{background:rgba(230,48,32,.1);border-color:var(--red);color:var(--red);transform:translateX(-6px);box-shadow:0 4px 12px rgba(230,48,32,.15)}.back-pointer{font-size:1.1rem;font-weight:600}.project-detail-shell{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-gap:4rem;gap:4rem;align-items:start}.project-detail-left{padding:2rem 0}.project-detail-kicker{font-size:.75rem;letter-spacing:.18em;color:hsla(0,0%,100%,.45);text-transform:uppercase;margin-bottom:1.2rem}.project-detail-title-row{display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap}.project-detail-title{font-family:var(--font-sans);font-weight:800;font-size:clamp(3rem,6.8vw,6.5rem);line-height:.95;letter-spacing:-.04em;color:var(--white)}.project-detail-year{font-size:.9rem;font-weight:700;letter-spacing:.14em;color:hsla(0,0%,100%,.8);text-transform:uppercase;transform:translateY(-.3rem)}.project-detail-subtitle{margin-top:2rem;max-width:42rem;font-size:clamp(1.1rem,2vw,1.5rem);line-height:1.45;color:hsla(0,0%,100%,.65)}.project-detail-description{margin-top:4rem;max-width:34rem;font-size:1rem;line-height:1.7;color:hsla(0,0%,100%,.72)}.project-detail-meta{margin-top:2.5rem;display:grid;grid-gap:2rem;gap:2rem;max-width:38rem}.project-detail-meta-label{font-size:.75rem;letter-spacing:.12em;color:hsla(0,0%,100%,.35);text-transform:uppercase;margin-bottom:1rem}.project-detail-techs{display:flex;flex-wrap:wrap;gap:.9rem}.project-detail-techs span{border:1px solid hsla(0,0%,100%,.08);background:hsla(0,0%,100%,.02);color:hsla(0,0%,100%,.72);border-radius:999px;padding:.8rem 1.3rem;font-size:.95rem;line-height:1}.project-detail-buttons{display:flex;flex-wrap:wrap;gap:1.2rem;margin-top:3.5rem}.project-detail-button{min-width:180px;height:64px;padding:0 1.8rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;gap:.7rem;font-size:1rem;font-weight:700;letter-spacing:.01em;transition:transform .2s ease,filter .2s ease,background .2s ease}.project-detail-button:hover{transform:translateY(-2px);filter:brightness(1.05)}.project-detail-button--primary{background:#b8ea22;color:#050505}.project-detail-button--red{background:var(--red);color:var(--white)}.project-detail-button--red:hover{background:#c93828;box-shadow:0 8px 24px rgba(230,48,32,.3)}.project-detail-button--secondary{background:transparent;color:var(--white);border:1px solid hsla(0,0%,100%,.16)}.project-detail-button span{font-size:1.15rem}.project-detail-right{display:flex;flex-direction:column;gap:2rem;padding:2rem 0;position:-webkit-sticky;position:sticky;top:2rem}.project-detail-image{width:100%;aspect-ratio:4/3;position:relative;overflow:hidden;background:#1c1c1c;border-radius:24px;box-shadow:0 20px 60px rgba(0,0,0,.4)}.project-detail-image img{object-fit:cover}.project-detail-image--inner{position:absolute;inset:0}.project-detail-video{width:100%;aspect-ratio:16/9;position:relative;overflow:hidden;background:#1c1c1c;border-radius:20px;box-shadow:0 12px 40px rgba(0,0,0,.3)}.project-detail-video--inner{width:100%;height:100%;object-fit:cover}.projects-snake{position:absolute;left:28%;top:4%;width:60px;height:520px;pointer-events:none;z-index:10;overflow:visible}.projects-side-label{right:2.5rem;letter-spacing:.1em;color:hsla(0,0%,100%,.45);text-transform:uppercase}.projects-side-label,.scroll-num{position:absolute;top:50%;transform:translateY(-50%);font-size:.7rem;writing-mode:vertical-rl}.scroll-num{left:2.5rem;letter-spacing:.05em;color:hsla(0,0%,100%,.3)}.skills{position:relative;width:100%;min-height:100vh;background:var(--black);display:grid;grid-template-columns:1fr 1fr}.skills-left{padding:6rem 3rem 6rem 4rem;display:flex;flex-direction:column;justify-content:space-between;position:relative}.skills-label{font-size:.75rem;letter-spacing:.12em;color:hsla(0,0%,100%,.4);text-transform:uppercase;margin-bottom:2rem}.skills-heading{font-family:var(--font-sans);font-weight:900;font-size:clamp(1.8rem,3.5vw,3.2rem);line-height:1.1;letter-spacing:-.01em;max-width:480px}.skills-contact-link,.skills-heading{text-transform:uppercase;color:var(--white)}.skills-contact-link{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:700;letter-spacing:.1em;margin-top:3rem;transition:gap .3s}.skills-contact-link:hover{gap:1rem}.skills-contact-link span{font-size:1rem}.skills-arrow{position:absolute;bottom:3rem;left:4rem;display:flex;align-items:center}.skills-arrow svg{width:220px;height:auto}.skills-right{padding:6rem 4rem 6rem 3rem;border-left:1px solid hsla(0,0%,100%,.08);overflow-y:auto;max-height:70vh;scrollbar-width:none}.skills-right::-webkit-scrollbar{display:none}.skill-accordion-item{border-top:1px solid hsla(0,0%,100%,.1)}.skill-accordion-item:last-child{border-bottom:1px solid hsla(0,0%,100%,.1)}.skill-accordion-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 0;cursor:pointer}.skill-accordion-title{font-family:var(--font-sans);font-weight:700;font-size:clamp(1.2rem,2.5vw,2rem);color:var(--white);letter-spacing:-.01em}.skill-accordion-icon{font-size:1.2rem;color:hsla(0,0%,100%,.5);transition:transform .3s ease;flex-shrink:0;font-weight:300;width:24px;text-align:center}.skill-accordion-item.is-open .skill-accordion-icon{transform:rotate(45deg)}.skill-accordion-body{overflow:hidden;max-height:0;transition:max-height .4s ease}.skill-accordion-item.is-open .skill-accordion-body{max-height:500px}.skill-accordion-list{list-style:none;padding-bottom:1.5rem;display:flex;flex-direction:column;gap:.5rem}.skill-accordion-list li{font-size:.85rem;letter-spacing:.06em;color:hsla(0,0%,100%,.45);padding-left:0;transition:color .2s}.skill-accordion-list li:hover{color:var(--red)}.skill-scroll-track{display:flex;gap:.75rem;padding-bottom:1.2rem;overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--red) transparent;-webkit-overflow-scrolling:touch;cursor:-webkit-grab;cursor:grab}.skill-scroll-track:active{cursor:-webkit-grabbing;cursor:grabbing}.skill-scroll-track::-webkit-scrollbar{height:3px}.skill-scroll-track::-webkit-scrollbar-track{background:transparent}.skill-scroll-track::-webkit-scrollbar-thumb{background:var(--red);border-radius:2px}.skill-scroll-chip{flex-shrink:0;padding:.35rem .9rem;border:1px solid rgba(230,48,32,.4);border-radius:2rem;font-size:.78rem;letter-spacing:.05em;color:hsla(0,0%,100%,.65);white-space:nowrap;transition:background .2s,color .2s,border-color .2s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.skill-scroll-chip:hover{background:var(--red);color:var(--white);border-color:var(--red)}.contact{position:relative;width:100%;min-height:100vh;background:var(--off-white);display:grid;grid-template-columns:1fr 1fr;overflow:hidden}.contact-left{padding:6rem 3rem 6rem 4rem;display:flex;flex-direction:column;justify-content:space-between}.contact-heading{font-family:var(--font-sans);font-weight:900;font-size:clamp(5rem,12vw,13rem);color:var(--black);line-height:.9;letter-spacing:-.04em}.contact-socials{display:flex;flex-direction:column;gap:.3rem;padding-bottom:0}.contact-socials a{font-size:1rem;font-weight:700;color:var(--black);letter-spacing:-.01em;transition:all .25s ease;position:relative;display:inline-block}.contact-socials a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--red);transition:width .25s ease}.contact-socials a:hover{color:var(--red)}.contact-socials a:hover:after{width:100%}.contact-right{padding:6rem 4rem 6rem 3rem;display:flex;flex-direction:column;justify-content:flex-end;gap:4rem;position:relative}.contact-desc{font-size:.85rem;line-height:1.9;color:var(--black);text-align:justify;max-width:240px;align-self:flex-end;margin-bottom:1rem}.contact-desc em{font-family:var(--font-serif);font-style:italic}.contact-img{width:100%;aspect-ratio:4/3;overflow:hidden;position:relative}.contact-img img,.contact-img-placeholder{width:100%;height:100%;object-fit:cover}.contact-img-placeholder{background:linear-gradient(135deg,#c00,#3a0080 60%,#60c);display:flex;align-items:center;justify-content:center;color:hsla(0,0%,100%,.2);font-size:.75rem;letter-spacing:.2em}.contact-img:after,.contact-img:before{content:"+";position:absolute;font-size:1rem;color:hsla(0,0%,100%,.7);z-index:5;font-weight:300}.contact-img:before{top:.8rem;left:.8rem}.contact-img:after{bottom:.8rem;right:.8rem}@media (max-width:900px){.hero-first,.hero-last{font-size:clamp(4rem,15vw,8rem)}.hero-bar{padding:1rem 1.5rem;flex-wrap:wrap;gap:.5rem}.about{grid-template-columns:1fr}.about-right{height:50vw;min-height:300px;position:relative}.about-photo-placeholder,.about-right img{position:absolute}.projects{grid-template-columns:1fr}.projects-preview{display:none}.project-detail-shell{grid-template-columns:1fr;gap:2rem}.project-detail-right{position:static}.project-detail-image{aspect-ratio:16/9}.contact,.skills{grid-template-columns:1fr}.contact-heading{font-size:clamp(4rem,18vw,8rem)}.project-detail{padding:1.25rem 1.1rem 2rem}.project-detail-left,.project-detail-right{padding:1rem 0 0}.about-side-label,.cursor-dot,.cursor-ring,.projects-side-label,.scroll-counter,.scroll-num,.side-label{display:none}a,button,html{cursor:auto}}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:1.2rem 2.5rem;background:hsla(0,0%,4%,0);transition:background .4s ease,border-bottom .4s ease}.navbar--scrolled{background:hsla(0,0%,4%,.92);border-bottom:1px solid hsla(0,0%,100%,.07);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.navbar-name a{font-size:.9rem;font-weight:600;color:var(--white);letter-spacing:.02em}.navbar-links{display:flex;align-items:center;gap:2.5rem}.navbar-links a{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:hsla(0,0%,100%,.55);transition:color .25s;font-weight:500}.navbar-links .nav-active,.navbar-links a:hover{color:var(--red)}.navbar-links .nav-resume{color:hsla(0,0%,100%,.55);border:1px solid hsla(0,0%,100%,.2);padding:.4rem .8rem;border-radius:.25rem;transition:all .25s ease}.navbar-links .nav-resume:hover{color:var(--white);border-color:var(--red);background:rgba(230,48,32,.1)}.page-back{display:inline-flex;align-items:center;gap:.6rem;font-size:.85rem;color:hsla(0,0%,100%,.6);letter-spacing:.08em;margin-bottom:3rem;margin-top:1rem;padding:.75rem 1.25rem;border:1px solid hsla(0,0%,100%,.12);border-radius:.5rem;background:hsla(0,0%,100%,.02);transition:all .3s ease;font-weight:500}.page-back:hover{background:rgba(230,48,32,.1);border-color:var(--red);color:var(--red);transform:translateX(-6px);box-shadow:0 4px 12px rgba(230,48,32,.15)}.projects-page{min-height:100vh;background:var(--black);padding:7rem 2.5rem 4rem;max-width:1300px;margin:0 auto}.projects-page-hero{padding:3rem 0 4rem;border-bottom:1px solid var(--border);margin-bottom:3rem}.projects-page-title{font-size:clamp(3.5rem,8vw,7rem);font-weight:800;letter-spacing:-.03em;color:var(--white);line-height:1;margin-bottom:1rem}.projects-page-sub{font-size:1rem;color:hsla(0,0%,100%,.45)}.cat-tabs{display:flex;gap:2rem;margin-bottom:3rem;border-bottom:1px solid var(--border);padding-bottom:1rem}.cat-tab{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:hsla(0,0%,100%,.35);transition:color .2s;font-weight:500}.cat-tab:hover{color:var(--white)}.cat-tab--active{color:var(--red)}.cat-sections{position:relative}.scroll-line-track{position:absolute;left:0;top:0;bottom:0;width:2px;background:hsla(0,0%,100%,.07)}.scroll-line-fill{width:100%;height:0;background:var(--red);transition:height .1s linear;border-radius:2px}.cat-section{padding-left:2.5rem;margin-bottom:5rem}.cat-label-row{display:flex;gap:2rem;align-items:baseline;margin-bottom:1.5rem;overflow:hidden}.cat-label{font-size:clamp(2.5rem,5vw,4.5rem);font-weight:800;letter-spacing:-.03em;color:hsla(0,0%,100%,.15);white-space:nowrap;transition:color .4s}.cat-label--active{color:var(--red)}.cat-label--ghost{color:hsla(0,0%,100%,.07)}.cat-projects{display:flex;flex-direction:column}.project-row{display:grid;grid-template-columns:3rem 1fr 1fr auto;align-items:center;grid-gap:1.5rem;gap:1.5rem;padding:1.4rem 0;border-top:1px solid var(--border);transition:background .2s;cursor:pointer}.project-row:hover{background:hsla(0,0%,100%,.03)}.project-row:last-child{border-bottom:1px solid var(--border)}.project-row-num{font-size:.75rem;color:hsla(0,0%,100%,.3);font-weight:500}.project-row-title{font-size:1.2rem;font-weight:600;color:var(--white)}.project-row-desc{font-size:.85rem;color:hsla(0,0%,100%,.4)}.project-row-year{font-size:.8rem;color:hsla(0,0%,100%,.3);text-align:right}.dsa-page{min-height:100vh;background:var(--black);padding:7rem 2.5rem 4rem;max-width:1300px;margin:0 auto}.dsa-hero{padding:3rem 0 2rem}.dsa-title{font-size:clamp(3rem,7vw,6rem);font-weight:800;letter-spacing:-.03em;color:var(--white);line-height:1;margin-bottom:.8rem}.dsa-loading,.dsa-sub{font-size:1rem;color:hsla(0,0%,100%,.4)}.dsa-loading{padding:4rem 0;text-align:center}.dsa-error-note{font-size:.75rem;color:hsla(0,0%,100%,.25);text-align:center;margin-bottom:1rem}.dsa-divider{border:none;border-top:1px solid var(--border);margin:3rem 0}.dsa-stats-row{display:flex;gap:4rem;padding:2rem 0;flex-wrap:wrap}.dsa-stat{display:flex;flex-direction:column;align-items:flex-start}.dsa-stat-num{font-size:clamp(3rem,8vw,6rem);font-weight:800;letter-spacing:-.04em;color:var(--white);line-height:1}.dsa-stat-num--red{color:var(--red)}.dsa-stat-unit{font-size:1rem;color:hsla(0,0%,100%,.4);margin-left:.3rem;align-self:flex-end;padding-bottom:.8rem}.dsa-stat-label{font-size:.75rem;letter-spacing:.06em;color:hsla(0,0%,100%,.4);margin-top:.4rem;text-transform:uppercase}.dsa-activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.dsa-activity-label{font-size:.75rem;letter-spacing:.12em;color:var(--red);font-weight:600}.dsa-activity-range{font-size:.75rem;color:hsla(0,0%,100%,.3)}.dsa-heatmap-wrap{overflow-x:auto}.dsa-heatmap-months{display:grid;grid-template-columns:repeat(53,14px);grid-gap:3px;gap:3px;margin-left:28px;margin-bottom:4px}.dsa-heatmap-months span{font-size:.65rem;color:hsla(0,0%,100%,.4)}.dsa-heatmap{display:flex;gap:6px}.dsa-heatmap-days{display:grid;grid-template-rows:repeat(7,14px);grid-gap:3px;gap:3px;margin-right:4px}.dsa-heatmap-days span{font-size:.65rem;color:hsla(0,0%,100%,.3);line-height:14px}.dsa-heatmap-col,.dsa-heatmap-grid{display:flex;gap:3px}.dsa-heatmap-col{flex-direction:column}.dsa-heatmap-cell{width:14px;height:14px;border-radius:2px;transition:opacity .2s;cursor:pointer}.dsa-heatmap-cell:hover{opacity:.8}.dsa-heatmap-legend{display:flex;align-items:center;gap:4px;margin-top:.8rem;font-size:.7rem;color:hsla(0,0%,100%,.35)}.dsa-diff-row{display:flex;gap:4rem;flex-wrap:wrap}.dsa-diff-stat{display:flex;flex-direction:column}.dsa-diff-num{font-size:clamp(2rem,5vw,3.5rem);font-weight:700;color:var(--white);letter-spacing:-.03em}.dsa-diff-num--red{color:var(--red)}.dsa-diff-label{font-size:.75rem;color:hsla(0,0%,100%,.4);letter-spacing:.05em;margin-top:.3rem;text-transform:uppercase}.dsa-topics-heading{font-size:.75rem;letter-spacing:.12em;color:var(--red);font-weight:600;margin-bottom:1.5rem}.dsa-topics-grid{display:flex;flex-wrap:wrap;gap:.8rem}.dsa-topic-tag{padding:.5rem 1.1rem;border:1px solid hsla(0,0%,100%,.15);border-radius:.25rem;font-size:.82rem;color:hsla(0,0%,100%,.75);transition:border-color .2s,color .2s}.dsa-topic-tag:hover{border-color:var(--red);color:var(--red)}.dsa-recent-list{display:flex;flex-direction:column;gap:1rem}.dsa-recent-item{display:flex;align-items:center;gap:1rem;padding:1rem;border:1px solid hsla(0,0%,100%,.1);border-radius:.5rem;transition:border-color .2s,background .2s}.dsa-recent-item:hover{border-color:rgba(230,48,32,.3);background:rgba(230,48,32,.05)}.dsa-recent-diff{padding:.3rem .8rem;border-radius:.25rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.dsa-recent-diff--easy{background:hsla(0,0%,100%,.1);color:hsla(0,0%,100%,.9)}.dsa-recent-diff--medium{background:rgba(230,48,32,.2);color:var(--red)}.dsa-recent-diff--hard{background:var(--red);color:var(--white)}.dsa-recent-title{flex:1 1;font-size:.9rem;font-weight:500;color:var(--white)}.dsa-recent-tags{display:flex;gap:.5rem;flex-wrap:wrap}.dsa-recent-tag{padding:.25rem .6rem;border:1px solid hsla(0,0%,100%,.15);border-radius:.25rem;font-size:.7rem;color:hsla(0,0%,100%,.6);transition:border-color .2s,color .2s}.dsa-recent-tag:hover{border-color:var(--red);color:var(--red)}.exp-page{min-height:100vh;background:var(--black);padding:7rem 2.5rem 4rem;max-width:1200px;margin:0 auto}.exp-hero{padding:3rem 0 4rem;border-bottom:1px solid var(--border);margin-bottom:0}.exp-title{font-size:clamp(3.5rem,8vw,7rem);font-weight:800;letter-spacing:-.03em;color:var(--white);line-height:1;margin-bottom:1rem}.exp-sub{font-size:1rem;color:hsla(0,0%,100%,.4)}.exp-list{display:flex;flex-direction:column}.exp-item{display:grid;grid-template-columns:220px 1fr;grid-gap:3rem;gap:3rem;padding:3rem 0;border-bottom:1px solid var(--border)}.exp-item-left{padding-top:.3rem}.exp-period{font-size:.8rem;color:hsla(0,0%,100%,.35);font-family:Courier New,monospace;letter-spacing:.02em;line-height:1.5}.exp-role{font-size:1.8rem;font-weight:700;color:var(--white);letter-spacing:-.02em;margin-bottom:.4rem}.exp-company{font-size:1rem;color:var(--red);font-weight:500;display:inline-block;margin-bottom:1rem;transition:opacity .2s}.exp-company:hover{opacity:.8}.exp-desc{font-size:.95rem;color:hsla(0,0%,100%,.55);line-height:1.7;margin-bottom:1.2rem}.exp-bullets{list-style:none;display:flex;flex-direction:column;gap:.7rem}.exp-bullets li{display:flex;gap:.8rem;font-size:.9rem;color:hsla(0,0%,100%,.7);line-height:1.6}.exp-bullet-arrow{color:var(--red);flex-shrink:0;margin-top:.1rem}.hero{padding-top:0}#contact,.about{scroll-margin-top:70px}@media (max-width:768px){.navbar{padding:1rem 1.5rem}.navbar-links{gap:1.2rem}.navbar-links a{font-size:.65rem}.exp-item{grid-template-columns:1fr;gap:1rem}.dsa-page,.exp-page,.projects-page{padding:6rem 1.5rem 3rem}.dsa-diff-row,.dsa-stats-row{gap:2rem}.project-row{grid-template-columns:2rem 1fr auto}.project-row-desc{display:none}.cat-tabs{gap:1rem;flex-wrap:wrap}}