:root,[data-theme=dark]{color-scheme:dark;--color-bg: #111111;--color-surface: #1c1c1c;--color-surface-raised: #252525;--color-border: #2e2e2e;--color-text: rgba(255, 255, 255, .87);--color-text-muted: #888;--color-link: #7c83ff;--color-link-hover: #a5aaff;--color-btn-bg: #252525;--color-btn-border: #3a3a3a;--color-btn-text: rgba(255, 255, 255, .87);--color-nav-bg: rgba(17, 17, 17, .85);--color-nav-border: #2e2e2e}[data-theme=light]{color-scheme:light;--color-bg: #ffffff;--color-surface: #f5f5f5;--color-surface-raised: #ebebeb;--color-border: #ddd;--color-text: #1a1a2e;--color-text-muted: #666;--color-link: #4a50e0;--color-link-hover: #3238c8;--color-btn-bg: #f0f0f0;--color-btn-border: #ccc;--color-btn-text: #1a1a2e;--color-nav-bg: rgba(255, 255, 255, .85);--color-nav-border: #e0e0e0}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--color-bg);color:var(--color-text);transition:background-color .2s ease,color .2s ease}a{color:var(--color-link);text-decoration:none;font-weight:500}a:hover{color:var(--color-link-hover)}h1,h2,h3,h4,h5,h6{line-height:1.2;margin:0}p{margin:0}button{font-family:inherit;cursor:pointer}.container{max-width:840px;width:100%;margin:0 auto;padding:0 1.25rem}.modal-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:#0000006b;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:overlay-in .22s ease}.modal{position:relative;width:min(700px,100%);max-height:86vh;min-height:50vh;background-color:var(--color-surface);border-radius:18px;overflow-y:auto;box-shadow:0 0 0 .5px #0000001f,0 2px 4px #0000000f,0 8px 20px #0000001a,0 24px 60px #0000002e;animation:modal-in .3s cubic-bezier(.16,1,.3,1)}.modal__close{position:sticky;top:1rem;float:right;margin:1rem 1rem -2.5rem 0;width:28px;height:28px;border-radius:50%;border:none;background-color:var(--color-surface-raised);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background-color .15s,color .15s}.modal__close:hover{background-color:var(--color-border);color:var(--color-text)}.modal__content{padding:2.5rem}.modal__body{display:flex;flex-direction:column;gap:1rem;margin-top:1.25rem;line-height:1.7;color:var(--color-text-muted)}.modal__body p{margin:0}.modal--resume{width:min(860px,100vw - 3rem)}.modal--resume .modal__close{position:absolute;top:1rem;right:1rem;float:none;margin:0;z-index:10;background-color:#ffffffeb;color:#444;box-shadow:0 1px 4px #0000001f}.modal--resume .modal__close:hover{background-color:#fff;color:#000}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.app-list{list-style:none;margin:1.5rem 0 0;padding:0;display:flex;flex-direction:column;gap:.75rem}.app-card{display:flex;align-items:stretch;overflow:hidden;border:1px solid var(--color-border);border-radius:16px;background-color:var(--color-surface-raised)}.app-card__thumb-wrap{width:180px;min-height:200px;flex-shrink:0;overflow:hidden}.app-card__thumb,.app-card__thumb-placeholder{width:100%;height:100%;display:block;object-fit:cover}.app-card__thumb-placeholder{background-color:var(--color-border)}.app-card__body{flex:1;display:flex;flex-direction:column;gap:.4rem;padding:1.25rem}.app-card__title{font-size:1rem;font-weight:600;margin:0;color:var(--color-text)}.app-card__desc{font-size:.875rem;line-height:1.6;color:var(--color-text-muted);margin:0}.app-card__link{display:inline-block;margin-top:auto;align-self:flex-end;font-size:.82rem;font-weight:500;color:var(--color-link);text-decoration:none;transition:color .15s}.app-card__link:hover{color:var(--color-link-hover)}.app-card__coming-soon{display:inline-block;margin-top:auto;align-self:flex-end;font-size:.78rem;color:var(--color-text-muted)}.resume-doc{font-family:Arial,Helvetica,sans-serif;display:grid;grid-template-columns:260px 1fr;background:#fff;border-radius:0 0 18px 18px;overflow:hidden}.resume-doc .rd-sidebar{background:#2c2c54;color:#fff;padding:40px 30px}.resume-doc .rd-profile-img{width:180px;height:180px;border-radius:50%;overflow:hidden;margin:0 auto 30px;border:3px solid #fff}.resume-doc .rd-profile-img img{width:100%;height:100%;object-fit:cover;display:block}.resume-doc .rd-sidebar-section{margin-bottom:48px}.resume-doc .rd-sidebar-section:last-child{margin-bottom:0}.resume-doc .rd-sidebar-section h3{font-size:14px;letter-spacing:1px;margin:0 0 20px;text-transform:uppercase;font-weight:700;color:#fff;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.3);line-height:1.2}.resume-doc .rd-item{display:flex;gap:15px;margin-bottom:18px;align-items:flex-start}.resume-doc .rd-item:last-child{margin-bottom:0}.resume-doc .rd-item-icon{width:18px;height:18px;flex-shrink:0;margin-top:3px;color:#ffffffd9;display:flex;align-items:center;justify-content:center}.resume-doc .rd-item-icon svg{width:100%;height:100%}.resume-doc .rd-item-content{flex:1}.resume-doc .rd-item-title{font-weight:700;color:#fff;font-size:14px;margin-bottom:6px}.resume-doc .rd-item-text{margin:0;font-size:13px;line-height:1.5;color:#ffffffd9}.resume-doc .rd-language-item{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;font-size:14px}.resume-doc .rd-language-item:last-child{margin-bottom:0}.resume-doc .rd-language-name{color:#ffffffd9;font-size:14px;flex:1}.resume-doc .rd-language-dots{display:flex;gap:6px;align-items:center}.resume-doc .rd-language-dots .rd-lang-dot{width:10px;height:10px;border-radius:50%;background:#fff3}.resume-doc .rd-language-dots .rd-lang-dot.filled{background:#fffc}.resume-doc .rd-content{padding:48px 30px;display:flex;flex-direction:column;gap:36px;background:#fff}.resume-doc .rd-header{display:flex;justify-content:space-between;align-items:flex-start}.resume-doc .rd-name{margin:0;font-size:36px;letter-spacing:-.5px;font-family:-apple-system,BlinkMacSystemFont,Inter,SF Pro Display,Roboto,sans-serif;font-weight:500;color:#000;line-height:1.2}.resume-doc .rd-job-subtitle{margin:5px 0 0;font-size:14px;color:#777;text-transform:uppercase;letter-spacing:.8px;font-family:-apple-system,BlinkMacSystemFont,Inter,SF Pro Display,Roboto,sans-serif;font-weight:500;line-height:1.2}.resume-doc .rd-location{margin:10px 0 0;font-size:13px;color:#999}.resume-doc .rd-contact{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:5px;min-width:200px;font-size:13px;color:#777}.resume-doc .rd-contact li{position:relative;padding-left:32px;min-height:28px;display:flex;align-items:center}.resume-doc .rd-contact a{color:#777;text-decoration:none;font-weight:400}.resume-doc .rd-contact a:hover{color:#2c2c54;text-decoration:underline}.resume-doc .rd-contact-icon{position:absolute;left:0;top:50%;transform:translateY(-50%);width:24px;height:24px;border:.5px solid #333;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#555}.resume-doc .rd-contact-icon svg{width:14px;height:14px}.resume-doc .rd-section-title{font-size:16px;font-weight:700;text-transform:uppercase;border-bottom:1px solid #e5e5e5;padding-bottom:8px;margin-bottom:20px;color:#000}.resume-doc .rd-timeline{position:relative;margin-top:30px}.resume-doc .rd-timeline:before{content:"";position:absolute;left:35.3%;top:14px;bottom:0;width:2px;background:#4a4a7a}.resume-doc .rd-timeline-item{display:grid;grid-template-columns:1.5fr 36px 3fr;column-gap:12px;margin-bottom:36px;position:relative}.resume-doc .rd-timeline-item:last-child{margin-bottom:0}.resume-doc .rd-timeline-left{text-align:left;font-size:13px;color:#777}.resume-doc .rd-org{font-weight:600;color:#000}.resume-doc .rd-meta{margin-top:4px}.resume-doc .rd-timeline-marker{display:flex;justify-content:center;align-items:flex-start;padding-top:2px}.resume-doc .rd-timeline-marker .rd-tl-dot{width:16px;height:16px;background:#fff;border:2.5px solid #2c2c54;border-radius:50%;z-index:2;flex-shrink:0;display:block}.resume-doc .rd-timeline-right{font-size:14px;color:#333}.resume-doc .rd-timeline-right .rd-job-title{font-weight:600;margin-bottom:6px;color:#000}.resume-doc .rd-timeline-right ul{margin:0;padding-left:18px}.resume-doc .rd-timeline-right ul li{margin-bottom:6px;color:#333;font-size:14px}.layout{display:flex;flex-direction:column;min-height:100vh}.main{flex:1}.footer{border-top:1px solid var(--color-border);padding:1rem 1.25rem}.footer__inner{max-width:840px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;font-size:.78rem}.footer__copy{color:var(--color-text-muted)}.footer__theme{display:flex;align-items:center;gap:.3rem;-webkit-user-select:none;user-select:none}.footer__theme-sep{color:var(--color-border)}.footer__theme-opt{color:var(--color-text-muted);cursor:pointer;transition:color .15s}.footer__theme-opt:hover{color:var(--color-text)}.footer__theme-opt--active{color:var(--color-text);font-weight:500;cursor:default;pointer-events:none}.contact-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-top:1.5rem}.contact-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2.5rem 1.5rem;border-radius:24px;border:1px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text);text-decoration:none;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.contact-card:hover{transform:translateY(-4px);border-color:transparent;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000f}.contact-card__icon{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:color .2s ease}.contact-card:hover .contact-card__icon{color:var(--color-text)}.contact-card__label{font-size:1.05rem;font-weight:500;color:var(--color-text-muted);transition:color .2s ease}.contact-card:hover .contact-card__label{color:var(--color-text)}.playground-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.playground-card{border-radius:20px;border:1px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text);text-decoration:none;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.playground-card:not(.playground-card--static):hover{transform:translateY(-4px);border-color:transparent;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000f}.playground-card__preview{height:160px;background-color:var(--color-surface-raised);overflow:hidden}.playground-card__img{width:100%;height:100%;object-fit:cover;display:block}.playground-card__body{padding:.875rem 1rem 1rem;display:flex;flex-direction:column;gap:.35rem}.playground-card__title{font-size:.95rem;font-weight:600;color:var(--color-text);margin:0}.playground-card__desc{font-size:.8rem;line-height:1.5;color:var(--color-text-muted);margin:0}.single-page{display:flex;flex-direction:column}.section{max-width:840px;width:100%;margin:0 auto;padding:3.5rem 1.25rem;display:flex;flex-direction:column;gap:2rem}.section-divider{border:none;border-top:1px solid var(--color-border);margin:0;max-width:840px;width:100%;align-self:center}.home-greeting{font-size:2rem;font-weight:600;line-height:1.2;margin:0}.home-intro{display:flex;align-items:flex-start;gap:2rem}.home-intro__text{flex:1;display:flex;flex-direction:column;gap:.85rem;line-height:1.7}.home-intro__text p{margin:0}.home-intro__photo{width:160px;height:160px;border-radius:50%;object-fit:cover;flex-shrink:0}@media(max-width:520px){.home-intro{flex-direction:column-reverse;align-items:center}.home-intro__photo{width:120px;height:120px}}.section-header{display:flex;align-items:baseline;justify-content:space-between}.see-all-link{font-size:.82rem;font-weight:500;color:var(--color-link);text-decoration:none;white-space:nowrap;transition:color .15s}.see-all-link:hover{color:var(--color-link-hover)}
