:root{--bg-sidebar:#0a0a0a;--bg-main:#0e0e0e;--bg-block:#141414;--bg-block-hover:#181818;--border:#242424;--border-strong:#333;--text-primary:#f0f0f0;--text-secondary:#aaa;--text-muted:gray;--accent:#00ff41;--accent-dim:#00ff4114;--accent-glow:#00ff4138;--font:"JetBrains Mono","Courier New",monospace;--sidebar-width:260px;--mobile-header:58px;--mobile-tabs:62px;--ease:cubic-bezier(.4,0,.2,1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{background:var(--bg-main);height:100vh;font-family:var(--font);color:var(--text-primary);line-height:1.6;overflow:hidden}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}.skip-link{z-index:9999;background:var(--accent);color:#000;font-family:var(--font);border-radius:2px;padding:8px 16px;font-size:13px;font-weight:700;text-decoration:none;transition:top .15s;position:absolute;top:-100%;left:16px}.skip-link:focus{top:16px}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.shell{width:100vw;height:100svh;display:flex}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border);z-index:100;flex-direction:column;display:flex}.sidebar-header{border-bottom:1px solid var(--border);padding:32px 28px 28px}.sidebar-name{color:var(--accent);font-size:17px;font-weight:700}.sidebar-role{color:var(--text-secondary);margin-top:6px;font-size:12px}.sidebar-prompt{color:var(--text-muted);align-items:center;margin-top:16px;font-size:12px;display:flex}.sidebar-nav{flex:1;padding:24px 0}.nav-section-label{color:var(--text-muted);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:6px;padding:0 28px;font-size:10px}.nav-item{color:var(--text-secondary);cursor:pointer;text-align:left;width:100%;font-size:14px;font-family:var(--font);background:0 0;border:none;border-left:2px solid #0000;align-items:center;gap:12px;min-height:44px;padding:11px 28px;transition:color .18s,background .18s,border-color .18s,transform .18s;display:flex}.nav-item:hover{color:var(--text-primary);background:#161616;transform:translate(3px)}.nav-item.active,.nav-item[aria-current=page]{color:var(--accent);background:var(--accent-dim);border-left-color:var(--accent);transform:translate(3px)}.nav-item .icon{text-align:center;width:18px;font-size:13px}.sidebar-links{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding:20px 28px;display:flex}.sidebar-links a{color:var(--text-muted);align-items:center;gap:8px;min-height:44px;font-size:13px;text-decoration:none;transition:color .18s,transform .18s;display:flex}.sidebar-links a:hover{color:var(--accent);transform:translate(3px)}.main{perspective:400px;flex:1;position:relative;overflow:hidden}.main:before{content:"";transform-origin:bottom;pointer-events:none;z-index:0;background-image:linear-gradient(#00ff4121 1px,#0000 1px),linear-gradient(90deg,#00ff4121 1px,#0000 1px);background-size:36px 36px;height:55%;position:absolute;bottom:-10px;left:-20%;right:-20%;transform:rotateX(55deg);-webkit-mask-image:linear-gradient(#0000 0%,#0000008c 100%);mask-image:linear-gradient(#0000 0%,#0000008c 100%)}.main:after{content:"";background:linear-gradient(to bottom, var(--bg-main) 0%, transparent 38%, transparent 58%, #0e0e0e59 100%);pointer-events:none;z-index:0;position:absolute;inset:0}.caret{background:var(--accent);vertical-align:text-bottom;border-radius:1px;width:2px;height:.85em;margin-left:3px;animation:1.05s step-end infinite blink;display:inline-block}.caret-sm{background:var(--accent);vertical-align:text-bottom;border-radius:1px;width:2px;height:.75em;margin-left:2px;animation:1.05s step-end infinite blink;display:inline-block}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}.section{opacity:0;pointer-events:none;transition:opacity .26s var(--ease), transform .26s var(--ease);z-index:2;flex-direction:column;justify-content:center;padding:72px 80px;display:flex;position:absolute;inset:0;overflow-y:auto;transform:translateY(14px)}.section::-webkit-scrollbar{width:3px}.section::-webkit-scrollbar-thumb{background:#2a2a2a}.section{scrollbar-width:thin;scrollbar-color:#2a2a2a transparent}.section.active{opacity:1;pointer-events:all;transform:translateY(0)}.section-cmd{color:var(--text-muted);margin-bottom:12px;font-size:14px}.section-cmd .prompt{color:var(--accent)}[data-anim]{opacity:1;transform:translateY(0)}.section:not(.active) [data-anim]{opacity:0;transform:translateY(10px)}body.animations-ready [data-anim]{transition:opacity .32s var(--ease), transform .32s var(--ease);transition-delay:var(--delay,0s)}body.animations-ready .section.active [data-anim]{opacity:1;transform:translateY(0)}#section-home{justify-content:flex-start}.hero-name{letter-spacing:-2px;color:var(--text-primary);font-size:clamp(48px,6.5vw,80px);font-weight:700;line-height:1;font-family:var(--font);align-items:flex-end;margin:0;display:flex}.hero-tagline{color:var(--text-secondary);margin-top:18px;font-size:clamp(15px,1.6vw,18px)}.hero-actions{flex-wrap:wrap;align-items:stretch;gap:12px;margin-top:44px;display:flex}.resume-btn{background:var(--accent);color:#000;font-family:var(--font);letter-spacing:.5px;cursor:pointer;border:none;border-radius:2px;flex-shrink:0;align-items:center;gap:10px;height:46px;padding:0 24px;font-size:13px;font-weight:700;text-decoration:none;transition:box-shadow .25s,transform .18s;display:inline-flex;position:relative;overflow:hidden}.resume-btn:before{content:"";background:linear-gradient(90deg,#0000,#ffffff2e,#0000);transition:transform .45s;position:absolute;inset:0;transform:translate(-100%)}.resume-btn:hover{box-shadow:0 0 28px 6px var(--accent-glow);transform:translateY(-2px)}.resume-btn:hover:before{transform:translate(100%)}.resume-btn:active{transform:translateY(0)}.open-to-work{border:1px solid var(--accent);height:46px;color:var(--accent);font-family:var(--font);letter-spacing:.3px;background:0 0;border-radius:2px;flex-shrink:0;align-items:center;padding:0 20px;font-size:13px;font-weight:500;transition:background .18s,box-shadow .25s;display:inline-flex}.open-to-work:hover{background:var(--accent-dim);box-shadow:0 0 14px 2px var(--accent-glow)}.home-divider{color:var(--border-strong);letter-spacing:.5px;margin:32px 0 20px;font-size:12px}.about-block{background:var(--bg-block);border-left:3px solid var(--accent);color:var(--text-secondary);border-radius:0 4px 4px 0;max-width:660px;padding:28px 30px;font-size:15px;line-height:1.9;transition:box-shadow .2s}.about-block:hover{box-shadow:-2px 0 18px -4px var(--accent-glow)}.comment{color:var(--text-muted);margin-bottom:14px;font-size:13px}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:32px;max-width:720px;display:grid}.skill-group-label{color:var(--text-muted);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:12px;font-size:11px}.skill-tags{flex-wrap:wrap;gap:8px;display:flex}.skill-tag{background:var(--bg-block);border:1px solid var(--border);color:var(--text-secondary);cursor:default;border-radius:2px;padding:6px 14px;font-size:13px;transition:border-color .15s,color .15s,background .15s,transform .15s}.skill-tag:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);transform:translateY(-2px)}.exp-list{flex-direction:column;gap:16px;max-width:700px;display:flex}.exp-item{background:var(--bg-block);border:1px solid var(--border);border-radius:0 4px 4px 0;padding:22px 24px;transition:border-color .18s,background .18s,transform .18s,box-shadow .18s;position:relative}.exp-item:hover{background:var(--bg-block-hover);border-color:var(--border-strong);box-shadow:-3px 0 0 var(--border-strong);transform:translate(4px)}.exp-item:before{content:"";background:var(--border);border-radius:2px 0 0 2px;width:3px;transition:background .18s;position:absolute;top:0;bottom:0;left:0}.exp-item.current:before,.exp-item:hover:before{background:var(--accent)}.exp-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.exp-role{color:var(--text-primary);font-size:15px;font-weight:700}.exp-dates{color:var(--text-muted);white-space:nowrap;font-size:12px}.exp-company{color:var(--accent);margin-top:4px;font-size:13px}.exp-desc{color:var(--text-secondary);margin-top:12px;font-size:13px;line-height:1.8}.contact-list{flex-direction:column;gap:12px;max-width:560px;display:flex}.contact-item{background:var(--bg-block);border:1px solid var(--border);border-radius:0 4px 4px 0;align-items:center;gap:16px;min-height:56px;padding:16px 20px;text-decoration:none;transition:border-color .18s,background .18s,transform .18s;display:flex}.contact-item:hover{border-color:var(--accent);background:var(--accent-dim);transform:translate(4px)}.contact-item .cmd{color:var(--text-muted);min-width:100px;font-size:12px}.contact-item .val{color:var(--text-primary);font-size:15px}.proj-list{flex-direction:column;gap:16px;max-width:700px;display:flex}.proj-item{background:var(--bg-block);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:0 4px 4px 0;padding:20px 22px;transition:box-shadow .18s,transform .18s}.proj-item:hover{box-shadow:-2px 0 18px -4px var(--accent-glow);transform:translate(4px)}.proj-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.proj-name{color:var(--text-primary);font-size:14px;font-weight:700}.proj-tags{color:var(--accent);margin-bottom:8px;font-size:12px}.proj-desc{color:var(--text-secondary);font-size:14px;line-height:1.7}.proj-links{flex-shrink:0;gap:8px;display:flex}.proj-link{color:var(--text-muted);border:1px solid var(--border);cursor:pointer;border-radius:2px;padding:2px 8px;font-size:11px;text-decoration:none;transition:color .15s,border-color .15s}.proj-link:hover{color:var(--accent);border-color:var(--accent)}.mobile-header{height:var(--mobile-header);background:var(--bg-sidebar);border-bottom:1px solid var(--border);z-index:200;align-items:center;padding:0 20px;display:none;position:fixed;top:0;left:0;right:0}.mobile-name{color:var(--accent);font-size:16px;font-weight:700}.bottom-tab-bar{border-top:1px solid var(--border);z-index:200;padding-bottom:env(safe-area-inset-bottom,0px);background:#080808;display:none;position:fixed;bottom:0;left:0;right:0}@supports ((-webkit-backdrop-filter:blur(12px)) or (backdrop-filter:blur(12px))){.bottom-tab-bar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#080808eb}}.tab-bar-inner{display:flex}.tab-btn-wrap{flex:1;display:flex;position:relative}.tab-btn{cursor:pointer;font-family:var(--font);color:var(--text-muted);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;min-height:58px;padding:10px 4px 12px;font-size:10px;transition:color .15s,transform .15s;display:flex}.tab-btn:hover{color:var(--text-secondary);transform:translateY(-2px)}.tab-btn.active{color:var(--accent)}.tab-btn .tab-icon{font-size:14px;line-height:1}.tab-indicator{background:var(--accent);opacity:0;border-radius:0 0 2px 2px;width:24px;height:2px;transition:opacity .15s,width .2s;position:absolute;top:0;left:50%;transform:translate(-50%)}.tab-btn-wrap.indicator-active .tab-indicator{opacity:1;width:32px}.tab-btn-wrap:has(.tab-btn.active) .tab-indicator{opacity:1;width:32px}@media (width<=768px){.sidebar{display:none}.mobile-header{display:flex}.bottom-tab-bar{display:block}.section{top:var(--mobile-header);right:0;bottom:calc(var(--mobile-tabs) + env(safe-area-inset-bottom,0px));justify-content:flex-start;padding:32px 24px;left:0}.hero-name{letter-spacing:-1px;font-size:38px}.hero-tagline{margin-top:14px;font-size:15px}.hero-actions{gap:10px;margin-top:32px}.resume-btn{height:42px;padding:0 18px;font-size:12px}.open-to-work{height:42px;padding:0 16px;font-size:12px}.about-block{padding:22px 20px;font-size:14px}.skills-grid{grid-template-columns:1fr 1fr;gap:24px}.exp-header{flex-direction:column;gap:4px}.exp-item:hover,.proj-item:hover{box-shadow:none;transform:none}.contact-item:hover{transform:none}.contact-item .val{word-break:break-all;flex:1;min-width:0;font-size:14px}.contact-item .cmd{min-width:80px;font-size:11px}}@media (width<=480px){.skills-grid{grid-template-columns:1fr}.hero-name{font-size:32px}.section{padding:24px 18px}.contact-item{flex-direction:column;align-items:flex-start;gap:4px;min-height:auto;padding:14px 16px}.contact-item .cmd{min-width:auto;font-size:11px}.contact-item .val{word-break:break-all;font-size:13px}}
