@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&display=block");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#ffffff;--surface:#f7f8fa;--surface-hover:#eef0f4;--border:#e2e4e9;--text:#1a1a2e;--text-secondary:#4a4a5a;--text-muted:#8a8a9a;--blue:#3b82f6;--blue-dim:#2563eb;--orange:#f97316;--orange-dim:#ea580c;--green:#16a34a;--radius:12px;--radius-sm:8px;--transition:0.3s cubic-bezier(0.4,0,0.2,1);--nav-width:240px}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;font-size:16px;overflow-x:hidden}.side-nav{position:fixed;top:0;left:0;width:var(--nav-width);height:100vh;background:var(--surface);border-right:1px solid var(--border);padding:1.5rem 0;display:flex;flex-direction:column;z-index:100;transition:transform var(--transition);overflow-y:auto}.side-nav__header{padding:0 1.25rem;margin-bottom:1.5rem}.side-nav__logo{font-family:Space Grotesk,sans-serif;font-size:1.05rem;font-weight:700;color:var(--text);text-decoration:none;letter-spacing:-.02em;display:block;margin-bottom:.15rem}.side-nav__subtitle{font-size:.72rem;color:var(--text-muted);line-height:1.4}.file-tree{list-style:none;flex:1 1;font-size:.82rem}.file-tree__link{display:flex;align-items:center;gap:.4rem;padding:.35rem 1.25rem;color:var(--text-secondary);text-decoration:none;font-weight:500;transition:all var(--transition);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.file-tree__link:hover{color:var(--text);background:var(--surface-hover)}.file-tree__link.active{color:var(--blue);background:rgba(59,130,246,.06)}.file-tree__folder{display:flex;align-items:center;gap:.35rem;padding:.35rem 1.25rem;color:var(--text-secondary);font-weight:600;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:all var(--transition);text-decoration:none}.file-tree__folder:hover{color:var(--text);background:var(--surface-hover)}.file-tree__folder.active{color:var(--blue)}.file-tree__chevron{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0;padding:0;margin:0;border:none;background:none;cursor:pointer;color:var(--text-muted);-moz-appearance:none;appearance:none;-webkit-appearance:none;outline:none;transition:color .2s ease}.file-tree__chevron:hover{color:var(--text)}.file-tree__chevron svg{transition:transform .2s ease}.file-tree__item.open>.file-tree__folder>.file-tree__chevron svg{transform:rotate(90deg)}.file-tree__sections-wrap{display:grid;grid-template-rows:0fr;transition:grid-template-rows .28s cubic-bezier(.4,0,.2,1)}.file-tree__item.open>.file-tree__sections-wrap{grid-template-rows:1fr}.file-tree__sections{list-style:none;overflow:hidden;min-height:0}.file-tree__section-link{display:block;padding:.25rem 1.25rem .25rem 2.75rem;color:var(--text-muted);text-decoration:none;font-size:.78rem;font-weight:400;transition:all var(--transition);position:relative}.file-tree__section-link:before{content:"";position:absolute;left:1.8rem;top:50%;width:4px;height:4px;border-radius:50%;background:var(--border);transform:translateY(-50%);transition:background var(--transition)}.file-tree__section-link:hover{color:var(--text-secondary)}.file-tree__section-link:hover:before{background:var(--text-muted)}.file-tree__section-link.active{color:var(--blue)}.file-tree__section-link.active:before{background:var(--blue)}.side-nav__footer{margin-top:auto;padding:1.25rem 1.25rem 0;border-top:1px solid var(--border);display:flex;gap:1rem;align-items:center}.side-nav__footer a{color:var(--text-muted);text-decoration:none;transition:color var(--transition);display:flex;align-items:center}.side-nav__footer a:hover{color:var(--blue)}.side-nav__footer svg{width:18px;height:18px;fill:currentColor}.contact-icons{display:flex;align-items:center;gap:1rem}.contact-icons a{color:var(--text-muted);text-decoration:none;transition:color var(--transition);display:flex;align-items:center}.contact-icons a:hover{color:var(--blue)}.contact-icons svg{width:22px;height:22px;fill:currentColor}.nav-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:200;width:40px;height:40px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);cursor:pointer;align-items:center;justify-content:center;font-size:1.2rem;box-shadow:0 2px 8px rgba(0,0,0,.06)}.main{margin-left:var(--nav-width);min-height:100vh}.hero{position:relative;min-height:80vh;display:flex;align-items:center;padding:3rem 4rem 3rem 5rem;overflow:hidden}.hero__bg{background:linear-gradient(135deg,rgba(59,130,246,.04),transparent 50%,rgba(249,115,22,.04))}.hero__bg,.hero__grid{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.hero__grid{background-image:linear-gradient(rgba(0,0,0,.03) 1px,transparent 0),linear-gradient(90deg,rgba(0,0,0,.03) 1px,transparent 0);background-size:60px 60px;mask-image:linear-gradient(180deg,black 50%,transparent);-webkit-mask-image:linear-gradient(180deg,black 50%,transparent);z-index:1}.hero__portrait{position:absolute;top:50%;right:4vw;transform:translateY(-50%);height:80%;max-height:640px;width:auto;object-fit:contain;object-position:right center;opacity:0;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:0;mask-image:linear-gradient(90deg,transparent 0,rgba(0,0,0,.6) 25%,black 50%,black);-webkit-mask-image:linear-gradient(90deg,transparent 0,rgba(0,0,0,.6) 25%,black 50%,black);animation:hero-portrait-in 1.2s cubic-bezier(.22,1,.36,1) .75s forwards}@keyframes hero-portrait-in{0%{opacity:0;transform:translateY(-50%) translateX(24px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}@media (max-width:900px){.hero__portrait{display:none}}.hero__content{position:relative;max-width:680px;z-index:2}.hero__greeting{font-family:JetBrains Mono,monospace;font-size:.85rem;color:var(--blue);margin-bottom:1rem;letter-spacing:.05em}.hero__name{font-family:Space Grotesk,sans-serif;font-size:clamp(2.5rem,5vw,3.5rem);font-weight:700;letter-spacing:-.03em;line-height:1.1;margin-bottom:1.5rem;color:var(--text)}.hero__name span{background:linear-gradient(135deg,var(--blue),var(--orange));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero__desc{font-size:1.1rem;color:var(--text-secondary);line-height:1.8;margin-bottom:2rem;max-width:560px}.hero__contact{margin-top:1.25rem;display:flex;align-items:center;gap:.6rem;font-size:.85rem}.hero__contact a{color:var(--text-muted);text-decoration:none;transition:color var(--transition)}.hero__contact a:hover{color:var(--blue)}.hero__contact-sep{color:var(--border)}.compile-el{opacity:0;transform:translateY(8px);filter:blur(6px);transition:opacity .4s ease,transform .4s ease,filter .4s ease}.compile-el.compiled{opacity:1;transform:translateY(0);filter:blur(0)}.compile-blur{display:inline-block;filter:blur(8px);opacity:0;transition:filter .5s ease,opacity .3s ease}.compile-el.compiled .compile-blur{filter:blur(0);opacity:1}.hero__greeting.compile-el:after{content:"|";animation:blink-cursor .6s step-end infinite;color:var(--blue);margin-left:2px}.hero__greeting.compile-el.compiled:after{animation:blink-cursor .6s step-end 3}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}@keyframes fadeIn{0%{opacity:0;transform:translateX(-50%) translateY(4px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.hero__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2.5rem}.tag{padding:.35rem .75rem;border-radius:100px;font-size:.75rem;font-weight:500;border:1px solid var(--border);color:var(--text-secondary);background:var(--bg);transition:all var(--transition)}.tag:hover{border-color:var(--blue);color:var(--blue)}.hero__cta{display:flex;gap:1rem}.btn,.hero__cta{align-items:center}.btn{display:inline-flex;gap:.5rem;padding:.7rem 1.5rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;text-decoration:none;transition:all var(--transition);cursor:pointer;border:none}.btn--primary{background:var(--blue);color:white}.btn--primary:hover{background:var(--blue-dim);transform:translateY(-1px);box-shadow:0 4px 20px rgba(59,130,246,.25)}.btn--ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn--ghost:hover{border-color:var(--text-muted);color:var(--text)}.section{padding:5rem 4rem 5rem 5rem}.section__label{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--orange);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.75rem}.section__title{font-family:Space Grotesk,sans-serif;font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;letter-spacing:-.02em;margin-bottom:1rem;color:var(--text)}.section__desc{color:var(--text-secondary);max-width:600px;margin-bottom:3rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));grid-gap:1.5rem;gap:1.5rem}.project-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all var(--transition);text-decoration:none;color:inherit;display:block;position:relative}.project-card:hover{border-color:#ccc;transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.08)}.project-card__img{width:100%;height:220px;object-fit:cover;display:block;transition:transform var(--transition)}.project-card:hover .project-card__img{transform:scale(1.03)}.project-card__img-wrap{overflow:hidden;position:relative}.project-card__overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,transparent 60%,rgba(255,255,255,.8));pointer-events:none}.project-card__body{padding:1.25rem 1.5rem 1.5rem}.project-card__tag{font-family:JetBrains Mono,monospace;font-size:.65rem;color:var(--orange);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.5rem}.project-card__title{font-family:Space Grotesk,sans-serif;font-size:1.15rem;font-weight:600;margin-bottom:.5rem;letter-spacing:-.01em;color:var(--text)}.project-card__excerpt{font-size:.85rem;color:var(--text-secondary);line-height:1.6}.project-card__arrow{position:absolute;bottom:1.5rem;right:1.5rem;color:var(--text-muted);font-size:1.1rem;transition:all var(--transition)}.project-card:hover .project-card__arrow{color:var(--blue);transform:translateX(4px)}.project-hero{padding:3rem 4rem 2rem 5rem}.project-hero__back{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-muted);text-decoration:none;font-size:.85rem;margin-bottom:2rem;transition:color var(--transition)}.project-hero__back:hover{color:var(--blue)}.project-hero__tag{font-family:JetBrains Mono,monospace;font-size:.7rem;color:var(--orange);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.75rem}.project-hero__title{font-family:Space Grotesk,sans-serif;font-size:clamp(2rem,4vw,2.75rem);font-weight:700;letter-spacing:-.03em;margin-bottom:1rem;color:var(--text)}.project-hero__subtitle{color:var(--text-secondary);font-size:1.05rem;max-width:650px;margin-bottom:1.5rem}.project-hero__meta{display:flex;gap:2rem;flex-wrap:wrap}.meta-item{font-size:.8rem}.meta-item__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.65rem;margin-bottom:.2rem}.meta-item__value{color:var(--text-secondary);font-weight:500}.project-content{padding:2rem 4rem 5rem 5rem;max-width:1100px}.project-content h2{font-family:Space Grotesk,sans-serif;font-size:1.5rem;font-weight:600;letter-spacing:-.02em;margin:3rem 0 1rem;padding-top:1rem;color:var(--text)}.project-content h2:first-child{margin-top:0}.project-content p{color:var(--text-secondary);margin-bottom:1.25rem;line-height:1.8}.project-content strong{color:var(--text);font-weight:600}.content-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:2.5rem;gap:2.5rem;align-items:center;margin:2rem 0}.content-row--reverse{direction:rtl}.content-row--reverse>*{direction:ltr}.content-row__text{padding-top:.5rem}.content-row__text h2{margin-top:0!important;padding-top:0!important}.content-row__text p:last-child{margin-bottom:0}.media-block{margin:2rem 0;border-radius:var(--radius);overflow:hidden;background:transparent}.media-block img,.media-block video{width:100%;display:block;border-radius:var(--radius)}.media-block--full-width{width:90%;margin-left:auto;margin-right:auto}.media-block__caption{padding:.5rem .25rem;font-size:.78rem;color:var(--text-muted)}.media-row{column-count:2;column-gap:1.5rem;margin:2rem 0}.media-row .media-block{margin:0 0 1.5rem}.media-row .media-block,.media-row>.reveal{page-break-inside:avoid;break-inside:avoid}.specs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:1rem;gap:1rem;margin:2rem 0}.spec-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:1rem 1.25rem}.spec-card__label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem}.spec-card__value{font-family:Space Grotesk,sans-serif;font-size:1.1rem;font-weight:600;color:var(--text)}.spec-card__value--blue{color:var(--blue)}.spec-card__value--orange{color:var(--orange)}.spec-card__value--green{color:var(--green)}.callout{background:rgba(59,130,246,.05);border-left:3px solid var(--blue);padding:1.25rem 1.5rem;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:2rem 0}.callout--orange{background:rgba(249,115,22,.05);border-left-color:var(--orange)}.callout p{color:var(--text-secondary);margin:0;font-size:.9rem}.callout strong{color:var(--text)}.code-block{background:#1e1e2e;border:1px solid #2a2a3e;border-radius:var(--radius-sm);padding:1.25rem 1.5rem;margin:1.5rem 0;overflow-x:auto}.code-block code{font-family:JetBrains Mono,monospace;font-size:.82rem;line-height:1.6;color:#cdd6f4}.about-row{display:grid;grid-template-columns:2fr 1fr;grid-gap:3rem;gap:3rem;align-items:start}.about-text p{color:var(--text-secondary);margin-bottom:1rem}.about-links{display:flex;flex-direction:column;gap:.75rem}.about-links>*{width:100%}.about-link{display:flex;align-items:center;gap:.6rem;padding:.75rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);text-decoration:none;color:var(--text-secondary);font-size:.85rem;width:100%;transition:all var(--transition)}.about-link:hover{border-color:var(--blue);color:var(--text)}.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}.reveal.visible{opacity:1;transform:translateY(0)}.timeline{margin-top:1.25rem;position:relative}.timeline__scroll{overflow-x:auto;overflow-y:visible;padding:.75rem 0 .5rem;scrollbar-width:thin;scrollbar-color:var(--border) transparent;-webkit-overflow-scrolling:touch}.timeline__scroll::-webkit-scrollbar{height:6px}.timeline__scroll::-webkit-scrollbar-track{background:transparent}.timeline__scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.timeline__track{position:relative;display:grid;grid-auto-flow:column;grid-auto-columns:minmax(240px,1fr);grid-gap:1.25rem;gap:1.25rem;padding:0 .25rem;min-width:min-content}.timeline__line{position:absolute;left:0;right:0;top:6px;height:2px;background:linear-gradient(to right,transparent 0,var(--border) 6%,var(--border) 94%,transparent 100%);z-index:0}.timeline__item{position:relative;display:flex;flex-direction:column;align-items:center;text-decoration:none;color:inherit;z-index:1;opacity:0;transform:translateY(12px);animation:timelineIn .6s cubic-bezier(.4,0,.2,1) forwards;animation-delay:calc(var(--i) * .12s + .12s)}@keyframes timelineIn{to{opacity:1;transform:translateY(0)}}.timeline__node{width:14px;height:14px;border-radius:50%;background:var(--bg);border:2px solid var(--border);display:grid;place-items:center;transition:all var(--transition);position:relative}.timeline__node-dot{width:5px;height:5px;border-radius:50%;background:var(--text-muted);transition:all var(--transition)}.timeline__item:hover .timeline__node{border-color:var(--blue);transform:scale(1.15)}.timeline__item:hover .timeline__node-dot{background:var(--blue)}.timeline__card{margin-top:.85rem;width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem .95rem 1.75rem;display:flex;flex-direction:column;align-items:flex-start;transition:all var(--transition);position:relative}.timeline__item:hover .timeline__card{border-color:#ccc;transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.07)}.timeline__card-head{display:flex;align-items:center;gap:.6rem;margin-bottom:.55rem;width:100%}.timeline__card-head-text{display:flex;flex-direction:column;min-width:0}.timeline__logo-wrap{width:36px;height:36px;border-radius:8px;background:var(--surface);border:1px solid var(--border);display:grid;place-items:center;overflow:hidden;flex-shrink:0}.timeline__logo{width:100%;height:100%;object-fit:contain;padding:4px}.timeline__company{font-family:Space Grotesk,sans-serif;font-size:.95rem;font-weight:600;letter-spacing:-.01em;color:var(--text);line-height:1.2}.timeline__role{font-size:.62rem;color:var(--orange);letter-spacing:.06em;margin-top:.15rem;line-height:1.2}.timeline__date,.timeline__role{font-family:JetBrains Mono,monospace;text-transform:uppercase}.timeline__date{font-size:.65rem;color:var(--text-muted);letter-spacing:.04em;margin-bottom:.55rem;white-space:nowrap}.timeline__skills{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.2rem}.timeline__skills li{font-size:.74rem;color:var(--text-secondary);line-height:1.4;padding-left:.75rem;position:relative}.timeline__skills li:before{content:"";position:absolute;left:0;top:.5rem;width:4px;height:1px;background:var(--text-muted)}.timeline__arrow{position:absolute;bottom:.65rem;right:.85rem;color:var(--text-muted);font-size:.9rem;transition:all var(--transition)}.timeline__item:hover .timeline__arrow{color:var(--blue);transform:translateX(4px)}@media (max-width:1024px){:root{--nav-width:0px}.side-nav{transform:translateX(-100%);width:280px;box-shadow:none}.side-nav.open{transform:translateX(0);box-shadow:20px 0 60px rgba(0,0,0,.1)}.nav-toggle{display:flex}.hero,.project-content,.project-hero,.section{padding-left:2rem;padding-right:2rem}.content-row{grid-template-columns:1fr}.content-row--reverse{direction:ltr}.media-row{column-count:1}.about-row{grid-template-columns:1fr}}@media (max-width:600px){.hero,.project-content,.project-hero,.section{padding-left:1.25rem;padding-right:1.25rem}.projects-grid{grid-template-columns:1fr}.timeline__track{grid-auto-columns:240px}.hero__name{font-size:2rem}.specs-grid{grid-template-columns:1fr 1fr}}