@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&family=Chakra+Petch:wght@500;600;700&display=swap";:root{--bg:#0a0a0b;--bg-elev:#111113;--bg-elev-2:#16161a;--line:#1f1f24;--line-strong:#2a2a31;--fg:#e6e6ea;--fg-mute:#8a8a95;--fg-dim:#55555e;--accent:#ff8a3d;--accent-soft:#ff8a3d1f;--accent-line:#ff8a3d59;--green:#7ac74f;--blue:#6aa9ff;--purple:#b490ff;--red:#ff6b6b;--mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--sans:"Inter", system-ui, -apple-system, Segoe UI, Helvetica, Arial, sans-serif}[data-theme=light]{--bg:#f5f3ee;--bg-elev:#ebe8e1;--bg-elev-2:#e3dfd6;--line:#d8d3c8;--line-strong:#c4beaf;--fg:#1a1a1a;--fg-mute:#5a5a5a;--fg-dim:#8a8a8a;--accent:#d2691e;--accent-soft:#d2691e1a;--accent-line:#d2691e66}.cursor-beam{pointer-events:none;z-index:9999;background:var(--accent);width:2px;height:22px;box-shadow:0 -10px 0 -9px var(--accent), 0 10px 0 -9px var(--accent);animation:1.1s steps(2,end) infinite beamBlink;position:fixed;top:0;left:0;transform:translate(-50%,-50%)}.cursor-beam:before,.cursor-beam:after{content:"";background:var(--accent);width:8px;height:2px;position:absolute;left:50%;transform:translate(-50%)}.cursor-beam:before{top:-1px}.cursor-beam:after{bottom:-1px}.cursor-label{pointer-events:none;z-index:9999;font-family:var(--mono);color:var(--bg);background:var(--accent);letter-spacing:.05em;white-space:nowrap;opacity:0;padding:2px 6px;font-size:10px;transition:opacity .15s;position:fixed;top:0;left:0;transform:translate(14px,8px)}.cursor-label.show{opacity:1}@media (pointer:coarse){.cursor-beam,.cursor-label{display:none}}.ide{grid-template:"titlebar titlebar titlebar"36px"activity sidebar main"1fr"statusbar statusbar statusbar"24px/56px 240px 1fr;height:100vh;display:grid}.titlebar{background:var(--bg-elev);border-bottom:1px solid var(--line);font-family:var(--mono);color:var(--fg-mute);grid-area:titlebar;align-items:center;gap:14px;padding:0 14px;font-size:12px;display:flex}.traffic{gap:8px;display:flex}.traffic span{background:var(--line-strong);border-radius:50%;width:12px;height:12px}.traffic span:first-child{background:#ff5f57}.traffic span:nth-child(2){background:#febc2e}.traffic span:nth-child(3){background:#28c840}.titlebar-title{text-align:center;letter-spacing:.02em;flex:1}.titlebar-title .accent{color:var(--accent)}.titlebar-controls{align-items:center;gap:10px;display:flex}.tb-btn{font-family:var(--mono);border:1px solid var(--line-strong);color:var(--fg-mute);letter-spacing:.05em;text-transform:uppercase;background:0 0;border-radius:3px;padding:4px 10px;font-size:11px;transition:all .15s}.tb-btn:hover{color:var(--accent);border-color:var(--accent-line)}.tb-btn.active{color:var(--accent);border-color:var(--accent-line);background:var(--accent-soft)}.activity{background:var(--bg-elev);border-right:1px solid var(--line);flex-direction:column;grid-area:activity;align-items:center;gap:4px;padding:14px 0;display:flex}.act-icon{width:40px;height:40px;color:var(--fg-dim);font-family:var(--mono);border-left:2px solid #0000;justify-content:center;align-items:center;font-size:14px;transition:all .15s;display:flex}.act-icon:hover{color:var(--fg)}.act-icon.active{color:var(--accent);border-left-color:var(--accent)}.act-icon svg{width:20px;height:20px}.activity-spacer{flex:1}.sidebar{background:var(--bg-elev);border-right:1px solid var(--line);font-family:var(--mono);grid-area:sidebar;padding:16px 0;font-size:12px;overflow-y:auto}.sb-header{color:var(--fg-mute);letter-spacing:.12em;text-transform:uppercase;justify-content:space-between;padding:0 16px 12px;font-size:10px;display:flex}.sb-tree{-webkit-user-select:none;user-select:none}.sb-item{color:var(--fg-mute);align-items:center;gap:8px;padding:3px 16px;font-size:12px;line-height:1.5;transition:all .1s;display:flex}.sb-item .f-ico{color:var(--fg-dim);text-align:center;width:12px;font-size:10px;display:inline-block}.sb-item:hover{color:var(--fg);background:var(--bg-elev-2)}.sb-item.active{color:var(--accent);background:var(--accent-soft)}.sb-item.active .f-ico{color:var(--accent)}.sb-folder{color:var(--fg);align-items:center;gap:6px;padding:4px 16px;font-weight:400;display:flex}.sb-folder:hover{background:var(--bg-elev-2)}.sb-folder-chev{color:var(--fg-dim);width:10px;font-size:10px}.main{scroll-behavior:smooth;grid-area:main;position:relative;overflow:hidden auto}.tabbar{z-index:10;background:var(--bg-elev);border-bottom:1px solid var(--line);font-family:var(--mono);height:36px;font-size:12px;display:flex;position:sticky;top:0;overflow-x:auto}.breadcrumb{color:var(--fg-mute);white-space:nowrap;align-items:center;gap:6px;padding:0 16px;font-size:11px;display:flex}.breadcrumb .sep{color:var(--fg-dim)}.breadcrumb .cur{color:var(--accent)}.breadcrumb-right{color:var(--fg-dim);align-items:center;gap:16px;margin-left:auto;padding:0 16px;font-size:11px;display:flex}.statusbar{background:var(--accent);color:#1a1a1a;font-family:var(--mono);grid-area:statusbar;align-items:center;gap:16px;padding:0 12px;font-size:11px;font-weight:500;display:flex}.sb-seg{align-items:center;gap:6px;display:flex}.sb-seg.right{margin-left:auto}.sb-dot{background:#1a1a1a;border-radius:50%;width:6px;height:6px}section{border-bottom:1px solid var(--line);padding:80px 64px;position:relative}.section-label{font-family:var(--mono);color:var(--accent);letter-spacing:.15em;text-transform:uppercase;align-items:center;gap:12px;margin-bottom:24px;font-size:11px;display:flex}.section-label:before{content:"";background:var(--accent);width:32px;height:1px}.hero{flex-direction:column;justify-content:center;min-height:calc(100vh - 96px);padding:64px;display:flex;position:relative;overflow:hidden}.hero-bg{pointer-events:none;opacity:.4;position:absolute;inset:0}.hero-bg:before{content:"";background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);background-size:64px 64px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(at 30% 40%,#000 0%,#0000 70%);mask-image:radial-gradient(at 30% 40%,#000 0%,#0000 70%)}.terminal{background:var(--bg-elev);border:1px solid var(--line-strong);width:min(820px,100%);font-family:var(--mono);z-index:1;border-radius:6px;margin-bottom:48px;font-size:14px;position:relative}.term-head{border-bottom:1px solid var(--line);color:var(--fg-mute);align-items:center;gap:10px;padding:8px 14px;font-size:11px;display:flex}.term-head .traffic span{width:10px;height:10px}.term-head .path{margin-left:8px}.term-body{min-height:220px;padding:20px 20px 24px;line-height:1.7}.term-line{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.term-prompt{color:var(--green);white-space:nowrap}.term-prompt .arrow{color:var(--accent)}.term-cmd{color:var(--fg)}.term-out{color:var(--fg-mute);white-space:pre-wrap;padding-left:0}.term-out .k{color:var(--blue)}.term-out .v{color:var(--fg)}.term-out .s{color:var(--accent)}.caret{background:var(--accent);width:8px;height:14px;animation:1s steps(2,end) infinite blink;display:inline-block}.hero-name{font-family:var(--sans);letter-spacing:-.03em;z-index:1;margin-bottom:12px;font-size:clamp(56px,9vw,128px);font-weight:300;line-height:.95;position:relative}.hero-name .bold{letter-spacing:-.01em;background:linear-gradient(180deg, var(--accent) 0%, #ffb072 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;padding:0 .12em .18em .02em;font-family:Chakra Petch,JetBrains Mono,monospace;font-style:italic;font-weight:700;line-height:1.1;display:inline-block;position:relative}.hero-role{font-family:var(--mono);color:var(--fg-mute);letter-spacing:.05em;z-index:1;flex-wrap:wrap;gap:16px;font-size:14px;display:flex;position:relative}.hero-role .chip{border:1px solid var(--line-strong);border-radius:3px;padding:6px 12px}.hero-role .chip.accent{border-color:var(--accent-line);color:var(--accent)}.parallax-num{font-family:var(--mono);color:var(--line);opacity:.5;pointer-events:none;z-index:0;letter-spacing:-.06em;font-size:320px;font-weight:700;line-height:1;position:absolute;bottom:-80px;right:-40px}.about-grid{grid-template-columns:1.2fr 1fr;align-items:start;gap:64px;display:grid}.about-heading{letter-spacing:-.02em;margin-bottom:32px;font-size:clamp(36px,5vw,64px);font-weight:300;line-height:1.05}.about-heading .em{color:var(--accent);font-style:normal}.about-body p{color:var(--fg-mute);max-width:56ch;margin-bottom:16px;font-size:15px;line-height:1.75}.about-card{border:1px solid var(--line);background:var(--bg-elev);font-family:var(--mono);font-size:13px}.about-card-head{border-bottom:1px solid var(--line);color:var(--fg-mute);letter-spacing:.1em;text-transform:uppercase;justify-content:space-between;padding:10px 16px;font-size:11px;display:flex}.about-card-body{padding:20px 16px}.kv{grid-template-columns:120px 1fr;gap:16px;padding:6px 0;display:grid}.kv .k{color:var(--fg-mute)}.kv .v{color:var(--fg)}.kv .v .hl{color:var(--accent)}.skills{background:var(--bg-elev)}.skills-grid{border:1px solid var(--line);grid-template-columns:repeat(4,1fr);gap:0;display:grid}.skill-cell{border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg);padding:24px 20px;transition:background .2s;position:relative;overflow:hidden}.skill-cell:nth-child(4n){border-right:none}.skill-cell:hover{background:var(--bg-elev-2)}.skill-cell:hover .skill-hover{opacity:1;transform:translateY(0)}.skill-num{font-family:var(--mono);color:var(--fg-dim);letter-spacing:.1em;font-size:10px}.skill-name{letter-spacing:-.01em;margin:12px 0 4px;font-size:22px;font-weight:500}.skill-tag{font-family:var(--mono);color:var(--fg-mute);font-size:11px}.skill-hover{font-family:var(--mono);color:var(--accent);opacity:0;font-size:11px;transition:all .2s;position:absolute;bottom:12px;right:16px;transform:translateY(6px)}.skill-categories{grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;display:grid}.skill-cat{border:1px solid var(--line);background:var(--bg);padding:24px}.skill-cat-title{font-family:var(--mono);color:var(--accent);letter-spacing:.12em;text-transform:uppercase;align-items:center;gap:8px;margin-bottom:16px;font-size:11px;display:flex}.skill-cat-title:before{content:"";border:1px solid var(--accent);width:8px;height:8px}.skill-cat ul{list-style:none}.skill-cat li{border-bottom:1px dashed var(--line);font-family:var(--mono);justify-content:space-between;padding:8px 0;font-size:13px;display:flex}.skill-cat li:last-child{border-bottom:none}.skill-cat li span:last-child{color:var(--fg-mute);font-size:11px}.projects-wrap{padding:0}.project{border-bottom:1px solid var(--line);align-items:center;gap:48px;padding:96px 64px;display:grid;position:relative;overflow:hidden}.project.layout-a{grid-template-columns:5fr 7fr}.project.layout-b{grid-template-columns:7fr 5fr}.project.layout-b .project-media{order:-1}.project-meta{font-family:var(--mono);color:var(--fg-mute);letter-spacing:.1em;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;font-size:11px;display:flex}.project-meta .year{color:var(--accent)}.project-meta .sep{color:var(--fg-dim)}.project-title{letter-spacing:-.03em;margin-bottom:24px;font-size:clamp(40px,6vw,72px);font-weight:300;line-height:1}.project-desc{color:var(--fg-mute);max-width:52ch;margin-bottom:24px;font-size:16px;line-height:1.7}.project-stack{flex-wrap:wrap;gap:8px;margin-bottom:32px;display:flex}.project-stack span{font-family:var(--mono);border:1px solid var(--line-strong);color:var(--fg-mute);padding:5px 10px;font-size:11px}.project-cta{font-family:var(--mono);color:var(--accent);border-bottom:1px solid var(--accent-line);align-items:center;gap:10px;padding:10px 0;font-size:13px;transition:gap .2s,border-color .2s;display:inline-flex}.project-cta:hover{border-color:var(--accent);gap:18px}.project-media{aspect-ratio:4/3;border:1px solid var(--line-strong);background:var(--bg-elev);position:relative;overflow:hidden}.browser-chrome{border-bottom:1px solid var(--line);background:var(--bg-elev-2);align-items:center;gap:8px;height:32px;padding:0 12px;display:flex}.browser-chrome .dot{background:var(--line-strong);border-radius:50%;width:10px;height:10px}.browser-url{font-family:var(--mono);color:var(--fg-mute);background:var(--bg);border:1px solid var(--line);border-radius:3px;flex:1;margin-left:10px;padding:4px 10px;font-size:11px}.browser-body{height:calc(100% - 32px);padding:24px;position:relative}.mock-trip{background:linear-gradient(var(--line) 1px, transparent 1px) 0 0 / 100% 28px, var(--bg);height:100%;font-family:var(--mono);flex-direction:column;gap:14px;padding:20px;font-size:11px;display:flex}.mock-trip-title{color:var(--accent);letter-spacing:-.01em;font-size:18px}.mock-trip-card{border:1px solid var(--line-strong);color:var(--fg-mute);justify-content:space-between;padding:12px;display:flex}.mock-trip-card .price{color:var(--fg)}.mock-trip-bar{gap:4px;height:6px;display:flex}.mock-trip-bar span{background:var(--line-strong);flex:1}.mock-trip-bar span.on{background:var(--accent)}.mock-ai{background:var(--accent-soft);border:1px solid var(--accent-line);color:var(--accent);align-items:center;gap:8px;margin-top:auto;padding:10px 12px;font-size:11px;display:flex}.mock-ai:before{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1.5s infinite blink}.mock-lucky{height:100%;font-family:var(--mono);flex-direction:column;justify-content:center;align-items:center;gap:20px;display:flex}.wheel{border:2px solid var(--line-strong);background:conic-gradient(var(--accent) 0 45deg, transparent 45deg 90deg, var(--accent) 90deg 135deg, transparent 135deg 180deg, var(--accent) 180deg 225deg, transparent 225deg 270deg, var(--accent) 270deg 315deg, transparent 315deg 360deg);border-radius:50%;width:180px;height:180px;animation:12s linear infinite spin;position:relative}.wheel:before{content:"";background:var(--bg);border:1px solid var(--line);border-radius:50%;position:absolute;inset:14px}.wheel:after{content:"";background:var(--accent);border-radius:50%;width:24px;height:24px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.mock-lucky-label{color:var(--fg-mute);letter-spacing:.15em;text-transform:uppercase;font-size:11px}.mock-lucky-btn{border:1px solid var(--accent);color:var(--accent);letter-spacing:.15em;text-transform:uppercase;padding:10px 28px;font-size:11px}.project-bignum{font-family:var(--mono);color:var(--line);opacity:.35;pointer-events:none;z-index:0;letter-spacing:-.06em;font-size:360px;font-weight:700;line-height:.8;position:absolute}.project.layout-a .project-bignum{top:-40px;right:-50px}.project.layout-b .project-bignum{bottom:-100px;left:-50px}.project>*{z-index:1;position:relative}.contact{padding:96px 64px}.contact-head{letter-spacing:-.03em;margin-bottom:48px;font-size:clamp(48px,8vw,120px);font-weight:300;line-height:1}.contact-head .line2{color:var(--fg-mute);padding-left:2ch;display:block}.contact-head .line2 .em{color:var(--accent)}.contact-grid{border-top:1px solid var(--line);border-bottom:1px solid var(--line);grid-template-columns:repeat(3,1fr);gap:0;display:grid}.contact-item{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:24px}.contact-item:nth-last-child(-n+3){border-bottom:none}.contact-item:nth-child(3n){border-right:none}.contact-item .label{font-family:var(--mono);color:var(--fg-mute);letter-spacing:.15em;text-transform:uppercase;margin-bottom:12px;font-size:10px}.contact-item .value{font-family:var(--mono);color:var(--fg);align-items:center;gap:10px;font-size:15px;transition:color .15s;display:flex}.contact-item a.value:hover,.contact-item .arrow{color:var(--accent)}.readme{max-width:920px;padding:48px 64px 80px}.md-doc{font-family:var(--sans);color:var(--fg);font-size:15px;line-height:1.7}.md-meta{font-family:var(--mono);color:var(--fg-dim);letter-spacing:.08em;text-transform:uppercase;border-bottom:1px dashed var(--line);align-items:center;gap:10px;margin-bottom:32px;padding-bottom:16px;font-size:11px;display:flex}.md-meta-dot{color:var(--line-strong)}.md-hash{color:var(--accent);font-family:var(--mono);opacity:.7;margin-right:12px;font-weight:500}.md-h1{font-family:var(--sans);letter-spacing:-.02em;margin:0 0 20px;font-size:40px;font-weight:700;line-height:1.15}.md-h2{font-family:var(--sans);letter-spacing:-.01em;border-top:1px solid var(--line);align-items:baseline;gap:4px;margin:48px 0 16px;padding-top:24px;font-size:22px;font-weight:600;display:flex}.md-h2 .md-hash{font-size:18px}.md-p{color:var(--fg);margin:0 0 16px}.md-p em,.md-quote em{color:var(--accent);font-style:normal;font-weight:500}.md-badges{flex-wrap:wrap;gap:10px;margin-bottom:28px;display:flex}.md-badge{font-family:var(--mono);border:1px solid var(--line-strong);border-radius:3px;font-size:11px;display:inline-flex;overflow:hidden}.md-badge .k{background:var(--bg-elev-2);color:var(--fg-mute);padding:4px 8px}.md-badge .v{background:var(--bg-elev);color:var(--fg);border-left:1px solid var(--line-strong);padding:4px 8px}.md-badge .v-green{color:#6fd19b}.md-badge .v-orange{color:var(--accent)}.md-doc code{font-family:var(--mono);background:var(--bg-elev);color:var(--accent);border:1px solid var(--line);border-radius:3px;padding:1px 6px;font-size:.88em}.md-table{border:1px solid var(--line);margin:12px 0 20px;font-size:13px;overflow:hidden}.md-tr{border-bottom:1px solid var(--line);grid-template-columns:1fr 2fr 1.4fr;display:grid}.md-tr:last-child{border-bottom:0}.md-tr>div{border-right:1px solid var(--line);color:var(--fg);padding:10px 16px}.md-tr>div:last-child{color:var(--fg-mute);border-right:0}.md-thead{background:var(--bg-elev-2);font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:11px}.md-thead>div{color:var(--fg-mute)!important}.md-code{background:var(--bg-elev);border:1px solid var(--line);font-family:var(--mono);margin:12px 0 20px;font-size:13px;line-height:1.7;overflow:hidden}.md-code-head{background:var(--bg-elev-2);border-bottom:1px solid var(--line);color:var(--fg-mute);letter-spacing:.08em;text-transform:uppercase;justify-content:space-between;padding:8px 16px;font-size:11px;display:flex}.md-code-copy{color:var(--fg-dim)}.md-code-copy:hover{color:var(--accent)}.md-code pre{color:var(--fg);margin:0;padding:16px;overflow-x:auto}.c-cm{color:var(--fg-dim);font-style:italic}.c-kw{color:var(--accent)}.c-dir{color:#7aa6ff}.c-str{color:#7ac74f}.c-num{color:#b490ff}.c-bool,.c-prop{color:#6aa9ff}.c-type{color:#b490ff}.c-fn{color:#ffd580}[data-theme=light] .c-str{color:#3a7a1a}[data-theme=light] .c-num{color:#7c3aed}[data-theme=light] .c-bool,[data-theme=light] .c-prop{color:#2563eb}[data-theme=light] .c-type{color:#7c3aed}[data-theme=light] .c-fn{color:#b45309}.code-file{padding:0}.code-file-header{background:var(--bg-elev);border-bottom:1px solid var(--line);font-family:var(--mono);color:var(--fg-mute);align-items:center;gap:12px;padding:14px 24px;font-size:12px;display:flex}.code-file-header .cf-dot{background:var(--accent);border-radius:50%;width:8px;height:8px;display:inline-block}.code-file-header .cf-name{color:var(--fg);font-weight:500}.code-file-header .cf-lines{margin-left:auto}.code-lines{font-family:var(--mono);counter-reset:ln;padding:16px 0 48px;font-size:13px;line-height:1.75}.code-line{align-items:baseline;min-height:1.75em;padding:0 24px 0 0;display:flex}.code-line:hover{background:var(--bg-elev)}.code-ln{min-width:44px;color:var(--fg-dim);text-align:right;-webkit-user-select:none;user-select:none;flex-shrink:0;padding:0 16px 0 24px}.code-text{white-space:pre;color:var(--fg);flex:1;overflow-x:visible}.code-section-gap{height:24px}.code-file-meta{font-family:var(--mono);color:var(--fg-dim);flex-wrap:wrap;gap:24px;padding:0 24px 24px;font-size:11px;display:flex}.md-ul{margin:0 0 20px;padding:0;list-style:none}.md-ul li{color:var(--fg);padding:4px 0}.md-bullet{color:var(--accent);font-family:var(--mono);margin-right:10px}.md-quote{border-left:3px solid var(--accent);background:var(--bg-elev);color:var(--fg-mute);margin:0 0 20px;padding:12px 20px;font-style:italic}.md-link{color:var(--accent);border-bottom:1px dashed var(--accent-line);text-decoration:none}.md-link:hover{border-bottom-style:solid}.md-hr{border:0;border-top:1px dashed var(--line);margin:40px 0 24px}.md-foot{font-family:var(--mono);color:var(--fg-dim);text-align:center;font-size:11px}.md-heart{color:var(--accent);margin:0 4px}[data-theme=light] .c-dir{color:#2563eb}.footer{font-family:var(--mono);color:var(--fg-mute);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:32px 64px;font-size:11px;display:flex}.footer .heart{width:12px;height:12px;color:var(--accent);vertical-align:-2px;transform-origin:50%;margin-left:4px;animation:1.6s ease-in-out infinite heartbeat;display:inline-block}.theme-toggle{border:1px solid var(--line-strong);width:26px;height:26px;color:var(--fg-mute);vertical-align:middle;justify-content:center;align-items:center;margin-right:8px;transition:color .15s,border-color .15s;display:inline-flex}.theme-toggle:hover{color:var(--accent);border-color:var(--accent-line)}.theme-toggle svg{width:13px;height:13px}.pages{min-height:calc(100vh - 96px)}.tweaks-panel{z-index:500;background:var(--bg-elev);border:1px solid var(--line-strong);font-family:var(--mono);min-width:240px;padding:14px 16px;font-size:12px;display:none;position:fixed;bottom:48px;right:24px}.tweaks-panel.open{display:block}.tweaks-panel h4{color:var(--accent);letter-spacing:.15em;text-transform:uppercase;margin-bottom:12px;font-size:10px;font-weight:600}.tweak-row{justify-content:space-between;align-items:center;padding:6px 0;display:flex}.tweak-row label{color:var(--fg-mute)}.tweak-row .seg{border:1px solid var(--line-strong);display:flex}.tweak-row .seg button{font-family:var(--mono);color:var(--fg-mute);background:0 0;border:none;padding:4px 10px;font-size:11px}.tweak-row .seg button.on{background:var(--accent);color:#1a1a1a}@media (width<=960px){.ide{grid-template-columns:1fr;grid-template-areas:"titlebar""main""statusbar"}.activity,.sidebar-panel{display:none}section,.hero{padding:56px 24px}.project,.contact{padding:64px 24px}.readme{padding:32px 24px 60px}.footer{padding:20px 24px}.project.layout-a,.project.layout-b{grid-template-columns:1fr}.project.layout-b .project-media{order:0}.about-grid{grid-template-columns:1fr;gap:32px}.skills-grid{grid-template-columns:repeat(2,1fr)}.skill-cell:nth-child(4n){border-right:1px solid var(--line)}.skill-cell:nth-child(2n){border-right:none}.skill-categories{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr 1fr}.contact-item{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}.contact-item:nth-child(2n){border-right:none}.contact-item:nth-last-child(-n+2){border-bottom:none}.md-h1{font-size:32px}.md-tr{grid-template-columns:1fr}.md-tr>div{border-right:0;border-bottom:1px solid var(--line)}.md-tr>div:last-child{border-bottom:0}.parallax-num{display:none}.project-bignum{font-size:180px}.terminal{font-size:12px}.hero-role{gap:10px}}@media (width<=600px){.titlebar-title{display:none}section,.hero,.project,.contact{padding:48px 18px}.readme{padding:24px 18px 48px}.footer{flex-direction:column;align-items:flex-start;gap:6px;padding:16px 18px}.terminal{font-size:11px}.term-body{min-height:160px;padding:14px 14px 18px}.skills-grid{grid-template-columns:1fr}.skill-cell:nth-child(2n){border-right:1px solid var(--line)}.contact-grid{grid-template-columns:1fr}.contact-item{border-right:none!important;border-bottom:1px solid var(--line)!important}.contact-item:last-child{border-bottom:none!important}.project-bignum{display:none}.md-h1{font-size:26px}.md-h2{font-size:18px}.about-card{overflow-x:auto}.kv{grid-template-columns:90px 1fr;font-size:12px}.hero-role .chip{padding:5px 10px;font-size:12px}.skills-grid{border:none}.skill-cell{border:1px solid var(--line);margin:-1px 0 0}.skill-cell:nth-child(n){border-right:1px solid var(--line)}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg);height:100%;color:var(--fg);font-family:var(--sans);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.6;overflow:hidden}@media (pointer:fine){html,body,*{cursor:none!important}}a{color:inherit;text-decoration:none}::selection{background:var(--accent);color:var(--bg)}body:before{content:"";pointer-events:none;opacity:.06;mix-blend-mode:overlay;z-index:1000;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");position:fixed;inset:0}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:0}[data-vi],[data-en]{display:inline}[data-lang=vi] [data-en],[data-lang=en] [data-vi]{display:none}.reveal{opacity:0;transition:opacity .8s,transform .8s;transform:translateY(24px)}.reveal.visible{opacity:1;transform:translateY(0)}.page-enter{animation:.3s pageIn}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes blink{50%{opacity:0}}@keyframes beamBlink{50%{opacity:.25}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes heartbeat{0%,40%,to{transform:scale(1)}15%{transform:scale(1.25)}30%{transform:scale(1.05)}}@media (width<=960px){.ide{grid-template-columns:0 0 1fr!important}.activity,.sidebar-panel{display:none!important}}
