*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #000;--bg-card: #0d0d0d;--border: #1c1c1e;--border-hover: rgba(255, 255, 255, .12);--text-primary: #ffffff;--text-secondary: #aeaeb2;--text-muted: #7c7c80}html{scroll-behavior:smooth}body{background-color:var(--bg);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:999px}a{color:inherit;text-decoration:none}.skip-link{position:fixed;top:-100%;left:1rem;z-index:9999;padding:.5rem 1.125rem;background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-hover);border-radius:6px;font-size:.875rem;font-weight:500;transition:top .2s ease}.skip-link:focus-visible{top:1rem;outline:none}:focus-visible{outline:2px solid rgba(255,255,255,.55);outline-offset:3px}#root{position:relative}.bg-terminal{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;display:flex;gap:0;overflow:hidden;opacity:.085}.bg-terminal__col{flex:1;display:flex;flex-direction:column;padding:0 .75rem;animation:termScroll linear infinite;will-change:transform}.bg-terminal__col:nth-child(2n){animation-direction:reverse}.bg-terminal__line{font-family:Courier New,Courier,monospace;font-size:.7rem;color:#e0ffe0;white-space:nowrap;line-height:2;overflow:hidden;text-overflow:ellipsis}@keyframes termScroll{0%{transform:translateY(0)}to{transform:translateY(-50%)}}.nav{position:fixed;top:0;inset-inline:0;z-index:100;isolation:isolate;height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(1.5rem,5vw,4rem);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);transition:background-color .4s ease,border-color .4s ease;border-bottom:1px solid transparent}.nav--scrolled{background-color:#000000b8;border-bottom-color:var(--border)}.nav__logo{font-size:.9375rem;font-weight:600;letter-spacing:-.025em}.nav__links{display:flex;gap:2rem;list-style:none;position:absolute;left:50%;transform:translate(-50%)}.nav__right{display:flex;align-items:center;gap:.5rem;margin-left:auto}.nav__link{position:relative;font-size:.875rem;color:var(--text-secondary);transition:color .2s ease}.nav__link:after{content:"";position:absolute;bottom:-3px;left:0;width:100%;height:1px;background:#ffffff59;transform:scaleX(0);transform-origin:left;transition:transform .25s ease}.nav__link:hover{color:var(--text-primary)}.nav__link:hover:after{transform:scaleX(1)}.nav__link--active{color:var(--text-primary)}.nav__link--active:after{transform:scaleX(1)}.hero{position:relative;z-index:1;min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:8rem clamp(1.5rem,5vw,4rem) 6rem;max-width:1400px;width:100%;margin:0 auto}.hero__eyebrow{font-size:1rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:#4afa6a;margin-bottom:1.25rem}@media (min-width: 768px){.hero__eyebrow{font-size:1.375rem}}.hero__name-row{display:flex;align-items:flex-start;gap:1.25rem;margin-bottom:2rem;min-width:0}.hero__name{font-size:clamp(2.75rem,11vw,9rem);font-weight:700;letter-spacing:-.04em;line-height:.93;flex-shrink:0;background:linear-gradient(160deg,#fff 55%,#ffffff61);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero__inline-terminal{display:flex;overflow:hidden;flex:1;min-width:0;height:calc(clamp(2.75rem,11vw,9rem)*1.86);background:#000000e0;border-radius:.25rem;padding:0 .5rem}.hero__inline-terminal__col{width:100%;display:flex;flex-direction:column;align-self:flex-start;animation:termScroll 22s linear infinite;will-change:transform}.hero__inline-terminal__line{font-family:Courier New,Courier,monospace;font-size:.5rem;color:#e0ffe0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.9;opacity:.6}@media (max-width: 767px){.bg-terminal{opacity:.14}.hero{padding-top:5rem;padding-bottom:4rem}.hero__eyebrow{margin-bottom:.75rem}.hero__name-row{margin-bottom:1.25rem}.hero__bio{font-size:.8125rem;line-height:1.65;margin-bottom:.5rem;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.hero__bio--expanded{display:block;overflow:visible}.hero__stack{margin-bottom:1.75rem}}@media (min-width: 768px){.hero__inline-terminal{max-width:clamp(220px,28vw,380px)}.hero__inline-terminal__line{font-size:.8rem;line-height:2}}.hero__bio-wrap{max-width:50ch;margin-bottom:2.5rem}.hero__bio{font-size:clamp(.9375rem,1.5vw,1.0625rem);color:var(--text-secondary);line-height:1.8}.hero__bio-toggle{display:none;background:none;border:none;padding:0;font-size:.8125rem;font-family:inherit;color:var(--text-muted);cursor:pointer;transition:color .2s}.hero__bio-toggle:hover{color:var(--text-secondary)}@media (max-width: 767px){.hero__bio-toggle{display:inline-block;margin-bottom:1rem}}.hero__stack{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:3rem}.pill{display:inline-flex;align-items:center;gap:.4rem;padding:.3125rem .875rem;border-radius:999px;font-size:.8125rem;font-weight:500;line-height:1;border:1px solid var(--border);background:#ffffff08;color:var(--text-secondary);transition:color .2s,border-color .2s,background .2s,transform .2s;cursor:default}.pill:hover{color:var(--text-primary);border-color:#ffffff24;background:#ffffff0f}.pill--link{cursor:pointer}.pill--link:hover{transform:translateY(-1px)}.hero__socials{display:flex;gap:.75rem;flex-wrap:wrap}.hero__scroll{position:absolute;bottom:2.5rem;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:.4rem;color:var(--text-secondary);transition:color .25s ease}.hero__scroll:hover{color:var(--text-primary)}@media (max-width: 767px){.hero__scroll{bottom:0}}.hero__scroll-label{font-size:.6875rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase}.section{position:relative;z-index:1;padding:7rem clamp(1.5rem,5vw,4rem);max-width:1400px;width:100%;margin:0 auto}.section-blur-wrap{position:relative;z-index:1}.section-blur-wrap:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#0000008c;pointer-events:none}.section-blur-wrap>*{position:relative;z-index:1}.section__eyebrow{font-size:.8125rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.75rem}.section__title{font-size:clamp(2.25rem,5vw,3.75rem);font-weight:700;letter-spacing:-.035em;line-height:1.02;margin-bottom:1rem}.section__subtitle{font-size:1rem;color:var(--text-secondary);max-width:48ch;line-height:1.75;margin-bottom:3.5rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,320px),1fr));gap:1rem}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:1.125rem;overflow:hidden;display:flex;flex-direction:column;transition:border-color .3s ease,box-shadow .3s ease}.project-card:hover{border-color:#ffffff1a;box-shadow:0 0 0 1px #ffffff0a,0 20px 50px #0000008c}.project-card__thumb{aspect-ratio:16 / 9;position:relative;overflow:hidden;background:#0a0a0a;display:block;cursor:pointer}.project-card__thumb-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease,filter .5s ease;filter:brightness(.88)}.project-card__thumb:hover .project-card__thumb-img{transform:scale(1.04);filter:brightness(1)}.project-card__thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,transparent 55%,rgba(0,0,0,.45) 100%);pointer-events:none}.project-card__thumb-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#161616,#090909)}.project-card__thumb-bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 1px);background-size:24px 24px}.project-card__thumb--placeholder{cursor:default}.project-card__wip-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.6875rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#ffffff80;border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:.3rem .875rem;z-index:1}.project-card__thumb-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.6875rem;letter-spacing:.12em;text-transform:uppercase;color:#ffffff2e;font-weight:500;z-index:1}.project-card__body{padding:1.25rem 1.375rem 1.375rem;flex:1;display:flex;flex-direction:column}.project-card__title{font-size:1rem;font-weight:600;letter-spacing:-.015em;margin-bottom:.4rem;color:var(--text-primary)}.project-card__desc{font-size:.875rem;color:var(--text-secondary);line-height:1.65;flex:1;margin-bottom:1.125rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-card__desc--expanded{display:block;overflow:visible;-webkit-line-clamp:unset}.project-card__toggle{background:none;border:none;padding:0;margin-top:-.625rem;margin-bottom:.875rem;font-size:.75rem;font-family:inherit;color:var(--text-muted);cursor:pointer;transition:color .2s;text-align:left}@media (hover: hover){.project-card__toggle:hover{color:var(--text-secondary)}}.project-card__footer{display:flex;flex-direction:column;gap:.625rem}.project-card__tags{display:flex;flex-wrap:wrap;gap:.375rem}.project-card__links{display:flex;gap:.5rem;align-self:flex-end}.project-card__link{display:flex;align-items:center;justify-content:center;width:1.875rem;height:1.875rem;border-radius:999px;border:1px solid var(--border);background:#ffffff05;color:var(--text-secondary);transition:color .2s,border-color .2s,background .2s}.project-card__link:hover{color:var(--text-primary);border-color:#ffffff24;background:#ffffff0f}.project-card__link--disabled{opacity:.25;cursor:default}.project-card__link--disabled:hover{color:var(--text-secondary);border-color:var(--border);background:#ffffff05}.project-tag{font-size:.6875rem;font-weight:500;padding:.2rem .6rem;border-radius:999px;border:1px solid var(--border);color:var(--text-secondary);background:#ffffff05;letter-spacing:.02em}@media (max-width: 767px){#stack{padding-top:1rem;scroll-margin-top:96px}}.stack-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem;margin-top:3rem}.stack-item{display:flex;flex-direction:column;align-items:center;gap:.625rem;padding:1.25rem .75rem 1.125rem;border-radius:.875rem;border:1px solid var(--border);background:#ffffff05;cursor:pointer;text-decoration:none;transition:border-color .2s,background .2s}.stack-item:hover{border-color:#ffffff1a;background:#ffffff0a}.stack-item__icon{flex-shrink:0;opacity:.9}.stack-item__name{font-size:.75rem;font-weight:500;color:var(--text-secondary);letter-spacing:.01em;text-align:center;line-height:1.3}@media (max-width: 480px){.stack-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.75rem}.stack-item{padding:1rem .5rem .875rem}}.contact-wrapper{position:relative;z-index:1}.contact{padding:7rem clamp(1.5rem,5vw,4rem) 5rem;max-width:1400px;width:100%;margin:0 auto}@media (max-width: 767px){.contact{padding-top:1rem;padding-bottom:2rem;scroll-margin-top:96px}}.contact__title{font-size:clamp(2.25rem,5vw,3.75rem);font-weight:700;letter-spacing:-.035em;line-height:1.02;margin-bottom:1rem}.contact__desc{font-size:1rem;color:var(--text-secondary);max-width:44ch;line-height:1.75;margin-bottom:2.5rem}.contact__links{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem}.contact__email{font-size:.875rem;color:var(--text-secondary);transition:color .2s;display:inline-block}.contact__email:hover{color:var(--text-primary)}.footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding:1.75rem clamp(1.5rem,5vw,4rem);font-size:.75rem;color:var(--text-muted)}@media (min-width: 768px){.footer{padding-right:calc(clamp(1.5rem,5vw,4rem) + 3.5rem)}}@media (max-width: 767px){.footer{padding-top:.75rem}}.footer__links{display:flex;align-items:center;gap:.5rem}.footer__sep{color:var(--text-muted);opacity:.4}.footer__link{background:none;border:none;padding:0;font-size:.75rem;font-family:inherit;color:var(--text-muted);cursor:pointer;transition:color .2s}.footer__link:hover{color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.modal{position:fixed;top:0;right:0;bottom:0;left:0;margin:auto;height:fit-content;z-index:201;width:min(92vw,480px);background:#0a0a0af7;border:1px solid var(--border-hover);border-radius:1.25rem;padding:2.25rem 2rem 2rem;box-shadow:0 32px 80px #000000b3}.modal__close{position:absolute;top:1.125rem;right:1.125rem;background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;padding:.25rem;transition:color .2s}.modal__close:hover{color:var(--text-secondary)}.modal__title{font-size:1.125rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1.5rem;color:var(--text-primary)}.modal__body{display:flex;flex-direction:column;gap:1.125rem;font-size:.875rem;color:var(--text-secondary);line-height:1.75}.modal__body strong{color:var(--text-primary);font-weight:600;display:block;margin-bottom:.125rem}.modal__body a{color:var(--text-secondary);text-decoration:underline;text-underline-offset:3px;transition:color .2s}.modal__body a:hover{color:var(--text-primary)}.nav__cv{display:flex;align-items:center;padding:.45rem 1.1rem;border-radius:999px;border:1px solid var(--border);font-size:.8rem;font-weight:700;letter-spacing:.08em;color:var(--text-secondary);text-decoration:none;transition:color .2s,border-color .2s,background .2s}.nav__cv:hover{color:var(--text-primary);border-color:#ffffff24;background:#ffffff0a}.nav__mobile-cv{position:absolute;bottom:2.5rem;left:0;right:0;padding:.75rem 0;font-size:1rem;font-weight:700;letter-spacing:.06em;color:var(--text-secondary);text-decoration:none;text-align:center;transition:color .2s}.nav__mobile-cv:hover{color:var(--text-primary)}@media (max-width: 767px){.nav__cv{display:none}}.nav__hamburger{display:none;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:.25rem;transition:color .2s;line-height:1}.nav__hamburger:hover{color:var(--text-primary)}.nav__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:98;background:#00000073}.nav__drawer{position:fixed;top:0;right:0;bottom:0;width:min(55vw,240px);z-index:99;background:#040404f5;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-left:1px solid var(--border);display:flex;flex-direction:column;justify-content:center;padding:2rem;gap:0;box-shadow:-24px 0 60px #ffffff21}.nav__mobile-link{display:block;padding:1.0625rem 0;font-size:1rem;font-weight:500;color:var(--text-secondary);text-align:center;transition:color .2s}.nav__mobile-link:hover,.nav__mobile-link--active{color:var(--text-primary)}@media (max-width: 767px){.nav__links{display:none}.nav__hamburger{display:flex}.nav__right{margin-left:auto}}.cv-button{position:fixed;bottom:5.25rem;right:2rem;z-index:50;width:2.75rem;height:2.75rem;border-radius:999px;border:1px solid var(--border);background:#121214b8;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-decoration:none;font-family:inherit;transition:color .2s,border-color .2s,background .2s,transform .2s}.cv-button:hover{color:var(--text-primary);border-color:#ffffff24;background:#ffffff0f;transform:translateY(-2px)}.back-to-top{position:fixed;bottom:2rem;right:2rem;z-index:50;width:2.75rem;height:2.75rem;border-radius:999px;border:1px solid var(--border);background:#121214b8;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s,border-color .2s,background .2s,transform .2s}.back-to-top:hover{color:var(--text-primary);border-color:#ffffff24;background:#ffffff0f;transform:translateY(-2px)}.contact-form{max-width:640px;display:flex;flex-direction:column;gap:1.125rem;margin-bottom:2rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.125rem}@media (max-width: 600px){.form-row{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-label{font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.form-input{background:#ffffff08;border:1px solid var(--border);border-radius:.625rem;padding:.65rem .875rem;font-size:1rem;color:var(--text-primary);font-family:inherit;outline:none;width:100%;transition:border-color .2s,background .2s;-webkit-appearance:none}.form-input:focus-visible{outline:2px solid rgba(255,255,255,.35);outline-offset:-2px}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:#ffffff2e;background:#ffffff0d}.form-group--error .form-input{border-color:#ff505073}.form-textarea{resize:vertical;min-height:130px;max-height:320px}.form-error{font-size:.75rem;color:#ff6464d9}.form-error-global{font-size:.8125rem;color:#ff6464d9;margin-top:-.25rem}.form-error-global a{color:var(--text-secondary);text-decoration:underline}.form-submit{align-self:flex-start;display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.25rem;border-radius:999px;font-size:.875rem;font-weight:500;font-family:inherit;border:1px solid var(--border);background:#ffffff0a;color:var(--text-primary);cursor:pointer;transition:border-color .2s,background .2s,transform .2s}.form-submit:hover:not(:disabled){border-color:#ffffff24;background:#ffffff14;transform:translateY(-1px)}.form-submit:disabled{opacity:.45;cursor:not-allowed}.form-success{max-width:640px;padding:1.25rem 1.375rem;border-radius:.875rem;border:1px solid rgba(80,200,120,.2);background:#50c8780a;color:#aaf0aae6;font-size:.875rem;line-height:1.7;margin-bottom:2rem;display:flex;flex-direction:column;gap:.875rem}.form-reset{align-self:flex-start;background:none;border:none;font-size:.8125rem;color:#aaf0aa99;cursor:pointer;padding:0;font-family:inherit;transition:color .2s}.form-reset:hover{color:#aaf0aae6}@media (prefers-reduced-motion: reduce){.hero__inline-terminal__col{animation:none}}.settings-wrap{position:relative}.nav__settings{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:999px;border:1px solid var(--border);background:none;color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:color .2s,border-color .2s,background .2s}.nav__settings:hover,.nav__settings--open{color:var(--text-primary);border-color:#ffffff24;background:#ffffff0d}.settings-dropdown{position:absolute;top:calc(100% + .625rem);right:0;min-width:200px;background:#0e0e10f5;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:.875rem;padding:.875rem 1rem;box-shadow:0 16px 40px #0000008c;z-index:200;transform-origin:top right}.settings-dropdown__title{font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.625rem}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.settings-label{display:flex;align-items:center;gap:.4rem;font-size:.8125rem;color:var(--text-secondary);-webkit-user-select:none;user-select:none;white-space:nowrap}.settings-toggle{flex-shrink:0;position:relative;width:2.25rem;height:1.25rem;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff14;cursor:pointer;padding:0;transition:background .25s,border-color .25s}.settings-toggle:after{content:"";position:absolute;top:2px;left:2px;width:.875rem;height:.875rem;border-radius:50%;background:var(--text-muted);transition:transform .25s ease,background .25s}.settings-toggle--on{background:#ffffff2e;border-color:#ffffff38}.settings-toggle--on:after{transform:translate(1rem);background:var(--text-primary)}.settings-separator{height:1px;background:var(--border);margin:.625rem 0}.settings-lang{font-size:.7rem;font-weight:700;letter-spacing:.08em;padding:.2rem .6rem;border-radius:999px;border:1px solid var(--border);background:#ffffff0f;color:var(--text-primary);cursor:pointer;transition:background .2s,border-color .2s}.settings-lang:hover{background:#ffffff1f;border-color:#ffffff24}[data-dyslexia] body,[data-dyslexia] input,[data-dyslexia] textarea,[data-dyslexia] button{font-family:OpenDyslexic,Trebuchet MS,sans-serif}[data-dyslexia] .hero__bio,[data-dyslexia] .section__subtitle,[data-dyslexia] .contact__desc,[data-dyslexia] .project-card__desc,[data-dyslexia] .modal__body,[data-dyslexia] .stack-item__name,[data-dyslexia] .form-label,[data-dyslexia] .form-input{letter-spacing:.04em;word-spacing:.1em;line-height:2}
