:root{--font-sans: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Helvetica Neue", Helvetica, Arial, "Apple LiGothic", "PingFang SC", "Hiragino Sans", "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, system-ui, sans-serif;--font-head: "Space Grotesk", "Inter", system-ui, sans-serif;--font-body: "Source Sans 3", system-ui, sans-serif;--font-nav: "Inter", "Space Grotesk", system-ui, sans-serif;--font-heading-weight: 600;font-family:var(--font-sans);line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#f7f2f2;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--page-bg: #f7f2f2;--card-bg: #ffffff;--card-border: rgba(0, 0, 0, .06)}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;font-family:var(--font-body);background:var(--page-bg);color:#111827;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5,h6{font-family:var(--font-head);font-weight:var(--font-heading-weight);letter-spacing:.25px}.sf-subtle{font-family:var(--font-sans);font-weight:400;letter-spacing:.15px}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.splash-root{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;font-weight:800;background:#f7f4ef;color:#111;overflow:visible}.splash-root.offwhite{background:#f7f4ef}.splash-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.05) 1px,transparent 1px);background-size:80px 80px,80px 80px;opacity:.55}.splash-svg{width:clamp(440px,60vw,760px);overflow:visible;transform:translate(var(--splash-shift-x, 0))}.letter-path{stroke-width:34;stroke-linecap:round;stroke-linejoin:round;fill:none;filter:none}.travel-dot{filter:none;transform-origin:center}@media(max-width:860px){.splash-svg{width:min(86vw,620px)}.splash-root{--splash-shift-x: 6px}}.splash-word{position:relative;display:flex;align-items:baseline;gap:1.2rem;font-size:clamp(48px,10vw,140px);line-height:.9;letter-spacing:.02em;perspective:800px}.splash-letter{display:inline-grid}.splash-letter .glyph{display:inline-block;transform-origin:50% 100%;filter:drop-shadow(0 12px 24px rgba(0,0,0,.35))}.splash-letter.J{background:linear-gradient(135deg,#1da1ff,#2563eb 70%);-webkit-background-clip:text;color:transparent}.splash-letter.o,.splash-letter.O{background:linear-gradient(135deg,#f472b6,#ec4899 70%);-webkit-background-clip:text;color:transparent}.splash-letter.V{background:linear-gradient(135deg,#22d3ee,#10b981 70%);-webkit-background-clip:text;color:transparent}.splash-travel-dot{position:absolute;top:50%;left:0;width:clamp(14px,1.8vw,28px);height:clamp(14px,1.8vw,28px);border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,#e9e9e9 60%,#d7d7d7);box-shadow:0 8px 22px #00000040,0 4px 10px #0000001f;transform:translate(-50%,-50%);will-change:transform}.emoji-marker{filter:drop-shadow(0 2px 6px rgba(0,0,0,.25))}.glass{background:#ffffff97;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5);box-shadow:0 10px 30px #0206171a,inset 0 1px #ffffff59}.glass-pill{border-radius:9999px}.topbar{margin:0 -2rem;padding:.5rem 0;position:sticky;top:0;z-index:50}.topbar__inner{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1.25rem;border-radius:16px}.topbar.compact .brand,.topbar.compact .actions{opacity:0;pointer-events:none;transform:translateY(-12px);transition:opacity .25s ease,transform .35s ease}.topbar .brand,.topbar .actions{transition:opacity .25s ease,transform .35s ease}.topbar.compact .topbar__inner{justify-content:center}.brand{font-size:1.5rem;font-weight:700;font-family:var(--font-head)}.brand-dot{color:#4e6ef2}.actions{display:flex;align-items:center;gap:.9rem}.icon-btn{background:transparent;border:none;padding:.2rem;cursor:pointer;font-size:1.1rem}.icon-group{display:flex;align-items:center;gap:1rem}.icon-btn svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8}.icon-btn{color:#0f172a;opacity:.85;transition:opacity .2s,transform .25s}.icon-btn:hover{opacity:1;transform:translateY(-2px)}.icon-btn:active{transform:translateY(0)}.icon-btn:focus-visible{outline:2px solid #4e6ef2;outline-offset:4px;border-radius:6px}.card{background:var(--card-bg);border:1px solid var(--card-border);padding:1.2rem;border-radius:1rem;box-shadow:0 4px 16px #00000014}.home{display:grid;place-items:center;padding:2rem}.home__grid{display:grid;grid-template-columns:repeat(2,minmax(320px,1fr));gap:2rem;width:100%;max-width:1200px;align-items:center;justify-items:stretch}@media(max-width:900px){.home__grid{grid-template-columns:1fr}}.hero-left h2{margin:0 0 .75rem}.aesthetic-hero{position:relative;border-radius:16px;overflow:hidden;padding:10px;background:radial-gradient(1200px 1200px at -20% -20%,rgba(78,110,242,.18),transparent 45%),radial-gradient(900px 900px at 120% 10%,rgba(139,92,246,.18),transparent 45%)}.aesthetic-hero .blob{position:absolute;width:220px;height:220px;border-radius:50%;filter:blur(48px);opacity:.65;animation:blobFloat 14s ease-in-out infinite}.aesthetic-hero .blob.b1{background:#6b5df2;top:-40px;left:-30px}.aesthetic-hero .blob.b2{background:#8a2be2;bottom:-50px;right:-40px;animation-delay:-6s}@keyframes blobFloat{0%{transform:translate(0) scale(1)}25%{transform:translate(20px,-14px) scale(1.05)}50%{transform:translateY(-24px) scale(.98)}75%{transform:translate(-16px,6px) scale(1.03)}to{transform:translate(0) scale(1)}}.hero-canvas{position:relative;border-radius:12px;background:#fff9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.7)}html{scroll-behavior:smooth;width:100%}body{width:100%}.site-root{min-height:100%;background:#f5f5f5;color:#111;position:relative;overflow-x:clip}.global-topo-bg{position:absolute;inset:0;height:clamp(640px,72vh,840px);pointer-events:none;z-index:0;background:repeating-linear-gradient(0deg,rgba(0,0,0,.055) 0 2px,transparent 2px 42px),repeating-linear-gradient(63deg,rgba(0,0,0,.045) 0 2px,transparent 2px 46px),repeating-linear-gradient(-61deg,rgba(0,0,0,.035) 0 2px,transparent 2px 54px);opacity:.5;-webkit-mask-image:linear-gradient(to bottom,#000 0%,#000 58%,transparent 98%);mask-image:linear-gradient(to bottom,#000 0%,#000 58%,transparent 98%)}.projects-section{padding:7rem 2rem;max-width:1240px;margin:0 auto;position:relative}.projects-layout{display:grid;grid-template-columns:300px minmax(0,1fr);gap:2.5rem;align-items:start}.projects-sidebar{position:sticky;top:120px;align-self:start;background:#ffffffb8;-webkit-backdrop-filter:saturate(130%) blur(10px);backdrop-filter:saturate(130%) blur(10px);border:1px solid #e9e9e9;border-radius:18px;padding:1.2rem;box-shadow:0 8px 24px #0000000f}.projects-title{font-size:1.35rem;margin:0;font-weight:650}.projects-intro{margin:.75rem 0 1.1rem;color:#4b5563;line-height:1.55;font-size:.95rem}.category-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem}.category-btn{border:1px solid #e4e4e4;background:#fcfcfc;color:#1f2937;border-radius:9999px;padding:.5rem .8rem;font-size:.9rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.45rem;transition:background .2s,color .2s,border-color .2s,transform .15s}.category-btn:hover{background:#f4f4f4;color:#111827;transform:translateY(-1px)}.category-btn.active{background:#111;color:#fff;border-color:#111}.category-count{font-size:.76rem;min-width:1.2rem;height:1.2rem;border-radius:9999px;display:inline-grid;place-items:center;padding:0 .3rem;background:#0000000f;color:inherit}.category-btn.active .category-count{background:#ffffff3d}.show-more-btn{margin-top:1rem;border:1px solid #e1e1e1;background:#fff;color:#1f2937;border-radius:9999px;padding:.5rem .95rem;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .2s,transform .15s}.show-more-btn:hover{background:#f8f8f8;transform:translateY(-1px)}.projects-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:1fr;gap:1.6rem;align-items:stretch}.project-card{background:#fff;border:1px solid #ececec;border-radius:18px;box-shadow:0 8px 24px #00000012;display:flex;flex-direction:column;height:100%;min-height:460px;overflow:hidden;transition:transform .22s ease,box-shadow .22s ease}.card-media{position:relative;width:100%;height:clamp(200px,21vw,236px);border-bottom:1px solid #efefef;background:linear-gradient(180deg,#f3f3f3,#e9e9e9);flex-shrink:0}.card-media img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.project-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px #0000001f}.card-content{padding:1.1rem;display:flex;flex-direction:column;flex:1;gap:.55rem}.card-header{margin:0}.card-title{margin:0;font-size:1.12rem;font-weight:640;line-height:1.3;letter-spacing:.005em;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.6em}.card-category{position:absolute;top:.75rem;left:.75rem;font-size:.72rem;color:#111;background:#ffffffe0;border:1px solid rgba(0,0,0,.08);border-radius:9999px;padding:.2rem .55rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.card-desc{margin:0;font-size:.92rem;color:#414141;line-height:1.58;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:4.74em}.card-tech{display:flex;flex-wrap:wrap;gap:.4rem;align-content:flex-start;min-height:2rem;max-height:4.2rem;overflow:hidden}.tech-chip{display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;line-height:1;background:#f5f5f5;border-radius:9999px;padding:.38rem .58rem;border:1px solid #e7e7e7}.tech-chip.muted{color:#6b7280}.card-actions{margin-top:auto;padding-top:.95rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem;align-items:stretch}.card-actions.with-github.with-website{grid-template-columns:auto repeat(2,minmax(0,1fr))}.card-actions.with-github.no-website{grid-template-columns:auto minmax(0,1fr)}.card-icon-link{width:34px;height:34px;border:1px solid #dfe3e8;border-radius:9999px;background:#fff;color:#111827;display:inline-flex;align-items:center;justify-content:center;transition:background .2s ease,border-color .2s ease,transform .15s ease}.card-icon-link svg{width:17px;height:17px;fill:currentColor}.card-icon-link:hover{background:#f8fafc;border-color:#cfd8e4;transform:translateY(-1px)}.card-link-btn{border:1px solid #dfe3e8;background:#fff;font-size:.86rem;font-weight:620;border-radius:9999px;padding:.44rem .78rem;color:#111827;text-decoration:none;text-align:center;white-space:nowrap;min-width:0;line-height:1.1;transition:background .2s ease,border-color .2s ease,transform .15s ease}.card-link-btn:hover{background:#f8fafc;border-color:#cfd8e4;transform:translateY(-1px)}.card-link-btn.secondary{background:#0f172a;border-color:#0f172a;color:#f8fafc}.card-link-btn.secondary:hover{background:#17233a;border-color:#17233a}.card-link-btn.disabled,.card-link-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.project-modal-backdrop{position:fixed;inset:0;z-index:1450;background:#0f172a7a;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:1.1rem}.project-modal{position:relative;box-sizing:border-box;width:min(940px,calc(100vw - 2rem));max-width:100%;max-height:min(86vh,calc(100vh - 2rem));overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;scrollbar-gutter:stable;background:#fff;border:1px solid #e8edf3;border-radius:18px;box-shadow:0 24px 60px #0f172a42;padding:1.3rem}.project-modal:focus{outline:none}.project-modal-close{position:absolute;top:.75rem;right:.75rem;width:32px;height:32px;padding:0;border:1px solid #d9e1ee;border-radius:10px;background:#f8fafc;color:#334155;font-size:1.08rem;font-weight:700;line-height:1;display:inline-grid;place-items:center;z-index:2}.project-modal-head{padding-right:2.1rem;margin-bottom:1.1rem;background:#fbfdff;border:1px solid #e8edf3;border-radius:14px;padding:.92rem 1rem}.project-modal-category{display:inline-block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#64748b;background:#f1f5f9;border:1px solid #dbe4ef;border-radius:9999px;padding:.2rem .52rem}.project-modal-head h4{margin:.56rem 0 .44rem;font-size:1.42rem;line-height:1.3}.project-modal-head p{margin:0;color:#475569;line-height:1.68;max-width:72ch}.project-modal-gallery{margin-top:1rem;margin-bottom:1.2rem}.project-modal-gallery>img{width:100%;height:auto;max-height:min(70vh,780px);object-fit:contain;border-radius:14px;border:1px solid #e6ebf2;background:#f8fafc;display:block;margin-inline:auto}.project-gallery-main{animation:projectGalleryIn .22s ease}.project-modal-thumbs{margin-top:.6rem;display:flex;gap:.45rem;overflow-x:auto}.project-thumb{border:1px solid #dce4ef;background:#fff;border-radius:10px;padding:0;width:88px;height:56px;overflow:hidden;flex-shrink:0;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.project-thumb:hover{transform:translateY(-1px)}.project-thumb img{width:100%;height:100%;object-fit:contain;background:#f8fafc;display:block}.project-thumb.active{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}@keyframes projectGalleryIn{0%{opacity:.72;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}.project-modal-close:focus-visible,.card-link-btn:focus-visible,.project-thumb:focus-visible,.card-icon-link:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.project-modal-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:.9rem}.project-modal-grid section{border:1px solid #e8edf3;border-radius:14px;background:#fcfdff;border-left:4px solid #dbe7ff;padding:.95rem 1rem}.project-modal-grid h5{margin:0 0 .44rem;font-size:.88rem;font-weight:720;letter-spacing:.08em;text-transform:uppercase;color:#334155}.project-modal-grid p{margin:0;color:#475569;line-height:1.72;font-size:1.02rem}.project-modal-grid ul{margin:0;padding-left:1.12rem;color:#475569;font-size:1.02rem;line-height:1.7;display:grid;gap:.42rem}@media(max-width:1080px){.projects-layout{grid-template-columns:1fr;gap:1.6rem}.projects-sidebar{position:static;top:auto}}@media(max-width:920px){.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.card-media{height:210px}}@media(max-width:700px){.projects-grid{grid-template-columns:1fr;grid-auto-rows:auto}.project-card{height:auto;min-height:0}.card-media{aspect-ratio:16 / 9;height:auto}.projects-section{padding:5rem 1rem}.card-content{min-height:auto}.card-actions{gap:.45rem}.card-link-btn{font-size:.82rem;padding:.4rem .7rem}.project-modal-backdrop{padding:.6rem;place-items:start center}.project-modal{width:min(680px,100%);max-width:100%;max-height:calc(100dvh - 1.2rem);padding:.9rem}.project-modal-close{top:.56rem;right:.56rem;width:30px;height:30px;border-radius:9px;font-size:1rem}.project-thumb{width:76px;height:50px}.project-modal-grid{grid-template-columns:1fr}}@media(max-width:420px){.projects-section{padding:4.75rem .85rem}.card-content{padding:.92rem}.card-actions,.card-actions.with-github.with-website,.card-actions.with-github.no-website{grid-template-columns:1fr}.card-link-btn{width:100%}.card-icon-link{width:100%;border-radius:9999px;min-height:34px}.project-modal-backdrop{padding:.35rem}.project-modal{width:100%;max-width:100%;max-height:calc(100dvh - .7rem);padding:.78rem}.project-modal-close{top:.48rem;right:.48rem;width:28px;height:28px;font-size:.94rem}}@media(min-width:1024px){.project-modal-backdrop{place-items:center;justify-items:center;padding:1.1rem}.project-modal{width:min(940px,calc(100vw - 2rem));max-height:min(86vh,calc(100vh - 2rem));border-radius:18px;border:1px solid #e8edf3;box-shadow:0 24px 60px #0f172a42}.project-modal-grid{grid-template-columns:minmax(0,1fr)}}@media(prefers-reduced-motion:reduce){.project-gallery-main,.project-thumb,.project-thumb:hover,.project-modal,.card-link-btn,.project-card{animation:none!important;transition:none!important;transform:none!important}.project-modal{scroll-behavior:auto}}.site-header-inner.abs-nav-layout{width:100%;max-width:100%;box-sizing:border-box;padding:0 clamp(12px,3vw,32px);position:relative;display:grid;grid-template-columns:1fr max-content 1fr;align-items:center;min-height:80px}.header-side{display:flex;align-items:center;transition:opacity .35s ease,transform .35s ease}.nav-center-slot{grid-column:2;display:flex;justify-content:center}.header-side,.nav-center-slot{min-width:0}.left-block{justify-content:flex-start;overflow:hidden}.right-block{justify-content:flex-end;gap:.55rem;min-width:max-content;flex-wrap:nowrap}.site-header-inner.abs-nav-layout.hide-sides .header-side.left-block,.site-header-inner.abs-nav-layout.hide-sides .header-side.right-block{opacity:0;pointer-events:none;transform:translateY(-6px)}.site-header-inner.abs-nav-layout.hide-sides .nav-center-slot .nav-menu{max-width:720px;width:auto;background:#f7f7f58f;-webkit-backdrop-filter:saturate(160%) blur(14px);backdrop-filter:saturate(160%) blur(14px);border:2px solid transparent}.site-header-inner.abs-nav-layout.hide-sides .nav-center-slot .nav-menu:hover,.site-header-inner.abs-nav-layout.hide-sides .nav-center-slot .nav-menu:focus-within{background:#f7f7f5;border-color:#e0e0db;border-width:5px;box-shadow:none}.contact-section{padding:6.5rem 2rem 2.5rem;max-width:1280px;margin:0 auto;position:relative;z-index:2}.contact-heading{text-align:center;margin-bottom:2.25rem}.contact-kicker{display:inline-block;text-transform:uppercase;letter-spacing:.11em;font-size:.76rem;color:#6b7280;font-weight:700}.contact-heading h2{margin:.35rem 0 .65rem;font-size:clamp(2rem,4vw,3.2rem);line-height:1.1}.contact-heading p{margin:0;color:#4b5563}.contact-layout{display:block}.contact-row{display:grid;gap:.85rem}.contact-row-top{grid-template-columns:1fr;margin-bottom:.85rem}.contact-row-bottom{grid-template-columns:.85fr 1.65fr}.contact-card{display:block;background:#f2f2f4;border-radius:24px;border:1px solid #ececee;color:#121212;text-decoration:none;padding:1.4rem 1.5rem;position:relative;z-index:2}.email-card{min-height:112px;display:grid;align-content:center;justify-items:center;text-align:center;transition:transform .22s ease,box-shadow .22s ease}.email-card:hover{transform:translateY(-2px);box-shadow:0 8px 18px #00000014}.contact-card-label{color:#6b7280;font-size:.95rem;font-weight:600;margin-bottom:.3rem}.email-card strong{font-size:clamp(1.22rem,2.2vw,1.8rem);line-height:1.15}.photo-card{min-height:296px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.quote-text{margin:0;color:#374151;font-size:clamp(1.15rem,1.7vw,1.35rem);font-weight:700;line-height:1.4;text-align:center}.photo-placeholder{margin-top:1.2rem;border-radius:16px;border:1px dashed #cdd1d7;background:#e9ecef;color:#6b7280;min-height:128px;display:grid;place-items:center;font-size:.95rem;font-weight:600}.contact-memoji{border-radius:50%;border:0;background:transparent;width:min(56%,160px);aspect-ratio:1 / 1;min-height:0;max-height:160px;object-fit:cover;object-position:center;display:block;padding:0}.links-card{min-height:296px;display:flex;flex-direction:column;justify-content:space-between}.links-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.2rem}.links-columns h4{margin:0 0 .65rem;text-transform:uppercase;font-size:.98rem;letter-spacing:.06em;color:#6b7280}.links-columns a{display:block;color:#0f172a;font-size:clamp(1.12rem,2.3vw,2rem);line-height:1.2;margin-bottom:.55rem;position:relative;z-index:3}.links-columns a:hover{color:#2563eb}.links-bottom{margin-top:1.15rem;display:flex;justify-content:space-between;align-items:center;color:#6b7280;font-size:.95rem}.links-bottom a{color:#6b7280;position:relative;z-index:3}.chatbot-drawer{--chat-surface: #ffffff;--chat-surface-soft: #f6f8fc;--chat-border: #dde3ee;--chat-text: #0f172a;--chat-muted: #64748b;--chat-accent: #0f274a;--chat-accent-strong: #0a1d38;box-sizing:border-box;background:var(--chat-surface);border:1px solid var(--chat-border);border-radius:24px;padding:1rem 1rem .62rem;display:flex;flex-direction:column;gap:.85rem;min-height:485px;position:fixed;right:1.25rem;bottom:5.75rem;width:min(388px,calc(100vw - 1.75rem));z-index:1400;box-shadow:0 24px 64px #0f172a33,0 2px 10px #0f172a14;transform:translateY(16px) scale(.985);transform-origin:bottom right;opacity:0;visibility:hidden;pointer-events:none;transition:transform .24s cubic-bezier(.22,1,.36,1),opacity .24s ease,visibility .24s ease}.chatbot-drawer.open{transform:translateY(0) scale(1);opacity:1;visibility:visible;pointer-events:auto}.chatbot-fab{position:fixed;right:1.25rem;bottom:1.25rem;z-index:1401;border:none;border-radius:50%;background:transparent;color:#fff;width:62px;height:62px;padding:0;display:grid;place-items:center;box-shadow:0 16px 32px #0f172a38;transition:transform .2s ease}.chatbot-fab:hover{transform:translateY(-2px)}.chatbot-fab-icon{width:100%;height:100%;border-radius:50%;border:1px solid #d2d9e7;background:radial-gradient(circle at 30% 25%,#f7f9fd,#e9eef7);color:#475569;font-size:.72rem;font-weight:700;letter-spacing:.08em;display:grid;place-items:center;overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.chatbot-fab-icon img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.chatbot-fab.open .chatbot-fab-icon{border-color:#9eb0ca;box-shadow:inset 0 0 0 3px #eef3fb,0 0 0 2px #ffffffa6;transform:scale(.98)}.chatbot-head h3{margin:0;font-size:.94rem;color:var(--chat-text);font-weight:700;letter-spacing:.01em;min-width:0}.chatbot-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.05rem .1rem .35rem}.chatbot-head-actions{display:inline-flex;align-items:center;gap:.4rem}.chatbot-clear{border:1px solid #d8deea;background:#fff;color:#4b5563;border-radius:10px;padding:.35rem .56rem;font-size:.71rem;font-weight:700;letter-spacing:.02em;transition:background-color .2s ease,border-color .2s ease,color .2s ease}.chatbot-clear:hover{background:#f8fafc;border-color:#c9d3e4;color:#1f2937}.chatbot-clear:disabled{opacity:.55;cursor:not-allowed}.chatbot-close{border:1px solid #d8deea;background:var(--chat-surface-soft);width:30px;height:30px;border-radius:10px;display:inline-grid;place-items:center;color:#475569;font-size:1rem;line-height:1;padding:0;transition:background-color .2s ease,border-color .2s ease,color .2s ease}.chatbot-close:hover{background:#edf2f9;border-color:#c9d3e4;color:#1e293b}.chat-suggestions{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.15rem}.chat-suggestions button{border:1px solid #d6e0ef;background:#f7faff;color:#334155;border-radius:999px;padding:.38rem .68rem;font-size:.73rem;font-weight:600;letter-spacing:.01em;transition:border-color .18s ease,background-color .18s ease,color .18s ease}.chat-suggestions button:disabled{opacity:.6;cursor:not-allowed}.chat-suggestions button:hover{background:#eef4ff;border-color:#b8c8e2;color:#1e293b}.chat-window{background:linear-gradient(180deg,#f8faff,#fff);border:1px solid #e1e8f3;border-radius:18px;padding:.85rem;display:flex;flex-direction:column;gap:.65rem;min-height:340px;max-height:390px;overflow-y:auto;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}.chat-window::-webkit-scrollbar{width:0;height:0}.chat-bubble{margin:0;max-width:88%;padding:.64rem .82rem;border-radius:16px;font-size:.84rem;line-height:1.52;word-break:break-word;white-space:pre-wrap;animation:chat-bubble-in .24s ease both}.chat-bubble.bot{align-self:flex-start;background:#fff;color:var(--chat-text);border:1px solid #dde5f1;border-bottom-left-radius:6px;box-shadow:0 2px 6px #0f172a0f}.chat-bubble.user{align-self:flex-end;background:linear-gradient(180deg,var(--chat-accent),var(--chat-accent-strong));color:#fff;border-bottom-right-radius:6px;box-shadow:0 4px 10px #0a1d3847}.chat-typing{display:inline-flex;align-items:center;gap:.3rem;min-width:66px;padding-top:.74rem;padding-bottom:.74rem}.typing-dot{width:6px;height:6px;border-radius:50%;background:#8da0bd;animation:chat-typing-dot 1.15s ease-in-out infinite}.typing-dot:nth-child(2){animation-delay:.16s}.typing-dot:nth-child(3){animation-delay:.32s}@keyframes chat-bubble-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@keyframes chat-typing-dot{0%,80%,to{transform:translateY(0);opacity:.42}40%{transform:translateY(-3px);opacity:1}}.chat-input-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:.45rem;padding:.32rem;margin:0;border:1px solid #e2e8f3;border-radius:16px;background:var(--chat-surface-soft)}.chat-input-control{min-width:0;display:flex;flex-direction:column;gap:.24rem}.chat-input-row textarea{box-sizing:border-box;width:100%;border:1px solid #d9e1ee;border-radius:12px;padding:.5rem .72rem;font-size:.8rem;font-family:var(--font-body);background:#fff;color:var(--chat-text);resize:none;min-height:34px;max-height:92px;line-height:1.35;transition:border-color .2s ease,box-shadow .2s ease}.chat-input-row textarea:focus{outline:none;border-color:#b8c6da;box-shadow:0 0 0 3px #b8c6da3d}.chat-input-row button{box-sizing:border-box;border:none;border-radius:999px;background:linear-gradient(180deg,#1e3b63,#102945);color:#fff;height:34px;padding:0 .72rem;font-weight:700;font-size:.72rem;line-height:1;white-space:nowrap;letter-spacing:.02em;min-width:54px;align-self:stretch;transition:transform .18s ease,filter .18s ease}.chat-input-row button:hover{transform:translateY(-1px);filter:brightness(1.05)}.chat-input-row button:disabled{opacity:.55;cursor:not-allowed;transform:none;filter:none}@media(max-width:880px){.contact-section{padding:5.5rem 1.25rem 2rem}.contact-row-top,.contact-row-bottom{grid-template-columns:1fr}.links-card,.photo-card{min-height:auto}.links-columns{grid-template-columns:1fr}.links-columns a{font-size:clamp(1.05rem,4vw,1.6rem)}}@media(max-width:520px){.contact-section{padding:5rem 1rem 1.1rem}.contact-card{border-radius:18px;padding:1rem}.contact-heading h2{font-size:1.9rem}.chat-window{min-height:260px;max-height:52vh}.chatbot-head{gap:.45rem}.chatbot-head h3{font-size:.88rem}.chatbot-clear{padding:.32rem .5rem;font-size:.68rem}.chat-input-row{grid-template-columns:minmax(0,1fr);gap:.35rem}.chat-input-row button{width:100%;max-width:92px;justify-self:end;min-width:0;height:32px;align-self:auto}.chatbot-fab{right:.8rem;bottom:.8rem;width:54px;height:54px}.chatbot-drawer{right:.8rem;bottom:4.35rem;width:calc(100vw - 1.6rem);border-radius:20px;padding:.9rem .9rem .52rem;min-height:min(485px,calc(100vh - 5.25rem))}}@media(prefers-reduced-motion:reduce){.chatbot-drawer,.chatbot-fab,.chatbot-fab-icon,.chat-suggestions button,.chat-input-row textarea,.chat-input-row button,.chat-bubble,.typing-dot{animation:none!important;transition:none!important}.chat-window{scroll-behavior:auto}}.site-header{position:fixed;z-index:1200;width:100%;padding:22px 0 0;background:transparent;transition:padding .32s cubic-bezier(.25,.6,.3,1)}.site-root>main{padding-top:120px}.logo-text{display:inline-block;white-space:nowrap;font-size:1.55rem;font-weight:700;font-family:var(--font-head);letter-spacing:.5px}.brand-dot{color:#6a3df0}.icon-group{justify-content:flex-end;gap:.55rem}.icon-btn{flex:0 0 38px;width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:#1111110d;color:#111;text-decoration:none}.icon-btn:hover{background:#1111111f;transform:translateY(-2px)}.icon-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.nav-shell{display:flex;justify-content:center}.nav-menu{box-sizing:border-box;list-style:none;position:sticky;top:calc(8px + env(safe-area-inset-top,0px));z-index:1000;display:flex;align-items:center;justify-content:center;gap:1.2rem;--nav-btn-h: 35px;--nav-py: 6px;height:60px;margin:0 auto;padding:0 1.1rem;border-radius:9999px;overflow:hidden;background:#f7f7f5;border:1.5px solid transparent;box-shadow:0 2px 12px #0000001a;transition:background .2s,border .2s;pointer-events:auto}.nav-menu:hover,.nav-menu:focus-within{background:#f7f7f5;border-color:#ecebe7;border-width:5px;box-shadow:none}.nav-menu .nav-item{display:flex;flex:0 0 auto;white-space:nowrap;margin:0}.nav-btn{box-sizing:border-box;flex-shrink:0;font-family:var(--font-nav);font-size:1.1rem;font-weight:510;letter-spacing:.01em;border:none;background:transparent;cursor:pointer;height:var(--nav-btn-h);line-height:var(--nav-btn-h);padding:0 1rem;display:flex;align-items:center;justify-content:center;border-radius:9999px;color:#7a7a7a;opacity:.85;transition:background .18s,color .18s;-webkit-font-smoothing:antialiased}.nav-btn.active{background:#e8e7e2;color:#1a1a1a;opacity:1;box-shadow:0 2px 8px #0000001f}.nav-btn:hover{background:#ecebe7;color:#232323;opacity:1}.nav-btn:focus-visible{outline:2px solid #4e6ef2;outline-offset:3px}.nav-btn:active{background:#1111111a}.home-hero{display:flex;align-items:center;justify-content:center;flex-direction:column;padding:2rem 0 3.5rem;position:relative;z-index:1}.skills-marquee{position:relative;margin-top:2rem;overflow:hidden;width:100%;max-width:1000px;margin-left:auto;margin-right:auto;padding:0 1rem;-webkit-mask-image:linear-gradient(to right,transparent 0%,#000 10%,#000 90%,transparent 100%);mask-image:linear-gradient(to right,transparent 0%,#000 10%,#000 90%,transparent 100%)}.marquee-track{display:flex;will-change:transform;width:max-content;animation:marquee-scroll 35s linear infinite}.skills-marquee:hover .marquee-track{animation-play-state:paused}.skills-list{display:flex;gap:.8rem;padding:.75rem 0;margin:0;list-style:none}.skill-pill{flex:0 0 auto;display:flex;align-items:center;justify-content:center;background:transparent}.skill-logo{height:48px;width:auto;display:block;background:transparent}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.hero-row{display:grid;grid-template-columns:minmax(220px,1fr) minmax(280px,400px) minmax(220px,1fr);--hero-gap: 3rem;column-gap:var(--hero-gap);align-items:center;width:100%;max-width:1400px;margin:0 auto;position:relative;z-index:2}@media(max-width:1180px){.hero-row{grid-template-columns:1fr 330px 1fr;--hero-gap: 1.5rem}.blob-wrapper{width:330px;height:330px}.greeting{font-size:clamp(4.4rem,7.6vw,5.6rem);gap:1.25rem;--greeting-shift: 2.2rem}.name-side .my-name{font-size:clamp(3.5rem,6.2vw,4.8rem)}.tagline{font-size:clamp(1.8rem,2.7vw,2.3rem)}}@media(max-width:1180px){.home-hero{padding:2.5rem 0 2.4rem}.hero-row{grid-template-columns:1fr;gap:2.2rem}.greeting{justify-content:center;transform:none;--greeting-shift: 0}.name-side{text-align:center}}.greeting{font-size:6.6rem;font-weight:700;display:flex;gap:2rem;position:relative;justify-content:center;width:100%;text-align:center}.greeting .wave{display:inline-block;transform-origin:75% 75%;animation:wave-hand 2.2s ease-in-out infinite,drift 10s linear infinite}.center{display:flex;flex-direction:column;align-items:center;gap:2.4rem}.blob-wrapper{width:400px;height:400px;position:relative}.blob-wrapper:before{content:"";position:absolute;inset:-16px;border-radius:58% 42% 63% 37%/44% 53% 47% 56%;background:radial-gradient(60% 60% at 50% 50%,#7a3ff273,#3f8bff73);filter:blur(28px);opacity:.9;pointer-events:none;animation:blob-morph 8s ease-in-out infinite;z-index:0}.blob-shape{position:absolute;inset:0;border-radius:58% 42% 63% 37%/44% 53% 47% 56%;overflow:hidden;animation:blob-morph 8s ease-in-out infinite;z-index:1}.blob-shape img{width:100%;height:100%;object-fit:cover;filter:saturate(1.1)}.name-side .my-name{font-size:6rem;font-weight:600;font-family:var(--font-head);line-height:1.05;margin:0}.name-side .aka{margin-top:.5rem;font-size:1rem;font-weight:200;font-family:var(--font-body);opacity:.75;letter-spacing:.25px}.name-side .aka em{font-style:italic;font-weight:500}.brand-dot-btn{background:none;border:none;padding:0 0 0 2px;cursor:pointer;line-height:1;display:inline-flex;align-items:center;justify-content:center;position:relative}.brand-dot-btn .brand-dot{display:inline-block;font-size:1.65rem;color:#6a3df0;transition:transform .35s cubic-bezier(.16,.68,.36,1),filter .35s}.brand-dot-btn:hover .brand-dot{transform:translateY(-2px) scale(1.15);filter:brightness(1.15)}.brand-dot-btn:focus-visible{outline:2px solid #4e6ef2;outline-offset:4px;border-radius:6px}@media(min-width:861px){.name-side{padding-left:3.9rem}}.tagline{font-size:2.5rem;min-height:1.5em;font-weight:500}.type-cycle{position:relative}.type-cycle .cursor{display:inline-block;width:1ch;margin-left:2px;animation:blink 1.1s steps(2,start) infinite;color:#6a3df0}@keyframes wave-hand{0%,to{transform:rotate(0)}10%{transform:rotate(18deg)}20%{transform:rotate(-10deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-6deg)}50%{transform:rotate(6deg)}60%{transform:rotate(-3deg)}70%{transform:rotate(2deg)}80%{transform:rotate(-1deg)}90%{transform:rotate(1deg)}}@keyframes drift{0%{translate:0 0}50%{translate:4px -6px}to{translate:0 0}}@keyframes blob-morph{0%,to{border-radius:58% 42% 63% 37%/44% 53% 47% 56%}25%{border-radius:54% 46% 41% 59%/58% 31% 69% 42%}50%{border-radius:47% 53% 55% 45%/39% 62% 38% 61%}75%{border-radius:63% 37% 58% 42%/46% 44% 56% 54%}}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes navFloatFade{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:1024px){.home-hero{padding:2.5rem 0 2.4rem}.hero-row{grid-template-columns:1fr;gap:2.2rem}.greeting{width:100%;justify-content:center;text-align:center;transform:none}.name-side{text-align:center}}@media(max-width:860px){.site-header{padding:14px 0 0}.site-header-inner.abs-nav-layout{padding:0 clamp(12px,4vw,18px);min-height:68px;justify-content:space-between;grid-template-columns:minmax(116px,1fr) auto minmax(116px,1fr);column-gap:clamp(.85rem,2.2vw,1.2rem)}.header-side.left-block,.header-side.right-block{flex:0 0 auto;min-width:116px}.header-side.left-block{padding-right:.35rem}.nav-center-slot{padding:0 .35rem}.header-side.right-block{min-width:max-content;gap:.4rem}.nav-menu{width:auto;max-width:min(62vw,620px);overflow-x:auto;justify-content:center;gap:.7rem;height:52px;min-height:52px;padding:6px .75rem}.nav-center-slot{min-width:0}.nav-menu::-webkit-scrollbar{display:none}.nav-btn{font-size:.95rem;padding:0 .75rem;min-height:40px}.icon-btn{flex:0 0 32px;width:32px;height:32px}.home-hero{padding:2.75rem 0 2.25rem}.hero-row{grid-template-columns:1fr;gap:2.4rem}.greeting{justify-content:center;font-size:clamp(3.2rem,14vw,4.6rem);gap:1rem;transform:none;--greeting-shift: 0}.name-side{text-align:center}.name-side .my-name{font-size:clamp(2.5rem,10vw,3rem);line-height:1.08}.name-side .aka{margin-top:.35rem;font-size:.95rem}.blob-wrapper{width:260px;height:260px}.center{gap:1.4rem}.tagline{font-size:1.65rem;text-align:center;padding:0 1rem}.skills-marquee{margin-top:1.5rem;padding:0 .75rem}.skills-list{gap:.65rem}.skill-logo{height:38px}}@media(max-width:720px){.site-header{top:0;bottom:auto;padding:12px 0 0;background:transparent}.site-header-inner.abs-nav-layout{grid-template-columns:1fr auto;grid-template-areas:"logo icons";row-gap:0;min-height:auto;padding-top:.2rem;padding-bottom:0}.site-header-inner.abs-nav-layout.hide-sides .header-side.left-block,.site-header-inner.abs-nav-layout.hide-sides .header-side.right-block{visibility:hidden}.header-side.left-block{grid-area:logo}.header-side.right-block{grid-area:icons}.nav-center-slot{position:fixed;left:0;right:0;bottom:calc(10px + env(safe-area-inset-bottom,0px));z-index:1210;display:flex;justify-content:center;padding-left:max(8px,env(safe-area-inset-left,0px));padding-right:max(8px,env(safe-area-inset-right,0px));box-sizing:border-box;pointer-events:none}.nav-shell{width:100%;min-width:0}.logo-text{font-size:1.25rem}.icon-btn{width:32px;height:32px}.nav-menu{width:min(100%,calc(100vw - 16px - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px)));max-width:min(100%,calc(100vw - 16px - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px)));overflow-x:auto;justify-content:center;gap:.42rem;margin:0;background:#f7f7f5f5;border:1px solid #e5e7eb;box-shadow:0 8px 20px #0f172a1f;-webkit-backdrop-filter:saturate(150%) blur(8px);backdrop-filter:saturate(150%) blur(8px);pointer-events:auto;padding:6px .5rem;min-height:48px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}.nav-btn{font-size:.86rem;padding:0 .48rem;min-height:36px}.nav-menu:hover,.nav-menu:focus-within{background:#f7f7f5fa;border-color:#d7dce4;border-width:1px;box-shadow:0 10px 24px #0f172a24}.nav-menu::-webkit-scrollbar{display:none}.site-root>main{padding-top:92px;padding-bottom:calc(78px + env(safe-area-inset-bottom,0px))}.site-root>footer{padding:.6rem 1rem calc(78px + env(safe-area-inset-bottom,0px))!important}.hero-row{gap:1.9rem}.greeting{width:100%;justify-content:center;text-align:center}.name-side{padding:0 1rem}.chatbot-fab{right:max(.72rem,env(safe-area-inset-right,0px));bottom:calc(74px + env(safe-area-inset-bottom,0px));width:52px;height:52px}.chatbot-drawer{left:max(.6rem,env(safe-area-inset-left,0px));right:max(.6rem,env(safe-area-inset-right,0px));width:auto;max-width:none;bottom:calc(134px + env(safe-area-inset-bottom,0px));min-height:0;height:min(485px,calc(100dvh - 10.3rem));max-height:calc(100dvh - 9.3rem);border-radius:18px;padding:.72rem .72rem .45rem;gap:.62rem}.chatbot-head{gap:.42rem;padding-bottom:.22rem}.chatbot-head h3{font-size:.86rem}.chatbot-clear{padding:.3rem .46rem;font-size:.66rem}.chatbot-close{width:28px;height:28px}.chat-window{flex:1 1 auto;min-height:0;max-height:none;padding:.68rem;gap:.5rem}.chat-suggestions{gap:.32rem;margin-bottom:.05rem}.chat-suggestions button{padding:.32rem .54rem;font-size:.68rem}.chat-input-row{border-radius:14px;padding:.26rem;gap:.3rem}.chat-input-row textarea{min-height:32px;max-height:80px;font-size:.78rem;padding:.46rem .64rem}.chat-input-row button{max-width:80px;height:30px;font-size:.68rem}.contact-section{padding-bottom:calc(60px + env(safe-area-inset-bottom,0px))}}@media(max-width:520px){.hero-row{gap:1.6rem}.greeting{font-size:clamp(2.8rem,13vw,3.8rem)}.blob-wrapper{width:220px;height:220px}.name-side .my-name{font-size:2.4rem}.name-side .aka{font-size:.9rem;line-height:1.3}.tagline{font-size:1.4rem}.skills-marquee{max-width:100%;padding:0 .5rem}.site-root>main{padding-bottom:calc(74px + env(safe-area-inset-bottom,0px))}.site-root>footer{padding-bottom:calc(74px + env(safe-area-inset-bottom,0px))!important}.contact-section{padding-bottom:calc(46px + env(safe-area-inset-bottom,0px))}.chatbot-drawer{left:max(.45rem,env(safe-area-inset-left,0px));right:max(.45rem,env(safe-area-inset-right,0px));bottom:calc(126px + env(safe-area-inset-bottom,0px));height:min(465px,calc(100dvh - 9.7rem));max-height:calc(100dvh - 8.9rem);border-radius:16px;padding:.64rem .64rem .42rem}.chatbot-fab{width:50px;height:50px;right:max(.58rem,env(safe-area-inset-right,0px))}}@media(max-width:420px){.nav-menu{gap:.34rem;padding:6px .45rem;min-height:46px}.nav-btn{font-size:.8rem;padding:0 .4rem;min-height:34px}}@media(max-width:380px){.site-header-inner.abs-nav-layout{padding:0 10px}.nav-menu{gap:.28rem;height:46px;padding:6px .38rem}.nav-btn{font-size:.76rem;padding:0 .34rem}}.about-section{--about-space-xs: .28rem;--about-space-sm: .46rem;--about-space-md: .9rem;--about-space-lg: 1.25rem;--about-text-strong: #0f172a;--about-text-body: #3f3f46;--about-text-muted: #6b7280;--about-line-soft: rgba(17, 24, 39, .1);--about-ease-standard: cubic-bezier(.22, .61, .36, 1);--about-ease-soft: cubic-bezier(.25, .46, .45, .94);--about-duration-fast: .22s;--about-duration-base: .32s;--about-duration-slow: .42s;--about-stagger-step: 45ms;padding:6rem 2rem;max-width:1400px;margin:0 auto}@media(min-width:1024px){.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem}}.about-left{display:flex;justify-content:center;align-items:flex-start;margin-bottom:3rem}@media(min-width:1024px){.about-left{margin-bottom:0}}.preview-frame{width:min(560px,94vw);-webkit-user-select:none;user-select:none;touch-action:pan-y}.preview-titlebar{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:linear-gradient(180deg,#f7f7f7,#efefef);border-bottom:1px solid #e5e5e5}.traffic-lights{display:inline-flex;gap:6px}.traffic-lights .light{width:12px;height:12px;border-radius:50%;display:inline-block}.traffic-lights .red{background:#ff5f57}.traffic-lights .yellow{background:#ffbd2e}.traffic-lights .green{background:#28c840}.preview-title{font-size:.95rem;font-weight:600;color:#333}.preview-canvas{position:relative;aspect-ratio:5 / 4;padding:18px}.preview-window{position:absolute;inset:18px;border-radius:12px;overflow:hidden;background:#fff;border:1px solid #d9d9d9;box-shadow:0 18px 44px #00000029;display:flex;flex-direction:column}.preview-window-body{flex:1;background:#f1f5f9}.preview-window-body img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.preview-window.pos-b{z-index:0;transform:translate(10px,10px) rotate(2deg) scale(.97);filter:brightness(.94)}.preview-window.pos-a{z-index:1;transform:translate(6px,6px) rotate(-1.5deg) scale(.985);filter:brightness(.97);transition:transform .26s cubic-bezier(.22,.61,.36,1),filter .26s ease,box-shadow .26s ease}.preview-window.pos-a.promoting{transform:translate(0) rotate(0) scale(1);filter:brightness(1);box-shadow:0 20px 52px #0003}.preview-window.pos-top{z-index:2;will-change:transform;touch-action:pan-y}.preview-window.pos-top.animating{transition:transform .26s cubic-bezier(.22,.61,.36,1),opacity .26s ease,filter .26s ease,box-shadow .26s ease}.preview-window.pos-top.going-back{box-shadow:0 10px 26px #0000001f}.preview-hint{text-align:center;font-size:.8rem;color:#666;padding:.5rem}.about-right{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2rem}.about-right .about-block{width:min(820px,100%);display:grid;grid-template-rows:auto 1fr;justify-items:center;row-gap:1.25rem;transform:none}.about-heading{font-size:2.4rem;font-weight:760;margin:0;text-align:center;width:min(42ch,100%);font-family:Futura,Futura PT,Avenir Next,Montserrat,sans-serif;text-transform:uppercase;letter-spacing:.06em;text-shadow:none}.about-subheading{font-size:1.3rem;font-weight:600;margin:0 0 1.25rem}.about-paras{display:grid;place-items:center;font-size:clamp(1.08rem,1.5vw,1.28rem);font-weight:550;line-height:2;color:#2f2f33;letter-spacing:.018em;font-family:Avenir Next,Segoe UI,Helvetica Neue,Arial,sans-serif;padding:0;width:min(52ch,100%);min-height:17.4rem;max-height:14.4rem;overflow:hidden}.about-paras p{margin:0;display:block}.about-quote-body{position:relative;padding:1.2rem .9rem;width:100%;text-align:center}.about-quote-body:before,.about-quote-body:after{content:none}.about-quote-mark{display:inline;font-family:Georgia,Palatino Linotype,Times New Roman,serif;font-size:clamp(2.1rem,3.4vw,2.9rem);line-height:0;color:#1118276b;vertical-align:-.22em;font-style:normal;font-weight:700}.about-quote-mark:first-child{margin-right:.18rem}.about-quote-mark:last-child{margin-left:.18rem}.about-quote-text{display:inline;text-align:center;overflow-wrap:anywhere;word-break:break-word}.about-highlight{display:inline-block;font-size:clamp(1.28em,2vw,1.56em);font-family:Bungee,Rockwell,Rockwell Nova,Roboto Slab,serif;font-weight:900;letter-spacing:.04em;line-height:1.02;transform-origin:center;-webkit-text-stroke:1.2px #000;paint-order:stroke fill;text-shadow:-3px 2px 0 rgb(0 0 0),0 0 10px rgba(231,184,178,.5),0 6px 14px rgba(15,23,42,.18);filter:saturate(1.12)}.about-highlight:before{content:none}.about-highlight-sakura{color:#e7b8b2}.about-highlight-boba{color:#daab63}.about-highlight-babyblue{color:#6ec1e4;text-shadow:-3px 2px 0 #0a2540,0 0 10px #b3e6fc,0 6px 14px rgba(15,23,42,.18);-webkit-text-stroke:1.2px #0a2540}.about-highlight-cnyred{color:#e63946;text-shadow:-3px 2px 0 #7c1d1d,0 0 10px #ffb4b4,0 6px 14px rgba(230,57,70,.18);-webkit-text-stroke:1.2px #7c1d1d}.about-highlight-gold{color:gold;text-shadow:-3px 2px 0 #bfa100,0 0 10px #fff8dc,0 6px 14px rgba(255,215,0,.18);-webkit-text-stroke:1.2px #bfa100}.about-highlight-flower{color:#e75480;text-shadow:-3px 2px 0 #a8325a,0 0 10px #ffd1ea,0 6px 14px rgba(231,84,128,.18);-webkit-text-stroke:1.2px #a8325a}.about-highlight-cool{color:#00c3a0;text-shadow:-3px 2px 0 #00594c,0 0 10px #a0ffe6,0 6px 14px rgba(0,195,160,.18);-webkit-text-stroke:1.2px #00594c}.about-highlight-electric{color:#7df9ff;text-shadow:0 0 8px #00e1ff,0 0 18px #00e1ff,0 0 2px #fff,-3px 2px 0 #0a2540;-webkit-text-stroke:1.2px #0a2540}.about-photo-copy{will-change:opacity;transition:opacity .32s cubic-bezier(.33,1,.68,1)}.about-photo-copy.is-fading-out{opacity:.22}.about-photo-copy.is-fading-in{opacity:1}.edu-timeline{position:relative;padding-left:1.6rem;display:flex;flex-direction:column;gap:2.25rem;border-left:2px solid #e0e0e0}.edu-item{position:relative;display:flex;gap:.75rem;transition:transform .32s ease}.edu-item:hover{transform:translate(4px)}.edu-dot{position:absolute;left:-10px;top:4px;width:12px;height:12px;background:#222;border-radius:50%}.edu-content{display:flex;flex-direction:column;gap:2px}.edu-inst{font-size:1rem;font-weight:600;color:#111;margin:0}.edu-degree{font-size:.85rem;color:#555;margin:0}.edu-years{font-size:.65rem;letter-spacing:.5px;text-transform:uppercase;color:#777;margin:0}.skills-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}@media(min-width:640px){.skills-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:880px){.skills-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.skill-pill{text-align:center;padding:.5rem 1rem;font-size:.8rem;font-weight:500;background:#f2f2f2;color:#222;border-radius:9999px;transition:background .25s}.skill-pill:hover{background:#e6e6e6}.folder-toggle-group{display:flex;flex-wrap:nowrap;gap:var(--about-space-sm);padding:.35rem;background:#fafaf9d9;border:1px solid var(--about-line-soft);border-radius:9999px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}.folder-toggle-group::-webkit-scrollbar{display:none}.folder-tab{appearance:none;border:0;background:transparent;padding:.52rem .92rem;border-radius:9999px;font-weight:620;color:#4b5563;display:inline-flex;align-items:center;cursor:pointer;flex:0 0 auto;white-space:nowrap;transition:background var(--about-duration-fast) var(--about-ease-soft),color var(--about-duration-fast) var(--about-ease-soft),box-shadow var(--about-duration-fast) var(--about-ease-soft)}.folder-tab:hover{background:#f3f4f6}.folder-tab[aria-selected=true]{background:#111827;color:#f8fafc;box-shadow:0 4px 10px #11182729}.folder-panels{margin-top:1.45rem}.folder-panel{overflow:visible;transition:grid-template-rows var(--about-duration-base) var(--about-ease-soft),opacity var(--about-duration-base) var(--about-ease-soft),transform var(--about-duration-base) var(--about-ease-standard);display:grid;grid-template-rows:0fr;opacity:0;transform:translateY(8px);border:0;border-radius:0;background:transparent;box-shadow:none;will-change:opacity,transform}.folder-panel[hidden]{display:none!important}.folder-panel.show{grid-template-rows:1fr;opacity:1;transform:translateY(0)}.folder-panel-inner{min-height:0}.panel-topbar{display:flex;justify-content:flex-end;gap:1rem;flex-wrap:wrap;align-items:center;min-height:44px;padding:0 0 var(--about-space-md);border-bottom:1px solid var(--about-line-soft);background:transparent}.panel-caption{position:relative;z-index:1;display:inline-block;padding-left:.5rem;background:#f5f5f5;font-size:.83rem;font-weight:700;letter-spacing:.08em;color:#64748b;text-transform:uppercase}.folder-panel>div,.folder-panel .folder-list{min-height:0}.folder-list{list-style:none;margin:0;padding:var(--about-space-lg) 0 0;display:flex;flex-direction:column;gap:.22rem;position:relative}.folder-list:before{content:"";position:absolute;left:125px;top:var(--about-space-lg);bottom:0;width:1px;background:linear-gradient(to bottom,#64748b2b,#64748b0f)}.folder-item{position:relative;display:grid;grid-template-columns:102px minmax(0,1fr);gap:1.25rem;align-items:start;padding:.75rem 0 1.65rem;border:0;border-radius:0;background:transparent;box-shadow:none;transition:transform var(--about-duration-fast) var(--about-ease-standard),color var(--about-duration-fast) var(--about-ease-soft)}.folder-item:before{content:"";position:absolute;left:144px;right:0;bottom:0;height:1px;background:linear-gradient(90deg,var(--about-line-soft),rgba(17,24,39,0))}.folder-item:after{content:"";position:absolute;left:121px;top:.95rem;width:8px;height:8px;border-radius:50%;background:#334155;box-shadow:0 0 0 5px #f5f5f5fa}.folder-item:hover{transform:translate(2px)}.folder-item:last-child{padding-bottom:0}.folder-item:last-child:before{display:none}.folder-item-media{width:112px;height:112px;border-radius:24px;overflow:hidden;border:1px solid rgba(17,24,39,.1);background:linear-gradient(180deg,#f8fafc,#eef2f7);box-shadow:0 4px 10px #0f172a0d;display:grid;place-items:center;flex-shrink:0}.folder-item-media img{width:100%;height:100%;object-fit:cover;object-position:center;padding:0;background:transparent;display:block}.folder-item-media.is-photo img{object-fit:cover;object-position:center;padding:0;background:transparent}.folder-item-media.is-logo img{object-fit:contain;object-position:center;padding:0;background:transparent}.folder-item-media.is-techdome{background:#fff}.folder-item-placeholder{font-size:.78rem;font-weight:800;letter-spacing:.08em;color:#0f172a}.folder-item-body{min-width:0;padding-left:.98rem}.folder-item-body>strong{display:block;font-size:1.08rem;line-height:1.38;color:var(--about-text-strong);margin-bottom:.34rem}.edu-link{color:inherit;text-decoration:none;text-decoration-thickness:1px;text-underline-offset:2px;transition:color var(--about-duration-fast) var(--about-ease-soft),text-decoration-color var(--about-duration-fast) var(--about-ease-soft)}.edu-link:hover{color:#0f4fbf;text-decoration:underline;text-decoration-color:#0f4fbf}.edu-link:focus-visible{outline:2px solid #2563eb;outline-offset:3px;border-radius:4px}.folder-item-body>.muted{display:inline-block;margin-top:.22rem;margin-bottom:.72rem;padding:0;border:0;background:transparent;color:var(--about-text-muted);font-size:.78rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase}#panel-exp .folder-item-body>.muted{padding-left:.2rem}#panel-edu .folder-item-body>.muted{margin-left:.34rem}.folder-list ul{margin:.3rem 0 0 1.08rem;padding:0;display:grid;gap:.54rem}.folder-list li li{color:var(--about-text-body);line-height:1.68}.folder-list .muted{color:#6b7280;font-size:.82rem}.folder-list.animated-list .folder-item{opacity:0;transform:translateY(8px);animation:aboutItemIn var(--about-duration-slow) var(--about-ease-standard) forwards;animation-delay:calc(var(--item-index, 0) * var(--about-stagger-step));will-change:opacity,transform}@keyframes aboutItemIn{to{opacity:1;transform:translateY(0)}}.about-folders-row{margin-top:2.9rem;max-width:1060px;margin-left:auto;margin-right:auto;position:relative}.about-block{position:relative}.about-fade-init{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}.about-fade-in{opacity:1;transform:translateY(0)}@media(max-width:900px){.about-section{padding:4.5rem 1.25rem}.about-right{gap:2.2rem;align-items:stretch}.about-right .about-block{width:100%;align-items:center;transform:none;row-gap:1rem}.about-paras{min-height:unset;max-height:none;overflow:visible;width:100%;word-break:break-word}.about-heading{font-size:2rem;margin:0}.about-subheading{font-size:1.15rem;margin-bottom:.9rem}.panel-caption{width:100%}}.about-paras{font-size:1rem;min-height:unset;max-height:none;overflow:visible;width:100%;word-break:break-word}@media(max-width:640px){.about-paras .about-section{padding:4rem 1rem}.about-paras .preview-frame{width:100%}.about-paras .preview-canvas{padding:12px}.about-paras .preview-window{inset:12px}.about-paras .preview-window.pos-b{transform:translate(6px,6px) rotate(1.5deg) scale(.98)}.about-paras .preview-window.pos-a{transform:translate(3px,3px) rotate(-1deg) scale(.99)}.about-paras .folder-item{grid-template-columns:1fr;gap:.66rem;padding:.48rem 0 1.1rem .62rem}.about-paras .folder-list:before{left:12px}.about-paras .folder-item-media{width:94px;height:94px;border-radius:18px;margin-left:.16rem}.about-paras .folder-item:before{left:12px}.about-paras .folder-item:after{left:8px}.about-paras .folder-item-body{padding-left:.38rem}.about-paras .folder-item-body>strong{margin-bottom:.24rem;font-size:1.02rem}.about-paras .folder-list{padding:1rem 0 0 .3rem}}@media(prefers-reduced-motion:reduce){.about-paras .folder-panel,.about-paras .folder-item,.about-paras .folder-tab,.about-paras .about-photo-copy,.about-paras .folder-list.animated-list .folder-item{transition:none;animation:none;transform:none;filter:none}}@media(max-width:420px){.about-paras .about-heading{font-size:1.7rem}.about-paras .about-paras{font-size:.95rem;min-height:unset;max-height:none;overflow:visible;width:100%;word-break:break-word}.about-paras .about-quote-body{padding:.9rem .1rem 1.05rem}.about-paras .folder-tab{padding:.42rem .58rem;font-size:.84rem}}
