:root{--color-bg:#f6f8fa;--color-bg-alt:#fff;--color-navbar-bg:#24292f;--color-navbar-link:#c9d1d9;--color-navbar-link-active:#2da44e;--color-primary:#24292f;--color-secondary:#57606a;--color-accent:#2da44e;--color-link-hover:#0969da;--color-footer-bg:#161b22;--color-footer-text:#8b949e;--color-gradient-1:linear-gradient(120deg,#f6f8fa,#eaeef2);--color-gradient-2:linear-gradient(120deg,#eaeef2,#fff);--color-gradient-accent:linear-gradient(90deg,rgba(45,164,78,0.13333333333333333),rgba(9,105,218,0.06666666666666667));--space-0:0;--space-1:clamp(3px,0.5vw,6px);--space-2:clamp(6px,1vw,12px);--space-3:clamp(12px,2vw,20px);--space-4:clamp(18px,3vw,32px);--space-5:clamp(24px,4vw,48px);--container-padding:var(--space-3);--max-width:820px;--section-spacing:var(--space-5);--font-main:"Inter","Segoe UI",Arial,sans-serif;--font-size-xs:clamp(12px,0.8vw + 0.5rem,13px);--font-size-sm:clamp(13px,1vw + 0.5rem,15px);--font-size-base:clamp(15px,1.1vw + 0.8rem,18px);--font-size-lg:clamp(18px,1.2vw + 1rem,20px);--font-size-h1:clamp(2.1rem,2.5vw + 1.5rem,2.7rem);--font-size-h2:clamp(1.4rem,1.5vw + 1.1rem,1.8rem);--font-size-h3:clamp(1.1rem,1vw + 0.9rem,1.3rem);--font-weight-normal:400;--font-weight-semibold:600;--font-weight-bold:700;--line-height-base:1.7;--line-height-heading:1.22;--radius:10px;--transition:0.22s cubic-bezier(.4,0,.2,1);--transition-fast:0.14s cubic-bezier(.4,0,.2,1);--shadow-navbar:0 2px 12px 0 rgba(208,215,222,0.2);--shadow-section:0 4px 24px 0 rgba(27,31,35,0.06);--shadow-footer:0 -1px 0 #21262d;--shadow-card:0 4px 24px 0 rgba(27,31,35,0.08);--shadow-card-hover:0 8px 24px 0 rgba(27,31,35,0.12);--focus-outline:2px solid #2da44e;--focus-outline-offset:2px}*,:after,:before{box-sizing:border-box}body,html{height:100%;margin:0;padding:0;font-family:var(--font-main);font-size:var(--font-size-base);background:var(--color-bg);color:var(--color-primary);line-height:var(--line-height-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-padding-top:calc(var(--navbar-height, 60px) + 8px);-moz-text-size-adjust:100%;text-size-adjust:100%;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{min-height:100dvh;width:100%;overflow-x:hidden;display:flex;flex-direction:column;background:var(--color-gradient-1)}.section-title,h1{font-size:var(--font-size-h1);margin-bottom:var(--space-2);letter-spacing:-.015em;text-shadow:0 2px 8px rgba(234,238,242,.8);transition:color var(--transition),text-shadow var(--transition)}.section-subtitle,.section-title,h1,h2{font-weight:var(--font-weight-bold);line-height:var(--line-height-heading);color:var(--color-primary);background:none;text-align:left}.section-subtitle,h2{font-size:var(--font-size-h2);margin-bottom:var(--space-1);letter-spacing:-.01em;transition:color var(--transition)}.section-heading,h3{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);line-height:var(--line-height-heading);margin-bottom:var(--space-1);text-align:left}.section-heading,h3,ol,p,ul{color:var(--color-secondary);letter-spacing:.01em;background:none;transition:color var(--transition)}ol,p,ul{font-size:var(--font-size-base);font-family:var(--font-main);font-weight:var(--font-weight-normal);line-height:var(--line-height-base);margin-bottom:var(--space-2);margin-top:0;word-break:break-word;text-align:justify}.navbar{--navbar-height:60px;position:fixed;top:0;left:0;background:var(--color-navbar-bg);color:var(--color-navbar-link);z-index:3000;height:var(--navbar-height);min-height:var(--navbar-height);box-shadow:var(--shadow-navbar);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);-webkit-user-select:none;user-select:none;transition:background var(--transition),box-shadow var(--transition);padding:0;backface-visibility:hidden}.navbar,.navbar .navbar-links{width:100%;display:flex;justify-content:center;align-items:center}.navbar .navbar-links{grid-gap:var(--space-2);gap:var(--space-2);flex-wrap:wrap;background:none}.navbar .navbar-links a{color:var(--color-navbar-link);font-size:inherit;padding:.5em 1.2em;border-radius:var(--radius);background:none;font-weight:var(--font-weight-semibold);letter-spacing:.01em;text-decoration:none;position:relative;transition:color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast);outline:none;min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(22,27,34,.0392156862745098);touch-action:manipulation}.navbar .navbar-links a:after{content:"";display:block;position:absolute;left:18%;right:18%;bottom:.18em;height:2px;border-radius:1px;background:var(--color-accent);opacity:0;transform:scaleX(.5);transition:opacity var(--transition-fast),transform var(--transition-fast)}.navbar .navbar-links a.active,.navbar .navbar-links a[aria-current=page]{color:var(--color-navbar-link-active);font-weight:var(--font-weight-bold);background:var(--color-gradient-accent);box-shadow:0 2px 8px rgba(45,164,78,.13333333333333333)}.navbar .navbar-links a.active:after,.navbar .navbar-links a:focus-visible:after,.navbar .navbar-links a:hover:after,.navbar .navbar-links a[aria-current=page]:after{opacity:1;transform:scaleX(1.1)}.navbar .navbar-links a:focus-visible,.navbar .navbar-links a:hover{color:var(--color-link-hover);background:var(--color-gradient-accent);outline:var(--focus-outline);outline-offset:var(--focus-outline-offset);box-shadow:0 4px 16px rgba(45,164,78,.13333333333333333)}.navbar .navbar-hamburger{display:none;background:none;border:none;color:var(--color-navbar-link);font-size:2rem;cursor:pointer;margin-left:var(--space-2);transition:color var(--transition-fast);min-width:48px;min-height:48px;border-radius:var(--radius);outline:none}.navbar .navbar-hamburger:focus-visible,.navbar .navbar-hamburger:hover{background:var(--color-gradient-accent);color:var(--color-link-hover);outline:var(--focus-outline);outline-offset:var(--focus-outline-offset)}.about-section,.certifications-section,.contact-section,.hero-section,.interests-section,.projects-section,.publications-section,.section,.skills-section,section{width:100%;min-height:70dvh;display:flex;align-items:center;justify-content:center;flex-direction:column;background:var(--color-gradient-2);position:relative;overflow:hidden;padding:var(--section-spacing) 0;z-index:1;isolation:isolate;box-shadow:var(--shadow-section);scroll-margin-top:calc(var(--navbar-height, 60px) + 8px)}.about-section:before,.certifications-section:before,.contact-section:before,.hero-section:before,.interests-section:before,.projects-section:before,.publications-section:before,.section:before,.skills-section:before,section:before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse at 60% 10%,rgba(45,164,78,.050980392156862744) 0,transparent 70%),radial-gradient(ellipse at 10% 80%,rgba(9,105,218,.0392156862745098) 0,transparent 70%);opacity:.7;transition:opacity var(--transition)}.section-content{flex-direction:column;align-items:flex-start;grid-gap:var(--space-4);gap:var(--space-4);padding:var(--space-5) var(--space-4);background:none;border-radius:var(--radius);max-width:var(--max-width);margin:0 auto;box-shadow:0 2px 16px rgba(234,238,242,.2)}.section-avatar,.section-content{position:relative;z-index:2;display:flex}.section-avatar{width:clamp(56px,12vw,120px);height:clamp(56px,12vw,120px);aspect-ratio:1/1;border-radius:50%;border:2px solid #d0d7de;background:var(--color-bg-alt);overflow:hidden;margin-bottom:var(--space-2);box-shadow:0 4px 24px rgba(208,215,222,.2);transition:box-shadow var(--transition),transform var(--transition);align-items:center;justify-content:center}.section-avatar:focus-visible{outline:var(--focus-outline);outline-offset:var(--focus-outline-offset)}.section-avatar img{width:100%;height:100%;object-fit:cover;object-position:center;border-radius:50%;display:block;filter:brightness(1.04) saturate(1.05);background:#fff;transition:filter var(--transition);aspect-ratio:1/1}.section-card{background:var(--color-bg-alt);border-radius:var(--radius);box-shadow:var(--shadow-card);border:1px solid #eaeef2;transition:box-shadow var(--transition),background var(--transition),filter var(--transition),transform var(--transition);padding:var(--space-5) var(--space-4);max-width:100%;margin-bottom:var(--space-3)}.section-card:focus-within,.section-card:hover{box-shadow:var(--shadow-card-hover);filter:brightness(1.025) saturate(1.04);transform:translateY(-2px) scale(1.012)}.section-btn{border:1px solid #d0d7de;box-shadow:0 2px 8px 0 rgba(27,31,35,.06);cursor:pointer;outline:none;text-decoration:none;letter-spacing:.01em;position:relative;overflow:hidden;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);border-radius:var(--radius);background:#f6f8fa;color:var(--color-primary);padding:.6em 1.7em;min-height:44px;min-width:44px;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast),filter var(--transition-fast),border-color var(--transition-fast);display:inline-flex;align-items:center;justify-content:center}.section-btn:focus-visible,.section-btn:hover{background:#eaeef2;color:var(--color-accent);border-color:var(--color-accent);transform:translateY(-1px) scale(1.03);box-shadow:0 8px 32px rgba(45,164,78,.13333333333333333);outline:var(--focus-outline);outline-offset:var(--focus-outline-offset);filter:brightness(1.04)}.section-btn:active{transform:scale(.97)}:focus-visible{outline:var(--focus-outline);outline-offset:var(--focus-outline-offset)}a{color:var(--color-link-hover);text-decoration:none;font-weight:var(--font-weight-semibold);transition:color var(--transition-fast),-webkit-text-decoration var(--transition-fast);transition:color var(--transition-fast),text-decoration var(--transition-fast);transition:color var(--transition-fast),text-decoration var(--transition-fast),-webkit-text-decoration var(--transition-fast);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a:focus,a:hover{color:var(--color-accent);text-decoration:underline;outline:none}.projects-grid,.section-card,.section-content,.timeline{min-width:0;min-height:0;max-width:100%;overflow-x:auto;padding-left:var(--container-padding);padding-right:var(--container-padding);box-sizing:border-box}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:var(--space-4);gap:var(--space-4);width:100%;margin-top:var(--space-4);align-items:stretch;background:none;box-shadow:none;position:relative;z-index:2}.skeleton{background:linear-gradient(90deg,#eaeef2 25%,#f6f8fa 50%,#eaeef2 75%);background-size:200% 100%;animation:skeleton-loading 1.1s linear infinite;border-radius:var(--radius);min-height:36px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.footer,footer{background:var(--color-footer-bg);min-height:2.5rem;margin-top:auto;font-size:var(--font-size-sm);position:relative;left:0;bottom:0;z-index:999;padding:var(--space-2) 0;flex-direction:column;grid-gap:.2em;gap:.2em;box-sizing:border-box;box-shadow:var(--shadow-footer);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.footer,.footer>*,footer,footer>*{color:var(--color-footer-text);width:100%;display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--font-main)}@media (max-width:1200px){:root{--max-width:99vw}}@media (max-width:900px){.section-content{max-width:98vw}.projects-grid{grid-template-columns:1fr 1fr}}@media (max-width:700px){.navbar{--navbar-height:auto;min-height:unset;height:auto;padding:0 var(--space-1);flex-wrap:wrap;align-items:flex-start}.navbar .navbar-links{flex-direction:row;flex-wrap:wrap;justify-content:flex-start;grid-gap:var(--space-1);gap:var(--space-1);margin:0}.navbar .navbar-hamburger{display:none}.navbar .navbar-links a{font-size:var(--font-size-base);padding:.5em .8em;min-height:40px;min-width:40px;margin:0 2px 2px 0;width:auto}.navbar .navbar-links a:last-child{border-bottom:none}.navbar .navbar-links a:active,.navbar .navbar-links a:focus-visible,.navbar .navbar-links a:hover{background:var(--color-gradient-accent);color:var(--color-link-hover);outline:var(--focus-outline);outline-offset:var(--focus-outline-offset)}.navbar .navbar-links a:after{left:18%;right:18%;bottom:.18em;height:2px;border-radius:1px;background:var(--color-accent);opacity:0;transform:scaleX(.5);transition:opacity var(--transition-fast),transform var(--transition-fast)}.navbar .navbar-links a.active:after,.navbar .navbar-links a:focus-visible:after,.navbar .navbar-links a:hover:after,.navbar .navbar-links a[aria-current=page]:after{opacity:1;transform:scaleX(1.1);background:var(--color-accent)}.about-section,.certifications-section,.contact-section,.hero-section,.interests-section,.projects-section,.publications-section,.section,.skills-section,section{padding:var(--space-3) 0;margin-top:80px;scroll-margin-top:80px}.section-avatar{margin-top:var(--space-3);overflow:visible!important;position:relative;z-index:5}.section-avatar img{object-fit:contain!important}}@media (max-width:600px){:root{--font-size-h1:1.5rem;--font-size-h2:1.15rem;--font-size-h3:1rem;--font-size-base:15px;--font-size-sm:13px;--section-spacing:var(--space-3)}.projects-grid,.section-card,.section-content,.timeline{padding-left:var(--space-1);padding-right:var(--space-1)}.projects-grid{grid-template-columns:1fr;grid-gap:var(--space-2);gap:var(--space-2)}.footer,footer{font-size:var(--font-size-sm)}.section,section{padding:var(--space-3) 0}.navbar .navbar-links a{font-size:var(--font-size-sm);padding:.4em .6em;min-height:36px;min-width:36px;margin:0 1px 1px 0}.section-avatar{width:80px;height:80px;margin:0 auto var(--space-2);overflow:visible!important}.section-avatar img{object-fit:contain!important;width:100%;height:100%;border-radius:50%}}@media (max-width:400px){:root{--font-size-h1:1.08rem;--font-size-h2:0.98rem;--font-size-h3:0.92rem;--font-size-base:13px;--font-size-sm:12px}.section-avatar{width:60px;height:60px;overflow:visible!important}.section-avatar img{object-fit:contain!important}.section,section{padding:var(--space-2) 0}.navbar .navbar-links a{font-size:var(--font-size-xs);padding:.3em .4em;min-height:32px;min-width:32px}}@media (prefers-reduced-motion:reduce){*,:after,:before{transition:none!important;animation:none!important}html{scroll-behavior:auto!important}}@keyframes fadeInMenu{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
/*# sourceMappingURL=main.d664a89c.chunk.css.map */