.navbar{z-index:50;background:color-mix(in srgb,var(--bg)88%,transparent);-webkit-backdrop-filter:blur(18px);width:100%;padding:1.25rem 3rem .75rem;position:sticky;top:0}.navbar__inner{justify-content:space-between;align-items:center;gap:1.5rem;max-width:1380px;margin:0 auto;display:flex}.navbar__logo{font-family:var(--font-heading),Sora,sans-serif;letter-spacing:-.02em;white-space:nowrap;color:var(--text);font-size:1.05rem;font-weight:700}.navbar__center{align-items:center;gap:.4rem;display:flex}.navbar__link{color:var(--muted);border-radius:14px;padding:.65rem .9rem;font-size:.92rem;font-weight:500;transition:all .25s}.navbar__link:hover{color:var(--text);background:var(--surface)}.navbar__actions{align-items:center;gap:1rem;display:flex}.theme-toggle{background:var(--surface);border:1px solid var(--line);cursor:pointer;border-radius:999px;align-items:center;gap:.5rem;padding:.4rem .65rem;transition:background .2s;display:flex}.theme-toggle:hover{background:#8b6fb81f}.theme-toggle__icon{font-size:.95rem;line-height:1}.theme-toggle__track{background:#8b6fb84d;border-radius:999px;width:34px;height:18px;display:inline-block;position:relative}.theme-toggle__thumb{background:var(--highlight);border-radius:999px;width:14px;height:14px;transition:transform .25s;position:absolute;top:2px;left:2px}.theme-toggle__thumb.is-light{transform:translate(16px)}@media (max-width:1100px){.navbar{padding:1.1rem 1.5rem 0}.navbar__center{display:none}}
.hero{grid-template-columns:48fr 52fr;align-items:center;column-gap:2rem;max-width:1380px;height:calc(100vh - 72px);max-height:900px;margin:0 auto;padding:1rem 3rem 1.5rem;display:grid;overflow:hidden}.hero__left{align-items:center;width:100%;height:100%;display:flex}.workspace-illustration{object-fit:contain;width:100%;height:100%;max-height:calc(100vh - 120px)}.led-blink{animation:2.4s ease-in-out infinite led-pulse}.led-blink--delay{animation-delay:.9s}@keyframes led-pulse{0%,to{opacity:.4}50%{opacity:1}}.lamp-glow{transition:opacity .4s}.pull-cord{-webkit-user-select:none;user-select:none}html[data-theme=light] .lamp-glow{opacity:0}html[data-theme=light] .lamp__bulb{opacity:.15;fill:var(--muted-2)}.robotic-arm__lower{transition:transform .6s cubic-bezier(.34,1.56,.64,1)}.robotic-arm__upper{transition:transform .6s cubic-bezier(.34,1.56,.64,1) 80ms}.robotic-arm__claw{transition:transform .6s cubic-bezier(.34,1.56,.64,1) .16s}.robotic-arm__lower{transform:rotate(-10deg)}.robotic-arm__upper{transform:rotate(18deg)}.robotic-arm__claw{transform:rotate(-6deg)}html[data-theme=light] .robotic-arm__lower{transform:rotate(22deg)}html[data-theme=light] .robotic-arm__upper{transform:rotate(-18deg)}html[data-theme=light] .robotic-arm__claw{transform:rotate(8deg)}.hero__right{width:100%;max-width:600px;margin-left:auto}.hero__greeting{color:var(--accent-2);margin-bottom:1.25rem;font-size:1rem;font-weight:600}.hero__title{letter-spacing:-.03em;color:var(--text);margin-bottom:1.5rem;font-size:clamp(2rem,3.6vw,3.6rem);font-weight:700;line-height:1.1}.hero__intro{max-width:560px;color:var(--muted);margin-bottom:2rem;font-size:.97rem;line-height:1.75}.hero__buttons{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.hero__primary-btn,.hero__secondary-btn{border-radius:16px;justify-content:center;align-items:center;gap:.6rem;min-height:54px;padding:0 1.6rem;font-size:.98rem;font-weight:600;transition:all .2s;display:inline-flex}.hero__primary-btn{color:#fff;background:linear-gradient(135deg,var(--accent)0%,var(--accent-2)100%);box-shadow:0 10px 28px #8b6fb859}.hero__primary-btn:hover{transform:translateY(-1px)}.hero__secondary-btn{color:var(--text);border:1px solid var(--line);background:var(--surface)}.hero__secondary-btn:hover{background:#8b6fb81f}@media (max-width:1100px){.hero{grid-template-columns:1fr;row-gap:2.5rem;padding:1.5rem 1.75rem 3rem}.hero__left{justify-content:center;display:flex}.workspace-illustration{max-width:380px}.hero__right{max-width:100%}}@media (max-width:600px){.hero__buttons{width:100%}.hero__primary-btn,.hero__secondary-btn{flex:1}}
.about{padding:6rem 3rem 5rem}.about__container{max-width:1100px;margin:0 auto}.about__label{letter-spacing:.22em;color:var(--accent-2);margin-bottom:1rem;font-size:.74rem;display:inline-block}.about__title{font-family:var(--font-heading),Sora,sans-serif;letter-spacing:-.02em;color:var(--text);margin-top:0;margin-bottom:0;font-size:clamp(2rem,3.5vw,3rem);font-weight:700}.about__body{grid-template-columns:1fr 320px;align-items:start;gap:3.5rem;display:grid}.about__text{flex-direction:column;gap:1.4rem;display:flex}.about__text p{color:var(--muted);font-size:1.02rem;line-height:1.82}.about__sidebar{flex-direction:column;gap:1.25rem;display:flex;position:sticky;top:6rem}.about__headshot-wrap{border:3px solid var(--accent);border-radius:50%;flex-shrink:0;width:110px;height:110px;margin:0 auto .5rem;overflow:hidden}.about__headshot{object-fit:cover;width:100%;height:100%;display:block}.about__card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:1.6rem 1.75rem}.about__card-label{letter-spacing:.18em;color:var(--accent);text-transform:uppercase;margin-bottom:.85rem;font-size:.7rem}.about__card-title{font-family:var(--font-heading),Sora,sans-serif;color:var(--text);margin-bottom:.55rem;font-size:1.05rem;font-weight:600;line-height:1.45}.about__card-school{color:var(--muted);margin-bottom:.2rem;font-size:.9rem}.about__card-year{color:var(--muted-2);font-size:.85rem}.about__spec-list{flex-direction:column;gap:.6rem;list-style:none;display:flex}.about__spec-list li{color:var(--text);align-items:center;gap:.6rem;font-size:.95rem;display:flex}.about__spec-list li:before{content:"";background:var(--highlight);border-radius:999px;flex-shrink:0;width:6px;height:6px;display:inline-block}@media (max-width:900px){.about{padding:4rem 1.75rem}.about__body{grid-template-columns:1fr;gap:2.5rem}.about__sidebar{flex-flow:wrap;position:static}.about__card{flex:260px}}@media (max-width:560px){.about__sidebar{flex-direction:column}}
.projects{padding:6rem 3rem 5rem}.projects__container{max-width:1100px;margin:0 auto}.projects__label{letter-spacing:.22em;color:var(--accent-2);margin-bottom:1rem;font-size:.74rem;display:inline-block}.projects__title{font-family:var(--font-heading),Sora,sans-serif;letter-spacing:-.02em;color:var(--text);margin-bottom:1rem;font-size:clamp(2rem,3.5vw,3rem);font-weight:700}.projects__caption{color:var(--muted);max-width:580px;margin-bottom:2.5rem;font-size:1rem;line-height:1.75}.projects__filters{flex-wrap:wrap;gap:.6rem;margin-bottom:4rem;display:flex}.projects__filter-btn{border:1px solid var(--line);background:var(--surface);color:var(--muted);cursor:pointer;border-radius:999px;padding:.5rem 1.1rem;font-size:.88rem;font-weight:500;transition:background .18s,color .18s,border-color .18s}.projects__filter-btn:hover{color:var(--text);background:#8b6fb81a}.projects__filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.projects__list{flex-direction:column;gap:3rem;display:flex}.project-card{border:1px solid var(--line);background:var(--surface);border-radius:20px;flex-direction:row;min-height:420px;display:flex;overflow:hidden}.project-card--reverse{flex-direction:row-reverse}.project-card__image{background:#0003;flex:0 0 50%;min-height:360px;position:relative;overflow:hidden}.project-card__image-placeholder{border-right:1px solid var(--line);background:linear-gradient(135deg,#8b6fb814,#5fa8ff0f);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.project-card__image-placeholder span{color:var(--muted-2);letter-spacing:.08em;font-size:.8rem}.project-card__carousel{position:absolute;inset:0;overflow:hidden}.project-card__carousel-track{width:100%;height:100%;display:flex}.project-card__carousel-img{object-fit:cover;flex-shrink:0;width:100%;height:100%;display:block}.project-card__carousel-btn{color:#fff;cursor:pointer;opacity:0;z-index:2;background:#00000073;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.4rem;line-height:1;transition:opacity .2s,background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.project-card__image:hover .project-card__carousel-btn,.project-card__image:hover .project-card__carousel-dots{opacity:1}.project-card__carousel-btn:hover{background:#8b6fb8b3}.project-card__carousel-btn--prev{left:10px}.project-card__carousel-btn--next{right:10px}.project-card__carousel-dots{z-index:2;opacity:0;gap:6px;transition:opacity .2s;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.project-card__carousel-dot{cursor:pointer;background:#fff6;border-radius:50%;width:7px;height:7px;transition:background .2s}.project-card__carousel-dot.active{background:var(--accent)}.project-card__body{flex-direction:column;flex:0 0 50%;gap:1rem;padding:2.25rem 2.5rem;display:flex}.project-card__top{justify-content:space-between;align-items:center;display:flex}.project-card__tags{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.project-card__tag{letter-spacing:.12em;text-transform:uppercase;color:var(--accent-2);border:1px solid #5fa8ff4d;border-radius:999px;padding:.25rem .65rem;font-size:.7rem;font-weight:600}.project-card__github{color:var(--muted);flex-shrink:0;transition:color .2s}.project-card__github:hover{color:var(--text)}.project-card__title{font-family:var(--font-heading),Sora,sans-serif;letter-spacing:-.02em;color:var(--text);font-size:clamp(1.25rem,1.8vw,1.65rem);font-weight:700;line-height:1.2}.project-card__active-wrap{cursor:default;align-items:center;margin-top:1px;display:inline-flex;position:relative}.project-card__active-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:1.8s ease-in-out infinite active-pulse;display:inline-block}.project-card__active-tip{background:var(--accent);color:#fff;white-space:nowrap;pointer-events:none;opacity:0;border-radius:8px;padding:.3rem .65rem;font-size:.72rem;font-weight:600;transition:opacity .15s,transform .15s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(4px)}.project-card__active-tip:after{content:"";border:5px solid #0000;border-top-color:var(--accent);position:absolute;top:100%;left:50%;transform:translate(-50%)}.project-card__active-wrap:hover .project-card__active-tip{opacity:1;transform:translate(-50%)translateY(0)}@keyframes active-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.7)}}.project-card__description{color:var(--muted);flex:1;font-size:.97rem;line-height:1.78}.project-card__actions{align-items:center;gap:1.25rem;display:flex}.project-card__progress{flex:1;padding:.5rem 0}.project-card__progress-track{background:var(--line);border-radius:999px;height:3px;position:relative}.project-card__progress-fill{background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:999px;height:100%;position:absolute;top:0;left:0}.project-card__progress-thumb{position:absolute;top:50%;transform:translate(-50%,-50%)}.project-card__progress-tip{background:var(--accent);color:#fff;white-space:nowrap;opacity:0;pointer-events:none;border-radius:8px;padding:.25rem .55rem;font-size:.72rem;font-weight:700;transition:opacity .15s,transform .15s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(4px)}.project-card__progress-tip:after{content:"";border:5px solid #0000;border-top-color:var(--accent);position:absolute;top:100%;left:50%;transform:translate(-50%)}.project-card__progress-track:hover .project-card__progress-tip,.project-card__actions:hover .project-card__progress-tip{opacity:1;transform:translate(-50%)translateY(0)}.project-card__case-btn{color:var(--accent);border:1px solid #8b6fb866;border-radius:10px;align-items:center;gap:.45rem;width:fit-content;padding:.6rem 1.1rem;font-size:.9rem;font-weight:600;transition:background .2s,color .2s;display:inline-flex}.project-card__case-btn:hover{background:#8b6fb81f}.project-card__stack{flex-wrap:wrap;gap:.45rem;margin-top:.25rem;display:flex}.project-card__stack-item{color:var(--muted-2);border:1px solid var(--line);background:#ffffff0a;border-radius:6px;padding:.22rem .55rem;font-size:.75rem;font-weight:500}@media (max-width:860px){.projects{padding:4rem 1.75rem}.project-card{grid-template-columns:1fr}.project-card--reverse{direction:ltr}.project-card__image{min-height:220px}.project-card__image-placeholder{border-left:none;border-right:none;border-bottom:1px solid var(--line)}}
.work{padding:6rem 3rem 5rem}.work__container{max-width:1100px;margin:0 auto}.work__label{letter-spacing:.22em;color:var(--accent-2);margin-bottom:1rem;font-size:.74rem;display:inline-block}.work__title{font-family:var(--font-heading),Sora,sans-serif;letter-spacing:-.02em;color:var(--text);margin-bottom:3.5rem;font-size:clamp(2rem,3.5vw,3rem);font-weight:700}.work__timeline{flex-direction:column;display:flex}.work__entry{grid-template-columns:220px 40px 1fr;gap:0 1.5rem;display:grid;position:relative}.work__meta{text-align:right;padding-top:.2rem;padding-bottom:3rem}.work__period{color:var(--muted-2);margin-bottom:.35rem;font-size:.85rem}.work__company{font-family:var(--font-heading),Sora,sans-serif;color:var(--text);margin-bottom:.25rem;font-size:1.05rem;font-weight:700}.work__location{color:var(--muted-2);margin-bottom:.75rem;font-size:.82rem}.work__badge{color:var(--highlight);border:1px solid #6ee7d866;border-radius:999px;align-items:center;gap:.4rem;padding:.25rem .7rem;font-size:.75rem;font-weight:600;display:inline-flex}.work__badge-dot{background:var(--highlight);border-radius:999px;width:6px;height:6px;animation:2s ease-in-out infinite led-pulse}.work__line-col{flex-direction:column;align-items:center;display:flex}.work__dot{background:var(--accent);border:2px solid var(--bg);width:14px;height:14px;box-shadow:0 0 0 2px var(--accent);z-index:1;border-radius:999px;flex-shrink:0;margin-top:.3rem}.work__line{background:var(--line);flex:1;width:2px;margin-top:6px}.work__entry:last-child .work__line{display:none}.work__body{padding-bottom:3.5rem}.work__role{font-family:var(--font-heading),Sora,sans-serif;color:var(--text);margin-bottom:1.1rem;font-size:clamp(1.2rem,1.8vw,1.5rem);font-weight:700;line-height:1.25}.work__bullets{flex-direction:column;gap:.75rem;margin-bottom:1.5rem;list-style:none;display:flex}.work__bullets li{color:var(--muted);padding-left:1.1rem;font-size:.97rem;line-height:1.75;position:relative}.work__bullets li:before{content:"–";color:var(--accent);position:absolute;left:0}.work__tags{flex-wrap:wrap;gap:.45rem;display:flex}.work__tag{color:var(--muted);border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:.22rem .65rem;font-size:.78rem;font-weight:500}@media (max-width:860px){.work{padding:4rem 1.75rem}.work__entry{grid-template-rows:auto 1fr;grid-template-columns:40px 1fr}.work__meta{text-align:left;grid-column:1/-1;padding-bottom:1rem}.work__line-col{grid-area:2/1}.work__body{grid-area:2/2}}@media (max-width:560px){.work__entry{grid-template-columns:28px 1fr}}
.skills{padding:6rem 3rem 5rem}.skills__container{max-width:1100px;margin:0 auto}.skills__label{letter-spacing:.22em;color:var(--accent-2);margin-bottom:1rem;font-size:.74rem;display:inline-block}.skills__title{font-family:var(--font-heading),Sora,sans-serif;letter-spacing:-.02em;color:var(--text);margin-bottom:2.25rem;font-size:clamp(2rem,3.5vw,3rem);font-weight:700}.skills__tabs{flex-wrap:wrap;gap:.55rem;margin-bottom:3rem;display:flex}.skills__tab{border:1px solid var(--line);background:var(--surface);color:var(--muted);cursor:pointer;white-space:nowrap;border-radius:999px;padding:.5rem 1.15rem;font-size:.88rem;font-weight:500;transition:background .18s,color .18s,border-color .18s}.skills__tab:hover{color:var(--text);background:#8b6fb81a}.skills__tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.skills__grid{grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:1.1rem;display:grid}.skill-card{border:1px solid var(--line);background:var(--surface);cursor:default;border-radius:18px;flex-direction:column;align-items:center;gap:1rem;padding:2rem 1.25rem;transition:transform .2s,border-color .2s,background .2s;display:flex}.skill-card:hover{background:#8b6fb80f;border-color:#8b6fb859;transform:translateY(-3px)}.skill-card__icon{width:104px;height:104px;font-size:.9rem;font-weight:700;font-family:var(--font-heading),Sora,monospace;letter-spacing:-.01em;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.skill-card__name{color:var(--text);text-align:center;font-size:.9rem;font-weight:600;line-height:1.3}.skills__ticker-wrap{flex-direction:column;gap:1.25rem;margin-top:4rem;display:flex;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 8% 92%,#0000 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 8% 92%,#0000 100%)}.skills__ticker{gap:.65rem;width:max-content;padding:4px 0;animation:60s linear infinite ticker-scroll;display:flex}.skills__ticker--reverse{animation:68s linear infinite ticker-scroll-reverse}.skills__ticker-wrap:hover .skills__ticker{animation-play-state:paused}.skills__ticker-pill{white-space:nowrap;background:var(--surface);cursor:pointer;border:1px solid;border-radius:999px;flex-shrink:0;align-items:center;padding:.35rem .9rem;font-size:.82rem;font-weight:500;transition:opacity .15s,transform .15s;display:inline-flex}html[data-theme=light] .skills__ticker-pill{color:var(--text)!important}.skills__ticker-pill:hover{background:#8b6fb81a;transform:translateY(-2px)}@keyframes ticker-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes ticker-scroll-reverse{0%{transform:translate(-50%)}to{transform:translate(0)}}@media (max-width:768px){.skills{padding:4rem 1.75rem}.skills__grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}}@media (max-width:480px){.skills__grid{grid-template-columns:repeat(3,1fr)}}
.contact{padding:6rem 3rem}.contact__container{max-width:1100px;margin:0 auto}.contact__label{letter-spacing:.22em;color:var(--accent-2);margin-bottom:1rem;font-size:.74rem;display:inline-block}.contact__title{font-family:var(--font-heading),Sora,sans-serif;letter-spacing:-.02em;color:var(--text);margin-bottom:.75rem;font-size:clamp(2rem,3.5vw,3rem);font-weight:700}.contact__subtitle{color:var(--muted);max-width:520px;margin-bottom:3rem;font-size:1rem}.contact__grid{grid-template-columns:1fr 1.3fr;align-items:start;gap:1.5rem;display:grid}.contact__left{flex-direction:column;gap:1rem;display:flex}.contact__info-card{border:1px solid var(--line);background:var(--surface);border-radius:16px;align-items:flex-start;gap:1rem;padding:1.25rem 1.4rem;display:flex}.contact__info-card--accent{background:#6ee7d80a;border-color:#6ee7d833}.contact__info-icon{width:42px;height:42px;color:var(--accent);background:#8b6fb826;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.contact__info-label{color:var(--muted-2);letter-spacing:.06em;text-transform:uppercase;margin-bottom:.25rem;font-size:.78rem;font-weight:600}.contact__info-value{color:var(--text);font-size:.95rem;font-weight:500}.contact__info-link{color:var(--accent-2);transition:color .2s}.contact__info-link:hover{color:var(--text)}.contact__response-emoji{flex-shrink:0;margin-top:.1rem;font-size:1.4rem}.contact__social-block{width:100%}.contact__social-heading{color:var(--text);margin-bottom:.85rem;font-size:.95rem;font-weight:600}.contact__socials{gap:.65rem;display:flex}.contact__social-icon{border:1px solid var(--line);background:var(--surface);width:42px;height:42px;color:var(--muted);border-radius:10px;justify-content:center;align-items:center;transition:color .2s,background .2s,border-color .2s;display:flex}.contact__social-icon:hover{color:var(--text);background:#8b6fb81f;border-color:#8b6fb866}.contact__form-card{border:1px solid var(--line);background:var(--surface);border-radius:20px;padding:2.25rem 2.5rem}.contact__form-title{font-family:var(--font-heading),Sora,sans-serif;color:var(--text);margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.contact__form-sub{color:var(--muted);margin-bottom:1.75rem;font-size:.92rem;line-height:1.6}.contact__form{flex-direction:column;gap:1.1rem;display:flex}.contact__field{flex-direction:column;gap:.4rem;display:flex}.contact__field-label{color:var(--text);font-size:.85rem;font-weight:600}.contact__field-label span{color:var(--accent)}.contact__input{border:1px solid var(--line);width:100%;color:var(--text);resize:none;background:#ffffff08;border-radius:10px;outline:none;padding:.75rem 1rem;font-family:inherit;font-size:.95rem;transition:border-color .2s,background .2s}.contact__input::placeholder{color:var(--muted-2)}.contact__input:focus{border-color:var(--accent);background:#8b6fb80d}.contact__textarea{min-height:140px}.contact__submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:.6rem;margin-top:.25rem;padding:.9rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:background .2s,transform .15s;display:flex}.contact__submit:hover{background:var(--accent-2);transform:translateY(-1px)}@media (max-width:860px){.contact{padding:4rem 1.75rem}.contact__grid{grid-template-columns:1fr}}
