@import"https://fonts.googleapis.com/css2?family=Inconsolata:wght@200..900&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0a;--bg-card: #0f0f0f;--border: #1e1e1e;--text: #e0e0e0;--muted: #666666;--accent: #4ecdc4;--max-w: 880px;--nav-h: 60px}html{scroll-behavior:smooth}body{font-family:Inconsolata,monospace;background:var(--bg);color:var(--text);line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-width:320px}a{color:inherit;text-decoration:none}.container{max-width:var(--max-w);margin:0 auto;padding:0 2rem}section{padding:7rem 0}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);background:#0a0a0aeb;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:100}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:100%}.nav-logo{font-size:.9rem;font-weight:600;color:var(--text);letter-spacing:.02em}.nav-logo .prefix{color:var(--accent)}.nav-links{display:flex;list-style:none;gap:2rem}.nav-links a{font-size:.82rem;color:var(--muted);letter-spacing:.06em;transition:color .2s ease}.nav-links a:hover{color:var(--accent)}.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:6px;flex-shrink:0;outline:none;-webkit-tap-highlight-color:transparent}.nav-links a{-webkit-tap-highlight-color:transparent}.nav-hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:1px;transition:opacity .2s ease}.hero{min-height:100vh;display:flex;align-items:center;padding-top:var(--nav-h)}.hero-content{max-width:620px}.hero-eyebrow{font-size:.78rem;color:var(--accent);letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.75rem;display:flex;align-items:center;gap:.6rem}.hero-eyebrow:before{content:"";display:inline-block;width:7px;height:7px;background:var(--accent);border-radius:50%;flex-shrink:0}.hero-name{font-size:clamp(3.2rem,8vw,5.5rem);font-weight:700;line-height:1.05;letter-spacing:-.025em;color:var(--text);margin-bottom:2rem}.cursor{display:inline-block;width:.1em;height:.88em;background:var(--accent);margin-left:.12em;vertical-align:baseline;position:relative;top:.04em;animation:blink 1.1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-tagline{font-size:clamp(1.1rem,2.8vw,1.4rem);font-weight:400;line-height:1.5;color:var(--muted);margin-bottom:1.5rem}.hero-tagline strong{color:var(--text);font-weight:600}.hero-sub{font-size:.83rem;color:var(--muted);letter-spacing:.04em;margin-bottom:2.5rem}.hero-links{display:flex;gap:.9rem;align-items:center}.hero-icon{display:flex;align-items:center;justify-content:center;color:var(--muted);transition:color .2s ease,transform .2s ease}.hero-icon:hover{color:var(--accent);transform:translateY(-2px)}.hero-icon svg{width:20px;height:20px}.section-tag{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.18em;color:var(--accent);margin-bottom:.6rem}.section-tag:before{content:"// ";opacity:.4}.section-title{font-size:1.55rem;font-weight:600;letter-spacing:-.015em;margin-bottom:3rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.about{border-top:1px solid var(--border)}.about-text{font-size:.93rem;line-height:1.88;color:var(--muted)}.about-text p+p{margin-top:1.2rem}.about-text strong{color:var(--text);font-weight:500}.projects{border-top:1px solid var(--border)}.proj-list{display:flex;flex-direction:column}.proj-row{border-bottom:1px solid var(--border)}.proj-summary{width:100%;background:none;border:none;font-family:inherit;-webkit-tap-highlight-color:transparent;color:inherit;cursor:pointer;display:grid;grid-template-columns:220px 1fr;gap:2rem;align-items:center;padding:1.4rem 0;text-align:left;transition:background .15s ease}.proj-summary:hover .proj-name{color:var(--accent)}.proj-summary:focus{outline:none}.proj-summary:focus-visible{outline:1px solid var(--accent);outline-offset:2px}.proj-summary-left{display:flex;flex-direction:column;gap:.25rem}.proj-name{font-size:1.1rem;font-weight:600;letter-spacing:-.01em;transition:color .15s ease}.proj-award{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);opacity:.8}.proj-summary-right{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-width:0}.proj-desc-inline{font-size:.87rem;color:var(--muted);line-height:1.5;flex:1;min-width:0}.proj-toggle{font-size:1.1rem;color:var(--muted);line-height:1;flex-shrink:0;transition:color .15s ease}.proj-row--open .proj-toggle{color:var(--accent)}.proj-detail{display:grid;grid-template-rows:0fr;transition:grid-template-rows .45s cubic-bezier(.4,0,.2,1)}.proj-row--open .proj-detail{grid-template-rows:1fr}.proj-detail-inner{overflow:hidden}.proj-detail-content{padding:0 0 2rem;display:flex;flex-direction:column;gap:1.5rem}.proj-preview{width:100%;height:auto;display:block;border:1px solid var(--border)}.proj-detail-sections{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem 2rem}.proj-detail-section{display:flex;flex-direction:column;gap:.5rem}.proj-detail-section:last-child{grid-column:1 / -1}.proj-detail-label{font-size:.72rem;color:var(--accent);opacity:.7;letter-spacing:.05em;font-weight:600}.proj-detail-text{font-size:.9rem;color:var(--muted);line-height:1.75}.proj-deep-dive{list-style:none;display:flex;flex-direction:column;gap:.4rem}.proj-deep-dive-item{font-size:.87rem;color:var(--muted);line-height:1.6;padding-left:1rem;position:relative}.proj-deep-dive-item:before{content:">";position:absolute;left:0;color:var(--accent);opacity:.6;font-weight:700}.proj-detail-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border)}.proj-links{display:flex;gap:1.25rem}.proj-link{font-size:.8rem;color:var(--accent);letter-spacing:.04em;transition:opacity .15s ease;white-space:nowrap}.proj-link:hover{opacity:.6}.project-tech{display:flex;flex-wrap:wrap;gap:.35rem}.tech-tag{font-size:.67rem;color:var(--muted);border:1px solid var(--border);padding:.12rem .45rem;letter-spacing:.04em}@media(max-width:640px){.proj-summary{grid-template-columns:1fr;gap:.4rem}.proj-desc-inline{display:none}.proj-summary-right{justify-content:flex-end}.proj-detail-sections{grid-template-columns:1fr}.proj-detail-section:last-child{grid-column:auto}}.experience{border-top:1px solid var(--border)}.exp-list{display:flex;flex-direction:column}.exp-item{display:grid;grid-template-columns:200px 1fr;gap:2.5rem;padding:2rem 0;border-bottom:1px solid var(--border)}.exp-item:last-child{border-bottom:none}.exp-role{font-size:.88rem;font-weight:600;margin-bottom:.25rem;line-height:1.3}.exp-company{font-size:.8rem;color:var(--accent);margin-bottom:.3rem}.exp-date{font-size:.73rem;color:var(--muted);letter-spacing:.04em}.exp-desc{font-size:.84rem;color:var(--muted);line-height:1.78;padding-top:.15rem}.cm-backdrop{position:fixed;inset:0;background:#000000bf;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:cmBackdropIn .22s ease forwards}.cm-backdrop--out{animation:cmBackdropOut .22s ease forwards}@keyframes cmBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes cmBackdropOut{0%{opacity:1}to{opacity:0}}.cm{background:var(--bg-card);border:1px solid #2e2e2e;width:100%;max-width:500px;padding:2rem;position:relative;animation:cmIn .22s ease forwards}.cm--out{animation:cmOut .22s ease forwards}@keyframes cmIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes cmOut{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.96) translateY(8px)}}.cm-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--muted);font-family:inherit;font-size:.9rem;cursor:pointer;padding:.25rem .4rem;transition:color .15s ease}.cm-close:hover{color:var(--text)}.cm-close:focus{outline:none}.cm-close:focus-visible{outline:1px solid var(--accent)}.cm-tag{font-size:.68rem;color:var(--accent);letter-spacing:.1em;text-transform:lowercase;margin-bottom:.4rem;opacity:.7}.cm-title{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1.75rem}.cm-form{display:flex;flex-direction:column;gap:.85rem}.cm-field{display:flex;flex-direction:column;gap:.25rem}.cm-input{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:.85rem;padding:.65rem .85rem;outline:none;transition:border-color .15s ease;resize:none}.cm-input::placeholder{color:var(--muted)}.cm-input:focus{border-color:var(--accent)}.cm-input--err{border-color:#e05c5c}.cm-textarea{min-height:110px}.cm-err{font-size:.7rem;color:#e05c5c;letter-spacing:.02em}.cm-err--global{margin-top:.25rem}.cm-submit{margin-top:.4rem;background:none;border:1px solid var(--accent);color:var(--accent);font-family:inherit;font-size:.82rem;letter-spacing:.06em;padding:.7rem 1.25rem;cursor:pointer;transition:background .15s ease,color .15s ease;align-self:flex-start}.cm-submit:hover:not(:disabled){background:var(--accent);color:var(--bg)}.cm-submit:disabled{opacity:.5;cursor:not-allowed}.cm-success{font-size:.88rem;color:var(--accent);line-height:1.7;padding:1rem 0}.hero-icon[aria-label=Email]{background:none;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent;padding:0}.hero-icon[aria-label=Email]:focus{outline:none}.hero-icon[aria-label=Email]:focus-visible{outline:1px solid var(--accent)}@media(max-width:600px){.cm-backdrop{padding:0;align-items:flex-end}.cm{max-width:100%;animation:cmInMobile .25s ease forwards}.cm--out{animation:cmOutMobile .25s ease forwards}@keyframes cmInMobile{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes cmOutMobile{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(40px)}}}.skills{border-top:1px solid var(--border)}.skills-list{display:flex;flex-direction:column}.skill-row{display:grid;grid-template-columns:100px 1fr;gap:2rem;align-items:start;padding:1.1rem 0;border-bottom:1px solid var(--border)}.skill-row:last-child{border-bottom:none}.skill-category{font-size:.75rem;color:var(--muted);letter-spacing:.04em;padding-top:.15rem}.skill-tags{display:flex;flex-wrap:wrap;gap:.35rem}.footer{border-top:1px solid var(--border);padding:2rem 0}.footer-inner{display:flex;align-items:center;justify-content:space-between}.footer-links{display:flex;gap:1.5rem}.footer-link{font-size:.77rem;color:var(--muted);letter-spacing:.06em;transition:color .2s ease}button.footer-link{background:none;border:none;padding:0;font-family:inherit;cursor:pointer}.footer-link:hover{color:var(--accent)}.footer-copy{font-size:.77rem;color:var(--muted)}@media(max-width:768px){section{padding:5rem 0}.nav-hamburger{display:flex}.nav-links{position:absolute;top:var(--nav-h);left:0;right:0;flex-direction:column;gap:0;background:#0a0a0af5;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:0 2rem .75rem;opacity:0;transform:translateY(-6px);pointer-events:none;visibility:hidden;transition:opacity .2s ease,transform .2s ease,visibility .2s}.nav-links--open{opacity:1;transform:translateY(0);pointer-events:auto;visibility:visible}.nav-links li{border-top:1px solid var(--border)}.nav-links a{display:block;padding:.75rem 0;font-size:.88rem}.projects-row{flex-direction:column}.projects-row--center{justify-content:initial}.project-card{flex:none;width:100%}.skill-row{grid-template-columns:80px 1fr;gap:1rem}.exp-item{grid-template-columns:1fr;gap:.6rem}.footer-inner{flex-direction:column;gap:1rem;text-align:center}}
