@import url(https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap);body{margin:0}:root{--primary-color:#0891b2;--primary-light:#22d3ee;--primary-dark:#0e7490;--accent-color:#f59e0b;--background-color:#f0f4f8;--surface-color:#fff;--card-background:#fff;--card-border:#0000000f;--text-color:#1a2332;--text-muted:#64748b;--text-on-primary:#fff;--secondary-color:#fff;--card-text-color:#1a2332;--link-color:#0891b2;--hover-color:#0e7490;--button-background:#0891b2;--button-text:#fff;--button-hover:#0e7490;--section-heading-border:#0891b2;--scroll-to-top-button-bg:#0891b2;--scroll-to-top-button-hover:#0e7490;--shadow-xs:0 1px 3px #0000000a,0 1px 2px #0000000f;--shadow-sm:0 2px 8px #0000000d,0 1px 3px #0000000a;--shadow-md:0 4px 16px #00000012,0 2px 6px #0000000d;--shadow-lg:0 10px 36px #0000001a,0 4px 12px #0000000f;--shadow-xl:0 20px 60px #0000001f,0 8px 20px #00000012;--gradient-primary:linear-gradient(135deg,#0891b2,#0e7490);--gradient-hero:linear-gradient(135deg,#0891b2,#0c4a6e);--gradient-subtle:linear-gradient(135deg,#0891b20f,#0e749005);--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:24px;--ease-out:cubic-bezier(0.4,0,0.2,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1)}[data-theme=dark]{--primary-color:#22d3ee;--primary-light:#67e8f9;--primary-dark:#0891b2;--accent-color:#fbbf24;--background-color:#0d1117;--surface-color:#161b22;--card-background:#161b22;--card-border:#ffffff12;--text-color:#e6edf3;--text-muted:#8b949e;--text-on-primary:#0d1117;--secondary-color:#161b22;--card-text-color:#e6edf3;--link-color:#22d3ee;--hover-color:#67e8f9;--button-background:#22d3ee;--button-text:#0d1117;--button-hover:#67e8f9;--shadow-xs:0 1px 3px #0000004d;--shadow-sm:0 2px 8px #00000059;--shadow-md:0 4px 16px #00000073;--shadow-lg:0 10px 36px #0000008c;--shadow-xl:0 20px 60px #000000a6;--gradient-primary:linear-gradient(135deg,#22d3ee,#0891b2);--gradient-hero:linear-gradient(135deg,#1a3a4a,#0d1117);--gradient-subtle:linear-gradient(135deg,#22d3ee12,#0891b208)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scrollbar-color:#0891b2 #0000;scrollbar-color:var(--primary-color) #0000;scrollbar-width:thin}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f0f4f8;background-color:var(--background-color);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:15px;line-height:1.65;overflow-x:hidden}body,h1,h2,h3,h4,h5,h6{color:#1a2332;color:var(--text-color)}h1,h2,h3,h4,h5,h6{font-family:Syne,sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.25;margin-bottom:.75rem}h1{font-size:clamp(2rem,5vw,2.75rem)}h2{font-size:clamp(1.5rem,3vw,2rem)}h3{font-size:1.25rem}p{margin-bottom:1rem}a{color:#0891b2;color:var(--link-color);text-decoration:none;transition:color .2s cubic-bezier(.4,0,.2,1);transition:color .2s var(--ease-out)}a:hover{color:#0e7490;color:var(--hover-color)}img{display:block;height:auto;max-width:100%}button{background:none;border:none;cursor:pointer;font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#0891b2;background:var(--primary-color);border-radius:3px;opacity:.6}::-webkit-scrollbar-thumb:hover{opacity:1}:focus-visible{border-radius:4px;outline:2px solid #0891b2;outline:2px solid var(--primary-color);outline-offset:3px}::selection{background-color:#0891b2;background-color:var(--primary-color);color:#fff;color:var(--text-on-primary)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}.animate-fade-in{animation:fadeInUp .6s cubic-bezier(.4,0,.2,1) both;animation:fadeInUp .6s var(--ease-out) both}.animate-slide-in{animation:slideInRight .5s cubic-bezier(.4,0,.2,1) both;animation:slideInRight .5s var(--ease-out) both}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;transition-duration:.01ms!important}}@media (max-width:768px){body{font-size:14px}}.cert-card,.contact-item,.education-item,.experience-card,.lang-card,.mobile-topbar,.profile-header,.profile-section,.project-card,.sidebar,.skill-category-card,.strip-card,.vol-card,body{transition:background-color .3s cubic-bezier(.4,0,.2,1),border-color .3s cubic-bezier(.4,0,.2,1),color .2s cubic-bezier(.4,0,.2,1);transition:background-color .3s var(--ease-out),border-color .3s var(--ease-out),color .2s var(--ease-out)}@media print{.contact-copy-btn,.dark-mode-toggle,.filter-btn,.header-actions,.mobile-topbar,.scroll-progress,.scroll-to-top-button,.sidebar,.skip-link,.strip-nav,.vol-toggle{display:none!important}.app-shell{display:block}.main-content{margin-left:0!important;padding:0!important}.sections-wrapper{max-width:100%}.profile-section{border:1px solid #ddd!important;box-shadow:none!important;break-inside:avoid;margin-bottom:12pt;opacity:1!important;padding:16pt;page-break-inside:avoid;transform:none!important}body{background:#fff;font-size:10pt}a,body{color:#000}a{text-decoration:underline}a[href^=http]:after,a[href^=mailto]:after{content:" (" attr(href) ")";font-size:8pt}}.skip-link{background:var(--primary-color);border-radius:0 0 10px 10px;box-shadow:var(--shadow-lg);color:var(--text-on-primary);font-size:.875rem;font-weight:700;left:16px;padding:10px 20px;position:fixed;text-decoration:none;top:-100px;transition:top .2s;z-index:9999}.skip-link:focus{outline:2px solid #fff;outline-offset:2px;top:0}.scroll-progress{height:2px;left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:1200}.scroll-progress-bar{background:var(--gradient-primary);box-shadow:0 0 8px var(--primary-color);height:100%;transition:width .08s linear}.app-shell{background:var(--background-color);display:flex;min-height:100vh}.sidebar{background:var(--card-background);border-right:1px solid var(--card-border);display:flex;flex-direction:column;height:100vh;left:0;overflow-x:hidden;overflow-y:auto;position:fixed;scrollbar-color:var(--primary-color) #0000;scrollbar-width:thin;top:0;transition:transform .3s var(--ease-out),box-shadow .3s;width:280px;width:var(--sidebar-w,280px);z-index:200}[data-theme=dark] .sidebar{border-right-color:#ffffff12}.sidebar-nav{flex-shrink:0;padding:10px 0 32px}.sidebar-nav-label{color:var(--text-muted);font-size:.62rem;font-weight:800;letter-spacing:.1em;margin:0;padding:0 20px 8px;text-transform:uppercase}.sidebar-nav ul{list-style:none;margin:0;padding:0}.sidebar-nav-link{align-items:center;background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;font-size:.83rem;font-weight:600;gap:10px;padding:9px 20px;position:relative;text-align:left;transition:color .2s,background .2s,padding-left .2s var(--ease-out);width:100%}.sidebar-nav-link:hover{background:#0891b20a;color:var(--text-color);padding-left:24px}.sidebar-nav-link.active{background:#0891b212;color:var(--primary-color);font-weight:700}[data-theme=dark] .sidebar-nav-link.active{background:#22d3ee14}.sidebar-nav-link.active:before{background:var(--gradient-primary);border-radius:0 2px 2px 0;bottom:6px;content:"";left:0;position:absolute;top:6px;width:3px}.nav-icon{flex-shrink:0;font-size:.9rem;opacity:.7;text-align:center;width:20px}.sidebar-nav-link.active .nav-icon{opacity:1}.nav-active-dot{background:var(--primary-color);border-radius:50%;flex-shrink:0;height:6px;margin-left:auto;width:6px}.main-content{flex:1 1;margin-left:280px;margin-left:var(--sidebar-w,280px);min-height:100vh;min-width:0;outline:none;padding:36px 44px 80px}.sections-wrapper{max-width:860px}.profile-section{background:var(--card-background);border:1px solid var(--card-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);margin-bottom:20px;opacity:0;padding:30px 34px;transform:translateY(24px);transition:opacity .65s var(--ease-out),transform .65s var(--ease-out)}[data-theme=dark] .profile-section{border-color:#ffffff0f}.profile-section.visible{opacity:1;transform:translateY(0)}.profile-section:hover{border-color:#0891b21a;box-shadow:var(--shadow-md);transition:box-shadow .3s,border-color .3s}.profile-section h2{align-items:center;color:var(--text-color);display:flex;font-family:Syne,sans-serif;font-size:1.15rem;font-weight:800;gap:10px;letter-spacing:-.03em;margin-bottom:22px}.profile-section h2:before{background:var(--gradient-primary);border-radius:2px;content:"";display:inline-block;flex-shrink:0;height:20px;width:4px}.about-text{color:var(--text-color);font-size:.95rem;line-height:1.85;margin:0;opacity:.88}.mobile-topbar{align-items:center;background:var(--card-background);border-bottom:1px solid var(--card-border);display:none;height:58px;justify-content:space-between;padding:0 16px;position:-webkit-sticky;position:sticky;top:0;z-index:100}[data-theme=dark] .mobile-topbar{border-bottom-color:#ffffff12}.mobile-brand{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-family:Syne,sans-serif;font-size:.95rem;font-weight:800;letter-spacing:-.03em;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-menu-btn{align-items:center;background:var(--background-color);border:1px solid var(--card-border);border-radius:10px;cursor:pointer;display:flex;flex-shrink:0;height:38px;justify-content:center;transition:background .2s,border-color .2s;width:38px}.mobile-menu-btn:hover{background:#0891b20d;border-color:var(--primary-color)}.hamburger{display:flex;flex-direction:column;gap:4px;width:18px}.hamburger span{background:var(--text-color);border-radius:1px;display:block;height:2px;transition:transform .25s var(--ease-out),opacity .2s,width .2s}.hamburger.open span:first-child{transform:translateY(6px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0;width:0}.hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.topbar-right-spacer{flex-shrink:0;width:40px}.drawer-overlay{animation:fadeIn .2s ease both;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);background:#00000080;display:none;inset:0;position:fixed;z-index:199}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.loading-container{align-items:center;background:var(--background-color);display:flex;justify-content:center;min-height:100vh}.loading-content{align-items:center;display:flex;flex-direction:column;gap:16px}.loading-spinner{animation:spin .75s linear infinite;border:3px solid #0891b226;border-radius:50%;border-top:3px solid var(--primary-color);height:36px;width:36px}.loading-text{color:var(--text-muted);font-size:.88rem}@media (min-width:1440px){:root{--sidebar-w:300px}.main-content{padding:40px 56px 80px}}@media (max-width:1439px) and (min-width:1025px){:root{--sidebar-w:260px}.main-content{padding:32px 40px 80px}}@media (max-width:1024px) and (min-width:769px){:root{--sidebar-w:234px}.main-content{padding:28px 28px 80px}.profile-section{padding:24px 26px}.sections-wrapper{max-width:100%}}@media (max-width:768px){.sidebar{--sidebar-w:280px;box-shadow:none;transform:translateX(-100%);width:280px}.sidebar.drawer-open{box-shadow:var(--shadow-xl);transform:translateX(0)}.drawer-overlay{display:block}.main-content{margin-left:0;padding:0 0 64px}.mobile-topbar{display:flex}.sections-wrapper{max-width:100%;padding:16px 12px 0}.profile-section{border-radius:16px;margin-bottom:14px;padding:20px 18px}.profile-section h2{font-size:1rem;margin-bottom:16px}}@media (max-width:480px){.sections-wrapper{padding:12px 8px 0}.profile-section{margin-bottom:12px;padding:18px 14px}.mobile-topbar{padding:0 12px}.mobile-brand{max-width:140px}}@media (prefers-contrast:high){.sidebar{border-right-width:2px}.profile-section{border:2px solid var(--text-color)}}@media (prefers-reduced-motion:reduce){.profile-section{opacity:1!important;transform:none!important}.profile-section,.sidebar{transition:none!important}}.section-count{align-items:center;background:#0891b217;border:1px solid #0891b22e;border-radius:50px;color:var(--primary-color);display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:800;height:20px;justify-content:center;letter-spacing:0;margin-left:4px;min-width:22px;padding:0 6px;vertical-align:middle}[data-theme=dark] .section-count{background:#22d3ee1a;border-color:#22d3ee33}.profile-header{align-items:center;background:#0000;border-bottom:1px solid var(--card-border);display:flex;flex-direction:column;gap:0;padding:32px 22px 20px;position:relative;text-align:center}.profile-header:before{background:var(--gradient-primary);content:"";height:3px;left:0;position:absolute;right:0;top:0}.avatar-wrapper{margin-bottom:16px;position:relative}.profile-pic{border:3px solid var(--primary-color);border-radius:50%;box-shadow:0 0 0 5px #0891b21f;display:block;height:96px;object-fit:cover;object-position:top;transition:transform .3s var(--ease-spring),box-shadow .3s;width:96px}.avatar-wrapper:hover .profile-pic{box-shadow:0 0 0 6px #0891b233,var(--shadow-md);transform:scale(1.04)}.online-dot{animation:pulseGreen 2.5s ease-in-out infinite;background:#22c55e;border:2.5px solid var(--card-background);border-radius:50%;bottom:4px;box-shadow:0 0 6px #22c55e8c;height:13px;position:absolute;right:4px;width:13px}@keyframes pulseGreen{0%,to{box-shadow:0 0 0 0 #22c55e66}50%{box-shadow:0 0 0 5px #22c55e00}}.header-name{color:var(--text-color);font-family:Syne,sans-serif;font-size:1.25rem;font-weight:800;letter-spacing:-.04em;line-height:1.2;margin:0 0 10px}.header-roles{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin-bottom:10px}.role-pill{background:#0891b217;border:1px solid #0891b233;border-radius:50px;color:var(--primary-color);display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.04em;padding:3px 10px;text-transform:uppercase}.header-tagline{color:var(--text-muted);font-size:.78rem;line-height:1.55;margin:0 0 8px;padding:0 4px}.header-location{align-items:center;color:var(--text-muted);display:inline-flex;font-size:.75rem;gap:4px;margin-bottom:16px}.header-contacts{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:16px}.contact-link{align-items:center;background:var(--background-color);border:1px solid var(--card-border);border-radius:7px;color:var(--text-muted);display:inline-flex;font-size:.72rem;font-weight:600;gap:5px;padding:4px 10px;text-decoration:none;transition:color .2s,background .2s,border-color .2s}.contact-link:hover{background:#0891b20d;border-color:#0891b24d;color:var(--primary-color)}.header-actions{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;width:100%}.btn-primary{align-items:center;background:var(--gradient-primary);border:none;border-radius:10px;box-shadow:0 4px 14px #0891b259;color:var(--text-on-primary);cursor:pointer;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:700;gap:7px;justify-content:center;padding:10px 16px;text-decoration:none;transition:box-shadow .25s,transform .2s var(--ease-spring),opacity .2s;width:100%}.btn-primary:hover{box-shadow:0 8px 22px #0891b273;color:var(--text-on-primary);transform:translateY(-2px)}.btn-primary:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.btn-secondary{align-items:center;background:#0000;border:1.5px solid var(--primary-color);border-radius:10px;color:var(--primary-color);cursor:pointer;display:flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:700;gap:7px;justify-content:center;padding:10px 16px;text-decoration:none;transition:background .2s,transform .2s var(--ease-spring),color .2s;width:100%}.btn-secondary:hover{background:#0891b214;color:var(--primary-color);transform:translateY(-2px)}.spinner-sm{animation:spin .7s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:13px;width:13px}@keyframes spin{to{transform:rotate(1turn)}}.header-stats{grid-gap:1px;background:var(--card-border);border-radius:12px;display:grid;gap:1px;grid-template-columns:1fr 1fr;overflow:hidden;width:100%}.stat-item{align-items:center;background:var(--card-background);display:flex;flex-direction:column;gap:2px;padding:12px 8px;text-align:center}.stat-value{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-family:Syne,sans-serif;font-size:1.2rem;font-weight:800;letter-spacing:-.04em;line-height:1.2}.stat-label{color:var(--text-muted);font-size:.62rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}[data-theme=dark] .profile-header{border-bottom-color:#ffffff12}[data-theme=dark] .header-stats{background:#ffffff12}.header-main{display:contents}@media (max-width:1024px){.profile-header{padding:24px 16px 16px}.profile-pic{height:80px;width:80px}.header-name{font-size:1.1rem}.header-actions{gap:7px}.btn-primary,.btn-secondary{font-size:.78rem;padding:9px 12px}.stat-value{font-size:1rem}}.timeline{list-style:none;margin:0;padding:0;position:relative}.timeline:before{background:linear-gradient(to bottom,var(--primary-color) 0,#0000 100%);border-radius:1px;bottom:0;content:"";left:9px;opacity:.4;position:absolute;top:12px;width:2px}.timeline-item{margin-bottom:20px;padding-left:38px;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-dot{background:var(--card-background);border:2.5px solid var(--primary-color);border-radius:50%;box-shadow:0 0 0 4px #0891b21a;height:16px;left:2px;position:absolute;top:18px;transition:transform .25s var(--ease-spring),box-shadow .25s,background .25s;width:16px;z-index:1}.timeline-item:hover .timeline-dot{background:var(--primary-color);box-shadow:0 0 0 5px #0891b22e;transform:scale(1.3)}.experience-card{background:var(--background-color);border:1px solid var(--card-border);border-radius:var(--radius-md);overflow:hidden;padding:20px 24px;position:relative;transition:transform .25s var(--ease-out),box-shadow .25s,border-color .25s}.experience-card:before{background:var(--gradient-primary);border-radius:0 0 2px 0;content:"";height:0;left:0;position:absolute;top:0;transition:height .3s var(--ease-out);width:3px}.timeline-item:hover .experience-card:before{height:100%}.timeline-item:hover .experience-card{border-color:#0891b22e;box-shadow:var(--shadow-md);transform:translateX(4px)}[data-theme=dark] .experience-card{background:#ffffff05;border-color:#ffffff0f}.exp-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:8px}.exp-duration,.exp-location{align-items:center;color:var(--text-muted);display:inline-flex;font-size:.75rem;font-weight:600;gap:4px;letter-spacing:.01em}.exp-title{color:var(--text-color);font-family:Syne,sans-serif;font-size:1.05rem;font-weight:700;line-height:1.3;margin:0 0 4px;transition:color .2s}.exp-company,.timeline-item:hover .exp-title{color:var(--primary-color)}.exp-company{font-size:.82rem;font-weight:700;letter-spacing:.01em;margin:0 0 12px;opacity:.9}.exp-description{color:var(--text-color);font-size:.86rem;line-height:1.78;opacity:.75}.exp-description em{display:block;font-size:.78rem;font-style:italic;margin-top:8px;opacity:.6}.education-item{background:var(--background-color);border:1px solid var(--card-border);border-radius:var(--radius-md);margin-bottom:16px;overflow:hidden;padding:20px 24px;position:relative;transition:transform .25s,box-shadow .25s,border-color .25s}.education-item:before{background:var(--gradient-primary);content:"";height:0;left:0;position:absolute;top:0;transition:height .3s var(--ease-out);width:3px}.education-item:hover:before{height:100%}.education-item:hover{border-color:#0891b22e;box-shadow:var(--shadow-md);transform:translateX(4px)}[data-theme=dark] .education-item{background:#ffffff05;border-color:#ffffff0f}.education-item h3{color:var(--text-color);font-family:Syne,sans-serif;font-size:1rem;font-weight:700;margin:0 0 6px;transition:color .2s}.education-item:hover h3{color:var(--primary-color)}.education-item p{color:var(--text-muted);font-size:.84rem;line-height:1.65;margin:0 0 4px}.education-item p i{color:var(--primary-color);font-style:normal;font-weight:600}@media (max-width:640px){.timeline:before{left:6px}.timeline-item{padding-left:28px}.timeline-dot{height:14px;left:0;width:14px}.experience-card{padding:16px}}@media (max-width:480px){.education-item,.experience-card{padding:14px}.timeline-item{padding-left:26px}}.edu-institution{color:var(--primary-color);font-weight:700}.edu-sep{margin:0 2px}.edu-duration,.edu-sep{color:var(--text-muted)}.edu-duration{font-size:.85em}.skills-wrapper{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.skill-category-card{background:var(--card-background);border:1px solid var(--card-border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow .25s var(--ease-out),border-color .25s}[data-theme=dark] .skill-category-card{border-color:#ffffff12}.skill-category-card.open{border-color:#0891b240;box-shadow:0 4px 20px #0891b21a;grid-column:1/-1}.skill-category-header{align-items:center;background:none;border:none;color:var(--text-color);cursor:pointer;display:flex;justify-content:space-between;padding:16px 18px;text-align:left;transition:background .2s;width:100%}.skill-category-header:hover{background:#0891b208}.skill-category-left{align-items:center;display:flex;gap:12px}.skill-icon{align-items:center;background:#0891b214;border-radius:10px;display:flex;flex-shrink:0;font-size:1.1rem;height:36px;justify-content:center;transition:background .25s;width:36px}.skill-category-card.open .skill-icon{background:#0891b224}.skill-category-name{color:var(--text-color);font-family:Syne,sans-serif;font-size:.9rem;font-weight:700}.skill-category-right{align-items:center;display:flex;gap:10px}.skill-count{background:var(--background-color);border-radius:50px;color:var(--text-muted);font-size:.72rem;font-weight:600;padding:2px 8px}.chevron{color:var(--primary-color);display:inline-block;font-size:1rem;font-style:normal;font-weight:600;transition:transform .3s var(--ease-out)}.chevron.up{transform:rotate(-90deg)}.chevron.down{transform:rotate(90deg)}.skill-levels{animation:expandIn .25s var(--ease-out) both;display:flex;flex-direction:column;gap:16px;padding:0 18px 18px}@keyframes expandIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.skill-level-group{display:flex;flex-direction:column;gap:8px}.level-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.skill-tags{display:flex;flex-wrap:wrap;gap:7px}.skill-tag{border:1px solid;border-radius:50px;cursor:default;font-size:.78rem;font-weight:600;padding:4px 12px;transition:opacity .2s,transform .15s var(--ease-spring)}.skill-tag:hover{opacity:.85;transform:translateY(-1px)}@media (max-width:640px){.skills-wrapper{grid-template-columns:1fr}.skill-category-card.open{grid-column:auto}}@media (max-width:480px){.skill-category-header{padding:13px 14px}}.projects-filter-bar{border-bottom:1px solid var(--card-border);flex-wrap:wrap;gap:8px;margin-bottom:20px;margin-left:-2px;padding:12px 0 10px;position:-webkit-sticky;position:sticky;top:8px;z-index:10}.filter-btn,.projects-filter-bar{background:var(--card-background);display:flex}.filter-btn{align-items:center;border:1.5px solid var(--card-border);border-radius:50px;color:var(--text-muted);cursor:pointer;font-size:.8rem;font-weight:700;gap:6px;letter-spacing:.02em;padding:7px 16px;transition:all .2s var(--ease-out)}.filter-btn:hover{background:#0891b20d;border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-1px)}.filter-btn.active{border-color:#0000;box-shadow:0 4px 14px #0003;color:#fff;transform:translateY(-1px)}.filter-count{background:#ffffff40;border-radius:20px;font-size:.72rem;padding:1px 7px}.filter-btn:not(.active) .filter-count{background:#00000012;color:var(--text-muted)}[data-theme=dark] .filter-btn:not(.active) .filter-count{background:#ffffff1a}.projects-empty{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;gap:10px;grid-column:1/-1;padding:48px 20px;text-align:center}.projects-empty span{font-size:2rem}.projects-empty p{font-size:.9rem;margin:0}.projects-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}.project-card{background:var(--card-background);border:1px solid var(--card-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);display:flex;flex-direction:column;overflow:hidden;padding:0;position:relative;transition:transform .25s var(--ease-out),box-shadow .25s,border-color .25s}.project-card:hover{border-color:#0891b226;box-shadow:var(--shadow-lg);transform:translateY(-4px)}[data-theme=dark] .project-card{border-color:#ffffff12}.card-stripe{flex-shrink:0;height:4px;opacity:.9;width:100%}.project-card>:not(.card-stripe):not(.card-footer){padding-left:20px;padding-right:20px}.card-badges{display:flex;flex-wrap:wrap;gap:7px;padding-top:16px}.badge{align-items:center;border-radius:50px;display:inline-flex;font-size:.7rem;font-weight:700;gap:4px;letter-spacing:.03em;padding:3px 10px}.featured-badge{background:#fef3c7;color:#92400e}[data-theme=dark] .featured-badge{background:#451a03;color:#fcd34d}.status-badge{background:#0000000d;color:var(--text-muted)}[data-theme=dark] .status-badge{background:#ffffff14}.project-title{color:var(--text-color);font-family:Syne,sans-serif;font-size:1.05rem;font-weight:700;letter-spacing:-.02em;line-height:1.3;margin:12px 0 6px;transition:color .2s}.project-card:hover .project-title{color:var(--primary-color)}.project-description{color:var(--text-muted);font-size:.84rem;line-height:1.68;margin-bottom:12px}.project-highlights{display:flex;flex-direction:column;gap:5px;list-style:none;margin:0 0 14px;padding:0}.project-highlights li{color:var(--text-muted);font-size:.8rem;line-height:1.55;padding-left:16px;position:relative}.project-highlights li:before{color:var(--primary-color);content:"›";font-size:1rem;font-weight:700;left:0;line-height:1.3;position:absolute}.card-footer{border-top:1px solid var(--card-border);display:flex;flex-direction:column;gap:11px;margin-top:auto;padding:14px 20px 18px}[data-theme=dark] .card-footer{border-color:#ffffff0f}.project-technologies{display:flex;flex-wrap:wrap;gap:6px}.tech-tag{background:var(--background-color);border:1px solid var(--card-border);border-radius:50px;color:var(--text-muted);font-size:.72rem;font-weight:600;padding:3px 9px;transition:background .2s,color .2s,border-color .2s}.tech-tag:hover{background:#0891b214;border-color:#0891b240;color:var(--primary-color)}.project-links{display:flex;flex-wrap:wrap;gap:8px}.link-btn{align-items:center;border-radius:9px;display:inline-flex;font-size:.78rem;font-weight:700;gap:5px;padding:7px 14px;text-decoration:none;transition:all .2s var(--ease-out)}.github-btn{background:var(--background-color);border:1px solid var(--card-border);color:var(--text-color)}.github-btn:hover{background:#24292e;border-color:#0000;color:#fff;transform:translateY(-1px)}[data-theme=dark] .github-btn:hover{background:#484f58}.live-btn{background:var(--primary-color);color:#fff}.live-btn-alt{background:#374151;color:#fff}.live-btn-alt:hover,.live-btn:hover{color:#fff;opacity:.88;transform:translateY(-1px)}.featured-strip-wrapper{margin-bottom:32px}.featured-strip-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px}.featured-strip-label{color:var(--text-muted);font-family:Syne,sans-serif;font-size:.78rem;font-weight:800;letter-spacing:.09em;text-transform:uppercase}.strip-nav{display:flex;gap:6px}.strip-nav-btn{align-items:center;background:var(--card-background);border:1px solid var(--card-border);border-radius:50%;color:var(--text-color);cursor:pointer;display:flex;font-size:1rem;height:30px;justify-content:center;transition:all .2s;width:30px}.strip-nav-btn:hover{background:var(--primary-color);border-color:#0000;color:#fff}.featured-strip{-webkit-overflow-scrolling:touch;display:flex;gap:16px;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x mandatory;scrollbar-width:none}.featured-strip::-webkit-scrollbar{display:none}.strip-card{background:var(--card-background);border:1px solid var(--card-border);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);display:flex;flex-direction:column;flex-shrink:0;max-width:290px;min-width:270px;overflow:hidden;scroll-snap-align:start;transition:transform .25s var(--ease-out),box-shadow .25s}.strip-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}[data-theme=dark] .strip-card{border-color:#ffffff12}.strip-card-stripe{flex-shrink:0;height:3px}.strip-card-body{display:flex;flex:1 1;flex-direction:column;gap:7px;padding:14px}.strip-card-badges{align-items:center;display:flex;gap:7px}.strip-badge{border-radius:50px;font-size:.68rem;font-weight:800;letter-spacing:.04em;padding:2px 8px}.strip-status{color:var(--text-muted);font-size:.68rem}.strip-card-title{color:var(--text-color);font-family:Syne,sans-serif;font-size:.92rem;font-weight:700;line-height:1.3;margin:0}.strip-card-desc{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:var(--text-muted);display:-webkit-box;flex:1 1;font-size:.78rem;line-height:1.55;margin:0;overflow:hidden}.strip-card-footer{border-top:1px solid var(--card-border);display:flex;flex-direction:column;gap:8px;margin-top:auto;padding-top:10px}[data-theme=dark] .strip-card-footer{border-color:#ffffff0f}.strip-techs{display:flex;flex-wrap:wrap;gap:4px}.strip-tech{background:var(--background-color);border:1px solid var(--card-border);border-radius:50px;color:var(--text-muted);font-size:.68rem;padding:2px 7px}.strip-tech.muted{opacity:.5}.strip-links{display:flex;gap:6px}.strip-link-btn{align-items:center;border-radius:7px;color:#fff;display:inline-flex;font-size:.72rem;font-weight:700;gap:4px;padding:5px 10px;text-decoration:none;transition:opacity .2s,transform .15s}.strip-link-btn:hover{color:#fff;opacity:.85;transform:translateY(-1px)}.strip-link-btn.alt{background:#374151!important}@media (max-width:640px){.projects-grid{grid-template-columns:1fr}.filter-btn{padding:6px 13px}}.certs-wrapper{width:100%}.certs-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.cert-card{align-items:center;background:var(--background-color);border:1px solid var(--card-border);border-radius:var(--radius-md);color:var(--text-color);display:flex;gap:13px;padding:14px 16px;position:relative;text-decoration:none;transition:transform .2s var(--ease-spring),box-shadow .2s,border-color .2s}.cert-card:hover:not(.no-link){border-color:#0891b240;box-shadow:var(--shadow-md);transform:translateY(-3px)}.cert-card.no-link{cursor:default}[data-theme=dark] .cert-card{border-color:#ffffff12}.cert-logo{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:44px;justify-content:center;overflow:hidden;width:44px}.cert-logo img{filter:brightness(0) invert(1);height:26px;object-fit:contain;width:26px}.cert-logo span{font-size:1.3rem;line-height:1}.cert-info{flex:1 1;min-width:0}.cert-title{color:var(--text-color);font-size:.84rem;font-weight:700;line-height:1.3;margin:0 0 3px}.cert-issuer{color:var(--primary-color);font-size:.74rem;font-weight:700;margin:0 0 2px}.cert-date{color:var(--text-muted);font-size:.7rem;margin:0}.cert-arrow{color:var(--primary-color);flex-shrink:0;font-size:.8rem;opacity:.35;transition:opacity .2s,transform .2s}.cert-card:hover .cert-arrow{opacity:1;transform:translate(2px,-2px)}@media (max-width:600px){.certs-grid{grid-template-columns:1fr}}@media (max-width:480px){.certs-grid{grid-template-columns:1fr}.cert-card{padding:12px 14px}}.languages-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.lang-card{background:var(--background-color);border:1px solid var(--card-border);border-radius:var(--radius-md);padding:16px 18px;transition:box-shadow .2s,border-color .2s,transform .2s var(--ease-spring)}.lang-card:hover{border-color:#0891b240;box-shadow:var(--shadow-md);transform:translateY(-2px)}[data-theme=dark] .lang-card{border-color:#ffffff12}.lang-header{align-items:center;display:flex;gap:10px;margin-bottom:10px}.lang-emoji{font-size:1.25rem;line-height:1}.lang-name{color:var(--text-color);font-family:Syne,sans-serif;font-size:.95rem;font-weight:700;line-height:1.2}.lang-level{color:var(--primary-color);font-size:.7rem;font-weight:700;letter-spacing:.05em;margin-top:2px;text-transform:uppercase}.lang-bar-track{background:#0891b21f;border-radius:2px;height:3px;overflow:hidden}.lang-bar-fill{background:var(--gradient-primary);border-radius:2px;height:100%;transition:width .8s var(--ease-out)}@media (max-width:640px){.languages-grid{grid-template-columns:1fr 1fr}}@media (max-width:380px){.languages-grid{grid-template-columns:1fr}}.un-strip{align-items:center;background:linear-gradient(135deg,#003580,#0058b0);border-radius:var(--radius-md);box-shadow:0 4px 18px #00358038;color:#fff;display:flex;gap:14px;margin-bottom:24px;padding:16px 22px}.un-strip-icon{flex-shrink:0;font-size:1.8rem}.un-strip>div{display:flex;flex:1 1;flex-direction:column;gap:2px}.un-strip strong{font-size:.92rem;font-weight:800}.un-strip span{font-size:.78rem;opacity:.85}.un-strip-link{background:#ffffff2e;border-radius:50px;color:#fff;flex-shrink:0;font-size:.78rem;font-weight:700;padding:6px 12px;text-decoration:none;transition:background .2s;white-space:nowrap}.un-strip-link:hover{background:#ffffff47;color:#fff}.vol-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(270px,1fr))}.vol-card{background:var(--card-background);border:1px solid var(--card-border);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);display:flex;flex-direction:column;overflow:hidden;transition:transform .22s var(--ease-out),box-shadow .22s,border-color .22s}.vol-card:hover{border-color:#0891b22e;box-shadow:var(--shadow-md);transform:translateY(-3px)}.vol-card.featured{border-color:#0058b0;border-width:1.5px}[data-theme=dark] .vol-card{border-color:#ffffff12}[data-theme=dark] .vol-card.featured{border-color:#4a90d9}.vol-stripe{flex-shrink:0;height:3px;width:100%}.vol-body{display:flex;flex:1 1;flex-direction:column;gap:10px;padding:16px 18px 18px}.vol-header{align-items:flex-start;display:flex;gap:10px}.vol-org-icon{flex-shrink:0;font-size:1.5rem;line-height:1;margin-top:2px}.vol-header-text{flex:1 1}.vol-role{color:var(--text-color);font-family:Syne,sans-serif;font-size:.92rem;font-weight:700;line-height:1.3;margin:0 0 3px}.vol-org{color:var(--primary-color);font-size:.78rem;font-weight:700;margin:0}.cert-badge{flex-shrink:0;font-size:1.2rem;text-decoration:none;transition:transform .2s var(--ease-spring)}.cert-badge:hover{transform:scale(1.25) rotate(-5deg)}.vol-meta{flex-wrap:wrap;gap:7px}.vol-duration,.vol-meta{align-items:center;display:flex}.vol-duration{color:var(--text-muted);font-size:.74rem;gap:4px}.vol-hours{background:#0891b217;color:var(--primary-color);font-size:.72rem}.vol-category,.vol-hours{border-radius:50px;font-weight:700;padding:2px 8px}.vol-category{font-size:.7rem;letter-spacing:.02em}.vol-description{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:var(--text-muted);display:-webkit-box;font-size:.82rem;line-height:1.65;margin:0;overflow:hidden}.vol-description.open{-webkit-line-clamp:unset;display:block}.vol-toggle{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:.76rem;font-weight:700;margin-top:-4px;padding:0;transition:opacity .2s}.vol-toggle:hover{opacity:.75}.vol-links{display:flex;flex-wrap:wrap;gap:7px;margin-top:4px}.vol-link-btn{align-items:center;background:var(--primary-color);border-radius:8px;color:#fff;display:inline-flex;font-size:.75rem;font-weight:700;gap:5px;padding:6px 12px;text-decoration:none;transition:all .2s}.vol-link-btn:hover{color:#fff;opacity:.85;transform:translateY(-1px)}.vol-link-btn.alt{background:#374151}.vol-link-btn.outline{background:#0000;border:1.5px solid var(--primary-color);color:var(--primary-color)}.vol-link-btn.outline:hover{background:var(--primary-color);color:#fff}@media (max-width:640px){.vol-grid{grid-template-columns:1fr}.un-strip{flex-wrap:wrap;gap:10px}}@media (max-width:480px){.vol-grid{grid-template-columns:1fr}.vol-body{padding:14px 16px 16px}}.contact-wrapper,.volunteering-wrapper{display:flex;flex-direction:column;gap:20px}.contact-cta-card{background:var(--gradient-hero);border-radius:var(--radius-lg);overflow:hidden;padding:44px 40px;position:relative;text-align:center}.contact-cta-card:after,.contact-cta-card:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.contact-cta-card:before{background:#ffffff0d;height:280px;right:-80px;top:-100px;width:280px}.contact-cta-card:after{background:#ffffff0a;bottom:-60px;height:160px;left:-40px;width:160px}.contact-cta-glow{display:none}.contact-cta-content{position:relative;z-index:1}.contact-headline{color:#fff;font-family:Syne,sans-serif;font-size:clamp(1.4rem,3vw,1.75rem);font-weight:800;letter-spacing:-.03em;margin:0 0 10px}.contact-subline{color:#ffffffc7;font-size:.9rem;line-height:1.65;margin:0 auto 28px;max-width:420px}.contact-primary-btn{align-items:center;background:#fff;border-radius:50px;box-shadow:0 4px 20px #0003;color:#0e7490;color:var(--primary-dark,#0e7490);display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-size:.88rem;font-weight:800;gap:8px;padding:13px 28px;text-decoration:none;transition:transform .2s var(--ease-spring),box-shadow .25s}.contact-primary-btn:hover{box-shadow:0 10px 30px #00000040;color:#0e7490;color:var(--primary-dark,#0e7490);transform:translateY(-3px)}.contact-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.contact-item{align-items:center;background:var(--background-color);border:1px solid var(--card-border);border-radius:var(--radius-md);display:flex;gap:12px;padding:14px 16px;transition:box-shadow .2s,border-color .2s,transform .2s var(--ease-spring)}.contact-item:hover{border-color:#0891b233;box-shadow:var(--shadow-md);transform:translateY(-2px)}[data-theme=dark] .contact-item{border-color:#ffffff12}.contact-item-icon{align-items:center;border-radius:10px;color:#fff;display:flex;flex-shrink:0;height:38px;justify-content:center;width:38px}.email-icon{background:linear-gradient(135deg,#ea4335,#c5221f)}.phone-icon{background:linear-gradient(135deg,#25d366,#1da851)}.github-icon{background:linear-gradient(135deg,#333,#24292e)}.linktree-icon{background:linear-gradient(135deg,#43e55e,#31c14a)}[data-theme=dark] .github-icon{background:linear-gradient(135deg,#6e7681,#484f58)}.contact-item-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.contact-item-label{color:var(--text-muted);font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase}.contact-item-value{color:var(--text-color);font-size:.82rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-item-value.link{color:var(--primary-color);transition:color .2s}.contact-item-value.link:hover{color:var(--hover-color)}.contact-copy-btn{background:var(--background-color);border:1px solid var(--card-border);border-radius:8px;color:var(--text-muted);cursor:pointer;flex-shrink:0;font-size:.78rem;font-weight:700;padding:5px 9px;transition:background .2s,color .2s,border-color .2s,transform .15s}.contact-copy-btn:hover{background:#0891b214;border-color:#0891b233;color:var(--primary-color);transform:scale(1.05)}.contact-social-strip{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;padding-top:4px}.social-link{align-items:center;background:var(--card-background);border:1px solid var(--card-border);border-radius:50px;color:var(--text-muted);display:inline-flex;font-size:.8rem;font-weight:700;gap:6px;padding:8px 16px;text-decoration:none;transition:color .2s,border-color .2s,box-shadow .2s,transform .2s}.social-link:hover{border-color:#0891b24d;box-shadow:0 4px 14px #0891b21f;color:var(--primary-color);transform:translateY(-2px)}@media (max-width:600px){.contact-cta-card{padding:32px 20px}.contact-grid{grid-template-columns:1fr}}@media (max-width:480px){.contact-cta-card{padding:28px 16px}.contact-headline{font-size:1.25rem}}.availability-bar{align-items:center;background:#22c55e12;border:1px solid #22c55e33;border-radius:var(--radius-md);color:var(--text-color);display:flex;font-size:.82rem;font-weight:600;gap:10px;padding:12px 18px}[data-theme=dark] .availability-bar{background:#22c55e0f;border-color:#22c55e26}.avail-dot{animation:availPulse 2.2s ease-in-out infinite;background:#22c55e;border-radius:50%;box-shadow:0 0 0 0 #22c55e66;flex-shrink:0;height:9px;width:9px}@keyframes availPulse{0%,to{box-shadow:0 0 0 0 #22c55e66}50%{box-shadow:0 0 0 5px #22c55e00}}.scroll-to-top-button{align-items:center;background:var(--gradient-primary);border:none;border-radius:50%;bottom:28px;box-shadow:0 4px 16px #0891b259;color:#fff;cursor:pointer;display:flex;height:46px;justify-content:center;opacity:1;position:fixed;right:28px;transition:transform .25s var(--ease-spring),box-shadow .25s,opacity .25s;width:46px;z-index:900}.scroll-to-top-button:hover{box-shadow:0 8px 24px #0891b273;transform:translateY(-3px) scale(1.08)}.scroll-to-top-button:active{transform:scale(.95)}@media (max-width:768px){.scroll-to-top-button{bottom:20px;height:42px;right:16px;width:42px}}@media (max-width:480px){.scroll-to-top-button{bottom:16px;height:38px;right:12px;width:38px}}.dark-mode-toggle{align-items:center;background:var(--card-background);border:1px solid var(--card-border);border-radius:50%;box-shadow:var(--shadow-md);color:var(--text-muted);cursor:pointer;display:flex;height:40px;justify-content:center;position:fixed;right:20px;top:16px;transition:background .3s,box-shadow .3s,transform .25s var(--ease-spring),border-color .3s,color .3s;width:40px;z-index:1100}.dark-mode-toggle:hover{border-color:var(--primary-color);box-shadow:var(--shadow-lg);color:var(--primary-color);transform:scale(1.1) rotate(14deg)}.dark-mode-toggle svg{height:16px;width:16px}@media (max-width:768px){.dark-mode-toggle{background:var(--background-color);box-shadow:none;height:34px;right:62px;top:9px;width:34px}}@media (max-width:380px){.dark-mode-toggle{right:56px}}
/*# sourceMappingURL=main.c2e9b284.css.map*/