*,*:before,*:after{box-sizing:border-box}:root{--bg: #0a0a0b;--bg-elevated: #141416;--bg-card: #18181b;--text: #fafafa;--text-muted: #a1a1aa;--accent: #a855f7;--accent-hover: #c084fc;--accent-dim: rgba(168, 85, 247, .15);--border: #27272a;--radius: 12px;--radius-sm: 8px;--font-sans: "DM Sans", system-ui, sans-serif;--font-display: "Outfit", system-ui, sans-serif;--transition: .25s cubic-bezier(.4, 0, .2, 1);--shadow: 0 4px 24px rgba(0, 0, 0, .3);--shadow-hover: 0 12px 40px rgba(168, 85, 247, .12)}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;font-family:var(--font-sans);font-size:1rem;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.2;margin:0 0 .5em}h1{font-size:clamp(2rem,5vw,3rem)}h2{font-size:clamp(1.5rem,3vw,2rem)}h3{font-size:1.25rem}p{margin:0 0 1em;color:var(--text-muted)}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-hover)}button{font-family:var(--font-sans);cursor:pointer}img{max-width:100%;height:auto;display:block}.container{width:100%;max-width:1100px;margin:0 auto;padding:0 1.5rem}.page{flex:1;padding:2rem 0 4rem}.page-title{margin-bottom:2rem;color:var(--text)}.page-title .accent,.section-title .accent{color:var(--accent)}.page-intro{max-width:36em;margin-bottom:2.5rem}.hero{padding:3rem 0 4rem}.hero-inner{display:flex;flex-wrap:wrap;align-items:center;gap:2rem;max-width:56em}.hero-text{flex:1;min-width:0}.hero-avatar{flex-shrink:0;margin-left:auto}.hero-avatar img{width:200px;height:200px;border-radius:var(--radius);object-fit:cover;border:2px solid var(--border);box-shadow:var(--shadow)}@media(min-width:520px){.hero-avatar img{width:260px;height:260px}}.hero-label{font-size:.95rem;color:var(--accent);font-weight:500;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.08em}.hero-title{font-size:clamp(2.25rem,6vw,3.25rem);font-weight:700;letter-spacing:-.03em;margin-bottom:1rem;color:var(--text)}.hero-subtitle{font-size:1.1rem;line-height:1.65;color:var(--text-muted);margin-bottom:2rem}.hero-subtitle .highlight{color:var(--accent);font-weight:500}.working-on-section{padding:2rem 0 3rem}.working-on-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}@media(max-width:700px){.working-on-grid{grid-template-columns:1fr}}.working-on-card{position:relative;padding:1.35rem 1.5rem 1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:border-color var(--transition),box-shadow var(--transition);overflow:hidden}.working-on-card:before{content:"";position:absolute;inset:0 0 auto;height:3px;background:linear-gradient(90deg,var(--accent),rgba(168,85,247,.35));opacity:.95}.working-on-card:hover{border-color:#a855f738;box-shadow:var(--shadow-hover)}.working-on-card-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.85rem}.working-on-pulse{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 #22c55e73;animation:working-on-pulse 2s ease-out infinite}@keyframes working-on-pulse{0%{box-shadow:0 0 #22c55e73}70%{box-shadow:0 0 0 8px #22c55e00}to{box-shadow:0 0 #22c55e00}}@media(prefers-reduced-motion:reduce){.working-on-pulse{animation:none;box-shadow:none}}.working-on-label{font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.working-on-title{margin:0 0 .35rem;font-size:1.15rem;font-family:var(--font-display);font-weight:600;color:var(--text);line-height:1.3}.working-on-context{margin:0 0 .65rem;font-size:.85rem;color:var(--accent);font-weight:500}.working-on-desc{margin:0 0 1rem;font-size:.95rem;line-height:1.55;color:var(--text-muted)}.working-on-desc:last-child{margin-bottom:0}.working-on-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin:0 0 .85rem;padding:0;list-style:none}.working-on-tags li{font-size:.75rem;padding:.2rem .55rem;border-radius:999px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted)}.working-on-link{display:inline-flex;align-items:center;font-size:.9rem;font-weight:500}.working-on-card .working-on-link{margin-top:.25rem}.experience-section{padding:4rem 0 2rem;border-top:1px solid var(--border)}.experience-list{display:flex;flex-direction:column;gap:1.25rem}.experience-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:box-shadow var(--transition),border-color var(--transition);overflow:hidden}.experience-card:hover{border-color:#a855f733}.experience-card.is-expanded{box-shadow:var(--shadow-hover);border-color:#a855f740}.experience-card-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem;text-align:left;background:none;border:none;cursor:pointer;color:inherit;font:inherit;transition:background var(--transition)}.experience-card-trigger:hover{background:#a855f70f}.experience-trigger-text{display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem .75rem;min-width:0}.experience-chevron{flex-shrink:0;color:var(--text-muted);transition:transform var(--transition),color var(--transition)}.experience-card-trigger:hover .experience-chevron,.experience-card.is-expanded .experience-chevron{color:var(--accent)}.experience-card.is-expanded .experience-chevron{transform:rotate(180deg)}.experience-card-details{overflow:hidden;max-height:0;border-top:1px solid transparent;transition:max-height .4s cubic-bezier(.4,0,.2,1)}.experience-card.is-expanded .experience-card-details{max-height:120rem;border-top-color:var(--border)}.experience-card-details .experience-content{padding:1.75rem}.experience-card--with-image{padding:0}.experience-card--with-image .experience-content{padding:1.75rem}.experience-image--banner{width:100%;height:0;padding-bottom:38%;position:relative;overflow:hidden;background:var(--bg-elevated)}.experience-image--banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center center}.experience-image--banner:after{content:"";position:absolute;inset:0;border-radius:var(--radius) var(--radius) 0 0;box-shadow:inset 0 0 0 1px var(--border),inset 0 -60px 40px -20px #0a0a0bb3;pointer-events:none}.experience-header{display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem .75rem;margin-bottom:.75rem}.experience-role{margin:0;font-size:1.15rem;color:var(--text);width:100%}.experience-org{font-size:.95rem;color:var(--accent);font-weight:500}.experience-meta{font-size:.85rem;color:var(--text-muted);opacity:.9}.experience-bullets{margin:0;padding-left:1.25rem;font-size:.95rem;color:var(--text-muted);line-height:1.6}.experience-bullets li{margin-bottom:.5rem}.experience-bullets li:last-child{margin-bottom:0}.experience-bullets strong{color:var(--text);font-weight:600}.experience-desc{margin:0;font-size:.95rem;color:var(--text-muted);line-height:1.55}.projects-section{padding:4rem 0 2rem;border-top:1px solid var(--border)}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}@media(max-width:640px){.projects-grid{grid-template-columns:1fr}}.section-title{margin-bottom:.5rem;color:var(--text)}.section-intro{margin-bottom:2rem;color:var(--text-muted)}.tech-stack-section{padding:4rem 0 2rem;border-top:1px solid var(--border)}.tech-stack-section .section-intro{max-width:34em;margin-bottom:1.75rem}.tech-stack-panel{position:relative;border-radius:var(--radius);border:1px solid rgba(39,39,42,.45);background:#18181b59;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:none;overflow:hidden}.tech-stack-panel:before{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(120% 80% at 100% 0%,rgba(168,85,247,.04) 0%,transparent 55%);pointer-events:none}.tech-stack-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem 1.5rem;padding:1.5rem 1.5rem 1.35rem}.tech-stack-group{padding:.15rem 0 .35rem}.tech-stack-group[data-tone="1"]{border-left:3px solid #a855f7;padding-left:1rem;margin-left:-1px}.tech-stack-group[data-tone="2"]{border-left:3px solid #38bdf8;padding-left:1rem;margin-left:-1px}.tech-stack-group[data-tone="3"]{border-left:3px solid #e879f9;padding-left:1rem;margin-left:-1px}.tech-stack-group-title{display:flex;align-items:center;gap:.5rem;margin:0 0 .85rem;font-family:var(--font-display);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.tech-stack-group-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:var(--accent);opacity:.85}.tech-stack-group[data-tone="1"] .tech-stack-group-dot{background:#a855f7;box-shadow:0 0 6px #a855f759}.tech-stack-group[data-tone="2"] .tech-stack-group-dot{background:#38bdf8;box-shadow:0 0 6px #38bdf84d}.tech-stack-group[data-tone="3"] .tech-stack-group-dot{background:#e879f9;box-shadow:0 0 6px #e879f94d}.tech-stack-pills{display:flex;flex-wrap:wrap;gap:.45rem .5rem;margin:0;padding:0;list-style:none}.tech-pill{display:inline-flex;align-items:center;gap:.45rem;padding:.35rem .65rem .35rem .5rem;font-size:.8125rem;font-weight:500;color:var(--text-muted);background:#0a0a0b40;border:1px solid rgba(39,39,42,.6);border-radius:6px;font-family:ui-monospace,SF Mono,Cascadia Code,monospace;transition:color var(--transition),border-color var(--transition),background var(--transition)}.tech-pill-icon{flex-shrink:0;display:block;opacity:.92}.tech-pill-icon--white{color:#f4f4f5;opacity:1}.tech-pill-icon--white svg{stroke:#f4f4f5}.tech-pill-icons--pair{display:inline-flex;align-items:center;gap:.12rem}.tech-pill-label{line-height:1.2}.tech-pill:hover{color:var(--text);border-color:#a855f759;background:#a855f714}.tech-pill:hover .tech-pill-icon{opacity:1}@media(max-width:640px){.tech-stack-grid{grid-template-columns:1fr;padding:1.25rem 1.15rem 1rem;gap:.75rem 0}.tech-stack-group[data-tone]{border-left:none;border-top:3px solid var(--border);padding-left:0;padding-top:.85rem;margin-left:0}.tech-stack-group[data-tone="1"]{border-top-color:#a855f7}.tech-stack-group[data-tone="2"]{border-top-color:#38bdf8}.tech-stack-group[data-tone="3"]{border-top-color:#e879f9}}.hobbies-section{padding:4rem 0 2rem;border-top:1px solid var(--border)}.hobbies-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.hobby-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:1.5rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--transition),box-shadow var(--transition)}.hobby-card:hover{border-color:#a855f740;box-shadow:var(--shadow-hover)}.hobby-icon{font-size:2rem;line-height:1}.hobby-label{font-family:var(--font-display);font-weight:500;font-size:.95rem;color:var(--text)}.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;border-radius:var(--radius-sm);transition:background var(--transition),color var(--transition),transform var(--transition)}.btn-primary{background:var(--accent);color:#fff;border:none}.btn-primary:hover{background:var(--accent-hover);color:#fff;transform:translateY(-1px)}.btn-secondary{background:transparent;color:var(--text);border:2px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.quick-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.quick-link{display:block;padding:1.5rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:box-shadow var(--transition),border-color var(--transition),transform var(--transition)}.quick-link:hover{box-shadow:var(--shadow-hover);border-color:#a855f759;transform:translateY(-2px)}.quick-link-title{display:block;font-family:var(--font-display);font-weight:600;font-size:1.1rem;color:var(--text);margin-bottom:.25rem}.quick-link-desc{font-size:.9rem;color:var(--text-muted)}.quick-link-arrow{display:inline-block;margin-top:.75rem;font-size:1rem;color:var(--accent);transition:transform var(--transition)}.quick-link:hover .quick-link-arrow{transform:translate(4px)}.project-card{padding:0;overflow:hidden;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);display:flex;flex-direction:column;min-height:100%;transition:border-color var(--transition),box-shadow var(--transition)}.project-card:hover{border-color:#a855f759;box-shadow:0 8px 32px #0003}.project-card-media-wrap{position:relative;width:100%;aspect-ratio:16 / 10;background:#0003;border-bottom:1px solid var(--border)}.project-card-media-wrap--contain{display:flex;align-items:center;justify-content:center;padding:.65rem .85rem;background:radial-gradient(100% 80% at 50% 20%,#a855f712,#00000047),#0c0c0ed9;aspect-ratio:16 / 11}.project-card-media{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}.project-card-media--pos-center{object-position:center center}.project-card-media.project-card-media--contain{width:auto;height:auto;max-width:94%;max-height:94%;object-fit:contain;object-position:center center}.project-card-body{padding:1.5rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.project-card-title{margin:0;font-size:1.1rem;font-weight:600;color:var(--text)}.project-card-desc{font-size:.9rem;margin:0;color:var(--text-muted);line-height:1.5;flex:1}.project-card-link{font-size:.875rem;font-weight:600;margin-top:.5rem;color:var(--accent)}.project-card-link:hover{color:var(--accent-hover)}.project-languages{margin-top:.25rem}.project-lang-bar{display:flex;flex-direction:row;width:100%;height:8px;border-radius:999px;overflow:hidden;background:var(--border)}.project-lang-segment{flex-shrink:0;min-width:2px;height:100%;transition:opacity var(--transition)}.project-lang-legend{display:flex;flex-wrap:wrap;gap:.5rem .85rem;margin:.5rem 0 0;padding:0;list-style:none;font-size:.75rem;color:var(--text-muted)}.project-lang-legend li{display:inline-flex;align-items:center;gap:.35rem}.project-lang-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.project-lang-name{color:var(--text-muted)}.project-lang-pct{color:var(--text-muted);opacity:.85;font-variant-numeric:tabular-nums}.projects-empty,.blog-empty{grid-column:1 / -1;text-align:center;padding:3rem 2rem;background:var(--bg-card);border:1px dashed var(--border);border-radius:var(--radius)}.projects-empty-icon,.blog-empty-icon{font-size:2.5rem;color:var(--border);margin-bottom:1rem;opacity:.8}.projects-empty h3,.blog-empty h3{margin-bottom:.5rem;color:var(--text)}.projects-empty code,.blog-empty code{padding:.15em .4em;font-size:.9em;background:var(--bg);border-radius:4px;color:var(--accent)}.blog-list{display:flex;flex-direction:column;gap:1rem;max-width:36em}.blog-card{padding:1.5rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--transition),box-shadow var(--transition)}.blog-card:hover{border-color:#a855f740;box-shadow:var(--shadow)}.blog-date{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:.35rem}.blog-card-title{margin-bottom:.35rem;font-size:1.1rem}.blog-card-excerpt{font-size:.95rem;margin-bottom:.75rem}.blog-card-link{font-size:.9rem;font-weight:600}.site-header{position:sticky;top:0;z-index:100;background:#0a0a0bd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:4rem}.logo{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--text);letter-spacing:-.02em}.logo:hover{color:var(--accent)}.header-socials{display:flex;align-items:center;gap:.5rem}.header-social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;color:var(--text-muted);transition:color var(--transition),background var(--transition),border-color var(--transition)}.header-social-link:hover{color:var(--accent);background:var(--accent-dim)}.main{flex:1;display:flex;flex-direction:column}.site-footer{margin-top:auto;padding:2.5rem 0;border-top:1px solid var(--border);background:var(--bg-elevated)}.footer-inner{text-align:center}.footer-text{margin:0 0 1rem;font-size:.9rem;color:var(--text-muted)}.social-links{display:flex;align-items:center;justify-content:center;gap:1.25rem;margin-bottom:1.5rem}.social-link{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);transition:color var(--transition),background var(--transition),border-color var(--transition)}.social-link:hover{color:var(--accent);background:var(--accent-dim);border-color:#a855f759}.footer-copy{margin:0;font-size:.8rem;color:var(--text-muted);opacity:.8}@media(max-width:640px){.header-social-link{width:32px;height:32px}}
