*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#060a14;--bg-secondary:#090e1c;--bg-card:#ffffff08;--bg-card-solid:#0d1424;--text:#dde6f5;--text-muted:#58698a;--accent:#6366f1;--accent-hover:#818cf8;--accent-2:#a78bfa;--accent-3:#34d399;--border:#ffffff12;--border-accent:#6366f166;--nav-bg:#060a14e0;--shadow-sm:0 1px 4px #00000080, 0 1px 2px #0006;--shadow-md:0 4px 20px #00000080, 0 1px 4px #0006;--shadow-lg:0 20px 60px #0009, 0 4px 20px #0006;--glow:#6366f14d;--sans:"Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--radius:10px;--radius-lg:16px;--radius-xl:24px}[data-theme=light]{--bg:#f4f7ff;--bg-secondary:#edf0fb;--bg-card:#ffffffbf;--bg-card-solid:#fff;--text:#0f172a;--text-muted:#64748b;--accent:#4f46e5;--accent-hover:#4338ca;--accent-2:#7c3aed;--accent-3:#059669;--border:#00000012;--border-accent:#4f46e54d;--nav-bg:#f4f7ffe6;--shadow-sm:0 1px 3px #00000012, 0 1px 2px #0000000d;--shadow-md:0 4px 16px #00000017, 0 2px 4px #0000000f;--shadow-lg:0 20px 60px #0000001f, 0 4px 16px #00000014;--glow:#4f46e52e}html{scroll-behavior:smooth}body{font-family:var(--sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(110% 55% at 50% -5%,#6366f124 0%,#0000 65%),linear-gradient(#ffffff06 1px,#0000 1px),linear-gradient(90deg,#ffffff06 1px,#0000 1px);background-position:top,0 0,0 0;background-repeat:no-repeat,repeat,repeat;background-size:100% 70vh,52px 52px,52px 52px;line-height:1.6}[data-theme=light] body{background-image:radial-gradient(110% 55% at 50% -5%,#4f46e514 0%,#0000 65%),linear-gradient(#0000000a 1px,#0000 1px),linear-gradient(90deg,#0000000a 1px,#0000 1px)}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}section:not(#hero){opacity:0;transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);transform:translateY(24px)}section:not(#hero).in-view{opacity:1;transform:translateY(0)}.skill-category,.project-entry,.timeline-item{opacity:0;transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1),border-color .25s,box-shadow .25s;transform:translateY(18px)}.skill-category.in-view,.project-entry.in-view,.timeline-item.in-view{opacity:1;transform:translateY(0)}.skill-category:first-child{transition-delay:40ms}.skill-category:nth-child(2){transition-delay:.11s}.skill-category:nth-child(3){transition-delay:.18s}.skill-category:nth-child(4){transition-delay:.25s}.skill-category:nth-child(5){transition-delay:.32s}.project-entry:first-child{transition-delay:0s}.project-entry:nth-child(2){transition-delay:.1s}.timeline-item:first-child{transition-delay:50ms}.timeline-item:nth-child(2){transition-delay:.18s}.timeline-item:nth-child(3){transition-delay:.31s}.timeline-item:nth-child(4){transition-delay:.44s}.portfolio{min-height:100svh;position:relative}.bg-orbs{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.orb{border-radius:50%;position:absolute}.orb-1{filter:blur(90px);background:radial-gradient(circle,#6366f12e 0%,#0000 70%);width:900px;height:900px;animation:22s ease-in-out infinite orbFloat;top:-25%;right:-15%}.orb-2{filter:blur(100px);background:radial-gradient(circle,#a78bfa24 0%,#0000 70%);width:650px;height:650px;animation:28s ease-in-out infinite reverse orbFloat;bottom:10%;left:-12%}.orb-3{filter:blur(85px);background:radial-gradient(circle,#34d39917 0%,#0000 70%);width:500px;height:500px;animation:24s ease-in-out 7s infinite orbFloat;top:50%;right:18%}@keyframes orbFloat{0%,to{transform:translate(0)scale(1)}25%{transform:translate(60px,-80px)scale(1.07)}50%{transform:translate(-50px,60px)scale(.93)}75%{transform:translate(80px,40px)scale(1.04)}}@media (prefers-color-scheme:light){.orb-1{background:radial-gradient(circle,#4f46e51a 0%,#0000 70%)}.orb-2{background:radial-gradient(circle,#7c3aed14 0%,#0000 70%)}.orb-3{background:radial-gradient(circle,#05966912 0%,#0000 70%)}}.navbar{z-index:100;background:var(--nav-bg);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border);white-space:nowrap;border-radius:100px;align-items:center;max-width:calc(100vw - 2rem);display:flex;position:fixed;top:1.25rem;left:50%;transform:translate(-50%);box-shadow:0 8px 40px #00000059,inset 0 1px #ffffff0f}.nav-brand{color:var(--text);letter-spacing:.04em;flex-shrink:0;padding:.6rem 1.1rem .6rem 1.4rem;font-size:.875rem;font-weight:800;text-decoration:none;transition:color .2s}.nav-brand:hover{color:var(--accent)}.nav-divider{background:var(--border);flex-shrink:0;width:1px;height:18px}.nav-theme-toggle{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:.6rem .9rem .6rem .6rem;transition:color .2s;display:flex}.nav-theme-toggle svg{width:15px;height:15px}.nav-theme-toggle:hover{color:var(--accent)}.nav-toggle{cursor:pointer;background:0 0;border:none;flex-direction:column;flex-shrink:0;gap:5px;padding:.6rem 1.4rem .6rem 1rem;display:none}.nav-toggle span{background:var(--text);border-radius:2px;width:20px;height:1.5px;transition:transform .25s,opacity .25s;display:block}.nav-toggle.open span:first-child{transform:rotate(45deg)translate(4.5px,4.5px)}.nav-toggle.open span:nth-child(2){opacity:0}.nav-toggle.open span:nth-child(3){transform:rotate(-45deg)translate(4.5px,-4.5px)}.nav-links{list-style:none;display:flex}.nav-links a{color:var(--text-muted);letter-spacing:.01em;padding:.6rem .9rem;font-size:.82rem;font-weight:500;transition:color .2s;display:block}.nav-links a:hover{color:var(--text)}.nav-links a.active{color:var(--accent)}.nav-cv-link{color:var(--accent);letter-spacing:.01em;flex-shrink:0;padding:.6rem .9rem;font-size:.82rem;font-weight:600;text-decoration:none;transition:color .2s}.nav-cv-link:hover{color:var(--accent-hover)}section{z-index:1;padding:7rem 2rem;position:relative}.section-inner{max-width:1100px;margin:0 auto}.section-title{color:var(--text);letter-spacing:-.025em;margin-bottom:3rem;font-size:clamp(1.8rem,4vw,2.5rem);font-weight:800;line-height:1.15}.section-title:after{content:"";background:linear-gradient(90deg, var(--accent), var(--accent-2), transparent);border-radius:2px;width:3rem;height:3px;margin-top:.625rem;display:block}#hero{flex-direction:column;min-height:100svh;padding:0;display:flex}.hero-main{flex:1;align-items:center;padding:7rem 2rem 4rem;display:flex}.hero-content{align-items:center;gap:5rem;width:100%;max-width:1100px;margin:0 auto;display:flex}.hero-text{flex:1;min-width:0}.hero-status{letter-spacing:.06em;text-transform:uppercase;color:var(--accent-3);background:#34d39914;border:1px solid #34d39933;border-radius:100px;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.3rem .875rem;font-size:.7rem;font-weight:600;display:inline-flex}@media (prefers-color-scheme:light){.hero-status{background:#05966912;border-color:#05966933}}.hero-status-dot{background:var(--accent-3);border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:2.5s ease-in-out infinite statusPulse}@keyframes statusPulse{0%,to{box-shadow:0 0 #34d39980}60%{box-shadow:0 0 0 5px #34d39900}}.hero-eyebrow{color:var(--text-muted);margin-bottom:.3rem;font-size:1rem;font-weight:400}#hero h1{letter-spacing:-.03em;background:linear-gradient(135deg, var(--text) 25%, var(--accent-2) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .6rem;font-size:clamp(2.75rem,7vw,5rem);font-weight:900;line-height:1.04}#hero h2{color:var(--text-muted);letter-spacing:-.01em;margin:0 0 1.5rem;font-size:clamp(1.05rem,2.5vw,1.45rem);font-weight:500}.hero-description{color:var(--text-muted);max-width:520px;margin:0 0 2.5rem;font-size:1rem;line-height:1.85}.hero-description strong{color:var(--text);font-weight:600}.hero-actions{flex-wrap:wrap;gap:.875rem;display:flex}.hero-avatar{flex-shrink:0}.hero-avatar-ring{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 55%, var(--accent-3) 100%);border-radius:50%;width:300px;height:300px;padding:3px;animation:6s ease-in-out infinite avatarFloat;box-shadow:0 0 0 1px #ffffff0d,0 30px 80px #6366f147,0 0 60px #a78bfa1f}.hero-avatar-img{object-fit:cover;object-position:center top;border:4px solid var(--bg);border-radius:50%;width:100%;height:100%;display:block}@keyframes avatarFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.btn{cursor:pointer;letter-spacing:.01em;border:1.5px solid #0000;border-radius:100px;align-items:center;padding:.75rem 1.75rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .22s cubic-bezier(.16,1,.3,1);display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;box-shadow:0 4px 20px #6366f161}.btn-primary:hover{color:#fff;transform:translateY(-2px);box-shadow:0 8px 32px #6366f18c}.btn-outline{border-color:var(--border);color:var(--text-muted);background:var(--bg-card);-webkit-backdrop-filter:blur(8px)}.btn-outline:hover{border-color:var(--border-accent);color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 20px #6366f11f}#skills{background:#6366f105}@media (prefers-color-scheme:light){#skills{background:#4f46e505}}.skill-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem;display:grid}.skill-block{background:var(--bg-card);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem 1.75rem}.skill-block--featured{grid-column:1/-1}.skill-block-title{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:1.25rem;font-size:.65rem;font-weight:700}.skill-subcategories{grid-template-columns:repeat(4,1fr);gap:.5rem 2.5rem;display:grid}.skill-subcat-stacked{margin-top:1.1rem;padding-top:1rem}.skill-subcat-title{color:var(--text-muted);letter-spacing:.04em;border-bottom:1px solid var(--border);margin-bottom:.5rem;padding-bottom:.4rem;font-size:.72rem;font-weight:600}.skill-row{border-radius:6px;justify-content:space-between;align-items:center;gap:.5rem;margin:0 -.5rem;padding:.35rem .5rem;transition:background .18s;display:flex}.skill-row:hover{background:#6366f10f}.skill-name{color:var(--text);white-space:nowrap;font-size:.875rem;font-weight:400}.skill-dots{flex-shrink:0;align-items:center;gap:4px;display:flex}.skill-dot{background:var(--border);border:1px solid #ffffff14;border-radius:50%;width:7px;height:7px;transition:background .18s,box-shadow .18s}.skill-dot--filled{background:var(--accent);border-color:var(--accent);box-shadow:0 0 5px #6366f173}@media (prefers-color-scheme:light){.skill-dot{background:#0000001a;border-color:#00000014}.skill-row:hover{background:#4f46e50d}}.projects-list{max-width:1100px;margin:2rem auto 0}.project-entry{padding:5rem 0}.project-entry+.project-entry{border-top:1px solid var(--border)}.project-entry-inner{grid-template-columns:55% 1fr;gap:4rem;display:grid}.project-entry--reverse .project-carousel{order:2}.project-entry--reverse .project-content{order:1}.project-carousel{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);background:var(--bg-card-solid);border:1px solid var(--border);position:relative;overflow:hidden}.carousel-frame{aspect-ratio:16/10;position:relative}.carousel-img{object-fit:cover;width:100%;height:100%;animation:.35s fadeIn;display:block}.carousel-btn{-webkit-backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:2;background:#00000080;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;padding-bottom:1px;font-size:1.3rem;line-height:1;transition:background .2s,transform .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.carousel-btn:hover{background:#000000bf;transform:translateY(-50%)scale(1.1)}.carousel-btn--prev{left:.875rem}.carousel-btn--next{right:.875rem}.carousel-dots{z-index:2;gap:6px;display:flex;position:absolute;bottom:.875rem;left:50%;transform:translate(-50%)}.carousel-dot{cursor:pointer;background:#ffffff59;border:none;border-radius:50%;width:6px;height:6px;padding:0;transition:background .2s,transform .2s}.carousel-dot.active{background:#fff;transform:scale(1.5)}.project-content{flex-direction:column;justify-content:center;gap:1.25rem;display:flex}.project-number{letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-size:.68rem;font-weight:700}.project-entry .project-title{color:var(--text);letter-spacing:-.02em;margin:0;font-size:1.9rem;font-weight:800;line-height:1.15}.project-entry .project-desc{color:var(--text-muted);margin:0;font-size:.92rem;line-height:1.85}.project-tags{flex-wrap:wrap;gap:.4rem;display:flex}.tag{color:var(--accent);letter-spacing:.01em;background:#6366f114;border:1px solid #6366f12e;border-radius:100px;padding:.22rem .65rem;font-size:.72rem;font-weight:600;display:inline-block}.timeline-tech{border-top:1px solid var(--border);flex-wrap:wrap;gap:.4rem;margin-top:1rem;padding-top:.875rem;display:flex}.project-actions{flex-wrap:wrap;gap:.75rem;padding-top:.25rem;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.timeline{flex-direction:column;padding-left:2rem;display:flex;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, var(--accent), #6366f10f);border-radius:2px;width:2px;position:absolute;top:.5rem;bottom:.5rem;left:0}.timeline-item{padding-bottom:2rem;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-marker{background:var(--accent);border:2px solid var(--bg);width:10px;height:10px;box-shadow:0 0 0 2px var(--accent), 0 0 10px #6366f173;border-radius:50%;position:absolute;top:.5rem;left:-2.28rem}.timeline-item:first-child .timeline-marker{animation:3s ease-in-out infinite markerPulse}@keyframes markerPulse{0%,to{box-shadow:0 0 0 2px var(--accent), 0 0 8px #6366f166}50%{box-shadow:0 0 0 2px var(--accent), 0 0 22px #6366f1bf, 0 0 35px #6366f140}}.timeline-body{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm), inset 0 1px 0 #ffffff0a;padding:1.5rem;transition:border-color .25s,box-shadow .25s}.timeline-body:hover{border-color:var(--border-accent);box-shadow:var(--shadow-md), 0 0 30px #6366f10f}.timeline-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.timeline-role{color:var(--text);letter-spacing:-.01em;margin:0 0 .25rem;font-size:1rem;font-weight:700}.timeline-company{color:var(--accent);margin:0;font-size:.85rem;font-weight:600}.timeline-period{color:var(--accent);white-space:nowrap;background:#6366f114;border:1px solid #6366f126;border-radius:100px;flex-shrink:0;height:fit-content;padding:.22rem .65rem;font-size:.72rem;font-weight:600}.timeline-description{flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.timeline-description li{color:var(--text-muted);padding-left:1rem;font-size:.875rem;line-height:1.65;position:relative}.timeline-description li:before{content:"–";color:var(--accent);position:absolute;left:0}.timeline-details{grid-template-rows:0fr;transition:grid-template-rows .35s cubic-bezier(.16,1,.3,1);display:grid}.timeline-details--open{grid-template-rows:1fr}.timeline-details-inner{overflow:hidden}.timeline-details-divider{background:var(--border);height:1px;margin:1rem 0}.timeline-details-list{padding-bottom:.25rem}.timeline-expand-btn{cursor:pointer;color:var(--accent);letter-spacing:.01em;background:0 0;border:none;align-items:center;gap:.4rem;margin-top:1rem;padding:0;font-size:.78rem;font-weight:600;transition:color .2s,gap .2s;display:inline-flex}.timeline-expand-btn:hover{color:var(--accent-hover)}.expand-chevron{flex-shrink:0;transition:transform .3s}.expand-chevron--open{transform:rotate(180deg)}.timeline-body--clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.timeline-body--open{border-color:var(--border-accent)}#contact{background:#6366f106}@media (prefers-color-scheme:light){#contact{background:#4f46e506}}.contact-inner{text-align:center}.contact-inner .section-title:after{margin-left:auto;margin-right:auto}.contact-description{color:var(--text-muted);max-width:460px;margin:0 auto 2.5rem;font-size:1rem;line-height:1.8}.contact-links{flex-wrap:wrap;justify-content:center;gap:.875rem;display:flex}.footer{text-align:center;border-top:1px solid var(--border);color:var(--text-muted);z-index:1;letter-spacing:.01em;padding:2rem;font-size:.8rem;position:relative}.footer a{color:var(--text-muted);transition:color .2s}.footer a:hover{color:var(--accent)}.lightbox-overlay{z-index:200;-webkit-backdrop-filter:blur(6px);background:#000000eb;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.lightbox-content{justify-content:center;align-items:center;max-width:90vw;max-height:90vh;display:flex;position:relative}.lightbox-img{border-radius:var(--radius-lg);object-fit:contain;width:auto;max-width:90vw;height:auto;max-height:88vh;animation:.25s cubic-bezier(.16,1,.3,1) lightboxIn;display:block;box-shadow:0 30px 80px #000c}@keyframes lightboxIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.lightbox-close{color:#fff;cursor:pointer;z-index:201;background:#ffffff14;border:1px solid #ffffff1f;border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-size:1.5rem;line-height:1;transition:background .2s;display:flex;position:fixed;top:1.25rem;right:1.5rem}.lightbox-close:hover{background:#ffffff29}.lightbox-nav{color:#fff;cursor:pointer;background:#ffffff14;border:1px solid #ffffff1f;border-radius:50%;justify-content:center;align-items:center;width:3rem;height:3rem;padding-bottom:2px;font-size:2rem;line-height:1;transition:background .2s,transform .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-nav:hover{background:#ffffff2e;transform:translateY(-50%)scale(1.08)}.lightbox-nav--prev{right:calc(100% + 1.25rem)}.lightbox-nav--next{left:calc(100% + 1.25rem)}.lightbox-counter{color:#ffffff73;letter-spacing:.06em;white-space:nowrap;font-size:.78rem;font-weight:500;position:absolute;bottom:-2.25rem;left:50%;transform:translate(-50%)}.carousel-img--zoomable{cursor:zoom-in}@media (width<=640px){.navbar{box-shadow:0 1px 0 var(--border), 0 8px 24px #00000040;border-top:none;border-left:none;border-right:none;border-radius:0;justify-content:space-between;max-width:100%;padding:0;top:0;left:0;right:0;transform:none}.nav-brand{border-right:none;padding:.9rem 1.25rem}.nav-divider{display:none}.nav-toggle{padding:.9rem 1.25rem;display:flex}.nav-links{background:var(--nav-bg);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border);flex-direction:column;max-height:0;transition:max-height .3s;position:absolute;top:100%;left:0;right:0;overflow:hidden}.nav-links.nav-open{max-height:300px}.nav-links li{border-top:1px solid var(--border)}.nav-links li a,.nav-links li:last-child a{border-radius:0;padding:.9rem 1.25rem;font-size:.95rem;display:block}.nav-cv-link,.nav-theme-toggle{padding:.9rem 1rem}section{padding:5rem 1.25rem}.hero-main{padding:6rem 1.25rem 3rem}.hero-content{text-align:center;flex-direction:column-reverse;gap:2.5rem}.hero-status{margin-left:auto;margin-right:auto}.hero-description{max-width:none;margin-left:auto;margin-right:auto}.hero-actions{justify-content:center}.hero-avatar-ring{width:190px;height:190px}.skill-grid{grid-template-columns:1fr;gap:1rem}.skill-subcategories{grid-template-columns:repeat(2,1fr);gap:.5rem 1.5rem}.project-entry-inner{grid-template-columns:1fr;gap:2rem}.project-entry--reverse .project-carousel,.project-entry--reverse .project-content{order:unset}.project-entry{padding:3rem 0}.project-entry .project-title{font-size:1.45rem}.timeline-header{flex-direction:column;gap:.35rem}.timeline-period{align-self:flex-start}}@media (width<=900px) and (width>=641px){.skill-grid{grid-template-columns:repeat(2,1fr)}.skill-subcategories{grid-template-columns:repeat(2,1fr);gap:.5rem 1.5rem}.project-entry-inner{grid-template-columns:1fr 1fr;gap:2.5rem}.project-entry .project-title{font-size:1.5rem}}
