*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #242424;--bg-panel: #2d2d2d;--bg-hover: #363636;--bg-select: #3a3a3a;--accent: #00e676;--text: #e8e8e8;--text-muted: #a0a0a0;--text-faint: #888888;--tag-bg: #2a2a2a;--tag-border: #444444;--border: #333333;font-family:Courier New,Consolas,Fira Code,monospace;font-size:15px;line-height:1.6;color:var(--text);background-color:var(--bg);-webkit-font-smoothing:antialiased}html,body{height:100%;overflow:hidden}#root{height:100%;display:flex;flex-direction:column}@media (max-width: 640px){html,body{height:auto;overflow:auto}#root{height:auto;min-height:100vh}}a{color:var(--text-muted);text-decoration:none}a:hover{color:var(--accent)}button{background:none;border:none;cursor:pointer;font-family:inherit;font-size:inherit}code{font-family:inherit;color:var(--accent)}.app{max-width:1100px;margin:0 auto;padding:1.5rem 2rem 1rem;height:100%;display:flex;flex-direction:column;overflow:hidden}.site-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1rem;flex-shrink:0}.header-left{flex-shrink:1;min-width:0}.site-title{font-size:clamp(2.4rem,6vw,3.84rem);font-weight:900;color:var(--text);letter-spacing:-.02em;line-height:1}.header-nav{display:flex;flex-direction:column;gap:.3rem;padding-top:.15rem;flex-shrink:0;text-align:right}.hash-link{font-size:1.1rem;font-weight:700;color:var(--accent);text-decoration:none;transition:opacity .2s}.hash-link:hover{opacity:.75;color:var(--accent)}.header-contact{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:var(--text-muted);margin-top:.4rem}.header-contact a{color:var(--text-muted)}.header-contact a:hover{color:var(--accent)}.hero-bio{margin-bottom:.75rem;max-width:860px;border-left:2px solid var(--accent);padding-left:1.25rem;flex-shrink:0}.hero-bio p{font-size:.9rem;color:var(--text);line-height:1.6}.bio-toggle{font-size:.78rem;color:var(--accent);margin-top:.3rem;padding:0;background:none;border:none;cursor:pointer;font-family:inherit}.bio-mobile-only,.bio-desktop-only{display:inline}@media (min-width: 641px){.bio-mobile-only{display:none}}@media (max-width: 640px){.bio-desktop-only{display:none}}.section-nav{display:flex;align-items:center;gap:1.25rem;margin-bottom:.75rem;flex-wrap:wrap;flex-shrink:0}.snav-tag{font-size:1rem;font-weight:700;color:var(--accent);cursor:pointer;background:none;border:none;font-family:inherit;padding:0;transition:opacity .2s}.snav-tag:hover{opacity:.75}.snav-plain{font-size:1rem;color:var(--text-muted);cursor:pointer;background:none;border:none;font-family:inherit;padding:0;transition:color .2s}.snav-plain:hover,.snav-plain.snav-active{color:var(--text)}.snav-tag.snav-active{opacity:1}.section{flex:1;min-height:0;overflow:hidden;margin-bottom:0}.exp-layout{display:flex;gap:0;height:100%;border:1px solid var(--border);border-radius:4px;overflow:hidden}.file-tree{width:240px;flex-shrink:0;background:var(--bg-panel);border-right:1px solid var(--border);padding:.75rem 0;font-size:.85rem;overflow-y:auto}.tree-company{display:flex;align-items:center;gap:.5rem;width:100%;text-align:left;padding:.4rem .75rem;color:var(--accent);font-weight:700;font-size:.82rem;cursor:pointer;transition:background .15s}.tree-company:hover{background:var(--bg-hover)}.tree-arrow{font-size:.65rem;color:var(--text-faint);flex-shrink:0}.tree-roles{padding-left:.5rem}.tree-role{display:flex;align-items:center;gap:.5rem;width:100%;text-align:left;padding:.35rem .75rem;color:var(--text-muted);cursor:pointer;font-size:.82rem;transition:background .15s;border-radius:2px}.tree-role:hover{background:var(--bg-hover);color:var(--text)}.tree-role-active{background:var(--bg-select)!important;color:var(--text)!important}.tree-file-icon{font-size:.7rem;flex-shrink:0}.role-detail{flex:1;padding:1.25rem 1.5rem;background:var(--bg);overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;min-width:0}.role-header{display:flex;align-items:flex-start;gap:1rem;flex-shrink:0}.role-header-left{flex-shrink:0}.role-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:1rem}.role-empty{color:var(--text-faint);font-style:italic}.role-title{font-size:1.15rem;font-weight:700;color:var(--text);margin-bottom:.25rem}.role-subtitle{font-size:.82rem;color:var(--accent);margin-bottom:.1rem}.role-period{font-size:.82rem;color:var(--text-faint)}.tree-role-title{color:inherit}.tree-role-sub{font-size:.72rem;color:var(--text-faint)}.role-bullets{list-style:none;display:flex;flex-direction:column;gap:.55rem;margin-bottom:1.5rem}.role-bullets li{font-size:.88rem;color:var(--text-muted);line-height:1.65;padding-left:1.25rem;position:relative}.role-bullets li:before{content:"•";position:absolute;left:0;color:var(--text-faint)}.stat-strip{display:flex;flex-direction:row;gap:.85rem;flex-wrap:wrap;align-items:flex-start;padding-top:1.5rem}.stat-card{display:flex;flex-direction:column;align-items:center;background:var(--bg-panel);border:1px solid var(--border);border-top:2px solid var(--accent);border-radius:4px;padding:.45rem .5rem}.stat-value{font-size:1.15rem;font-weight:900;color:var(--accent);line-height:1;margin-bottom:.2rem}.stat-label{font-size:.58rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;text-align:center;line-height:1.3}.role-bullets li{display:flex;align-items:baseline;gap:.65rem;padding-left:0}.role-bullets li:before{display:none}.bullet-cat{font-size:.62rem;font-weight:700;letter-spacing:.1em;color:var(--accent);background:#00e67614;border:1px solid rgba(0,230,118,.2);border-radius:3px;padding:.15rem .4rem;flex-shrink:0;align-self:flex-start;margin-top:.2rem}.bullet-text{color:var(--text-muted);font-size:.88rem;line-height:1.65}.num-highlight{color:var(--accent);font-weight:700}.role-tags{display:flex;flex-wrap:wrap;gap:.5rem}.role-tag{font-size:.78rem;padding:.25rem .7rem;background:var(--tag-bg);border:1px solid var(--tag-border);border-radius:20px;color:var(--text-muted)}.projects-desktop{display:flex;flex-direction:column;gap:1.5rem}.projects-mobile{display:none;flex-direction:column;gap:0}@media (max-width: 640px){.projects-desktop{display:none}.projects-mobile{display:flex}}.proj-accordion{border:1px solid var(--border);border-radius:4px;overflow:hidden;margin-bottom:.5rem;background:var(--bg-panel)}.proj-accordion-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.85rem 1rem;background:none;border:none;cursor:pointer;font-family:inherit;gap:.75rem;text-align:left}.proj-accordion-title{display:flex;flex-direction:column;gap:.15rem;flex:1;min-width:0}.proj-accordion-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.proj-chevron{font-size:.6rem;color:var(--text-faint)}.proj-accordion-body{padding:.85rem 1rem 1rem;display:flex;flex-direction:column;gap:.75rem;border-top:1px solid var(--border)}.section-scroll{height:100%;overflow-y:auto;padding-right:.5rem}.projects-list{display:flex;flex-direction:column;gap:1.5rem}.proj-card{border:1px solid var(--border);border-radius:4px;padding:1.5rem;background:var(--bg-panel);display:flex;flex-direction:column;gap:.65rem}.proj-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.proj-name{font-size:1.1rem;font-weight:700;color:var(--text)}.proj-link{font-size:.85rem;color:var(--accent);font-weight:600}.proj-subtitle{font-size:.85rem;color:var(--accent)}.proj-desc{font-size:.88rem;color:var(--text-muted);line-height:1.65}.proj-demo{font-size:.8rem;color:var(--text-faint)}.skills-list{display:flex;flex-direction:column;gap:1.1rem}.skill-row{display:flex;align-items:flex-start;gap:1.5rem;flex-wrap:wrap}.skill-cat{font-size:.82rem;font-weight:700;color:var(--accent);min-width:130px;padding-top:.25rem;flex-shrink:0}.edu-entry{border:1px solid var(--border);border-radius:4px;padding:1.5rem;background:var(--bg-panel)}.edu-school{font-size:.9rem;color:var(--text-muted);margin-top:.75rem}.edu-cred{font-size:.85rem;color:var(--accent);margin-top:.3rem}.site-footer{flex-shrink:0;padding-top:.75rem}.section-nav-footer{margin-bottom:.75rem}.footer-title{font-size:clamp(2.4rem,6vw,3.84rem);font-weight:900;color:var(--text);letter-spacing:-.02em}@media (max-width: 640px){.exp-layout{flex-direction:column}.file-tree{width:100%;border-right:none;border-bottom:1px solid var(--border)}.skill-row{flex-direction:column;gap:.5rem}.role-header{flex-direction:column}.stat-strip{padding-top:0}.app{height:auto;min-height:100vh;overflow:visible;padding:1.25rem 1rem}.section{overflow:visible;min-height:auto}.exp-layout{height:auto;min-height:300px}.file-tree,.role-detail{overflow-y:visible;height:auto}.section-scroll{height:auto;overflow-y:visible}}
