@import url("https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,700;1,400&family=Playfair+Display:ital,wght@1,400;1,700&display=swap");:root{--c1:#0d0d0d;--c2:#111;--c3:#1a1a1a;--accent:#e8ff3b;--accent2:#ff3b6b;--text:#f0ede6;--muted:#5a5a5a;--muted2:#3a3a3a;--font-hero:"Bebas Neue",sans-serif;--font-body:"DM Sans",sans-serif;--font-italic:"Playfair Display",serif}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{cursor:none;overflow-x:hidden;background:var(--c1);color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.6}body.welcome-active{overflow:hidden}body:before{content:"";position:fixed;inset:0;z-index:1000;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23noise)'/%3E%3C/svg%3E");background-size:200px}a{color:inherit;text-decoration:none}.section-label{display:flex;align-items:center;gap:.75rem;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1.2rem}.section-label:before{content:"";display:block;width:1.5rem;height:1px;background:var(--accent);flex-shrink:0}.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes marquee{0%{transform:translateX(0)}to{transform:translateX(-50%)}}@keyframes blobmove{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.97)}}@keyframes scrollpulse{0%,to{opacity:.3}50%{opacity:1}}#cursor{width:12px;height:12px;background:var(--accent);border-radius:50%;z-index:9999;mix-blend-mode:difference;transition:width .15s ease,height .15s ease}#cursor,#cursor-trail{position:fixed;pointer-events:none;transform:translate(-50%,-50%);top:0;left:0}#cursor-trail{width:36px;height:36px;border:1px solid rgba(232,255,59,.4);border-radius:50%;z-index:9998;transition:left .12s ease,top .12s ease}.welcome-screen{position:fixed;inset:0;z-index:5000;background:var(--c1);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .9s ease,transform .9s ease}.welcome-screen.exit{opacity:0;transform:scale(1.04)}.welcome-ghost{position:absolute;font-family:var(--font-hero);font-size:25vw;color:transparent;-webkit-text-stroke:1px rgba(232,255,59,.04);-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none;opacity:0;transition:opacity .4s ease;letter-spacing:-.02em;top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap}.welcome-ghost.visible{opacity:1}.welcome-text-wrap{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:0}.welcome-line{display:flex;overflow:hidden;line-height:1}.welcome-line .char{display:inline-block;font-family:var(--font-hero);font-size:clamp(5rem,11vw,11rem);transform:translateY(110%);opacity:0;transition:transform .7s cubic-bezier(.16,1,.3,1),opacity .7s cubic-bezier(.16,1,.3,1);letter-spacing:.01em}.welcome-line .char.show{transform:translateY(0);opacity:1}.welcome-line-1 .char{color:var(--accent)}.welcome-line-2 .char{color:var(--text)}.welcome-line-2 .char.apos{color:var(--accent2);font-family:var(--font-italic);font-style:italic}.welcome-divider{width:0;height:1px;background:var(--accent);margin:.8rem 0 .6rem;transition:width .9s cubic-bezier(.76,0,.24,1)}.welcome-divider.open{width:100%}.welcome-subtitle{font-size:.65rem;letter-spacing:.35em;text-transform:uppercase;color:var(--muted);opacity:0;transition:opacity .6s ease}.welcome-subtitle.show{opacity:1}.nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:1.4rem 4rem;display:flex;align-items:center;justify-content:space-between;mix-blend-mode:difference}.nav-logo{font-family:var(--font-hero);font-size:1.6rem;color:var(--text);line-height:1}.nav-logo span{color:var(--accent)}.nav-links{display:flex;gap:2.5rem;list-style:none}.nav-links a{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;opacity:.5;transition:opacity .2s;color:var(--text)}.nav-links a:hover{opacity:1}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:8rem 4rem 4rem;position:relative;overflow:hidden}.hero-blob{position:absolute;border-radius:50%;pointer-events:none}.hero-blob-1{width:500px;height:500px;background:rgba(232,255,59,.07);top:-10%;right:-8%}.hero-blob-1,.hero-blob-2{filter:blur(80px);animation:blobmove 14s infinite}.hero-blob-2{width:350px;height:350px;background:rgba(255,59,107,.06);bottom:5%;left:-5%;animation-delay:-7s}.hero-content{position:relative;z-index:2;max-width:900px}.hero-welcome-small{font-family:var(--font-body);font-size:.85rem;letter-spacing:.12em;color:hsla(42,25%,92%,.4);margin-bottom:.3rem;opacity:0;animation:fadeUp .8s .1s forwards}.hero-welcome-large{font-family:var(--font-hero);font-size:clamp(2rem,5vw,4rem);color:var(--text);margin-bottom:1.2rem;opacity:0;animation:fadeUp .8s .15s forwards;line-height:1}.hero-welcome-large em{font-family:var(--font-italic);font-style:italic;color:var(--accent2)}.hero-eyebrow{display:flex;align-items:center;gap:1rem;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem;opacity:0;animation:fadeUp .8s .2s forwards}.hero-eyebrow:before{content:"";display:block;width:2rem;height:1px;background:var(--accent);flex-shrink:0}.hero-h1{font-family:var(--font-hero);font-size:clamp(4.5rem,12vw,11rem);line-height:.88;margin-bottom:2rem;opacity:0;animation:fadeUp .9s .4s forwards;letter-spacing:-.01em}.hero-h1 em{font-family:var(--font-italic);font-style:italic;color:var(--accent);font-size:.85em}.hero-sub{font-size:.92rem;line-height:1.9;color:hsla(42,25%,92%,.55);max-width:420px;margin-bottom:2.5rem;opacity:0;animation:fadeUp .9s .6s forwards}.hero-ctas{display:flex;align-items:center;gap:2rem;opacity:0;animation:fadeUp .9s .8s forwards}.btn-primary{display:inline-block;padding:.85rem 2rem;background:var(--accent);color:var(--c1);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;-webkit-clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,0 100%);clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,0 100%);transition:background .25s,color .25s,transform .25s;cursor:none}.btn-primary:hover{background:var(--accent2);color:#fff;transform:translateY(-3px)}.btn-ghost{font-size:.85rem;color:hsla(42,25%,92%,.5);border-bottom:1px solid var(--muted2);padding-bottom:2px;transition:color .2s;cursor:none}.btn-ghost:hover{color:var(--text)}.hero-scroll-indicator{position:absolute;right:4rem;bottom:3rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;opacity:0;animation:fadeUp .8s 1.2s forwards;z-index:2}.hero-scroll-line{width:1px;height:60px;background:linear-gradient(to bottom,var(--accent),transparent);animation:scrollpulse 2s infinite}.hero-scroll-text{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);writing-mode:vertical-rl}.hero-marquee-wrap{position:absolute;bottom:3rem;left:0;right:0;overflow:hidden;pointer-events:none;z-index:1}.hero-marquee{display:flex;white-space:nowrap;animation:marquee 18s linear infinite;font-family:var(--font-hero);font-size:clamp(4rem,9vw,7rem);color:transparent;-webkit-text-stroke:1px var(--muted2);line-height:1}.about{background:var(--c2);padding:7rem 4rem}.about-grid{display:grid;grid-template-columns:1fr 1.3fr;grid-gap:6rem;gap:6rem;align-items:start}.about-h2{font-family:var(--font-hero);font-size:clamp(2.5rem,4vw,4.5rem);line-height:.95;margin-bottom:1.8rem}.about-h2 span{color:var(--accent)}.about-para{font-size:.9rem;line-height:1.95;color:hsla(42,25%,92%,.55);margin-bottom:1.2rem}.about-badge{display:inline-block;margin-top:1.2rem;padding:.55rem 1.2rem;border:1px solid var(--muted2);font-size:.75rem;letter-spacing:.08em;-webkit-clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%);clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%);color:hsla(42,25%,92%,.6)}.about-stats{display:flex;flex-direction:column;gap:1.5rem}.stat-card{background:var(--c3);border:1px solid var(--muted2);padding:1.8rem;display:flex;align-items:center;gap:1.5rem;-webkit-clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,0 100%);clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,0 100%);position:relative;overflow:hidden;transition:border-color .3s,transform .3s;cursor:none}.stat-card:before{content:"";position:absolute;left:0;top:0;width:3px;height:0;background:var(--accent);transition:height .3s ease}.stat-card:hover:before{height:100%}.stat-card:hover{border-color:rgba(232,255,59,.3);transform:translateX(6px)}.stat-icon{font-size:1.8rem;flex-shrink:0}.stat-num{font-family:var(--font-hero);font-size:2.2rem;color:var(--text);line-height:1;display:block}.stat-num .accent-dot{color:var(--accent)}.stat-label{font-size:.78rem;color:hsla(42,25%,92%,.5);margin-top:.25rem;display:block}.skills{background:var(--c1);padding:7rem 4rem}.skills-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4rem}.skills-h2{font-family:var(--font-hero);font-size:clamp(2.5rem,4vw,4.5rem);line-height:1;margin-top:.5rem}.skills-h2 em{font-family:var(--font-italic);font-style:italic;color:var(--accent)}.skills-note{font-size:.75rem;color:var(--muted);max-width:200px;text-align:right;line-height:1.6}.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);background:var(--muted2);grid-gap:1px;gap:1px}.skill-cat{background:var(--c1);padding:2rem 1.8rem;transition:background .25s}.skill-cat:hover{background:var(--c3)}.skill-cat-num{font-size:.6rem;letter-spacing:.2em;color:var(--muted);margin-bottom:.6rem}.skill-cat-title{font-family:var(--font-hero);font-size:1.1rem;color:var(--text);margin-bottom:1.4rem;line-height:1.2}.chips{display:flex;flex-wrap:wrap;gap:.5rem}.chip{font-size:.65rem;letter-spacing:.06em;padding:.3rem .6rem;border:1px solid var(--muted2);color:hsla(42,25%,92%,.5);cursor:none;transition:border-color .2s,color .2s,background .2s}.chip.hot,.chip:hover{border-color:rgba(232,255,59,.4);color:var(--accent);background:rgba(232,255,59,.05)}.projects{background:var(--c2);padding:7rem 4rem}.projects-header{margin-bottom:3rem}.projects-h2{font-family:var(--font-hero);font-size:clamp(2.5rem,4vw,4.5rem);line-height:.95;margin-top:.5rem}.projects-h2 em{font-family:var(--font-italic);font-style:italic;color:var(--accent2)}.proj-list{display:flex;flex-direction:column}.proj-item{display:grid;grid-template-columns:5rem 1fr auto;align-items:center;grid-gap:2rem;gap:2rem;padding:2rem 0;border-bottom:1px solid var(--muted2);cursor:none;position:relative;transition:padding-left .3s ease;overflow:hidden}.proj-item:before{content:"";position:absolute;left:0;top:0;height:1px;background:var(--accent);width:100%;transform:scaleX(0);transform-origin:left;transition:transform .4s ease}.proj-item:hover:before{transform:scaleX(1)}.proj-item:hover{padding-left:.75rem}.proj-item:hover .proj-num{color:var(--accent)}.proj-item:hover .proj-arrow{color:var(--accent);transform:translate(5px,-5px)}.proj-num{font-family:var(--font-hero);font-size:1rem;color:var(--muted);transition:color .3s}.proj-info{display:flex;flex-direction:column;gap:.5rem}.proj-name{font-family:var(--font-hero);font-size:1.8rem;color:var(--text);line-height:1}.proj-tags{display:flex;gap:.5rem;flex-wrap:wrap}.proj-tag{font-size:.65rem;letter-spacing:.06em;color:var(--muted)}.proj-tag:after{content:"·";margin-left:.5rem}.proj-tag:last-child:after{content:""}.proj-desc{font-size:.82rem;color:hsla(42,25%,92%,.4)}.proj-arrow{font-size:1.5rem;color:var(--muted);transition:color .3s,transform .3s}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:500;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-card{background:var(--c3);border:1px solid var(--muted2);-webkit-clip-path:polygon(0 0,calc(100% - 20px) 0,100% 20px,100% 100%,0 100%);clip-path:polygon(0 0,calc(100% - 20px) 0,100% 20px,100% 100%,0 100%);padding:2.5rem;max-width:520px;width:90%;position:relative;animation:fadeUp .3s ease}.modal-close{position:absolute;top:1.2rem;right:1.4rem;font-size:1.4rem;color:var(--muted);background:none;border:none;cursor:none;line-height:1;transition:color .2s}.modal-close:hover{color:var(--accent)}.modal-title{font-family:var(--font-hero);font-size:2rem;color:var(--text);margin-bottom:1rem}.modal-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.2rem}.modal-chip{font-size:.65rem;letter-spacing:.06em;padding:.3rem .7rem;border:1px solid rgba(232,255,59,.3);color:var(--accent)}.modal-desc{font-size:.88rem;line-height:1.85;color:hsla(42,25%,92%,.6);margin-bottom:1.8rem}.modal-stack-title{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:.8rem}.modal-stack-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-top:1px solid var(--muted2);font-size:.82rem;color:hsla(42,25%,92%,.55)}.modal-stack-dot{width:5px;height:5px;background:var(--accent);border-radius:50%;flex-shrink:0}.modal-stack-tech{color:var(--text);font-size:.8rem;margin-right:.4rem}.contact{background:var(--c1);padding:7rem 4rem 5rem;position:relative;overflow:hidden}.contact-ghost{position:absolute;bottom:-2rem;right:-1rem;font-family:var(--font-hero);font-size:clamp(8rem,20vw,18rem);color:transparent;-webkit-text-stroke:1px rgba(232,255,59,.04);pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.contact-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:5rem;gap:5rem;position:relative;z-index:1}.contact-h2{font-family:var(--font-hero);font-size:clamp(2.5rem,4vw,4.5rem);line-height:.95;margin-bottom:1.2rem}.contact-h2 em{font-family:var(--font-italic);font-style:italic;color:var(--accent)}.contact-blurb{font-size:.9rem;line-height:1.85;color:hsla(42,25%,92%,.5);margin-bottom:2.5rem;max-width:340px}.contact-socials{display:flex;flex-direction:column;gap:1rem}.contact-social-link{display:flex;align-items:center;gap:.75rem;font-size:.78rem;color:hsla(42,25%,92%,.55);transition:color .2s;cursor:none}.contact-social-link:hover{color:var(--accent)}.contact-social-dot{width:5px;height:5px;background:var(--accent);border-radius:50%;flex-shrink:0}.contact-form{gap:1.2rem}.contact-form,.form-field{display:flex;flex-direction:column}.form-field{gap:.4rem}.form-label{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}.form-input,.form-textarea{background:var(--c3);border:1px solid var(--muted2);color:var(--text);font-family:var(--font-body);font-size:.88rem;padding:.85rem 1rem;-webkit-clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%);clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%);outline:none;transition:border-color .2s,background .2s;resize:none;cursor:none}.form-input:focus,.form-textarea:focus{border-color:var(--accent);background:rgba(232,255,59,.03)}.form-textarea{height:130px}.btn-submit{align-self:flex-start;padding:.9rem 2.2rem;background:var(--accent);color:var(--c1);font-family:var(--font-body);font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border:none;-webkit-clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,0 100%);clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,0 100%);cursor:none;transition:background .25s,color .25s,transform .25s}.btn-submit:hover{background:var(--accent2);color:#fff;transform:translateY(-2px)}.footer{border-top:1px solid var(--muted2);padding:1.5rem 4rem;display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:var(--muted)}.footer-heart,.footer-name{color:var(--accent)}@media (max-width:900px){.nav{padding:1.2rem 2rem}.nav-links{gap:1.5rem}.hero{padding:7rem 2rem 10rem}.hero-scroll-indicator{display:none}.about{padding:5rem 2rem}.about-grid{grid-template-columns:1fr;gap:3rem}.skills{padding:5rem 2rem}.skills-grid{grid-template-columns:repeat(2,1fr)}.skills-header{flex-direction:column;align-items:flex-start;gap:1rem}.projects{padding:5rem 2rem}.proj-item{grid-template-columns:3rem 1fr auto;gap:1rem}.contact{padding:5rem 2rem}.contact-grid{grid-template-columns:1fr;gap:3rem}.footer{padding:1.5rem 2rem;flex-direction:column;gap:.5rem;text-align:center}}@media (max-width:600px){.skills-grid{grid-template-columns:1fr}.hero-marquee-wrap{bottom:7rem}.nav-links{display:none}}