*{box-sizing:border-box}html,body{width:100%;height:100%;padding:0;margin:0;overflow-x:hidden;overflow-y:auto;background:#fff;border:0;font:100%/150% Open Sans,sans-serif;color:#2f2f2f;-webkit-overflow-scrolling:touch}article,section,nav,main{display:block}h1{margin:0;font-size:125%;line-height:100%}h2{margin:0;font-size:110%;line-height:100%}h3{margin:0;font-size:100%;line-height:120%}h4{margin:0 0 .35em;font-size:75%;letter-spacing:.08em;text-transform:uppercase;color:#666}a{color:#555;transition:.25s color;cursor:pointer}a:hover{color:#00b2ee}button:focus-visible,a:focus-visible{outline:2px solid #00b2ee;outline-offset:3px;border-radius:6px}button{font:inherit;color:inherit;background:none;border:none;padding:0;cursor:pointer}p{font-size:90%}.section-lead{margin:0 0 1.5em;max-width:720px;color:#4f4f4f}.inline-code{font-family:Courier New,Courier,monospace;font-size:90%;background:#f4f4f4;padding:.1em .35em;border-radius:4px}hr{border:none;background-color:#e7e7e7;height:1px;margin:1em 0}.page{width:100%;padding:0 1em}.page main,.page header{width:100%;height:auto;margin:0;padding:0}.page header{margin-bottom:4em}.page section{margin:4em auto}@media all and (min-width: 600px){.page{padding:0 3em}}@media all and (min-width: 768px){.page{display:grid;grid-template-columns:minmax(260px,340px) minmax(0,1fr);gap:3em;align-items:start}.page header{margin-bottom:0;position:sticky;top:2.5em;text-align:center}.page section{margin:2.25em auto 4em}}@media all and (min-width: 1200px){.page{grid-template-columns:minmax(280px,420px) minmax(0,1fr);padding:0 6em}}.sidebar-container{position:relative;width:270px;margin:0 auto;text-align:center}.shape-container{position:relative;height:300px;margin-bottom:1.25em}.square{position:absolute;height:310px;width:382px;background-image:url(/stars.jpg);margin-left:-50px;border-radius:40px}.circle{position:absolute;height:270px;width:270px;background-color:#555;border-radius:50%;border:10px solid white;margin-top:35px;background-image:url(/Me.png);background-position:center;background-size:300px}.earth{position:absolute;top:-10px;left:-10px;height:270px;width:270px;border-radius:50%;background-color:#fff;opacity:0;transition:all .2s ease-in-out}.earth:hover{opacity:1}.job-title{font-weight:400;margin-top:.75em;margin-bottom:1.25em}.inner-svg{transition:.25s fill}svg:hover .inner-svg{fill:#00b2ee}button:hover .inner-svg{fill:#00b2ee}nav ul{padding:0;list-style:none;margin-bottom:0}nav li{margin:0 1em 0 0;display:inline-block}nav li:last-child{margin:0}#copied-prompt{margin-top:.5em;display:none;font-size:80%;color:#777}.section-links{display:flex;flex-wrap:wrap;gap:.75em;justify-content:center;margin-top:1.25em}.section-links a{text-decoration:none;font-weight:700;font-size:80%;border:1px solid #e0e0e0;padding:.35em .85em;border-radius:999px;color:#4f4f4f}.section-links a:hover{border-color:#00b2ee;color:#00b2ee}.section-links a.is-active{border-color:#00b2ee;color:#00b2ee;background:#f0faff}.about-highlights{padding-left:1.2em;margin:0 0 1.5em}.about-highlights li{margin-bottom:.5em}.about-meta{display:flex;flex-direction:column;gap:.25em;font-size:85%;color:#666}.card-grid{display:grid;gap:1.5em}.card{border:1px solid #e7e7e7;border-radius:16px;padding:1.5em;background:#fff;box-shadow:0 10px 30px #0000000a}.card-title{margin:0 0 .5em;font-size:110%}.card-desc{margin:0 0 1em;color:#555}.card-link{text-decoration:none;font-weight:700;font-size:85%}.inline-link{text-decoration:none;font-weight:700}article{padding:0}.timeline{margin:2em 0;padding-left:1.5em;border-left:2px solid #e7e7e7}.timeline-item{position:relative;margin-bottom:2em;padding-left:.5em}.timeline-marker{position:absolute;left:-.95em;top:.25em;width:.85em;height:.85em;background:#00b2ee;border-radius:50%}.timeline-content{padding-left:.5em}.timeline-header{display:flex;flex-direction:column;gap:.35em}.timeline-title{display:flex;align-items:center;gap:.75em}.timeline-logo{width:38px;height:38px;border-radius:10px;border:1px solid #e7e7e7;background:#fff;object-fit:contain;padding:4px}.timeline-date{font-size:80%;color:#777}.timeline-subtitle{margin:.5em 0 .75em;font-size:85%;color:#555}.timeline-list{margin:0;padding-left:1.2em}.timeline-list li{margin-bottom:.5em}.skills{margin-top:2em;padding:1.5em;border:1px solid #e7e7e7;border-radius:16px;background:#fafafa}.skills-grid{display:grid;grid-template-columns:1fr;gap:1.5em;margin-top:1em}.skills-grid p{margin:0;color:#4f4f4f}.icon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1em}.icon-item{display:flex;align-items:center;gap:.75em;padding:.75em 1em;border:1px solid #e7e7e7;border-radius:12px;background:#fff}.icon-badge{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#f0faff;border:1px solid #e7e7e7;overflow:hidden;font-size:1.1em}.icon-image{width:20px;height:20px;object-fit:contain}.icon-label{font-size:90%;font-weight:600;color:#444}.project-grid{display:grid;gap:1.5em}.project-card-link{display:block;text-decoration:none;color:inherit;cursor:pointer}.project-card-link:hover{color:inherit}.project-card{display:grid;grid-template-columns:minmax(0,1fr) 220px;column-gap:1.25em;align-items:start;border:1px solid #e7e7e7;border-radius:16px;padding:1.5em;background:#fff;box-shadow:0 10px 30px #0000000a;transition:border-color .2s ease,box-shadow .2s ease}.project-preview{grid-column:2;grid-row:1 / span 8;width:100%;height:140px;object-fit:cover;border-radius:12px;border:1px solid #e7e7e7;background:#f8f8f8}.project-card>:not(.project-preview){grid-column:1}.project-header{display:flex;flex-direction:column;gap:.75em;margin-bottom:1em}.project-title{display:flex;align-items:center;gap:.4em;font-size:110%;margin-bottom:.25em;transition:color .2s ease}.project-emoji{font-size:120%}.project-description{margin:.25em 0 0;font-size:90%;color:#555}.project-tags{margin-top:.5em;font-size:75%;letter-spacing:.08em;text-transform:uppercase;color:#777}.project-links{display:flex;gap:1em;flex-wrap:wrap}.project-links a{text-decoration:none;font-weight:700;font-size:85%}.project-bullets{margin:0;padding-left:1.2em}.project-bullets li{margin-bottom:.5em}.project-card:hover{border-color:#00b2ee;box-shadow:0 12px 32px #00b2ee1f}.project-card:hover .project-title{color:#00b2ee}.project-card-link:hover .project-date,.project-card-link:hover .project-description,.project-card-link:hover .project-section-label,.project-card-link:hover .project-tech,.project-card-link:hover .project-bullets li{color:inherit}.blog-body{background:linear-gradient(180deg,#f8fbff,#fcfcfc 34% 100%)}.blog-shell{max-width:1160px;margin:0 auto;padding:2.5em 1.25em 4em}.blog-nav{display:flex;flex-direction:column;gap:1em;margin-bottom:2.6em}.blog-logo{font-size:115%;font-weight:700;text-decoration:none;color:#2f2f2f;letter-spacing:-.01em}.blog-links{display:flex;flex-wrap:wrap;gap:1em;font-size:85%}.blog-links a{text-decoration:none;font-weight:600;color:#4f5a6b}.blog-main{min-width:0}.blog-hero{margin-bottom:2em}.blog-hero h1{font-size:170%;margin-bottom:.4em}.blog-list{display:grid;gap:2.5em}.blog-post-link{display:block;text-decoration:none;color:inherit;cursor:pointer}.blog-post{border:1px solid #e7e7e7;border-radius:16px;padding:1.5em;background:#fff;box-shadow:0 12px 30px #0000000a;transition:border-color .2s ease,box-shadow .2s ease}.blog-header{display:flex;flex-direction:column;gap:.5em;margin-bottom:1em}.blog-header h2,.blog-header h3{transition:color .2s ease}.blog-date{margin:0;font-size:80%;color:#777}.blog-summary{margin:0;color:#555}.blog-tags{display:flex;flex-wrap:wrap;gap:.5em;margin-bottom:1em}.blog-tags span{border:1px solid #d8d8d8;border-radius:999px;padding:.2em .6em;font-size:70%;color:#666}.blog-content h1{font-size:120%;margin-bottom:.5em}.blog-content h2{font-size:110%;margin:1em 0 .5em}.blog-content h3{font-size:100%;margin:1em 0 .5em}.blog-content p{margin:0 0 .75em}.blog-content pre{background:#1f1f1f;color:#f2f2f2;padding:.75em 1em;border-radius:10px;overflow-x:auto;font-size:85%}.blog-content code{font-family:Courier New,Courier,monospace;font-size:90%}.blog-content blockquote{margin:1em 0;padding-left:1em;border-left:3px solid #00b2ee;color:#555}.blog-post:hover{border-color:#00b2ee;box-shadow:0 14px 34px #00b2ee1f}.blog-post:hover .blog-header h2,.blog-post:hover .blog-header h3{color:#00b2ee}.post-layout{display:grid;gap:1.5em;align-items:start}.post-article{background:#fff;border:1px solid #e5ebf3;border-radius:20px;padding:clamp(1.2rem,2.6vw,2.4rem);box-shadow:0 24px 52px #0f172a0f}.post-header{margin-bottom:1.8em;padding-bottom:1.15em;border-bottom:1px solid #edf2f8}.post-title{font-size:clamp(1.85rem,3.4vw,2.55rem);margin:0 0 .35em;line-height:115%;letter-spacing:-.02em;color:#0f172a}.post-meta{font-size:78%;color:#5f6c7e;display:flex;flex-wrap:wrap;gap:.8em;align-items:center;letter-spacing:.08em;text-transform:uppercase}.post-toc-mobile{margin:0 0 1.4em;padding:.9em 1em;border:1px solid #dce9fb;border-radius:14px;background:linear-gradient(180deg,#f8fbff,#f4f8ff)}.post-toc-desktop{display:none}.post-toc-card{position:sticky;top:1.2rem;padding:1em;border:1px solid #dbe5f2;border-radius:16px;background:#ffffffe0;backdrop-filter:blur(6px);max-height:calc(100vh - 2.5rem);overflow-y:auto}.post-toc-label{margin:0 0 .65em;font-size:72%;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#2563eb}.post-toc-list{list-style:none;padding:0;margin:0;display:grid;gap:.24em}.post-toc-list li.is-child .post-toc-link{padding-left:1.1em;font-size:88%}.post-toc-link{display:block;padding:.36em .55em;border-radius:8px;text-decoration:none;color:#4a5769;font-size:90%;line-height:1.35;transition:background .2s ease,color .2s ease}.post-toc-link:hover{background:#ecf3ff;color:#1d4ed8}.post-toc-link.is-active{background:#dbeafe;color:#1d4ed8;font-weight:700}.post-content{font-size:101%;line-height:1.85;color:#243347}.post-content>p:first-of-type{font-size:112%;color:#314055}.post-content p{margin:0 0 1.06em}.post-content a{color:#1d4ed8;font-weight:600;text-decoration:none;text-decoration-thickness:2px;text-underline-offset:2px}.post-content a:hover{text-decoration:underline}.post-content ul,.post-content ol{padding-left:1.25em;margin:0 0 1.12em}.post-content li{margin-bottom:.48em}.post-content h2,.post-content h3,.post-content h4{color:#0f172a;line-height:130%;letter-spacing:-.01em;scroll-margin-top:5.4rem}.post-content h2{font-size:165%;margin:1.9em 0 .66em}.post-content h3{font-size:130%;margin:1.45em 0 .52em}.post-content h4{font-size:114%;margin:1.2em 0 .42em}.post-content pre{margin:1.3em 0;padding:1em 1.05em;border-radius:14px;overflow-x:auto;background:#0f172a;color:#e2e8f0;border:1px solid #1e293b;box-shadow:0 14px 30px #0f172a3d;font-size:88%;line-height:1.58}.post-content pre code{background:transparent;color:inherit;padding:0;border:0;font-size:inherit}.post-content :not(pre)>code{font-family:Courier New,Courier,monospace;font-size:88%;background:#edf3ff;color:#1e3a8a;border:1px solid #d7e4ff;border-radius:7px;padding:.16em .4em}.post-content blockquote{margin:1.2em 0;padding:.9em 1em;border-left:4px solid #2563eb;background:#f7faff;border-radius:0 12px 12px 0;color:#324156}.post-content hr{border:0;border-top:1px solid #e6edf5;margin:1.8em 0}.post-content img{max-width:100%;border-radius:14px;display:block;margin:1.2em auto}.post-content table{display:block;width:100%;max-width:100%;overflow-x:auto;margin:1.35em 0;border-collapse:collapse;border-spacing:0;border:1px solid #dfe8f3;border-radius:12px;background:#fff;font-size:91%}.post-content table thead{background:#f5f9ff}.post-content table th,.post-content table td{padding:.68em .9em;text-align:left;border-bottom:1px solid #e9eef5;vertical-align:top}.post-content table th+th,.post-content table td+td{border-left:1px solid #e9eef5}.post-content table tbody tr:last-child td{border-bottom:0}.post-content table code{white-space:nowrap}.blog-footer{margin-top:2.2em}.empty-state{padding:1.25em;border-radius:12px;border:1px dashed #d8d8d8;color:#777;margin-top:1.5em}.empty-state.error{border-color:#f0b6b6;color:#a94442;background:#fff3f3}.footer-rule{margin-top:0;margin-bottom:2.8em}.footer{height:50px;width:100%}.footer-title{width:fit-content;white-space:nowrap}.footer-email{color:#999}@media all and (min-width: 500px) and (max-width: 768px),all and (min-width: 860px) and (max-width: 1200px),all and (min-width: 1300px){.footer-title{float:left}.footer-email{float:right;margin:0}}@media all and (min-width: 700px){.skills-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.about-meta{flex-direction:row;gap:1.5em}.blog-nav{flex-direction:row;justify-content:space-between;align-items:center}}@media all and (min-width: 900px){.project-header{flex-direction:row;justify-content:space-between;align-items:flex-start}.section-links{justify-content:flex-start}.card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media all and (min-width: 1200px){.post-layout{grid-template-columns:minmax(0,1fr) 250px;gap:2em}.post-toc-mobile{display:none}.post-toc-desktop{display:block}}@media all and (max-width: 700px){.project-card{grid-template-columns:minmax(0,1fr) 130px}.project-preview{height:96px}.post-article{border-radius:16px;padding:1em}.post-title{line-height:118%}.post-content{font-size:96%}.post-content table{font-size:86%}}
