@import "https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Space+Mono:wght@400;700&family=DM+Mono:wght@400;500&display=swap";
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.block{display:block}.flex{display:flex}.grid{display:grid}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}:root{--bg:#000;--white:#fff;--red:#c00;--red-muted:#1a0000;--grey:#444;--grey-light:#666;--grey-dark:#1a1a1a;--grey-mid:#333;--font-display:"Bebas Neue", sans-serif;--font-mono:"Space Mono", monospace;--font-body:"DM Mono", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}::selection{background:var(--red);color:var(--white)}html{cursor:none}body{background:var(--bg);color:var(--white);font-family:var(--font-body);cursor:none;font-size:14px;line-height:1.5;overflow-x:hidden}a{color:inherit;cursor:none;text-decoration:none}button{cursor:none;background:0 0;border:none;font-family:inherit}ul{list-style:none}#root{flex-direction:column;min-height:100vh;display:flex}.cursor-dot{background:var(--red);pointer-events:none;z-index:10001;opacity:0;border-radius:50%;width:8px;height:8px;transition:opacity .3s;position:fixed}.cursor-follower{border:1.5px solid var(--red);pointer-events:none;z-index:10000;opacity:0;border-radius:50%;width:32px;height:32px;transition:opacity .3s,width .3s,height .3s;position:fixed}.global-glitch{z-index:0;pointer-events:none;position:fixed;inset:0}.grain-container{pointer-events:none;z-index:9999;opacity:.06;width:400%;height:400%;position:fixed;top:-150%;left:-150%;overflow:hidden}.grain-animation{filter:url(#grainFilter);width:100%;height:100%;animation:.3s steps(3,end) infinite grain-shift}@keyframes grain-shift{0%{transform:translate(0)}25%{transform:translate(-2%,-3%)}50%{transform:translate(3%,1%)}75%{transform:translate(-1%,2%)}to{transform:translate(2%,-1%)}}.scanlines{pointer-events:none;z-index:9998;background:repeating-linear-gradient(0deg,#00000026 0 1px,#0000 1px 2px);width:100%;height:100%;animation:8s linear infinite scanline-drift;position:fixed;top:0;left:0}@keyframes glitch-shadow{0%{text-shadow:-3px 0 var(--red), 3px 0 #0ff}20%{text-shadow:2px 0 var(--red), -2px 0 #0ff}40%{text-shadow:-2px 3px var(--red), 2px -3px #0ff}60%{text-shadow:3px 1px var(--red), -3px 1px #0ff}80%{text-shadow:-1px -2px var(--red), 1px 2px #0ff}to{text-shadow:2px -1px var(--red), -2px 1px #0ff}}@keyframes glitch-clip{0%{clip-path:inset(40% 0 57%)}20%{clip-path:inset(92% 0 1%)}40%{clip-path:inset(43% 0 25%)}60%{clip-path:inset(25% 0 54%)}80%{clip-path:inset(54% 0 38%)}to{clip-path:inset(58% 0 34%)}}@keyframes word-reveal{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes loading-bar{0%{width:0%}80%{width:95%}to{width:100%}}@keyframes fade-out{0%{opacity:1}to{opacity:0}}@keyframes scroll-ticker{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes scroll-line-bob{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.4;transform:scaleY(.6)}}@keyframes scanline-drift{0%{background-position:0 0}to{background-position:0 4px}}@keyframes reveal-up{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.reveal-on-scroll{opacity:0;transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);transform:translateY(40px)}.reveal-on-scroll.revealed{opacity:1;transform:translateY(0)}.section-sep{background:var(--grey-dark);width:100%;height:1px}@media (max-width:768px){html,body,a,button{cursor:auto}.cursor-dot,.cursor-follower{display:none!important}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.reveal-on-scroll{opacity:1;transform:none}}.intro-screen{background:var(--bg);z-index:10002;justify-content:center;align-items:center;animation:.8s ease-in-out 2.2s forwards fade-out;display:flex;position:fixed;inset:0;overflow:hidden}.intro-content{text-align:center;z-index:1;flex-direction:column;align-items:center;gap:1.5rem;display:flex;position:relative}.intro-title{font-family:var(--font-display);letter-spacing:.08em;color:var(--white);font-size:clamp(6rem,18vw,14rem);font-weight:700;line-height:.9}.intro-title.glitch{animation:80ms infinite glitch-shadow;position:relative}.intro-title.glitch:before,.intro-title.glitch:after{content:"VRAJ";width:100%;height:100%;position:absolute;top:0;left:0}.intro-title.glitch:before{color:var(--red);animation:.15s linear infinite alternate-reverse glitch-clip;left:2px}.intro-title.glitch:after{color:#0ff;animation:.15s linear infinite alternate glitch-clip;left:-2px}.intro-subtitle{font-family:var(--font-mono);letter-spacing:.25em;text-transform:uppercase;color:var(--grey-light);align-items:center;gap:1rem;font-size:.7rem;display:flex}.intro-dash{color:var(--grey);font-size:.6rem}.loading-container{background:var(--grey-dark);width:220px;height:2px;margin-top:.5rem;overflow:hidden}.loading-bar{background:var(--red);height:100%;animation:2.2s ease-out forwards loading-bar}.header{z-index:1000;mix-blend-mode:difference;justify-content:space-between;align-items:center;height:72px;padding:0 3rem;display:flex;position:fixed;top:0;left:0;right:0}.logo{font-family:var(--font-display);letter-spacing:.08em;color:var(--white);font-size:1.75rem;font-weight:700}.hamburger{flex-direction:column;gap:7px;width:28px;padding:4px 0;display:flex}.hamburger span{background:var(--white);transform-origin:50%;width:100%;height:1px;transition:all .3s cubic-bezier(.16,1,.3,1);display:block}.hamburger.active span:first-child{transform:rotate(45deg)translate(5.5px,5.5px)}.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.active span:nth-child(3){transform:rotate(-45deg)translate(5.5px,-5.5px)}.nav-overlay{background:var(--bg);z-index:999;pointer-events:none;opacity:0;flex-direction:column;justify-content:center;padding:120px 4rem 4rem;transition:opacity .4s;display:flex;position:fixed;inset:0}.nav-overlay.active{opacity:1;pointer-events:all;overflow-y:auto}.nav-links{z-index:1;flex-direction:column;gap:.25rem;margin-bottom:auto;display:flex;position:relative}.nav-links li{opacity:0;transition:transform .5s cubic-bezier(.16,1,.3,1),opacity .5s cubic-bezier(.16,1,.3,1);overflow:hidden;transform:translateY(100%)}.nav-overlay.active .nav-links li{opacity:1;transform:translateY(0)}.nav-links a{font-family:var(--font-display);letter-spacing:.06em;color:var(--white);font-size:clamp(3.5rem,7vw,6rem);font-weight:700;line-height:1.1;transition:color .2s,transform .3s;display:inline-block}.nav-links a:hover{color:var(--red);transform:translate(12px)}.nav-socials{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;z-index:1;gap:2.5rem;padding-top:2rem;font-size:.65rem;display:flex;position:relative}.nav-socials a{color:var(--grey-light);transition:color .2s}.nav-socials a:hover{color:var(--white)}.portfolio{position:relative}.hero-section{background:radial-gradient(at 30% 80%,#14000099 0%,#0000 70%);flex-direction:column;justify-content:flex-end;min-height:100vh;padding:0 4rem 4rem;display:flex;position:relative;overflow:visible}.hero-content{z-index:1;flex-direction:column;gap:2.5rem;width:100%;max-width:1312px;margin:0 auto;display:flex;position:relative}.hero-main{align-items:flex-end;gap:3rem;display:flex}.hero-text{flex-direction:column;flex:1;gap:2rem;display:flex}.hero-portrait{border-radius:4px;flex-shrink:0;width:520px;height:600px;position:relative;overflow:visible}.hero-portrait>div{pointer-events:none;width:820px!important;height:1000px!important;position:absolute!important;top:-200px!important;left:-150px!important}.hero-portrait canvas{cursor:grab;pointer-events:auto;display:block;width:100%!important;height:100%!important}.hero-portrait canvas:active{cursor:grabbing}.hero-portrait-loading{background:var(--grey-dark);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.hero-label{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--red);font-size:.7rem}.hero-title{flex-direction:column;line-height:.9;display:flex;overflow:hidden}.hero-title .word-reveal{font-family:var(--font-display);letter-spacing:.04em;color:var(--white);opacity:0;font-size:clamp(4rem,10vw,9rem);font-weight:700;animation:.7s cubic-bezier(.16,1,.3,1) forwards word-reveal;display:block;transform:translateY(100%)}.hero-bottom{justify-content:space-between;align-items:flex-end;display:flex}.hero-tagline{font-family:var(--font-body);letter-spacing:.06em;color:var(--grey-light);max-width:280px;font-size:.75rem;line-height:1.6}.scroll-indicator{font-family:var(--font-mono);letter-spacing:.2em;color:var(--grey-light);align-items:center;gap:.75rem;font-size:.6rem;display:flex}.scroll-line{background:var(--red);transform-origin:0;width:48px;height:1px;animation:2s ease-in-out infinite scroll-line-bob}.about-section{flex-direction:column;align-items:center;gap:3rem;padding:6rem 4rem;display:flex;position:relative;overflow:hidden}.about-label{font-family:var(--font-mono);letter-spacing:.25em;text-transform:uppercase;color:var(--white);text-align:center;z-index:1;text-shadow:0 0 20px #c006;font-size:.85rem;position:relative}.about-waveform-row{z-index:1;align-items:center;gap:2rem;width:100%;max-width:900px;display:flex;position:relative}.year-marker{font-family:var(--font-display);color:var(--grey);letter-spacing:.04em;text-shadow:0 0 30px #cc00004d;flex-shrink:0;font-size:clamp(3rem,5vw,5rem);font-weight:700}.waveform-canvas{flex:1;height:80px}.about-quote{font-family:var(--font-body);letter-spacing:.06em;text-align:center;color:var(--white);z-index:1;text-shadow:0 0 20px #cc00004d;min-height:1.5em;font-size:1.3rem;position:relative}.experience-section{width:100%;max-width:1312px;margin:0 auto;padding:5rem 4rem;position:relative;overflow:hidden}.section-title{font-family:var(--font-display);letter-spacing:.06em;color:var(--white);z-index:1;margin-bottom:3rem;font-size:clamp(2.5rem,5vw,4.5rem);font-weight:700;position:relative}.experience-list{z-index:1;flex-direction:column;display:flex;position:relative}.experience-item{cursor:pointer;transition:background .2s}.experience-item:hover{background:#cc000008}.exp-row{border-bottom:1px solid #c003;align-items:center;gap:2rem;padding:1.5rem 0;transition:border-color .2s;display:flex}.experience-item:hover .exp-row{border-color:var(--red)}.exp-company{font-family:var(--font-display);letter-spacing:.04em;color:var(--white);min-width:320px;font-size:clamp(1.2rem,2vw,1.75rem);font-weight:700;transition:color .2s}.experience-item:hover .exp-company{color:var(--red)}.exp-role{font-family:var(--font-mono);letter-spacing:.12em;color:var(--grey-light);flex:1;font-size:.75rem}.exp-date{font-family:var(--font-mono);letter-spacing:.12em;color:var(--red);white-space:nowrap;font-size:.75rem}.exp-details{max-height:0;padding:0;transition:max-height .4s cubic-bezier(.16,1,.3,1),padding .4s cubic-bezier(.16,1,.3,1);overflow:hidden}.exp-details.active{max-height:200px;padding:1rem 0 1.5rem}.exp-details ul{flex-direction:column;gap:.5rem;padding-left:1rem;display:flex}.exp-details li{font-family:var(--font-body);color:var(--grey-light);padding-left:1.25rem;font-size:.85rem;position:relative}.exp-details li:before{content:"▹";color:var(--red);position:absolute;left:0}.works-header{width:100%;max-width:1312px;margin:0 auto;padding:5rem 4rem 2rem}.project-showcase{cursor:pointer;background:var(--bg);align-items:center;min-height:100vh;display:flex;position:sticky;top:0;overflow:hidden}.project-showcase:before{content:"";background:linear-gradient(to right, transparent, var(--grey-dark), transparent);height:1px;transform:scaleX(var(--sep-scale,0));z-index:4;position:absolute;top:0;left:0;right:0}.project-showcase:after{content:"";z-index:3;pointer-events:none;background:linear-gradient(#00000080,#0000);height:120px;position:absolute;top:0;left:0;right:0}.ps-bg{z-index:0;will-change:transform, opacity, filter;transform-origin:50%;position:absolute;inset:0}.ps-bg-gradient{background:radial-gradient(at 70%,#cc00000f 0%,#0000 60%),radial-gradient(at 20% 80%,#1e000080 0%,#0000 50%),linear-gradient(160deg,#0a0a0a 0%,#120202f2 50%,#0a0a0a 100%);position:absolute;inset:0}.project-showcase:nth-child(2n) .ps-bg-gradient{background:radial-gradient(at 30% 40%,#cc00000d 0%,#0000 55%),radial-gradient(at 80% 70%,#1e000066 0%,#0000 50%),linear-gradient(200deg,#0a0a0a 0%,#0f0505f2 50%,#0a0a0a 100%)}.ps-bg-image{object-fit:cover;opacity:.4;filter:blur(12px)saturate(1.2)contrast(1.1);width:100%;height:100%;transition:opacity 1s cubic-bezier(.16,1,.3,1),filter 1s cubic-bezier(.16,1,.3,1),transform 1.6s cubic-bezier(.16,1,.3,1);position:absolute;inset:0;transform:scale(1.06)}.ps-revealed .ps-bg-image{opacity:.85;filter:blur()saturate(1.1)contrast(1.05);transform:scale(1)}.project-showcase:hover .ps-bg-image{opacity:.95;transform:scale(1.02)}.ps-viz{z-index:0;pointer-events:none;will-change:opacity, transform;transform-origin:50%;width:100%;height:100%;position:absolute;inset:0}.ps-bg-overlay{z-index:1;background:linear-gradient(90deg,#000c 0%,#00000059 35%,#0000001a 60%,#0003 100%);position:absolute;inset:0}.ps-layout{z-index:2;will-change:transform, opacity;transform-origin:50%;justify-content:space-between;align-items:center;gap:3rem;width:100%;max-width:1312px;margin:0 auto;padding:0 4rem;display:flex;position:relative}.ps-left{flex-direction:column;flex-shrink:0;gap:1.25rem;max-width:420px;display:flex}.ps-meta{font-family:var(--font-mono);letter-spacing:.2em;color:var(--grey-light);text-transform:uppercase;flex-direction:column;gap:.3rem;font-size:.65rem;display:flex}.ps-year{color:var(--red);letter-spacing:.15em;font-size:.7rem}.ps-subtitle{font-family:var(--font-body);letter-spacing:.04em;color:var(--grey-light);font-size:.9rem;line-height:1.6}.ps-description{font-family:var(--font-body);letter-spacing:.02em;color:var(--grey-mid);max-width:380px;font-size:.8rem;line-height:1.7}.ps-tags{flex-wrap:wrap;gap:.5rem;display:flex}.ps-tag{font-family:var(--font-mono);letter-spacing:.15em;color:var(--white);border:1px solid var(--grey-mid);padding:.3rem .75rem;font-size:.55rem;transition:border-color .4s}.project-showcase:hover .ps-tag{border-color:var(--red)}.ps-tech{flex-wrap:wrap;gap:.4rem;display:flex}.ps-tech-item{font-family:var(--font-mono);letter-spacing:.1em;color:var(--grey-light);text-transform:uppercase;background:#ffffff0a;border:1px solid #ffffff0f;padding:.25rem .6rem;font-size:.5rem}.ps-cta{font-family:var(--font-mono);letter-spacing:.2em;color:var(--grey-mid);font-size:.6rem;transition:color .3s}.ps-revealed .ps-cta{opacity:1}.project-showcase:hover .ps-cta{color:var(--red)}.ps-cta-arrow{transition:transform .3s;display:inline-block}.project-showcase:hover .ps-cta-arrow{transform:translate(6px)}.ps-right{flex:1;justify-content:flex-end;align-items:center;display:flex}.ps-title{font-family:var(--font-display);letter-spacing:.04em;color:var(--red);text-align:right;text-shadow:0 0 60px #cc00004d;font-size:clamp(5rem,12vw,11rem);font-weight:700;line-height:.85;transition:text-shadow .4s}.project-showcase:hover .ps-title{text-shadow:0 0 100px #cc000080,0 0 40px #cc00004d}.ps-counter{z-index:3;font-family:var(--font-mono);letter-spacing:.15em;color:var(--grey-mid);will-change:transform;font-size:.6rem;position:absolute;top:3rem;right:4rem}.ps-counter-current{color:var(--white);font-size:.75rem}.ps-counter-sep{color:var(--grey-dark);margin:0 .4rem}.skills-section{width:100%;max-width:1312px;margin:0 auto;padding:5rem 4rem;position:relative;overflow:hidden}.skills-grid{z-index:1;grid-template-columns:1fr 1fr;gap:4rem;margin-bottom:3rem;display:grid;position:relative}.skills-label{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:1.25rem;font-size:.7rem}.skills-tags{flex-wrap:wrap;gap:.6rem;display:flex}.skill-tag{font-family:var(--font-body);letter-spacing:.06em;border:1px solid var(--grey-mid);color:var(--white);cursor:pointer;padding:.5rem 1rem;font-size:.8rem;transition:all .25s}.skill-tag:hover{background:var(--red);border-color:var(--red);color:var(--bg)}.tech-ticker{z-index:1;background:#050505b3;width:100%;margin-top:.5rem;padding:.75rem 0;position:relative;overflow:hidden}.tech-ticker-track{white-space:nowrap;animation:30s linear infinite scroll-ticker;display:flex}.tech-ticker-set{flex-shrink:0;gap:0;padding-right:0;display:flex}.tech-ticker-set span{font-family:var(--font-mono);letter-spacing:.2em;color:var(--grey-mid);white-space:nowrap;font-size:.6rem}.ticker-dot{color:var(--red);margin:0 1.5rem;font-size:.8rem}.achievements-section{background:#1a0000b3;padding:1.25rem 0;position:relative;overflow:hidden}.achievements-ticker{white-space:nowrap;z-index:1;animation:40s linear infinite scroll-ticker;display:flex;position:relative}.ach-set{flex-shrink:0;display:flex}.ach-set span{font-family:var(--font-mono);letter-spacing:.12em;color:var(--white);white-space:nowrap;font-size:.7rem}.ach-dot{color:var(--red);opacity:.5;margin:0 2rem}.contact-section{width:100%;max-width:1312px;margin:0 auto;padding:6rem 4rem;position:relative;overflow:hidden}.contact-title{font-family:var(--font-display);letter-spacing:.06em;color:var(--white);z-index:1;margin-bottom:4rem;font-size:clamp(3rem,7vw,6rem);font-weight:700;line-height:.95;position:relative}.contact-grid{z-index:1;flex-direction:column;margin-bottom:3rem;display:flex;position:relative}.contact-row{border-bottom:1px solid var(--grey-dark);align-items:center;gap:2rem;padding:1rem 0;display:flex}.contact-label{font-family:var(--font-mono);letter-spacing:.2em;color:var(--grey-light);min-width:160px;font-size:.7rem}.contact-row a,.contact-value{font-family:var(--font-body);letter-spacing:.04em;color:var(--white);font-size:.9rem;position:relative}.contact-row a:after{content:"";background:var(--red);width:0;height:1px;transition:width .3s;position:absolute;bottom:-2px;left:0}.contact-row a:hover:after{width:100%}.cta-btn{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--white);background:var(--red);z-index:1;align-items:center;gap:.75rem;padding:1.1rem 3rem;font-size:.8rem;font-weight:600;transition:all .3s;display:inline-flex;position:relative}.cta-btn:hover{transform:scale(1.03);box-shadow:0 0 30px #c006}.cta-arrow{font-size:1.1rem;transition:transform .3s}.cta-btn:hover .cta-arrow{transform:translate(4px)}.footer{padding:3rem 4rem;position:relative;overflow:hidden}.footer-top{z-index:1;justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex;position:relative}.footer-logo{font-family:var(--font-display);letter-spacing:.08em;color:var(--white);font-size:1.5rem;font-weight:700}.footer-socials{gap:2rem;display:flex}.footer-socials a{font-family:var(--font-mono);letter-spacing:.15em;color:var(--grey-light);font-size:.6rem;transition:color .2s}.footer-socials a:hover{color:var(--white)}.footer-sep{z-index:1;background:#111;width:100%;height:1px;margin-bottom:2rem;position:relative}.footer-bottom{z-index:1;justify-content:space-between;align-items:center;display:flex;position:relative}.footer-bottom span{font-family:var(--font-mono);letter-spacing:.12em;color:var(--grey-mid);font-size:.6rem}.back-to-top{font-family:var(--font-mono);letter-spacing:.12em;color:var(--grey-light);font-size:.6rem;transition:color .2s}.back-to-top:hover{color:var(--white)}@media (max-width:768px){.header{padding:0 1.5rem}.hero-section{padding:0 1.5rem 3rem}.hero-main{flex-direction:column;align-items:flex-start;gap:2rem}.hero-portrait{width:100%;height:450px}.hero-bottom{flex-direction:column;align-items:flex-start;gap:2rem}.scroll-indicator{display:none}.about-section{padding:3rem 1.5rem}.about-waveform-row{flex-direction:column;gap:1rem}.about-waveform-row .year-marker{font-size:1.5rem}.experience-section,.works-section,.skills-section,.contact-section{padding:3rem 1.5rem}.exp-row{flex-direction:column;align-items:flex-start;gap:.5rem}.exp-company{min-width:auto}.work-item{flex-wrap:wrap}.work-name{width:100%;min-width:auto}.works-header{padding:3rem 1.5rem 1.5rem}.project-showcase{min-height:100vh}.ps-layout{flex-direction:column;align-items:flex-start;gap:2rem;padding:0 1.5rem}.ps-left{max-width:100%}.ps-right{justify-content:flex-start}.ps-title{text-align:left;font-size:clamp(3rem,10vw,6rem)}.ps-subtitle{opacity:1;transform:none}.ps-description{max-width:100%}.ps-counter{top:1.5rem;right:1.5rem}.skills-grid{grid-template-columns:1fr;gap:2rem}.contact-row{flex-direction:column;align-items:flex-start;gap:.5rem}.contact-label{min-width:auto}.footer{padding:2rem 1.5rem}.footer-top{flex-direction:column;align-items:flex-start;gap:1.5rem}.footer-bottom{flex-direction:column;align-items:flex-start;gap:1rem}.nav-overlay{padding:100px 1.5rem 2rem}}@media (max-width:1200px){.header{padding:0 2.25rem}.hero-section,.about-section,.experience-section,.works-header,.skills-section,.contact-section,.footer{padding-left:2.5rem;padding-right:2.5rem}.hero-portrait{width:460px;height:540px}.hero-portrait>div{width:740px!important;height:900px!important;top:-160px!important;left:-120px!important}.exp-company{min-width:240px}.ps-layout{padding:0 2.5rem}.ps-title{font-size:clamp(4rem,10vw,8rem)}.ps-counter{right:2.5rem}.nav-overlay{padding:110px 2.5rem 2.5rem}}@media (max-width:1024px){.hero-main{flex-direction:column;align-items:flex-start;gap:2rem}.hero-portrait{width:100%;max-width:560px;height:430px}.hero-portrait>div{transform:translate(-50%);width:min(760px,160vw)!important;height:860px!important;top:-140px!important;left:50%!important}.hero-bottom{flex-direction:column;align-items:flex-start;gap:1.5rem}.about-waveform-row{flex-direction:column;gap:1rem}.ps-layout{flex-direction:column;justify-content:center;align-items:flex-start;gap:2rem}.ps-left,.ps-description{max-width:100%}.ps-right{justify-content:flex-start;width:100%}.ps-title{text-align:left;font-size:clamp(3.5rem,11vw,6.5rem)}.skills-grid{grid-template-columns:1fr;gap:2.5rem}.contact-row{align-items:flex-start}.footer-top,.footer-bottom{flex-direction:column;align-items:flex-start;gap:1rem}.nav-socials{flex-wrap:wrap;row-gap:1rem}}@media (max-width:640px){.intro-subtitle{flex-wrap:wrap;justify-content:center;row-gap:.35rem}.loading-container{width:min(220px,72vw)}.nav-links a{font-size:clamp(2.2rem,10vw,3.75rem)}.nav-socials{gap:1.25rem;font-size:.55rem}.hero-portrait{height:380px}.hero-portrait>div{width:min(680px,180vw)!important;height:760px!important;top:-110px!important}.ps-counter{display:none}.cta-btn{justify-content:center;width:100%;padding-left:1.5rem;padding-right:1.5rem}}@media (max-width:480px){.intro-title{font-size:clamp(4rem,28vw,6rem)}.hero-label,.skills-label,.contact-label{letter-spacing:.14em}.hero-tagline{font-size:.7rem}.year-marker{font-size:2rem}.about-quote{font-size:1rem}.ps-tag{padding:.25rem .55rem;font-size:.5rem}.ps-tech-item{letter-spacing:.08em;font-size:.45rem}.contact-row a,.contact-value{word-break:break-word;font-size:.8rem}.footer-socials{flex-wrap:wrap;gap:1rem}}@supports (height:100svh){@media (max-width:1024px){.hero-section,.project-showcase{min-height:100svh}}}@media (max-width:1024px) and (max-height:760px){.nav-overlay{justify-content:flex-start;padding-top:88px}.nav-links a{font-size:clamp(2.1rem,8vw,3.5rem);line-height:1}.nav-socials{padding-top:1.25rem}.hero-section{padding-bottom:2rem}.hero-portrait{height:320px}.hero-portrait>div{width:min(620px,180vw)!important;height:680px!important;top:-90px!important}.project-showcase{position:relative}}@media (max-width:768px){.header,.hero-section,.about-section,.experience-section,.works-header,.skills-section,.contact-section,.footer,.nav-overlay,.ps-layout{padding-left:1.5rem;padding-right:1.5rem}.nav-overlay{padding-top:100px;padding-bottom:2rem}.hero-portrait{max-width:100%}.hero-portrait>div{transform:translate(-50%);left:50%!important}.ps-counter{right:1.5rem}}@media (max-width:380px){.header,.hero-section,.about-section,.experience-section,.works-header,.skills-section,.contact-section,.footer,.nav-overlay,.ps-layout{padding-left:1rem;padding-right:1rem}.nav-links a{font-size:clamp(1.8rem,11vw,2.7rem)}.hero-title .word-reveal,.ps-title,.contact-title{overflow-wrap:anywhere}.hero-portrait{height:320px}.hero-portrait>div{width:min(560px,195vw)!important;height:620px!important;top:-90px!important}}@media (max-width:768px){.portfolio{width:100%;max-width:100vw;overflow-x:clip}.hero-content{gap:1.5rem}.hero-main{align-items:center;width:100%}.hero-text{width:100%}.hero-portrait{width:100%;max-width:360px;height:360px;margin:0 auto}.hero-portrait>div{transform:translate(-50%);width:min(620px,185vw)!important;height:700px!important;top:-70px!important;left:50%!important}.about-section{text-align:center;align-items:center}.about-waveform-row{justify-content:center;align-items:center;width:100%;max-width:100%}.waveform-canvas{width:100%;min-height:64px}.about-quote{width:100%;max-width:24ch;margin:0 auto;line-height:1.5}.works-header{max-width:none}.project-showcase{align-items:flex-end;min-height:100svh;position:relative}.ps-bg-overlay{background:linear-gradient(#0000004d 0%,#0000007a 55%,#000000c2 100%)}.ps-layout{gap:1.1rem;width:100%;max-width:100%;margin:0;padding:0 1.25rem 1.5rem}.ps-left{gap:.8rem;width:100%}.ps-subtitle,.ps-description{line-height:1.45}.ps-title{text-wrap:balance;font-size:clamp(2.2rem,12vw,3.8rem);line-height:.9}}@media (max-width:480px){.hero-portrait{max-width:320px;height:320px}.hero-portrait>div{width:min(560px,190vw)!important;height:620px!important;top:-64px!important}.ps-layout{padding:0 1rem 1.25rem}.ps-title{font-size:clamp(2rem,11.5vw,3.1rem)}.about-quote{max-width:22ch}}.project-detail{background:var(--bg);z-index:1;min-height:100vh;position:relative}.pd-back{z-index:1000;font-family:var(--font-mono);letter-spacing:.2em;color:var(--grey-light);mix-blend-mode:difference;align-items:center;gap:.5rem;font-size:.65rem;transition:color .2s;display:flex;position:fixed;top:24px;left:3rem}.pd-back:hover{color:var(--white)}.pd-back-arrow{font-size:1rem;transition:transform .3s}.pd-back:hover .pd-back-arrow{transform:translate(-4px)}.pd-hero{background:var(--bg);flex-direction:column;justify-content:flex-end;min-height:100vh;padding:0 4rem 5rem;display:flex;position:relative;overflow:hidden}.pd-hero-image{object-fit:cover;opacity:.55;filter:grayscale(30%)contrast(1.15);width:100%;height:100%;position:absolute;inset:0}.pd-hero-overlay{z-index:1;background:linear-gradient(#00000080 0%,#00000040 40%,#00000073 70%,#000000e6 100%);position:absolute;inset:0}.pd-hero-meta{font-family:var(--font-mono);letter-spacing:.2em;color:var(--grey-light);z-index:2;gap:2rem;margin-bottom:2rem;font-size:.65rem;display:flex;position:relative}.pd-num{color:var(--red);font-size:.75rem}.pd-title{font-family:var(--font-display);letter-spacing:.04em;color:var(--white);z-index:2;margin-bottom:1.5rem;font-size:clamp(5rem,14vw,12rem);font-weight:700;line-height:.9;position:relative}.pd-subtitle{font-family:var(--font-body);letter-spacing:.04em;color:var(--grey-light);z-index:2;max-width:500px;margin-bottom:2rem;font-size:1rem;position:relative}.pd-tags-row{z-index:2;align-items:center;gap:1rem;display:flex;position:relative}.pd-tag{font-family:var(--font-mono);letter-spacing:.15em;color:var(--white);border:1px solid var(--grey-mid);padding:.4rem 1rem;font-size:.65rem}.pd-year{font-family:var(--font-mono);letter-spacing:.15em;color:var(--red);font-size:.65rem}.pd-content{z-index:1;flex-direction:column;gap:4rem;max-width:900px;margin:0 auto;padding:5rem 4rem;display:flex;position:relative}.pd-section-label{font-family:var(--font-mono);letter-spacing:.25em;color:var(--red);margin-bottom:1.5rem;font-size:.65rem}.pd-description{flex-direction:column;gap:1.25rem;display:flex}.pd-description p{font-family:var(--font-body);letter-spacing:.03em;color:var(--grey-light);font-size:.9rem;line-height:1.8}.pd-features{flex-direction:column;display:flex}.pd-features li{border-bottom:1px solid var(--grey-dark);font-family:var(--font-body);color:var(--grey-light);letter-spacing:.03em;align-items:baseline;gap:1.25rem;padding:1rem 0;font-size:.85rem;display:flex}.pd-feat-num{font-family:var(--font-mono);color:var(--grey-mid);letter-spacing:.1em;flex-shrink:0;font-size:.6rem}.pd-tech-tags{flex-wrap:wrap;gap:.6rem;display:flex}.pd-tech-tag{font-family:var(--font-body);letter-spacing:.06em;border:1px solid var(--grey-mid);color:var(--white);padding:.45rem 1rem;font-size:.75rem;transition:all .25s}.pd-tech-tag:hover{background:var(--red);border-color:var(--red);color:var(--bg)}.pd-links{gap:1.5rem;display:flex}.pd-link{font-family:var(--font-mono);letter-spacing:.2em;color:var(--white);align-items:center;gap:.5rem;font-size:.7rem;transition:color .2s;display:flex;position:relative}.pd-link:after{content:"";background:var(--red);width:0;height:1px;transition:width .3s;position:absolute;bottom:-2px;left:0}.pd-link:hover:after{width:100%}.pd-link-arrow{transition:transform .3s}.pd-link:hover .pd-link-arrow{transform:translate(4px)}.pd-next{border-top:1px solid var(--grey-dark);justify-content:space-between;align-items:center;padding:3rem 4rem;transition:background .3s;display:flex}.pd-next:hover{background:#cc000008}.pd-next-label{font-family:var(--font-mono);letter-spacing:.2em;color:var(--grey-light);font-size:.6rem}.pd-next-name{font-family:var(--font-display);letter-spacing:.06em;color:var(--white);font-size:clamp(2rem,4vw,3.5rem);font-weight:700;transition:color .2s}.pd-next:hover .pd-next-name{color:var(--red)}.pd-next-arrow{color:var(--grey-light);font-size:2rem;transition:transform .3s,color .2s}.pd-next:hover .pd-next-arrow{color:var(--red);transform:translate(8px)}.project-not-found{background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:100vh;display:flex}.pnf-label{font-family:var(--font-display);color:var(--grey-dark);font-size:8rem;line-height:1}.pnf-title{font-family:var(--font-display);letter-spacing:.1em;color:var(--white);font-size:2rem}.pnf-back{font-family:var(--font-mono);letter-spacing:.2em;color:var(--red);font-size:.7rem;transition:color .2s}.pnf-back:hover{color:var(--white)}@media (max-width:768px){.pd-back{top:20px;left:1.5rem}.pd-hero{padding:0 1.5rem 3rem}.pd-hero-meta{flex-wrap:wrap;gap:1rem}.pd-content{gap:3rem;padding:3rem 1.5rem}.pd-tags-row{flex-wrap:wrap}.pd-title{font-size:clamp(2.4rem,14vw,4.75rem)}.pd-subtitle{max-width:100%;font-size:.9rem}.pd-links{flex-wrap:wrap;row-gap:1rem}.pd-link{font-size:.62rem}.pd-next{flex-direction:column;align-items:flex-start;gap:1rem;padding:2rem 1.5rem}}@media (max-width:1200px){.pd-back{left:2.5rem}.pd-hero,.pd-content,.pd-next{padding-left:2.5rem;padding-right:2.5rem}}@media (max-width:1024px){.pd-back{left:2rem}.pd-hero{min-height:85vh;padding:0 2rem 3.5rem}.pd-title{font-size:clamp(3.5rem,12vw,8rem)}.pd-content{padding:4rem 2rem}.pd-features li{align-items:flex-start}.pd-links{flex-wrap:wrap}.pd-next{padding:2.5rem 2rem}}@media (max-width:480px){.pd-back{letter-spacing:.14em;font-size:.55rem;top:16px;left:1rem}.pd-hero{padding:0 1rem 2.5rem}.pd-hero-meta{letter-spacing:.14em;gap:.7rem;margin-bottom:1.25rem;font-size:.55rem}.pd-subtitle{margin-bottom:1.5rem}.pd-tag,.pd-year,.pd-tech-tag{letter-spacing:.1em;font-size:.58rem}.pd-content{gap:2.5rem;padding:2.5rem 1rem}.pd-description p,.pd-features li{font-size:.8rem;line-height:1.7}.pd-next{padding:1.75rem 1rem}.pd-next-name{font-size:clamp(1.5rem,9vw,2.4rem)}.pnf-label{font-size:5rem}.pnf-title{font-size:1.4rem}}@supports (height:100svh){@media (max-width:1024px){.pd-hero{min-height:100svh}}}@media (max-width:1024px) and (max-height:760px){.pd-back{top:14px}.pd-hero{padding-bottom:2rem}.pd-title{line-height:.82}.pd-subtitle{margin-bottom:1.25rem}}@media (max-width:768px){.pd-back{left:1.5rem}.pd-hero,.pd-content,.pd-next{padding-left:1.5rem;padding-right:1.5rem}.pd-title,.pd-next-name{overflow-wrap:anywhere}}@media (max-width:380px){.pd-back{letter-spacing:.1em;left:1rem}.pd-hero,.pd-content,.pd-next{padding-left:1rem;padding-right:1rem}.pd-links{gap:.75rem}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
html.lenis,html.lenis body{height:auto}.lenis:not(.lenis-autoToggle).lenis-stopped{overflow:clip}.lenis [data-lenis-prevent],.lenis [data-lenis-prevent-wheel],.lenis [data-lenis-prevent-touch],.lenis [data-lenis-prevent-vertical],.lenis [data-lenis-prevent-horizontal]{overscroll-behavior:contain}.lenis.lenis-smooth iframe{pointer-events:none}.lenis.lenis-autoToggle{transition-behavior:allow-discrete;transition-property:overflow;transition-duration:1ms}
