*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:JetBrains Mono,Fira Code,Menlo,Monaco,Courier New,monospace;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;font-size:13px;line-height:1.5}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea{font-family:inherit;font-size:inherit}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}ul{list-style:none}:root{--bg-primary: #1e1e1e;--bg-secondary: #252526;--bg-sidebar: #181818;--bg-activitybar: #1c1c1c;--bg-tab-inactive: #2d2d2d;--bg-input: #3c3c3c;--bg-hover: #2a2d2e;--bg-active: #37373d;--bg-overlay: #252526;--border: #2d2d30;--border-strong: #454545;--text-primary: #d4d4d4;--text-secondary: #a0a0a0;--text-muted: #6e7681;--text-bright: #ffffff;--accent: #007acc;--accent-hover: #1f9cf0;--statusbar: #007acc;--statusbar-text: #ffffff;--selection: rgba(38, 79, 120, .6);--scrollbar: rgba(121, 121, 121, .4);--scrollbar-hover: rgba(150, 150, 150, .7);--focus-ring: #007fd4;--syn-keyword: #c586c0;--syn-keyword2: #569cd6;--syn-string: #ce9178;--syn-comment: #6a9955;--syn-number: #b5cea8;--syn-function: #dcdcaa;--syn-variable: #9cdcfe;--syn-property: #9cdcfe;--syn-type: #4ec9b0;--syn-constant: #569cd6;--syn-operator: #d4d4d4;--syn-punctuation: #d4d4d4;--syn-tag: #569cd6;--syn-attr: #9cdcfe;--syn-bracket: #ffd700;--syn-regex: #d16969;--folder-color: #c09553}[data-theme=github]{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-sidebar: #010409;--bg-activitybar: #010409;--bg-tab-inactive: #0d1117;--bg-input: #0d1117;--bg-hover: #161b22;--bg-active: #1f2937;--bg-overlay: #161b22;--border: #21262d;--border-strong: #30363d;--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #6e7681;--text-bright: #ffffff;--accent: #2f81f7;--accent-hover: #58a6ff;--statusbar: #161b22;--statusbar-text: #e6edf3;--selection: rgba(56, 139, 253, .4);--scrollbar: rgba(110, 118, 129, .4);--scrollbar-hover: rgba(110, 118, 129, .7);--focus-ring: #2f81f7;--syn-keyword: #ff7b72;--syn-keyword2: #ff7b72;--syn-string: #a5d6ff;--syn-comment: #8b949e;--syn-number: #79c0ff;--syn-function: #d2a8ff;--syn-variable: #e6edf3;--syn-property: #79c0ff;--syn-type: #ffa657;--syn-constant: #79c0ff;--syn-operator: #ff7b72;--syn-punctuation: #c9d1d9;--syn-tag: #7ee787;--syn-attr: #79c0ff;--syn-bracket: #f0883e;--syn-regex: #7ee787;--folder-color: #7d8590}[data-theme=dracula]{--bg-primary: #282a36;--bg-secondary: #21222c;--bg-sidebar: #21222c;--bg-activitybar: #191a21;--bg-tab-inactive: #21222c;--bg-input: #1e1f29;--bg-hover: #313342;--bg-active: #44475a;--bg-overlay: #21222c;--border: #191a21;--border-strong: #44475a;--text-primary: #f8f8f2;--text-secondary: #b9bcc9;--text-muted: #6272a4;--text-bright: #ffffff;--accent: #bd93f9;--accent-hover: #d6acff;--statusbar: #bd93f9;--statusbar-text: #282a36;--selection: rgba(68, 71, 90, .99);--scrollbar: rgba(98, 114, 164, .4);--scrollbar-hover: rgba(98, 114, 164, .7);--focus-ring: #bd93f9;--syn-keyword: #ff79c6;--syn-keyword2: #ff79c6;--syn-string: #f1fa8c;--syn-comment: #6272a4;--syn-number: #bd93f9;--syn-function: #50fa7b;--syn-variable: #f8f8f2;--syn-property: #8be9fd;--syn-type: #8be9fd;--syn-constant: #bd93f9;--syn-operator: #ff79c6;--syn-punctuation: #f8f8f2;--syn-tag: #ff79c6;--syn-attr: #50fa7b;--syn-bracket: #ffb86c;--syn-regex: #ff5555;--folder-color: #bd93f9}[data-theme=nord]{--bg-primary: #2e3440;--bg-secondary: #2b303b;--bg-sidebar: #2b303b;--bg-activitybar: #272c36;--bg-tab-inactive: #2b303b;--bg-input: #3b4252;--bg-hover: #3b4252;--bg-active: #434c5e;--bg-overlay: #2e3440;--border: #242933;--border-strong: #434c5e;--text-primary: #d8dee9;--text-secondary: #a3acbd;--text-muted: #4c566a;--text-bright: #eceff4;--accent: #88c0d0;--accent-hover: #8fbcbb;--statusbar: #4c566a;--statusbar-text: #eceff4;--selection: rgba(67, 76, 94, .99);--scrollbar: rgba(76, 86, 106, .5);--scrollbar-hover: rgba(76, 86, 106, .8);--focus-ring: #88c0d0;--syn-keyword: #81a1c1;--syn-keyword2: #81a1c1;--syn-string: #a3be8c;--syn-comment: #616e88;--syn-number: #b48ead;--syn-function: #88c0d0;--syn-variable: #d8dee9;--syn-property: #8fbcbb;--syn-type: #8fbcbb;--syn-constant: #81a1c1;--syn-operator: #81a1c1;--syn-punctuation: #eceff4;--syn-tag: #81a1c1;--syn-attr: #8fbcbb;--syn-bracket: #ebcb8b;--syn-regex: #ebcb8b;--folder-color: #ebcb8b}::selection{background:var(--selection);color:inherit}::-webkit-scrollbar{width:14px;height:14px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar);border:3px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover);background-clip:content-box}::-webkit-scrollbar-corner{background:transparent}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar) transparent}.app-shell{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;background:var(--bg-primary)}.app-body{flex:1;display:flex;min-height:0;position:relative}.editor-region{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--bg-primary)}.editor-main,.editor-view{flex:1;display:flex;flex-direction:column;min-height:0}.titlebar{height:35px;background:var(--bg-activitybar);display:flex;align-items:center;justify-content:space-between;padding:0 8px;border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none;flex-shrink:0;-webkit-app-region:drag}.titlebar-left,.titlebar-right{display:flex;align-items:center;gap:2px}.titlebar-logo{display:flex;align-items:center;padding:0 6px}.titlebar-logo svg{width:18px;height:18px}.menu-item{padding:3px 8px;font-size:12.5px;color:var(--text-secondary);border-radius:4px;position:relative}.menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.titlebar-center{position:absolute;left:50%;transform:translate(-50%);font-size:12.5px;color:var(--text-secondary);display:flex;align-items:center;gap:6px;pointer-events:none}.window-controls{display:flex;gap:8px;padding-left:8px}.window-dot{width:12px;height:12px;border-radius:50%}.window-dot.red{background:#ff5f57}.window-dot.yellow{background:#febc2e}.window-dot.green{background:#28c840}.menu-dropdown{position:absolute;top:100%;left:0;margin-top:2px;min-width:220px;background:var(--bg-overlay);border:1px solid var(--border-strong);border-radius:6px;box-shadow:0 8px 24px #0006;padding:4px;z-index:200}.menu-dropdown button{display:flex;align-items:center;justify-content:space-between;width:100%;padding:5px 10px;font-size:12.5px;border-radius:4px;color:var(--text-primary);text-align:left;gap:16px}.menu-dropdown button:hover{background:var(--accent);color:#fff}.menu-dropdown .shortcut{color:var(--text-muted);font-size:11px}.menu-dropdown button:hover .shortcut{color:#fffc}.menu-divider{height:1px;background:var(--border);margin:4px 2px}.activity-bar{width:48px;background:var(--bg-activitybar);display:flex;flex-direction:column;align-items:center;border-right:1px solid var(--border);flex-shrink:0;padding:4px 0}.activity-bar-top,.activity-bar-bottom{display:flex;flex-direction:column;align-items:center;width:100%}.activity-bar-bottom{margin-top:auto}.activity-btn{width:48px;height:48px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);position:relative;transition:color .12s ease}.activity-btn:hover,.activity-btn.active{color:var(--text-bright)}.activity-btn.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--text-bright)}.activity-btn .badge{position:absolute;bottom:8px;right:7px;background:var(--accent);color:#fff;font-size:9px;min-width:15px;height:15px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;font-family:Inter,sans-serif}.activity-btn .tooltip,.has-tooltip .tooltip{position:absolute;left:calc(100% + 6px);top:50%;transform:translateY(-50%);background:var(--bg-overlay);color:var(--text-primary);border:1px solid var(--border-strong);padding:3px 8px;font-size:12px;white-space:nowrap;border-radius:4px;opacity:0;pointer-events:none;transition:opacity .1s ease;z-index:300;box-shadow:0 2px 8px #0006}.activity-btn:hover .tooltip,.has-tooltip:hover .tooltip{opacity:1}.sidebar{width:280px;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.sidebar-header{height:35px;display:flex;align-items:center;justify-content:space-between;padding:0 16px 0 20px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);flex-shrink:0}.sidebar-header .actions{display:flex;gap:4px;opacity:0;transition:opacity .1s}.sidebar:hover .sidebar-header .actions{opacity:1}.sidebar-header .actions button{padding:3px;border-radius:4px;color:var(--text-secondary);display:flex}.sidebar-header .actions button:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-body{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:12px}.sidebar-panel-title{padding:6px 16px 6px 12px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-primary);display:flex;align-items:center;gap:4px;cursor:pointer;-webkit-user-select:none;user-select:none}.sidebar-panel-title .chevron{transition:transform .15s ease}.sidebar-panel-title.collapsed .chevron{transform:rotate(-90deg)}.tree{font-size:13px;-webkit-user-select:none;user-select:none}.tree-row{display:flex;align-items:center;gap:6px;height:22px;padding-right:8px;color:var(--text-primary);cursor:pointer;position:relative;white-space:nowrap}.tree-row:hover{background:var(--bg-hover)}.tree-row.active{background:var(--bg-active)}.tree-row.active:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:1px solid var(--focus-ring);pointer-events:none}.tree-row:focus-visible{outline:1px solid var(--focus-ring);outline-offset:-1px}.tree-chevron{display:flex;align-items:center;justify-content:center;width:16px;flex-shrink:0;color:var(--text-secondary);transition:transform .12s ease}.tree-chevron.collapsed{transform:rotate(-90deg)}.tree-icon{display:flex;align-items:center;flex-shrink:0;width:16px}.tree-label{overflow:hidden;text-overflow:ellipsis}.tree-children{overflow:hidden}.tabs-bar{height:35px;background:var(--bg-secondary);display:flex;align-items:stretch;border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.tabs-bar::-webkit-scrollbar{height:0}.tab{display:flex;align-items:center;gap:8px;padding:0 10px 0 12px;min-width:120px;max-width:220px;height:100%;background:var(--bg-tab-inactive);border-right:1px solid var(--border);color:var(--text-secondary);font-size:13px;position:relative;cursor:pointer;flex-shrink:0}.tab:hover{background:var(--bg-hover)}.tab.active{background:var(--bg-primary);color:var(--text-primary)}.tab.active:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--accent)}.tab-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.tab.dirty .tab-label{font-style:italic}.tab-close{width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:4px;flex-shrink:0;opacity:0}.tab:hover .tab-close,.tab.active .tab-close{opacity:1}.tab-close:hover{background:var(--bg-active)}.tab .dot{width:8px;height:8px;border-radius:50%;background:var(--text-primary)}.breadcrumbs{height:24px;display:flex;align-items:center;gap:4px;padding:0 16px;font-size:12px;color:var(--text-muted);background:var(--bg-primary);border-bottom:1px solid var(--border);flex-shrink:0}.breadcrumbs .crumb{display:flex;align-items:center;gap:4px}.editor-area{flex:1;overflow:auto;min-height:0;position:relative;background:var(--bg-primary)}.code-editor{display:flex;font-size:14px;line-height:21px;min-height:100%;-moz-tab-size:2;tab-size:2}.gutter{flex-shrink:0;text-align:right;color:var(--text-muted);padding:12px 0;-webkit-user-select:none;user-select:none;background:var(--bg-primary);position:sticky;left:0}.gutter .ln{padding:0 16px 0 20px;height:21px}.code-content{padding:12px 0;flex:1;min-width:0}.code-line{min-height:21px;padding:0 24px 0 4px;white-space:pre}.code-line:hover{background:#ffffff06}.tok-keyword{color:var(--syn-keyword)}.tok-keyword2{color:var(--syn-keyword2)}.tok-string{color:var(--syn-string)}.tok-comment{color:var(--syn-comment);font-style:italic}.tok-number{color:var(--syn-number)}.tok-function{color:var(--syn-function)}.tok-variable{color:var(--syn-variable)}.tok-property{color:var(--syn-property)}.tok-type{color:var(--syn-type)}.tok-constant{color:var(--syn-constant)}.tok-operator{color:var(--syn-operator)}.tok-punctuation{color:var(--syn-punctuation)}.tok-tag{color:var(--syn-tag)}.tok-attr{color:var(--syn-attr)}.tok-bracket{color:var(--syn-bracket)}.tok-regex{color:var(--syn-regex)}.tok-heading{color:var(--syn-keyword2);font-weight:700}.tok-link{color:var(--accent)}.tok-bold{color:var(--text-bright);font-weight:700}.type-cursor{display:inline-block;width:8px;height:18px;background:var(--accent-hover);vertical-align:text-bottom;margin-left:1px;animation:blink 1s step-end infinite}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}.rich-view{padding:0;max-width:980px;margin:0 auto}.rich-inner{padding:32px 40px 80px}.welcome{padding:48px 56px;max-width:900px}.welcome h1{font-size:42px;font-weight:600;font-family:Inter,sans-serif;letter-spacing:-.02em}.welcome .subtitle{font-size:18px;color:var(--text-secondary);margin-top:4px;font-family:Inter,sans-serif;font-weight:300}.welcome .columns{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:40px}.welcome h2{font-size:15px;font-weight:600;font-family:Inter,sans-serif;color:var(--text-primary);margin-bottom:12px}.welcome .start-link{display:flex;align-items:center;gap:10px;padding:6px 0;color:var(--accent);cursor:pointer;font-size:14px}.welcome .start-link:hover{color:var(--accent-hover)}.welcome .start-link .desc{color:var(--text-muted);font-size:13px}.welcome .recent{color:var(--text-secondary);font-size:13px;padding:4px 0;cursor:pointer}.welcome .recent:hover{color:var(--accent)}.welcome .ascii{color:var(--accent);font-size:11px;line-height:1.2;white-space:pre;margin-bottom:24px;opacity:.9}.welcome .tips{margin-top:40px;padding-top:20px;border-top:1px solid var(--border);color:var(--text-muted);font-size:12.5px}.welcome .tips kbd{background:var(--bg-input);border:1px solid var(--border-strong);border-bottom-width:2px;border-radius:4px;padding:1px 6px;font-size:11px;color:var(--text-primary);margin:0 2px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;margin-top:24px}.project-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .15s,transform .15s;display:flex;flex-direction:column}.project-card:hover{border-color:var(--accent);transform:translateY(-2px)}.project-card .thumb{height:200px;background:linear-gradient(135deg,var(--card-from, #264f78),var(--card-to, #1e1e1e));display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.project-card .thumb-img{background:var(--bg-secondary)}.project-card .thumb-img img{width:100%;height:100%;object-fit:cover;object-position:top;display:block}.project-card .thumb .glyph{font-size:48px;opacity:.85}.project-card .thumb .grid-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);background-size:22px 22px}.project-card .body{padding:14px 16px;flex:1;display:flex;flex-direction:column}.project-card .name{font-size:15px;font-weight:600;font-family:Inter,sans-serif;display:flex;align-items:center;gap:8px}.project-card .tagline{color:var(--text-secondary);font-size:12.5px;margin-top:6px;line-height:1.5;font-family:Inter,sans-serif;flex:1}.project-card .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.tag-chip{font-size:11px;padding:2px 8px;border-radius:20px;background:var(--bg-active);color:var(--text-secondary);font-family:Inter,sans-serif}.project-card .meta{display:flex;gap:14px;margin-top:12px;color:var(--text-muted);font-size:12px;font-family:Inter,sans-serif}.project-card .meta span{display:flex;align-items:center;gap:4px}.proj-detail .hero{height:200px;border-radius:10px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;margin-bottom:24px;border:1px solid var(--border)}.proj-detail .hero-img img{width:100%;height:100%;object-fit:cover;object-position:top;display:block}.proj-detail .hero .glyph{font-size:72px}.proj-detail h1{font-size:30px;font-family:Inter,sans-serif;font-weight:700;display:flex;align-items:center;gap:12px}.proj-detail .links{display:flex;gap:12px;margin:18px 0 28px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:6px;font-size:13px;font-family:Inter,sans-serif;font-weight:500;border:1px solid var(--border-strong);color:var(--text-primary);background:var(--bg-secondary);transition:background .12s,border-color .12s}.btn:hover{background:var(--bg-hover);text-decoration:none;border-color:var(--accent)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.proj-detail h2,.rich-md h2{font-size:18px;font-family:Inter,sans-serif;font-weight:600;margin:28px 0 12px;padding-bottom:6px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}.proj-detail p,.rich-md p{font-family:Inter,sans-serif;color:var(--text-secondary);line-height:1.7;margin-bottom:12px}.metrics-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin:16px 0}.metric-box{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:16px;text-align:center}.metric-box .num{font-size:26px;font-weight:700;color:var(--accent);font-family:Inter,sans-serif}.metric-box .lbl{font-size:12px;color:var(--text-muted);margin-top:4px;font-family:Inter,sans-serif}.feature-list{font-family:Inter,sans-serif}.feature-list li{display:flex;gap:10px;padding:6px 0;color:var(--text-secondary);line-height:1.6}.feature-list li svg{flex-shrink:0;margin-top:3px;color:var(--syn-function)}.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:13px;margin-bottom:20px;cursor:pointer}.back-link:hover{color:var(--accent)}.skills-cat{margin-bottom:28px}.skills-cat h3{font-family:Inter,sans-serif;font-size:14px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:8px;color:var(--text-primary)}.skill-row{display:flex;align-items:center;gap:14px;margin-bottom:10px}.skill-row .skill-name{width:130px;font-size:13px;font-family:Inter,sans-serif;flex-shrink:0}.skill-bar{flex:1;height:7px;background:var(--bg-active);border-radius:4px;overflow:hidden}.skill-bar .fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-hover));border-radius:4px}.skill-row .pct{width:38px;text-align:right;font-size:12px;color:var(--text-muted)}.rich-md{font-family:Inter,sans-serif}.rich-md h1{font-size:28px;font-weight:700;margin-bottom:8px}.rich-md .lead{color:var(--text-secondary);margin-bottom:24px;line-height:1.7}.rich-md h3{font-size:15px;font-weight:600;margin:22px 0 8px}.rich-md .md-list{list-style:none;margin:8px 0 14px;padding-left:4px}.rich-md .md-list li{position:relative;padding-left:20px;margin-bottom:7px;color:var(--text-secondary);line-height:1.6}.rich-md .md-list li:before{content:"▹";position:absolute;left:2px;color:var(--accent)}.rich-md .md-ol{counter-reset:ol}.rich-md .md-ol li:before{content:counter(ol) ".";counter-increment:ol;font-size:12px;top:1px}.rich-md .md-quote{border-left:3px solid var(--accent);padding:8px 16px;margin:14px 0;background:var(--bg-secondary);border-radius:0 6px 6px 0;color:var(--text-secondary);font-style:italic}.rich-md .md-hr{border:none;border-top:1px solid var(--border);margin:22px 0}.md-inline-code{background:var(--bg-active);border-radius:4px;padding:1px 6px;font-family:JetBrains Mono,monospace;font-size:.9em;color:var(--syn-string)}.contact-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:20px 0}.contact-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .12s,background .12s;text-decoration:none;min-width:0}.contact-card:hover{border-color:var(--accent);background:var(--bg-active)}.contact-card .ic{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--bg-active);flex-shrink:0;color:var(--accent)}.contact-card .info{min-width:0;flex:1;display:flex;flex-direction:column;gap:3px}.contact-card .info .label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-family:Inter,sans-serif}.contact-card .info .value{font-size:13px;font-weight:500;color:var(--text-primary);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Inter,sans-serif}.contact-card .copy-ic{flex-shrink:0;color:var(--text-muted);opacity:0;transition:opacity .12s}.contact-card:hover .copy-ic{opacity:1;color:var(--accent)}.contact-form{margin-top:24px;max-width:560px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:6px;font-family:JetBrains Mono,monospace}.form-group label .tk{color:var(--syn-keyword)}.form-control{width:100%;padding:9px 12px;background:var(--bg-input);border:1px solid var(--border-strong);border-radius:4px;color:var(--text-primary);font-size:13px;transition:border-color .12s}.form-control:focus{outline:none;border-color:var(--focus-ring)}textarea.form-control{resize:vertical;min-height:110px;font-family:Inter,sans-serif}.form-note{font-size:12px;color:var(--text-muted);margin-top:10px}.timeline{position:relative;margin-top:24px;padding-left:28px}.timeline:before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;background:var(--border-strong)}.timeline-item{position:relative;margin-bottom:28px}.timeline-item:before{content:"";position:absolute;left:-28px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--bg-primary);border:3px solid var(--accent)}.timeline-item .year{font-size:12px;color:var(--accent);font-weight:700}.timeline-item .role{font-size:15px;font-weight:600;font-family:Inter,sans-serif;margin-top:2px}.timeline-item .org{font-size:13px;color:var(--text-secondary);font-family:Inter,sans-serif}.timeline-item .desc{font-size:13px;color:var(--text-muted);margin-top:6px;line-height:1.6;font-family:Inter,sans-serif}.resume-view{display:flex;flex-direction:column;flex:1;min-height:0;height:100%}.resume-toolbar{display:flex;align-items:center;gap:12px;padding:8px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);font-size:12px;color:var(--text-secondary)}.resume-toolbar .spacer{flex:1}.resume-paper{flex:1;overflow:auto;padding:32px;display:flex;justify-content:center;background:#525659}.resume-sheet{width:100%;max-width:760px;background:#fff;color:#1a1a1a;padding:48px 56px;font-family:Inter,Segoe UI,sans-serif;box-shadow:0 4px 24px #0006;min-height:980px}.resume-sheet h1{font-size:30px;letter-spacing:-.01em}.resume-sheet .title{color:#007acc;font-weight:600;font-size:15px;margin-top:2px}.resume-sheet .contact-line{font-size:12.5px;color:#555;margin-top:8px;display:flex;flex-wrap:wrap;gap:14px}.resume-sheet h2{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:#007acc;border-bottom:2px solid #e2e2e2;padding-bottom:4px;margin:26px 0 12px}.resume-sheet .exp-item{margin-bottom:14px}.resume-sheet .exp-head{display:flex;justify-content:space-between;font-weight:600;font-size:14px}.resume-sheet .exp-sub{font-size:12.5px;color:#666}.resume-sheet ul{list-style:disc;padding-left:18px;margin-top:6px}.resume-sheet li{font-size:12.5px;color:#333;margin-bottom:4px;line-height:1.5}.resume-sheet .pill-row{display:flex;flex-wrap:wrap;gap:8px}.resume-sheet .pill{background:#eef4fb;color:#007acc;font-size:12px;padding:3px 10px;border-radius:20px}.gh-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.gh-avatar{width:64px;height:64px;border-radius:50%;background:var(--bg-active);display:flex;align-items:center;justify-content:center;border:2px solid var(--border-strong)}.gh-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:12px;margin:16px 0 24px}.gh-stat{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:14px}.gh-stat .n{font-size:22px;font-weight:700;font-family:Inter,sans-serif;color:var(--text-primary)}.gh-stat .l{font-size:12px;color:var(--text-muted);font-family:Inter,sans-serif}.contrib-graph{display:grid;grid-template-rows:repeat(5,12px);grid-auto-flow:column;gap:3px;margin-top:8px;overflow-x:auto}.contrib-cell{width:12px;height:12px;border-radius:2px;background:var(--bg-active)}.status-bar{height:22px;background:var(--statusbar);color:var(--statusbar-text);display:flex;align-items:center;font-size:12px;flex-shrink:0;-webkit-user-select:none;user-select:none;font-family:Inter,sans-serif}.status-left,.status-right{display:flex;align-items:center;height:100%}.status-right{margin-left:auto}.status-item{display:flex;align-items:center;gap:4px;padding:0 8px;height:100%;cursor:pointer;white-space:nowrap}.status-item:hover{background:#ffffff29}.status-item svg{width:14px;height:14px}.overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;justify-content:center;padding-top:0}.palette{position:absolute;top:0;left:50%;transform:translate(-50%);width:min(600px,90vw);background:var(--bg-overlay);border:1px solid var(--border-strong);border-top:none;border-radius:0 0 8px 8px;box-shadow:0 8px 32px #00000080;overflow:hidden}.palette-input-wrap{padding:8px}.palette-input{width:100%;padding:7px 10px;background:var(--bg-input);border:1px solid var(--focus-ring);border-radius:4px;color:var(--text-primary);font-size:13px}.palette-input:focus{outline:none}.palette-list{max-height:340px;overflow-y:auto;padding:0 4px 6px}.palette-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:4px;cursor:pointer;font-size:13px;color:var(--text-primary)}.palette-item .pi-icon{color:var(--text-secondary);display:flex;flex-shrink:0}.palette-item.active{background:var(--accent);color:#fff}.palette-item.active .pi-icon,.palette-item.active .pi-sub{color:#ffffffd9}.palette-item .pi-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.palette-item .pi-label .match{color:var(--accent-hover);font-weight:700}.palette-item.active .pi-label .match{color:#fff;text-decoration:underline}.palette-item .pi-sub{color:var(--text-muted);font-size:11.5px;flex-shrink:0}.palette-empty{padding:16px;text-align:center;color:var(--text-muted);font-size:13px}.palette-hint{padding:6px 12px;font-size:11px;color:var(--text-muted);border-top:1px solid var(--border);display:flex;gap:16px}.palette-hint kbd{background:var(--bg-input);border:1px solid var(--border-strong);border-radius:3px;padding:0 5px;font-size:10px}.panel{height:260px;background:var(--bg-primary);border-top:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.panel-tabs{display:flex;align-items:center;height:35px;padding:0 8px 0 16px;border-bottom:1px solid var(--border);gap:16px}.panel-tab{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);height:100%;display:flex;align-items:center;border-bottom:1px solid transparent;cursor:pointer}.panel-tab.active{color:var(--text-primary);border-bottom-color:var(--text-primary)}.panel-actions{margin-left:auto;display:flex;gap:6px}.panel-actions button{padding:4px;border-radius:4px;color:var(--text-secondary);display:flex}.panel-actions button:hover{background:var(--bg-hover);color:var(--text-primary)}.terminal{flex:1;overflow-y:auto;padding:8px 16px;font-size:13px;line-height:1.5}.terminal-line{white-space:pre-wrap;word-break:break-word}.terminal .prompt-user{color:var(--syn-function)}.terminal .prompt-at{color:var(--text-primary)}.terminal .prompt-host{color:var(--syn-type)}.terminal .prompt-path{color:var(--syn-variable)}.terminal .prompt-symbol{color:var(--syn-keyword)}.terminal-output{color:var(--text-primary)}.terminal-output.muted{color:var(--text-muted)}.terminal-output.accent{color:var(--accent-hover)}.terminal-output.success{color:var(--syn-function)}.terminal-output.error{color:var(--syn-regex)}.terminal-input-row{display:flex;align-items:center;gap:6px}.terminal-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:13px;caret-color:var(--accent-hover)}.terminal-input:focus{outline:none}.boot-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--bg-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px}.boot-logo{animation:boot-pulse 2s ease-in-out infinite}.boot-logo svg{width:84px;height:84px}@keyframes boot-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.06);opacity:.85}}.boot-log{width:min(440px,86vw);font-size:13px;min-height:160px}.boot-log-line{display:flex;align-items:center;gap:8px;padding:3px 0;color:var(--text-secondary)}.boot-log-line .check{color:var(--syn-function)}.boot-log-line .spin{color:var(--accent-hover);animation:spin .8s linear infinite;display:inline-flex}@keyframes spin{to{transform:rotate(360deg)}}.boot-progress{width:min(440px,86vw);height:3px;background:var(--bg-active);border-radius:3px;overflow:hidden}.boot-progress .bar{height:100%;background:var(--accent);border-radius:3px;transition:width .3s ease}.boot-brand{font-family:Inter,sans-serif;color:var(--text-muted);font-size:13px}.boot-brand b{color:var(--text-primary);font-weight:600}.editor-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);gap:22px;-webkit-user-select:none;user-select:none}.editor-empty .big-logo{opacity:.13}.editor-empty .big-logo svg{width:120px;height:120px}.editor-empty .shortcuts{display:grid;grid-template-columns:auto auto;gap:8px 24px;font-size:13px}.editor-empty .shortcuts .k{text-align:right;color:var(--text-secondary)}.editor-empty .shortcuts kbd{background:var(--bg-input);border:1px solid var(--border-strong);border-radius:4px;padding:1px 7px;font-size:11px;color:var(--text-primary)}.mobile-nav{display:none}.mobile-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 0 6px;color:var(--text-secondary);font-size:10px;font-family:Inter,sans-serif}.mobile-nav-btn:active,.mobile-nav-btn:hover{color:var(--text-primary)}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:90}@keyframes drawerIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@media (max-width: 820px){body{font-size:13px}.titlebar-center{display:none}.sidebar{position:absolute;top:0;bottom:0;left:48px;z-index:100;box-shadow:8px 0 24px #0006;width:min(280px,calc(100vw - 48px));animation:drawerIn .18s ease}.welcome{padding:28px 22px}.welcome h1{font-size:30px}.welcome .columns{grid-template-columns:1fr;gap:28px}.rich-inner{padding:22px 18px 80px}.tab{min-width:110px}.resume-paper{padding:12px}.resume-sheet{padding:28px 22px;min-height:auto}.status-item.hide-mobile{display:none}}@media (max-width: 540px){.mobile-nav{display:flex;background:var(--bg-activitybar);border-top:1px solid var(--border);flex-shrink:0}.activity-bar{display:none}.sidebar{left:0;width:100vw}.projects-grid{grid-template-columns:1fr}.menu-item.hide-sm{display:none}.skill-row .skill-name{width:92px}.welcome h1{font-size:26px}.titlebar .menu-item{padding:3px 6px}}.about-hero{display:flex;align-items:center;gap:24px;padding:28px 0 24px;border-bottom:1px solid var(--border);margin-bottom:28px}.about-avatar{width:72px;height:72px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 3px var(--bg-primary),0 0 0 5px var(--accent);overflow:hidden}.about-avatar img{width:100%;height:100%;object-fit:cover;display:block}.about-hero-text{flex:1;min-width:0}.about-name-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.about-name{font-size:28px;font-weight:700;font-family:Inter,sans-serif;letter-spacing:-.03em;color:var(--text-bright)}.about-badge{font-size:11px;font-family:Inter,sans-serif;color:#3fb950;background:#3fb9501f;border:1px solid rgba(63,185,80,.3);border-radius:20px;padding:2px 10px;white-space:nowrap}.about-role{font-size:14px;color:var(--text-secondary);font-family:Inter,sans-serif;margin-top:4px}.about-location{font-size:12px;color:var(--text-muted);font-family:Inter,sans-serif;margin-top:4px;display:flex;align-items:center}.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:32px}.about-stat{background:var(--bg-secondary);border:1px solid var(--border-strong);border-top:2px solid var(--accent);border-radius:8px;padding:14px 16px;display:flex;flex-direction:column;gap:4px;transition:border-color .15s,transform .15s}.about-stat:hover{border-top-color:var(--accent-hover);transform:translateY(-2px)}.about-stat-icon{color:var(--accent);display:flex;margin-bottom:4px}.about-stat-num{font-size:22px;font-weight:700;font-family:Inter,sans-serif;color:var(--text-bright);letter-spacing:-.02em}.about-stat-label{font-size:11px;color:var(--text-muted);font-family:Inter,sans-serif}.about-section{margin-bottom:32px}.about-section-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;font-family:Inter,sans-serif;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}.about-body{font-size:13.5px;color:var(--text-secondary);font-family:Inter,sans-serif;line-height:1.75}.about-quote{margin-top:16px;border-left:3px solid var(--accent);padding:10px 16px;background:#007acc0f;border-radius:0 6px 6px 0;color:var(--text-primary);font-size:14px;font-family:Inter,sans-serif;font-style:italic}.about-currently{display:flex;flex-direction:column;gap:8px}.about-currently-row{display:flex;align-items:center;gap:10px;font-size:13px;padding:4px 0}.about-currently-icon{display:flex;align-items:center;flex-shrink:0;width:22px;color:var(--text-muted)}.about-currently-key{font-family:Inter,sans-serif;color:var(--text-muted);min-width:110px;flex-shrink:0}.about-currently-val{color:var(--text-primary);font-family:Inter,sans-serif}.about-stack-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.about-stack-group{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:14px 16px}.about-stack-group-label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-family:Inter,sans-serif;margin-bottom:10px;display:block}.about-stack-tags{display:flex;flex-wrap:wrap;gap:6px}.about-tag{font-size:11.5px;font-family:Inter,sans-serif;padding:3px 9px;border-radius:4px;background:var(--bg-active);color:var(--text-primary);border:1px solid var(--border-strong)}.about-timeline{display:flex;flex-direction:column;gap:0}.about-tl-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.about-tl-row:last-child{border-bottom:none}.about-tl-year{font-size:12px;font-weight:700;color:var(--accent);font-family:Inter,sans-serif;min-width:36px;padding-top:1px}.about-tl-line{width:1px;align-self:stretch;background:var(--border);flex-shrink:0;margin-top:4px}.about-tl-content{flex:1;display:flex;flex-direction:column;gap:2px;padding-left:4px}.about-tl-role{font-size:13px;font-weight:600;font-family:Inter,sans-serif;color:var(--text-primary)}.about-tl-org{font-size:12px;color:var(--text-muted);font-family:Inter,sans-serif}.about-ctas{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding-top:8px;border-top:1px solid var(--border);margin-top:4px}.about-cta-primary{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;background:var(--accent);color:#fff;border-radius:6px;font-size:13px;font-family:Inter,sans-serif;font-weight:500;cursor:pointer;border:none;transition:background .15s}.about-cta-primary:hover{background:var(--accent-hover)}.about-cta-secondary{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;background:var(--bg-secondary);color:var(--text-primary);border-radius:6px;font-size:13px;font-family:Inter,sans-serif;font-weight:500;cursor:pointer;border:1px solid var(--border-strong);transition:border-color .15s,background .15s}.about-cta-secondary:hover{border-color:var(--accent);background:var(--bg-hover)}.about-cta-ghost{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;color:var(--text-secondary);border-radius:6px;font-size:13px;font-family:Inter,sans-serif;cursor:pointer;text-decoration:none!important;transition:color .15s}.about-cta-ghost:hover{color:var(--text-primary)}@media (max-width: 820px){.about-stats{grid-template-columns:repeat(2,1fr)}.about-stack-grid{grid-template-columns:1fr}}@media (max-width: 540px){.about-hero{flex-direction:column;align-items:flex-start;gap:16px}.about-stats{grid-template-columns:repeat(2,1fr)}}.flex{display:flex}.spacer{flex:1}.muted{color:var(--text-muted)}.accent{color:var(--accent)}.fade-in{animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:focus-visible{outline:2px solid var(--focus-ring);outline-offset:-1px}
