@import "https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600&display=swap";:root{--white:#fff;--gray-50:#f9f9f9;--gray-100:#f0f0f0;--gray-200:#e0e0e0;--gray-300:#ccc;--gray-500:#666;--gray-600:#555;--gray-800:#353535;--black:#000;--accent-blue-rgb:235, 241, 248;--accent-blue:rgb(var(--accent-blue-rgb));--accent-blue-soft:rgba(var(--accent-blue-rgb), .4);--text-heading:var(--gray-800);--text-primary:var(--gray-800);--text-secondary:var(--gray-600);--text-muted:var(--gray-500);--text-on-dark:var(--white);--surface-page:var(--white);--surface-muted:var(--gray-50);--surface-card:var(--white);--surface-inverse:var(--gray-800);--surface-inverse-hover:var(--black);--surface-accent:var(--accent-blue-soft);--border-strong:var(--gray-800);--border-hairline:var(--gray-200);--border-inactive:var(--gray-300);--quote-mark:#35353533;--font-sans:"Poppins", -apple-system, blinkmacsystemfont, "Segoe UI", sans-serif;--weight-light:300;--weight-regular:400;--weight-medium:500;--weight-semibold:600;--text-hero:3rem;--text-2xl:1.75rem;--text-xl:1.5rem;--text-lg:1.25rem;--text-md:1rem;--text-sm:.95rem;--text-xs:.85rem;--leading-tight:1.2;--leading-snug:1.4;--leading-normal:1.5;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-6:1.5rem;--space-8:2rem;--space-12:3rem;--space-16:4rem;--radius-sm:2px;--radius-md:8px;--radius-card:10px;--radius-pill:2rem;--radius-round:50%;--shadow-nav:0 2px 4px #00000014;--shadow-soft:0 2px 10px #0000001a;--shadow-card:0 4px 6px #0000001a;--shadow-card-hover:0 8px 12px #00000026;--transition-base:.3s ease;--container-wide:1160px;--container-content:1000px;--container-narrow:700px}*,:before,:after{box-sizing:border-box}html{text-size-adjust:100%}body{font-family:var(--font-sans);background:var(--surface-page);color:var(--text-heading);line-height:var(--leading-normal);margin:0}img{max-width:100%;display:block}a{color:inherit}.portfolio{max-width:var(--container-wide);padding:0 var(--space-6);margin:0 auto}.profile{justify-content:center;align-items:center;gap:var(--space-12);padding:var(--space-16) var(--space-4) var(--space-8);text-align:center;flex-wrap:wrap;display:flex}.profile__avatar-ring{border-radius:var(--radius-round);background:var(--surface-accent);flex-shrink:0;padding:8px}.profile__avatar{border-radius:var(--radius-round);object-fit:cover;width:156px;height:156px}.profile__text{max-width:520px}.profile__hello{font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--text-muted);margin:0}.profile__name{font-size:2.75rem;font-weight:var(--weight-semibold);color:var(--text-heading);margin:.1rem 0 .4rem;line-height:1.03}.profile__role{font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--text-secondary);margin:0 0 .9rem}.profile__bio{font-size:var(--text-md);color:var(--text-secondary);line-height:var(--leading-normal);margin:0 0 var(--space-6)}.profile__actions{gap:var(--space-4);flex-wrap:wrap;justify-content:center;align-items:center;display:flex}.profile__socials{gap:var(--space-2);margin-left:.1rem;display:flex}.profile__socials a{display:flex}.profile__socials img{width:28px;height:28px;transition:transform var(--transition-base)}.profile__socials a:hover img{transform:translateY(-2px)}@media (width>=700px){.profile{text-align:left}.profile__actions{justify-content:flex-start}}.btn{font-family:var(--font-sans);font-size:var(--text-md);font-weight:var(--weight-semibold);border-radius:var(--radius-pill);cursor:pointer;transition:background-color var(--transition-base), color var(--transition-base), border-color var(--transition-base), transform var(--transition-base);border:1px solid #0000;justify-content:center;align-items:center;padding:.85rem 1.6rem;line-height:1;text-decoration:none;display:inline-flex}.btn:hover{transform:translateY(-2px)}.btn--primary{background:var(--surface-inverse);color:var(--text-on-dark);border-color:var(--surface-inverse)}.btn--primary:hover{background:var(--surface-inverse-hover);border-color:var(--surface-inverse-hover)}.btn--ghost{color:var(--text-heading);border-color:var(--border-strong);background:0 0}.btn--ghost:hover{background:var(--surface-accent)}.btn--sm{font-size:var(--text-sm);padding:.6rem 1.15rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.tag{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-secondary);background:var(--surface-muted);border:1px solid var(--border-hairline);border-radius:var(--radius-pill);white-space:nowrap;align-items:center;padding:.3rem .75rem;display:inline-flex}.tabbar{z-index:10;background:var(--surface-page);justify-content:flex-start;gap:var(--space-6);border-bottom:1px solid var(--border-hairline);scrollbar-width:none;display:flex;position:sticky;top:0;overflow-x:auto}.tabbar::-webkit-scrollbar{display:none}.tabbar__tab{padding:var(--space-4) .25rem;color:var(--text-muted);font-family:var(--font-sans);font-size:var(--text-md);font-weight:var(--weight-medium);white-space:nowrap;cursor:pointer;transition:color var(--transition-base), border-color var(--transition-base);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px}.tabbar__tab:hover{color:var(--text-heading)}.tabbar__tab--active{color:var(--text-heading);border-bottom-color:var(--gray-800);font-weight:var(--weight-semibold)}@media (width>=700px){.tabbar{justify-content:center;gap:2.25rem}}.tabpanel{padding:var(--space-12) 0 var(--space-16);min-height:520px}.eyebrow{font-size:var(--text-xs);font-weight:var(--weight-semibold);letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--space-4)}.col-heading{font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--text-heading);margin:0 0 1.75rem}.overview{gap:var(--space-8);flex-direction:column;display:flex}.metrics{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.metric{background:var(--surface-muted);border-radius:var(--radius-card);text-align:center;padding:1.4rem 1.5rem}.metric__value{font-size:2rem;font-weight:var(--weight-semibold);color:var(--text-heading);line-height:1}.metric__label{font-size:var(--text-xs);color:var(--text-muted);margin-top:.35rem}.featured{border-radius:var(--radius-card);box-shadow:var(--shadow-card);border-top:3px solid var(--gray-800);grid-template-columns:1fr;display:grid;overflow:hidden}.featured__img{object-fit:cover;background:var(--gray-100);width:100%;height:100%;min-height:220px}.featured__body{padding:var(--space-8);flex-direction:column;justify-content:center;gap:.65rem;display:flex}.featured__title{font-size:var(--text-2xl);font-weight:var(--weight-semibold);color:var(--text-heading);margin:0}.featured__desc{font-size:var(--text-md);color:var(--text-secondary);line-height:var(--leading-normal);margin:0}.featured__tags{flex-wrap:wrap;gap:.4rem;margin-top:.35rem;display:flex}.featured__cta{margin-top:var(--space-2);align-self:flex-start}@media (width>=620px){.metrics{grid-template-columns:repeat(4,1fr)}}@media (width>=800px){.featured{grid-template-columns:1.1fr 1fr}}.work-grid{justify-content:center;gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.project-card{background:var(--surface-card);border:1px solid var(--border-hairline);border-radius:var(--radius-card);box-shadow:var(--shadow-card);transition:transform var(--transition-base), box-shadow var(--transition-base);flex-direction:column;text-decoration:none;display:flex;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.project-card__media{aspect-ratio:3/2;background:var(--gray-100);overflow:hidden}.project-card__img{object-fit:cover;width:100%;height:100%}.project-card__img--contain{object-fit:contain;padding:var(--space-4)}.project-card__body{flex-direction:column;flex:1;gap:.5rem;padding:1.25rem 1.35rem 1.4rem;display:flex}.project-card__date{font-size:var(--text-xs);color:var(--text-muted)}.project-card__title{font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--text-heading);margin:0}.project-card__desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-normal);flex:1;margin:0}.project-card__tags{flex-wrap:wrap;gap:.4rem;margin-top:.35rem;display:flex}.experience{gap:var(--space-12);max-width:var(--container-content);grid-template-columns:1fr;margin:0 auto;display:grid}.timeline{flex-direction:column;display:flex}.timeline__row{gap:var(--space-4);grid-template-columns:110px 1fr;display:grid}.timeline__period{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-muted);padding-top:.1rem}.timeline__entry{border-left:2px solid var(--border-inactive);padding:0 0 2.25rem 1.5rem;position:relative}.timeline__dot{border-radius:var(--radius-round);background:var(--gray-800);border:2px solid var(--surface-page);width:12px;height:12px;position:absolute;top:5px;left:-7px}.timeline__role{font-size:var(--text-md);font-weight:var(--weight-semibold);color:var(--text-heading)}.timeline__org{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-secondary);margin:.1rem 0 .4rem}.timeline__note{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-normal)}.skills{gap:var(--space-6);flex-direction:column;display:flex}.skills__cat-name{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-secondary);margin-bottom:.7rem}.skills__tags{gap:var(--space-2);flex-wrap:wrap;display:flex}@media (width>=800px){.experience{grid-template-columns:1.3fr 1fr;gap:3.5rem}}.testimonials{max-width:820px;margin:0 auto}.testimonial-card{background:var(--surface-accent);border-radius:20px;padding:2.25rem 1.75rem}.testimonial-card__mark{color:var(--quote-mark);height:2rem;font-family:Georgia,serif;font-size:4rem;line-height:.4}.testimonial-card__quote{font-size:1.25rem;font-weight:var(--weight-medium);color:var(--text-heading);text-wrap:pretty;margin:0 0 2.25rem;line-height:1.5}.testimonial-card__footer{justify-content:space-between;align-items:center;gap:var(--space-6);flex-wrap:wrap;display:flex}.testimonial-card__person{align-items:center;gap:.9rem;display:flex}.testimonial-card__avatar{border-radius:var(--radius-round);background:var(--surface-page);width:52px;height:52px;font-weight:var(--weight-semibold);font-size:var(--text-md);color:var(--text-heading);flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.testimonial-card__photo{object-fit:cover;width:100%;height:100%}.testimonial-card__avatar--link{cursor:pointer;transition:transform var(--transition-base), box-shadow var(--transition-base);text-decoration:none}.testimonial-card__avatar--link:hover,.testimonial-card__avatar--link:focus-visible{box-shadow:var(--shadow-soft);transform:translateY(-2px)}.testimonial-card__author{font-size:var(--text-md);font-weight:var(--weight-semibold);color:var(--text-heading)}.testimonial-card__meta{font-size:var(--text-sm);color:var(--text-muted)}.testimonial-card__controls{align-items:center;gap:1.25rem;display:flex}.testimonial-card__dots{align-items:center;gap:.4rem;display:flex}.dot{background:var(--border-inactive);cursor:pointer;width:10px;height:6px;transition:width var(--transition-base), background-color var(--transition-base);border:none;border-radius:3px;padding:0}.dot--active{background:var(--gray-800);width:26px}.testimonial-card__arrows{gap:var(--space-2);display:flex}.arrow-btn{border-radius:var(--radius-round);border:1px solid var(--border-strong);width:40px;height:40px;color:var(--text-heading);cursor:pointer;transition:background-color var(--transition-base);background:0 0;justify-content:center;align-items:center;font-size:14px;display:flex}.arrow-btn:hover{background:var(--surface-page)}@media (width>=640px){.testimonial-card{padding:2.75rem 3rem}.testimonial-card__quote{font-size:1.4rem}}.askai{border:1px solid var(--border-hairline);border-radius:16px;grid-template-columns:1fr;max-width:960px;min-height:500px;margin:0 auto;display:grid;overflow:hidden}.askai__sidebar{background:var(--surface-muted);border-bottom:1px solid var(--border-hairline);gap:var(--space-6);flex-direction:column;padding:1.5rem 1.25rem;display:flex}.askai__sidebar-title{font-size:var(--text-xs);font-weight:var(--weight-semibold);letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.askai__group-name{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-secondary);margin-bottom:var(--space-2)}.askai__group-items{flex-direction:column;gap:.35rem;display:flex}.askai__preset{text-align:left;font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:background-color var(--transition-base), color var(--transition-base);background:0 0;border:none;border-radius:8px;padding:.4rem .5rem;line-height:1.35}.askai__preset:hover:not(:disabled){background:var(--surface-accent);color:var(--text-heading)}.askai__preset:disabled{opacity:.5;cursor:not-allowed}.askai__panel{flex-direction:column;min-height:0;display:flex}.askai__header{border-bottom:1px solid var(--border-hairline);flex-shrink:0;align-items:center;gap:.9rem;padding:1.1rem 1.5rem;display:flex}.askai__mark{border-radius:var(--radius-round);background:var(--surface-accent);width:40px;height:40px;color:var(--text-heading);flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.askai__name{font-size:var(--text-md);font-weight:var(--weight-semibold);color:var(--text-heading)}.askai__sub{font-size:var(--text-xs);color:var(--text-muted)}.askai__status{font-size:var(--text-xs);color:var(--text-muted);border:1px solid var(--border-hairline);border-radius:var(--radius-pill);align-items:center;gap:.4rem;margin-left:auto;padding:.3rem .75rem;display:inline-flex}.askai__status-dot{border-radius:var(--radius-round);background:var(--gray-800);width:7px;height:7px;display:inline-block}.askai__messages{gap:var(--space-4);flex-direction:column;flex:1;max-height:420px;padding:1.5rem;display:flex;overflow-y:auto}.msg{align-items:flex-end;gap:.6rem;display:flex}.msg--user{flex-direction:row-reverse}.msg__avatar{border-radius:var(--radius-round);background:var(--surface-accent);width:30px;height:30px;color:var(--text-heading);flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.bubble{font-size:var(--text-md);line-height:var(--leading-normal);overflow-wrap:break-word;border-radius:14px;max-width:80%;padding:.7rem 1rem}.bubble--assistant{background:var(--surface-accent);color:var(--text-heading);border-bottom-left-radius:var(--radius-sm)}.bubble--assistant a{color:var(--text-heading);text-decoration:underline}.bubble--user{background:var(--surface-inverse);color:var(--text-on-dark);border-bottom-right-radius:var(--radius-sm)}.bubble.typing{align-items:center;gap:4px;display:inline-flex}.bubble.typing span{border-radius:var(--radius-round);background:var(--text-muted);width:7px;height:7px;animation:1.2s ease-in-out infinite bounce}.bubble.typing span:nth-child(2){animation-delay:.15s}.bubble.typing span:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,60%,to{opacity:.5;transform:translateY(0)}30%{opacity:1;transform:translateY(-5px)}}.askai__composer{padding:var(--space-4) 1.5rem 1.5rem;border-top:1px solid var(--border-hairline);flex-shrink:0}.askai__input-row{border:1px solid var(--border-strong);background:var(--surface-page);border-radius:14px;align-items:center;gap:.6rem;padding:.45rem .45rem .45rem 1rem;display:flex}.askai__input{font-family:var(--font-sans);font-size:var(--text-md);color:var(--text-heading);background:0 0;border:none;outline:none;flex:1}.askai__hint{font-size:var(--text-xs);color:var(--text-muted);margin:.6rem 0 0}@media (width>=720px){.askai{grid-template-columns:240px 1fr}.askai__sidebar{border-bottom:none;border-right:1px solid var(--border-hairline)}}.contact{text-align:center;max-width:520px;margin:0 auto}.contact__lead{color:var(--text-secondary);line-height:var(--leading-normal);margin:0 0 1.75rem}.contact__actions{gap:var(--space-4);flex-wrap:wrap;justify-content:center;display:flex}.site-footer{border-top:1px solid var(--border-hairline);padding:1.75rem 0}.site-footer p{text-align:center;color:var(--text-muted);font-size:var(--text-xs);margin:0}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
