:root{--bg: #0d0d12;--surface: #16161e;--surface-2: #1e1e28;--border: rgba(255, 255, 255, .08);--text: #e2e2ea;--text-muted: #7f7f99;--accent: #6c63ff;--accent-h: #8b84ff;--accent-dim: rgba(108, 99, 255, .15);--accent-tag: rgba(108, 99, 255, .12);--tag-text: #9b94ff;--page-x: clamp(1.25rem, 5vw, 3rem);--nav-h: 60px;--max-w: 1100px;--max-w-text: 680px;--r-sm: 6px;--r-md: 10px;--r-lg: 16px;--shadow-sm: 0 1px 4px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .6);--t: .2s ease;font-family:Inter,system-ui,-apple-system,Helvetica,Arial,sans-serif;line-height:1.6;font-size:16px;color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:var(--bg);color:var(--text)}img{max-width:100%;height:auto;display:block}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.2;font-weight:700;color:var(--text)}p{margin:0}a{color:var(--accent);text-decoration:none;transition:color var(--t)}a:hover{color:var(--accent-h)}.layout{display:flex;flex-direction:column;min-height:100vh}.layout__main{flex:1;padding-top:var(--nav-h)}.page{max-width:var(--max-w);margin:0 auto;padding:3rem var(--page-x) 5rem}.btn{display:inline-flex;align-items:center;gap:.4em;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.6em 1.4em;border-radius:var(--r-md);border:2px solid transparent;cursor:pointer;transition:background-color var(--t),color var(--t),border-color var(--t),transform var(--t);text-decoration:none}.btn:hover{transform:translateY(-1px)}.btn:active{transform:none}.btn--primary{background-color:var(--accent);color:#fff;border-color:var(--accent)}.btn--primary:hover{background-color:var(--accent-h);border-color:var(--accent-h);color:#fff}.btn--outline{background-color:transparent;color:var(--accent);border-color:var(--accent)}.btn--outline:hover{background-color:var(--accent-dim);color:var(--accent-h);border-color:var(--accent-h)}.btn--ghost{background-color:transparent;color:var(--text-muted);border-color:var(--border)}.btn--ghost:hover{color:var(--text);border-color:#fff3}.tag{display:inline-block;background-color:var(--accent-tag);color:var(--tag-text);font-size:.75rem;font-weight:600;padding:.25em .75em;border-radius:100px;white-space:nowrap}.section{margin-top:3.5rem}.section__header{margin-bottom:1.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.section__header h2{font-size:1.4rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.page-title{font-size:clamp(2rem,4vw,3rem);margin-bottom:.5rem}.page-subtitle{color:var(--text-muted);font-size:1.1rem;margin-bottom:2.5rem}.footer{border-top:1px solid var(--border);padding:1.5rem var(--page-x)}.footer__inner{max-width:var(--max-w);margin:0 auto;display:flex;align-items:center;justify-content:space-between;color:var(--text-muted);font-size:.875rem;flex-wrap:wrap;gap:.75rem}.footer__links{display:flex;gap:1.5rem}.footer__links a{color:var(--text-muted)}.footer__links a:hover{color:var(--text)}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);background-color:#0d0d12d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.navbar__inner{max-width:var(--max-w);margin:0 auto;height:100%;padding:0 var(--page-x);display:flex;align-items:center;justify-content:space-between}.navbar__brand{font-size:1.05rem;font-weight:700;color:var(--text);letter-spacing:-.02em;transition:color var(--t)}.navbar__brand:hover{color:var(--accent-h)}.navbar__links{display:flex;align-items:center;gap:.25rem}.navbar__link{padding:.4em .75em;border-radius:var(--r-sm);font-size:.9375rem;font-weight:500;color:var(--text-muted);transition:color var(--t),background-color var(--t)}.navbar__link:hover,.navbar__link--active{color:var(--text);background-color:var(--surface-2)}.navbar__dropdown{position:relative}.navbar__dropdown-menu{position:absolute;top:calc(100% + .5rem);left:50%;transform:translate(-50%);background-color:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:.4rem;min-width:200px;display:flex;flex-direction:column;gap:.1rem;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transform:translate(-50%) translateY(-4px);transition:opacity var(--t),visibility var(--t),transform var(--t);z-index:200}.navbar__dropdown:hover .navbar__dropdown-menu{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.navbar__dropdown-item{padding:.45em .75em;border-radius:var(--r-sm);font-size:.9rem;font-weight:500;color:var(--text-muted);transition:color var(--t),background-color var(--t);white-space:nowrap}.navbar__dropdown-item:hover,.navbar__dropdown-item--active{color:var(--text);background-color:var(--surface-2)}.project-card{background-color:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform var(--t),box-shadow var(--t),border-color var(--t)}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#6c63ff4d}.project-card__image{aspect-ratio:16 / 9;overflow:hidden;background-color:var(--surface-2)}.project-card__image img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.project-card:hover .project-card__image img{transform:scale(1.04)}.project-card__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:900;color:var(--accent);opacity:.25;background:linear-gradient(135deg,var(--surface-2) 0%,var(--bg) 100%);-webkit-user-select:none;user-select:none}.project-card__body{padding:1.25rem;flex:1;display:flex;flex-direction:column;gap:.5rem}.project-card__meta{font-size:.8rem;color:var(--text-muted)}.project-card__title{font-size:1.1rem;font-weight:700;color:var(--text);margin:0}.project-card__desc{font-size:.9rem;color:var(--text-muted);line-height:1.6;flex:1}.project-card__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.25rem}.project-card__links{display:flex;align-items:center;gap:1rem;margin-top:.75rem;flex-wrap:wrap}.project-card__cta{font-size:.875rem;font-weight:600;color:var(--accent)}.project-card__cta:hover{color:var(--accent-h)}.project-card__ext{font-size:.875rem;font-weight:500;color:var(--text-muted)}.project-card__ext:hover{color:var(--text)}.hero{padding:5rem 0 3rem;max-width:var(--max-w-text)}.hero__greeting{font-size:1.05rem;color:var(--accent);font-weight:600;margin-bottom:.5rem}.hero__name{font-size:clamp(2.5rem,6vw,4rem);letter-spacing:-.03em;margin-bottom:.25rem;background:linear-gradient(135deg,var(--text) 30%,var(--text-muted) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero__role{font-size:1.2rem;color:var(--accent);font-weight:600;margin-bottom:1rem}.hero__tagline{font-size:1.1rem;color:var(--text-muted);max-width:480px;margin-bottom:2rem;line-height:1.7}.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}.home__see-all{margin-top:2rem;display:flex;justify-content:center}.wip-notice{display:inline-block;font-size:.9rem;color:var(--text-muted);background-color:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:.6em 1em;margin-bottom:1rem}.about-bio{font-size:1.125rem;color:var(--text-muted);max-width:var(--max-w-text);line-height:1.8;margin-top:1.25rem}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem}.skill-group{background-color:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.25rem}.skill-group__category{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:.75rem}.skill-group__list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}.projects-section{position:relative}.projects-section__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.projects-section__view-all{font-size:.8125rem;padding:.3em .9em;flex-shrink:0}.projects-section__empty{color:var(--text-muted);font-style:italic;padding:1.5rem 0}.projects-all-btn{margin-top:3rem;display:flex;justify-content:center}.projects-list{display:flex;flex-direction:column;gap:1.5rem}.projects-list .project-card{flex-direction:row}.projects-list .project-card__image{width:260px;flex-shrink:0;aspect-ratio:unset;min-height:180px;border-radius:var(--r-lg) 0 0 var(--r-lg)}.projects-list .project-card__image img{width:100%;height:100%;object-fit:cover;border-radius:var(--r-lg) 0 0 var(--r-lg)}@media(max-width:600px){.projects-list .project-card{flex-direction:column}.projects-list .project-card__image{width:100%;aspect-ratio:16 / 9;min-height:unset;border-radius:var(--r-lg) var(--r-lg) 0 0}.projects-list .project-card__image img{border-radius:var(--r-lg) var(--r-lg) 0 0}}.page-back-link{display:inline-block;font-size:.875rem;color:var(--text-muted);margin-bottom:1.25rem;transition:color var(--t)}.page-back-link:hover{color:var(--text)}.back-link{display:inline-flex;align-items:center;gap:.25em;font-size:.9rem;font-weight:500;color:var(--text-muted);margin-bottom:2rem;transition:color var(--t)}.back-link:hover{color:var(--text)}.project-detail__hero-image{width:100%;aspect-ratio:16 / 9;border-radius:var(--r-lg);overflow:hidden;margin-bottom:2rem;background-color:var(--surface-2)}.project-detail__hero-image img{width:100%;height:100%;object-fit:cover}.project-detail__header{margin-bottom:2rem}.project-detail__date{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem}.project-detail__title{font-size:clamp(1.75rem,4vw,2.75rem);letter-spacing:-.02em;margin-bottom:1rem}.project-detail__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.project-detail__actions{display:flex;gap:.75rem;flex-wrap:wrap}.project-detail__description{max-width:var(--max-w-text);font-size:1.05rem;color:var(--text-muted);line-height:1.8;display:flex;flex-direction:column;gap:1rem}.video-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:var(--r-lg);background-color:var(--surface-2)}.video-embed iframe,.video-embed video{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.project-detail__team{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.project-detail__team-member{display:flex;align-items:baseline;gap:.75rem;flex-wrap:wrap}.project-detail__team-name{font-weight:600;font-size:.9375rem;color:var(--accent);transition:color var(--t);white-space:nowrap}a.project-detail__team-name:hover{color:var(--accent-h)}.project-detail__team-name--no-link{color:var(--text)}.project-detail__team-role{font-size:.875rem;color:var(--text-muted)}.project-detail__gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.project-detail__gallery-img{border-radius:var(--r-md);border:1px solid var(--border);width:100%;aspect-ratio:16 / 9;object-fit:cover;transition:border-color var(--t)}.project-detail__gallery-img:hover{border-color:#6c63ff66}.resume-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem}.resume-header__title{color:var(--accent);font-size:1.1rem;font-weight:600;margin-top:.25rem}.resume-entries{display:flex;flex-direction:column;gap:2rem}.resume-entry{border-left:2px solid var(--border);padding-left:1.25rem}.resume-entry__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:.75rem}.resume-entry__org{font-size:1.05rem;font-weight:700;color:var(--text);margin:0 0 .2rem}.resume-entry__role{font-size:.95rem;color:var(--accent);font-weight:500;margin:0}.resume-entry__right{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;text-align:right}.resume-entry__period{font-size:.875rem;color:var(--text-muted);white-space:nowrap}.resume-entry__location{font-size:.8rem;color:var(--text-muted)}.resume-entry__bullets{margin:0;padding-left:1.25rem;display:flex;flex-direction:column;gap:.4rem}.resume-entry__bullets li{font-size:.95rem;color:var(--text-muted);line-height:1.6}.resume-skills{display:flex;flex-direction:column;gap:.75rem}.resume-skill-group{font-size:.95rem;display:flex;gap:.5rem;flex-wrap:wrap;align-items:baseline}.resume-skill-group__label{font-weight:600;color:var(--text);white-space:nowrap}.resume-skill-group__items{color:var(--text-muted)}.contact-header{max-width:var(--max-w-text);margin-bottom:3rem}.contact-header__sub{font-size:1.1rem;color:var(--text-muted);line-height:1.7;margin-top:1rem}.contact-links{display:flex;flex-direction:column;gap:.75rem;max-width:560px}.contact-link{display:flex;align-items:center;padding:1.1rem 1.25rem;background-color:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);transition:border-color var(--t),transform var(--t),box-shadow var(--t);gap:1rem;color:inherit}.contact-link:hover{border-color:#6c63ff66;transform:translate(4px);box-shadow:var(--shadow-sm);color:inherit}.contact-link__label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent);min-width:80px}.contact-link__value{font-size:.95rem;color:var(--text-muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-link__arrow{color:var(--text-muted);font-size:1rem;transition:color var(--t)}.contact-link:hover .contact-link__arrow{color:var(--accent)}#root{min-height:100vh}
