@import"https://fonts.bunny.net/css?family=fantasque-sans-mono:400,700";:root{--bg: #0f172a;--bg-soft: #111827;--text: #e5e7eb;--muted: #94a3b8;--card: #111827;--card-raised: #0b1222;--border: #1f2937;--border-strong: #273449;--accent: #7c3aed;--accent-soft: rgba(124, 58, 237, .18);--shadow: 0 24px 60px -32px rgba(0, 0, 0, .6)}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:radial-gradient(120% 120% at 20% 12%,rgba(124,58,237,.06),transparent 45%),radial-gradient(140% 140% at 82% 0%,rgba(14,165,233,.05),transparent 52%),linear-gradient(180deg,#111827,#0d1426 60%,#0a0f1d);color:var(--text);font-family:Fantasque Sans Mono,Inter,SF Pro Display,system-ui,sans-serif;-webkit-font-smoothing:antialiased;position:relative;overflow-x:hidden}#root{min-height:100vh;position:relative;z-index:1}a{color:var(--text);text-decoration:underline;text-decoration-color:#7c3aed59;text-decoration-thickness:2px}.app-shell{max-width:1000px;margin:0 auto;padding:36px 22px 88px}.site-header{display:grid;grid-template-columns:minmax(0,1fr) minmax(180px,220px);align-items:start;gap:24px;padding-bottom:32px;border-bottom:1px solid var(--border-strong)}.header-text{display:flex;flex-direction:column;gap:8px}.hero-name{margin:0;font-size:clamp(38px,5vw,56px);letter-spacing:.08em;font-family:Fantasque Sans Mono,Courier New,ui-monospace,SFMono-Regular,monospace}.hero-headline{margin:0;color:#cbd5e1;font-size:18px;font-weight:500}.hero-contact{margin:6px 0 0;color:var(--muted);font-size:15px}.header-actions{margin-top:12px}.summary-inline{margin:18px 0 0;color:#cbd5e1;font-weight:600;font-size:18px;text-align:left}.ghost-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:14px;background:#7c3aed52;color:#e9d5ff;border:1px solid rgba(124,58,237,.48);text-decoration:none;font-size:14px;font-weight:600;transition:all .2s ease}.ghost-button:hover{background:#7c3aed66;transform:translateY(-1px);box-shadow:0 10px 25px -20px #7c3aed99}.ghost-button--secondary{background:#0ea5e93d;border-color:#0ea5e966;color:#dbeafe}.ghost-button--secondary:hover{background:#0ea5e952;box-shadow:0 10px 25px -20px #0ea5e999}.header-photo{width:min(200px,28vw);aspect-ratio:1 / 1;border-radius:22px;border:1px solid var(--border-strong);box-shadow:inset 0 0 0 1px #ffffff0f,0 20px 38px -28px #000;justify-self:end;align-self:start;overflow:hidden;background:#0b1222;cursor:pointer;transform-style:preserve-3d}.header-photo img{width:100%;height:100%;object-fit:cover;backface-visibility:hidden}.header-photo.is-spinning{animation:profile-spin .9s ease-in-out;transform-origin:center}@media (max-width: 780px){.site-header{grid-template-columns:1fr;justify-items:center;text-align:center}.header-text{align-items:center}.hero-contact{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.header-actions{width:100%;display:flex;justify-content:center}.summary-card{max-width:480px}.header-photo{order:-1;justify-self:center;margin-bottom:8px}}.dwasm-launch{display:flex;justify-content:center;margin:64px 0 0}.dwasm-launch button:disabled{opacity:.45;cursor:not-allowed}.section-grid{margin:48px auto 0;display:grid;grid-template-columns:repeat(2,minmax(300px,1fr));gap:24px;max-width:880px}.resume-card{background:var(--card);border:1px solid var(--border-strong);border-radius:18px;padding:22px 24px 18px;text-align:left;box-shadow:0 8px 18px -16px #0009;cursor:pointer;transition:all .2s ease;color:var(--text)}.resume-card:hover,.resume-card:focus-visible{outline:none;transform:translateY(-4px);border-color:#7c3aed80;box-shadow:0 18px 38px -24px #000c,0 0 0 1px #7c3aed66}.resume-card.is-active{border-color:#7c3aedcc;box-shadow:0 18px 38px -20px #7c3aed66}.card-heading{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;letter-spacing:.01em}.card-icon{font-size:20px}.card-title{color:#e5e7eb}.card-short{margin:10px 0 0;color:var(--muted);font-size:14px;line-height:1.5}.expanded-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#06080fb3;display:flex;align-items:center;justify-content:center;padding:18px;z-index:20;animation:overlayIn .16s ease forwards}.expanded-overlay.is-exiting{animation:overlayOut .16s ease-in forwards}.expanded-card{width:min(960px,100%);max-height:88vh;background:var(--card);border-radius:18px;border:1px solid var(--border-strong);box-shadow:var(--shadow);padding:22px 24px 26px;overflow:hidden;display:flex;flex-direction:column;animation:cardIn .18s ease-out forwards}.expanded-card.is-exiting{animation:cardOut .16s ease-in forwards}.expanded-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;border-bottom:1px solid var(--border-strong);padding-bottom:12px}.expanded-title{display:flex;align-items:center;gap:12px}.expanded-title h2{margin:4px 0 0;font-size:24px}.eyebrow{margin:0;text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--muted);font-weight:700}.close-button{border:1px solid var(--border);background:#1f2937;padding:6px 10px;min-width:32px;border-radius:10px;font-weight:700;cursor:pointer;color:#e5e7eb;transition:all .2s ease;font-size:18px;line-height:1}.close-button:hover{background:#273449}.expanded-body{overflow-y:auto;padding-right:6px;margin-right:2px}.detail-paragraph{margin:12px 0 0;line-height:1.6;color:#e9ecf5;font-size:17px}.detail-block{margin-top:16px}.titled-paragraph{border:1px solid var(--border);border-radius:12px;padding:12px;background:#0f172a80}.titled-paragraph__title{margin:0;text-transform:uppercase;letter-spacing:.04em;font-weight:700;color:#a7b9e7}.titled-paragraph__body{margin:8px 0 0}.paragraph-image-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.paragraph-image-card{border:1px solid var(--border);border-radius:14px;padding:12px;background:#0f172a73;display:flex;flex-direction:column;gap:8px}.paragraph-image-text{font-size:14px;color:#ced7f3;margin:4px 0 0}.paragraph-image-media{width:100%;border-radius:12px;overflow:hidden;border:1px solid var(--border-strong);margin-bottom:6px}.paragraph-image-media img{display:block;width:100%;height:auto}.detail-block h3,.detail-block h4{margin:0;color:#e2e8f0}.detail-list{margin:10px 0 0 18px;color:var(--muted);line-height:1.6;padding:0}.detail-list li{margin-bottom:6px}.experience-items,.education-items{display:flex;flex-direction:column;gap:14px;margin-top:8px}.experience-item,.education-item{padding:12px 12px 6px;border:1px solid var(--border);border-radius:12px;background:var(--card-raised)}.education-logo{width:80px;height:80px;border-radius:12px;overflow:hidden;border:1px solid var(--border-strong);background:#0f172a;margin-left:auto}.education-logo img{width:100%;height:100%;object-fit:contain;display:block}.experience-body,.education-body{display:flex;flex-direction:column;gap:10px;margin-top:8px}.experience-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.experience-head h4{margin:2px 0 0;font-size:17px}.experience-dates{margin:0;color:var(--muted);font-weight:600;font-size:13px}.dwasm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#06080fd1;display:flex;align-items:center;justify-content:center;padding:18px;z-index:30;animation:overlayIn .16s ease forwards}.dwasm-card{width:min(1400px,96vw);max-height:90vh;background:var(--card);border-radius:20px;border:1px solid var(--border-strong);box-shadow:var(--shadow);padding:20px 22px 18px;display:flex;flex-direction:column;gap:14px}.dwasm-header{display:flex;justify-content:flex-end;align-items:center;gap:12px;border-bottom:none;padding-bottom:4px;margin-bottom:6px}.dwasm-title{margin:4px 0 0;font-size:22px}.dwasm-subtitle{margin:6px 0 0;color:#cbd5e1;line-height:1.5}.dwasm-body{display:flex;flex-direction:column;gap:12px;flex:1}.dwasm-callouts{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.dwasm-frame{width:100%;aspect-ratio:4 / 3;height:auto;flex:1;min-height:560px;max-height:76vh;border-radius:14px;border:1px solid var(--border-strong);background:#000;box-shadow:inset 0 0 0 1px #ffffff0a}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}@keyframes overlayOut{0%{opacity:1}to{opacity:0}}@keyframes cardIn{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes cardOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(8px) scale(.98)}}@keyframes profile-spin{0%{transform:rotateY(0)}50%{transform:rotateY(180deg)}to{transform:rotateY(360deg)}}@media (max-width: 640px){.app-shell{padding:28px 18px 72px}.header-photo{width:140px;height:140px}.section-grid{grid-template-columns:1fr}.expanded-card{padding:18px}.expanded-title h2{font-size:20px}}
