:root{--color-bg-0:#0a0a0a;--color-bg-1:#121212;--color-bg-2:#1a1a1a;--color-bg-3:#242424;--color-bg-4:#2e2e2e;--color-fg-0:#ffffff;--color-fg-1:#f5f5f7;--color-fg-2:#a1a1aa;--color-fg-3:#71717a;--color-fg-4:#52525b;--color-accent-teal:#00f5ff;--color-accent-teal-dim:#00b8c4;--color-accent-green:#4ade80;--color-accent-green-dim:#22c55e;--color-warning:#ffb800;--color-danger:#ff3b30;--glow-teal:0 0 0 1px rgba(0,245,255,.35),0 0 24px rgba(0,245,255,.25);--glow-green:0 0 0 1px rgba(0,245,255,.35),0 0 24px rgba(0,245,255,.25);--paper:var(--color-bg-1);--paper-2:var(--color-bg-2);--ink:var(--color-fg-1);--ink-2:var(--color-fg-2);--ink-3:var(--color-fg-3);--rule:var(--color-bg-3);--accent:var(--color-accent-teal);--accent-soft:rgba(0,245,255,.08);--accent-warn:var(--color-warning);--accent-warn-soft:rgba(255,184,0,.08);--font-sans:var(--font-inter),-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:var(--font-jetbrains-mono),ui-monospace,"SF Mono",Menlo,Consolas,monospace;--display:var(--font-sans);--body:var(--font-sans);--sans:var(--font-sans);--mono:var(--font-mono);--ease-out:cubic-bezier(0.2,0.7,0.2,1);--ease-in-out:cubic-bezier(0.65,0,0.35,1);--dur-fast:120ms;--dur-base:200ms;--dur-slow:320ms}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--paper);color:var(--ink)}body{font-family:var(--body);font-size:17px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh;background-size:200% 200%;background-image:radial-gradient(1200px 600px at 85% -10%,#0e1018 0,transparent 60%),radial-gradient(900px 500px at -10% 110%,#0a0c14 0,transparent 55%);animation:gradient-drift 25s ease-in-out infinite}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.08;mix-blend-mode:screen;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}.wrap{position:relative;z-index:2;max-width:none;margin:0 auto;padding:20px 0 80px}.content{max-width:860px;margin:0 auto;padding:0 48px}.nav{position:-webkit-sticky;position:sticky;top:0;z-index:100;height:56px;background:rgba(10,10,10,.55);border-bottom:1px solid transparent;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nav,.nav-inner{display:flex;align-items:center}.nav-inner{width:100%;max-width:1200px;margin:0 auto;padding:0 48px;gap:32px}.nav-mark{font-family:var(--mono);font-weight:700;font-size:16px;letter-spacing:-.01em;text-decoration:none;display:inline-flex;align-items:baseline;transition:transform var(--dur-fast) var(--ease-out)}.nav-mark:hover{transform:translateY(-1px)}.nav-mark .ch{color:var(--color-accent-teal)}.nav-mark .nm{color:var(--color-fg-0)}.nav-mark .sl{color:var(--color-accent-green)}.nav-links{display:flex;align-items:center;gap:24px;margin-left:auto;font-family:var(--mono);font-size:13px;letter-spacing:.02em}.nav-links a{color:var(--color-fg-2);text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:color var(--dur-fast) var(--ease-out)}.nav-links a:hover{color:var(--color-fg-0)}.nav-cta{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:13px;letter-spacing:.02em;color:var(--color-accent-teal);text-decoration:none;padding:8px 14px;border:1px solid rgba(0,245,255,.4);border-radius:4px;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}.nav-cta:hover{background:var(--color-accent-teal);color:var(--color-bg-0);border-color:var(--color-accent-teal);box-shadow:0 0 0 1px rgba(0,245,255,.5),0 0 20px rgba(0,245,255,.25)}.hero{position:relative;padding:24px 0 56px;overflow:hidden}.hero-grid{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.055) 1px,transparent 0);background-size:24px 24px;-webkit-mask-image:radial-gradient(ellipse at top,black 35%,transparent 72%);mask-image:radial-gradient(ellipse at top,black 35%,transparent 72%);pointer-events:none;z-index:0}.hero-inner{position:relative;z-index:1}.hero-eyebrow{display:inline-flex;align-items:center;gap:12px;padding:7px 16px 7px 14px;border:1px solid rgba(74,222,128,.4);border-radius:999px;background:linear-gradient(180deg,rgba(74,222,128,.14),rgba(74,222,128,.04)),rgba(18,18,18,.55);font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--color-fg-1);box-shadow:0 0 0 1px rgba(74,222,128,.08),0 8px 24px -10px rgba(74,222,128,.35),inset 0 1px 0 rgba(255,255,255,.04);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:28px}.hero-eyebrow-dot{width:7px;height:7px;border-radius:50%;background:var(--color-accent-green);box-shadow:0 0 10px var(--color-accent-green),0 0 0 3px rgba(74,222,128,.15);animation:pulse 2s ease-in-out infinite;flex:0 0 auto}.hero-name{margin:0 0 14px;font-family:var(--display);font-weight:800;font-size:clamp(40px,7.2vw,80px);line-height:.96;letter-spacing:-.04em;color:var(--color-fg-0)}.hero-name em{font-style:italic;color:var(--accent);font-weight:400}.hero-word{display:inline-block;opacity:0;transform:translateY(24px) scale(.95);filter:blur(6px)}.hero-word--accent{color:var(--accent);font-style:italic;font-weight:400;text-shadow:0 0 14px rgba(0,245,255,.18)}[data-intro=done] .hero-word{animation:reveal-blur .9s cubic-bezier(.22,1,.36,1) forwards;animation-delay:calc(var(--i) * .13s + .1s)}.hero-cursor{display:inline-block;width:clamp(8px,1vw,12px);height:clamp(36px,6.2vw,70px);background:var(--color-accent-green);margin-left:10px;vertical-align:-8px;box-shadow:0 0 14px rgba(74,222,128,.45);opacity:0;animation:blink 1s steps(2) infinite;animation-delay:1.6s;animation-fill-mode:both}[data-intro=done] .hero-cursor{opacity:1}.hero-role{font-family:var(--mono);font-size:14px;letter-spacing:.02em;color:var(--color-fg-2);margin:0 0 24px}.hero-role-pre{color:var(--color-fg-4)}.hero-lede{font-family:var(--body);font-size:19px;line-height:1.55;color:var(--color-fg-1);margin:0 0 32px;max-width:62ch}.hero-lede .hl{color:var(--color-fg-0);font-weight:600;border-bottom:2px solid var(--color-accent-teal);padding-bottom:1px}.hero-lede .hl-green{color:var(--color-accent-green);font-family:var(--mono);font-size:17px;letter-spacing:.01em}.hero-meta{display:grid;grid-template-columns:repeat(3,max-content);grid-gap:36px;gap:36px;padding:18px 0;border-top:1px solid var(--color-bg-3);border-bottom:1px solid var(--color-bg-3);margin-bottom:8px}.hero-meta-item{display:flex;flex-direction:column;gap:4px}.hero-meta-item .k{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--color-fg-3)}.hero-meta-item .v{font-family:var(--mono);font-size:16px;font-weight:600;color:var(--color-fg-0)}.chat{margin:20px 0 0;padding:0 48px}.chat,.chat-card{position:relative}.chat-card{background:linear-gradient(180deg,#f4f1ea,#ebe7dc);color:#12131a;border:1px solid rgba(0,0,0,.14);border-radius:10px;padding:44px 48px 26px;box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 2px 0 rgba(0,0,0,.3),0 60px 120px -40px rgba(0,245,255,.12),0 30px 60px -20px rgba(0,0,0,.6);overflow:hidden;max-width:1200px;margin:0 auto}.chat:before{content:"";position:absolute;inset:-40px -10px -60px;background:radial-gradient(60% 50% at 50% 40%,rgba(0,245,255,.1) 0,transparent 70%),radial-gradient(40% 40% at 20% 60%,rgba(0,245,255,.06) 0,transparent 70%);filter:blur(40px);pointer-events:none;z-index:0}.chat>*{position:relative;z-index:1}.chat-card:after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");opacity:.08;mix-blend-mode:multiply;pointer-events:none}.chat-card>*{position:relative;z-index:2}.chat-header-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.chat-header-row .chat-sub{margin-bottom:0}.chat-status .sys-status{display:inline-flex;align-items:center;gap:8px;padding:5px 10px;border-radius:4px;font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.14em;line-height:1;text-transform:uppercase;white-space:nowrap}.chat-status .sys-status.is-online{color:#15803d;background:rgba(74,222,128,.14);border:1px solid rgba(22,101,52,.35)}.chat-status .sys-status.is-loading{color:#92400e;background:rgba(255,184,0,.14);border:1px solid rgba(180,83,9,.35)}.chat-status .sys-status.is-offline{color:#52525b;background:rgba(82,82,91,.08);border:1px solid rgba(82,82,91,.3)}.chat-status .sys-status-dot{width:6px;height:6px;border-radius:50%;flex:0 0 auto}.chat-status .sys-status.is-online .sys-status-dot{background:var(--color-accent-green);box-shadow:0 0 6px rgba(74,222,128,.55);animation:pulse 2s ease-in-out infinite}.chat-status .sys-status.is-loading .sys-status-dot{background:#f59e0b;animation:pulse 2s ease-in-out infinite}.chat-status .sys-status.is-offline .sys-status-dot{background:#71717a}.chat-lede{font-family:var(--display);font-weight:600;font-size:clamp(34px,4.4vw,58px);line-height:1.02;letter-spacing:-.025em;margin:0 0 8px;color:#12131a}.chat-lede em{font-style:italic;color:#0e7490}.chat-sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:#0e7490;margin-bottom:24px;display:flex;align-items:center;gap:10px}.chat-sub:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--color-accent-teal);box-shadow:0 0 14px var(--color-accent-teal);animation:pulse 2s ease-in-out infinite}@keyframes pulse{50%{opacity:.4;transform:scale(.85)}}.chat-input-row{display:flex;align-items:stretch;gap:12px;border-top:1px solid rgba(0,0,0,.12);padding-top:20px;margin-top:12px}.chat-input{flex:1 1;border:none;outline:none;background:transparent;font-family:var(--body);font-size:clamp(20px,2vw,26px);color:#12131a;padding:12px 4px;resize:none;min-height:52px;max-height:280px;line-height:1.4;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(18,19,26,.15) transparent}.chat-input::-webkit-scrollbar{width:4px}.chat-input::-webkit-scrollbar-track{background:transparent}.chat-input::-webkit-scrollbar-thumb{background:rgba(18,19,26,.15);border-radius:4px}.chat-input::placeholder{color:rgba(18,19,26,.45);font-style:italic}.chat-send{align-self:flex-end;font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;background:var(--accent);color:#0a0b10;border:none;padding:14px 22px;border-radius:4px;cursor:pointer;box-shadow:0 4px 16px -4px rgba(0,245,255,.4)}.chat-send:hover{box-shadow:0 0 0 1px rgba(0,245,255,.5),0 0 24px rgba(0,245,255,.4);transform:translateY(-1px)}.chat-send:active{transform:translateY(0)}.chat-send[disabled]{opacity:.5;cursor:wait}.chat-send .arrow{display:inline-block;margin-left:6px;transition:transform .2s ease}.chat-send:hover .arrow{transform:translateX(3px)}.chat-foot{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(18,19,26,.5);margin-top:12px}.chat-foot a{color:rgba(18,19,26,.55);text-decoration:none;border-bottom:1px dotted rgba(18,19,26,.3)}.chat-foot a:hover{color:#0e7490;border-bottom-color:#0e7490}.chat-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.chat-chip{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;background:transparent;color:rgba(18,19,26,.65);border:1px solid rgba(18,19,26,.2);border-radius:999px;padding:7px 12px;cursor:pointer;transition:background .16s ease,color .16s ease,border-color .16s ease,transform .16s ease}.chat-chip:hover{background:rgba(0,245,255,.1);color:#0e7490;border-color:rgba(0,245,255,.5);transform:translateY(-1px)}.chat-chip:disabled{opacity:.5;cursor:not-allowed;transform:none}.answer{margin-top:20px;padding:18px 20px;background:rgba(18,19,26,.06);border-left:3px solid var(--accent);border-radius:4px;font-family:var(--body);font-size:18px;line-height:1.55;color:#12131a;white-space:pre-wrap;display:none;animation:fadein .4s ease both}.answer.visible{display:block}.answer .doan,.answer .you{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px}.answer .you{color:rgba(18,19,26,.5)}.answer .doan{color:#0e7490}.answer .qtext{font-style:italic;color:rgba(18,19,26,.7);display:block;margin-bottom:10px;padding-bottom:10px;border-bottom:1px dashed rgba(18,19,26,.15)}.cursor{display:inline-block;width:8px;height:18px;background:#12131a;vertical-align:-2px;animation:blink 1s steps(2) infinite;margin-left:2px}@keyframes blink{50%{opacity:0}}@keyframes fadein{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}section.block{margin-top:48px}.label{font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--color-accent-teal);display:inline-block;margin-bottom:16px}.label:before{content:"// "}.skills{display:grid;grid-template-columns:160px 1fr;grid-gap:10px 22px;gap:10px 22px;font-family:var(--sans);font-size:15px;line-height:1.55}.skills dt{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);padding-top:4px}.skills dd{margin:0;color:var(--ink);font-weight:400}.skills dd .yr{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.04em;padding:1px 6px;border:1px solid var(--accent-soft);border-radius:2px;margin-right:4px;white-space:nowrap;background:rgba(0,245,255,.08);box-shadow:0 0 8px rgba(0,245,255,.12)}.skills dd b{font-weight:600;color:var(--ink)}.skills dd+dt{border-top:1px dashed var(--rule)}.awards{display:flex;flex-direction:column;gap:16px}.award{position:relative;display:grid;grid-template-columns:88px 1fr;grid-gap:22px;gap:22px;padding:24px 26px;background:var(--color-bg-2);border:1px solid var(--color-bg-3);border-radius:4px;box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 4px 12px rgba(0,0,0,.35);transition:border-color var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out)}.award:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--color-accent-teal);opacity:.55}.award .yr{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--color-fg-3);padding-top:4px}.award h3{font-family:var(--display);font-weight:600;font-size:22px;line-height:1.2;margin:0 0 2px;letter-spacing:-.02em}.award .meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px}.award p{margin:4px 0 0;color:var(--ink-2);font-size:16px;max-width:56ch}.award p a{color:var(--ink);text-decoration:none;border-bottom:1.5px solid var(--accent);transition:color .15s ease,border-color .15s ease}.award .place,.award p a:hover{color:var(--accent)}.award .place{display:inline-block;font-family:var(--display);font-style:italic;font-size:13px;letter-spacing:.02em;margin-left:6px}.awards--bento{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px}.awards--bento .award{display:flex;flex-direction:column;gap:6px;grid-template-columns:none;padding:20px 22px}.awards--bento .award .yr{padding-top:0;font-size:10px}.awards--bento .award h3{font-size:18px;margin-top:4px}.awards--bento .award .meta{font-size:10px}.awards--bento .award p{font-size:14px;margin-top:4px}footer{margin-top:70px;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);padding-top:18px;border-top:1px solid var(--rule)}footer a{color:var(--ink);text-decoration:none;border-bottom:1.5px solid var(--accent)}footer a:hover{color:var(--accent)}@keyframes reveal-blur{to{opacity:1;transform:none;filter:blur(0)}}@keyframes gradient-drift{0%,to{background-position:0 0}50%{background-position:100% 100%}}.entrance{opacity:0;transform:translateY(10px)}.entrance--sub{filter:blur(4px)}.entrance--card{filter:blur(8px);transform:scale(.96) translateY(28px)}.entrance--card .chat-input-row,.entrance--card .chat-lede,.entrance--card .chat-sub{opacity:0;transform:translateY(8px)}.entrance--card .chat-foot{opacity:0}[data-intro=done] .entrance{animation:reveal-blur .7s cubic-bezier(.22,1,.36,1) 50ms forwards}[data-intro=done] .hero-role.entrance{animation-delay:.25s}[data-intro=done] .hero-meta.entrance{animation-delay:.85s}[data-intro=done] .entrance--sub{animation:reveal-blur .8s cubic-bezier(.22,1,.36,1) .65s forwards}[data-intro=done] .entrance--card{animation:reveal-blur 1.2s cubic-bezier(.22,1,.36,1) .9s forwards}[data-intro=done] .entrance--card .chat-sub{animation:reveal-blur .5s cubic-bezier(.22,1,.36,1) 1.4s forwards}[data-intro=done] .entrance--card .chat-lede{animation:reveal-blur .5s cubic-bezier(.22,1,.36,1) 1.55s forwards}[data-intro=done] .entrance--card .chat-input-row{animation:reveal-blur .5s cubic-bezier(.22,1,.36,1) 1.7s forwards}[data-intro=done] .entrance--card .chat-foot{animation:reveal-blur .4s ease 1.85s forwards}.scroll-reveal{opacity:0;transform:translateY(24px);filter:blur(4px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1),filter .8s cubic-bezier(.22,1,.36,1)}.scroll-reveal.is-visible{opacity:1;transform:none;filter:blur(0)}.scroll-reveal.is-visible .award{opacity:0;transform:translateY(14px);animation:reveal-blur .55s cubic-bezier(.22,1,.36,1) forwards}.scroll-reveal.is-visible .award:first-child{animation-delay:80ms}.scroll-reveal.is-visible .award:nth-child(2){animation-delay:.18s}.scroll-reveal.is-visible .award:nth-child(3){animation-delay:.28s}@media (hover:hover) and (pointer:fine){.award:hover{border-color:rgba(0,245,255,.6);box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 0 0 1px rgba(0,245,255,.25),0 0 32px rgba(0,245,255,.12),0 12px 24px rgba(0,0,0,.45);transform:translateY(-2px)}.skills .yr{transition:transform .15s cubic-bezier(.22,1,.36,1),box-shadow .15s ease}.skills .yr:hover{transform:scale(1.08);box-shadow:0 0 14px rgba(0,245,255,.3)}.hero-name:hover .hero-word--accent{text-shadow:0 0 30px rgba(0,245,255,.4),0 0 60px rgba(0,245,255,.12);transition:text-shadow .4s ease}footer a{transition:color .2s ease,border-bottom-color .2s ease,letter-spacing .3s cubic-bezier(.22,1,.36,1)}footer a:hover{letter-spacing:.2em}}.chat-send{transition:transform .16s cubic-bezier(.22,1,.36,1),background .16s ease,box-shadow .16s ease}.chat-send:active{transform:scale(.97)!important}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.cinematic{position:fixed;inset:0;z-index:1000;background:radial-gradient(900px 500px at 12% 18%,rgba(0,245,255,.06) 0,transparent 60%),radial-gradient(800px 460px at 90% 110%,rgba(74,222,128,.05) 0,transparent 55%),var(--color-bg-0);display:flex;align-items:center;justify-content:center;padding:48px 24px;transition:opacity .9s cubic-bezier(.22,1,.36,1)}.cinematic--exit{opacity:0}[data-intro=done] .cinematic{display:none}.cinematic-grid{background-image:linear-gradient(rgba(0,245,255,.045) 1px,transparent 0),linear-gradient(90deg,rgba(0,245,255,.045) 1px,transparent 0);background-size:32px 32px;-webkit-mask-image:radial-gradient(ellipse 70% 55% at 50% 45%,#000 30%,transparent 80%);mask-image:radial-gradient(ellipse 70% 55% at 50% 45%,#000 30%,transparent 80%);opacity:.6}.cinematic-grid,.cinematic-vignette{position:absolute;inset:0;pointer-events:none}.cinematic-vignette{background:radial-gradient(ellipse at center,transparent 55%,rgba(0,0,0,.6) 100%)}.cinematic-inner{position:relative;z-index:1;width:min(760px,92vw)}.intro-frame{border:1px solid rgba(0,245,255,.2);border-radius:8px;background:rgba(10,10,10,.72);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 0 0 1px rgba(0,245,255,.04),0 30px 80px -20px rgba(0,0,0,.8),0 0 60px -20px rgba(0,245,255,.25);overflow:hidden;opacity:0;transform:translateY(8px) scale(.985);animation:intro-frame-in .7s cubic-bezier(.22,1,.36,1) 60ms forwards}.intro-frame-bar{display:flex;align-items:center;gap:12px;padding:10px 14px;background:linear-gradient(180deg,rgba(255,255,255,.035),transparent);border-bottom:1px solid rgba(0,245,255,.12);font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-3)}.intro-frame-dots{display:inline-flex;gap:6px}.intro-frame-dot{width:10px;height:10px;border-radius:50%;background:var(--color-bg-3);box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}.intro-frame-dot:first-child{background:#ff5f57}.intro-frame-dot:nth-child(2){background:#febc2e}.intro-frame-dot:nth-child(3){background:#28c840}.intro-frame-title{flex:1 1;text-align:center;color:var(--ink-3);letter-spacing:.04em}.intro-frame-meta{display:inline-flex;align-items:center;gap:6px;text-transform:uppercase;color:var(--color-accent-teal);letter-spacing:.14em}.intro-frame-meta-dot{width:6px;height:6px;border-radius:50%;background:var(--color-accent-teal);box-shadow:0 0 10px var(--color-accent-teal);animation:pulse 2s ease-in-out infinite}.intro-terminal{padding:22px 26px 28px;font-family:var(--mono)}.intro-boot{display:flex;flex-direction:column;gap:6px;font-size:13.5px;line-height:1.7;color:var(--ink-2)}.intro-boot-line{opacity:0;transform:translateX(-6px);animation:intro-boot-in .28s cubic-bezier(.2,.7,.2,1) forwards;white-space:pre-wrap;word-break:break-word}.intro-boot-prompt{color:var(--color-accent-green)}.intro-boot-sep{color:var(--ink-3);margin:0 6px 0 2px}.intro-boot-cmd{color:var(--ink)}.intro-boot-line--ok{color:var(--ink-2)}.intro-boot-tag{color:var(--color-accent-teal);margin-right:10px;letter-spacing:.04em}.intro-story{margin-top:26px;display:flex;flex-direction:column}.intro-divider{display:flex;align-items:center;gap:10px;margin-bottom:18px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);opacity:0;animation:intro-reveal .6s cubic-bezier(.22,1,.36,1) 80ms forwards}.intro-divider-cap{color:var(--color-accent-teal);font-weight:600}.intro-divider-rule{flex:1 1;height:1px;background:linear-gradient(90deg,transparent,rgba(0,245,255,.35),transparent)}.intro-divider-meta{color:var(--ink-2)}.intro-name{margin:0 0 18px;font-family:var(--display);font-weight:700;font-size:clamp(34px,5.5vw,56px);letter-spacing:-.025em;line-height:1;color:var(--ink);opacity:0;animation:intro-reveal .7s cubic-bezier(.22,1,.36,1) .22s forwards}.intro-paragraph{margin:0;font-family:var(--body);font-size:clamp(15px,1.55vw,17.5px);line-height:1.75;color:var(--ink-1);text-align:left;max-width:60ch;opacity:0;animation:intro-reveal .6s cubic-bezier(.22,1,.36,1) .38s forwards}.intro-cursor{display:inline-block;width:7px;height:1.05em;margin-left:4px;background:var(--color-accent-teal);vertical-align:text-bottom;animation:blink 1s steps(2) infinite;box-shadow:0 0 12px rgba(0,245,255,.6)}.intro-skip{position:fixed;bottom:28px;right:28px;z-index:1001;display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--color-accent-teal);background:rgba(10,10,10,.55);border:1px solid rgba(0,245,255,.4);padding:9px 14px;border-radius:4px;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}.intro-skip:hover{background:var(--color-accent-teal);color:var(--color-bg-0);box-shadow:0 0 0 1px rgba(0,245,255,.5),0 0 20px rgba(0,245,255,.25);transform:translateY(-1px)}.intro-skip-key{display:inline-flex;align-items:center;justify-content:center;min-width:26px;padding:2px 6px;border:1px solid;border-radius:3px;font-size:10.5px;letter-spacing:.12em;opacity:.9}.intro-skip-arrow{font-size:13px;opacity:.8}@keyframes intro-frame-in{to{opacity:1;transform:none}}@keyframes intro-boot-in{to{opacity:1;transform:none}}@keyframes intro-reveal{0%{opacity:0;transform:translateY(6px);filter:blur(4px)}to{opacity:1;transform:none;filter:blur(0)}}.sys-status{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2)}.sys-status-dot{width:6px;height:6px;border-radius:50%;background:var(--ink-3);flex:0 0 auto}.sys-status.is-online .sys-status-dot{background:var(--color-accent-teal);box-shadow:0 0 10px var(--color-accent-teal)}.sys-status.is-loading .sys-status-dot,.sys-status.is-online .sys-status-dot{animation:pulse 2s ease-in-out infinite}.sys-status.is-offline{color:var(--ink-3)}.sys-status.is-offline .sys-status-dot{background:#6b6b73}.badge{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:4px 8px;border:1px solid transparent;border-radius:4px;white-space:nowrap;line-height:1.4}.badge--live,.badge--shipped{color:var(--color-accent-teal);background:rgba(0,245,255,.08);border-color:rgba(0,245,255,.4)}.badge--wip{color:var(--color-warning);background:rgba(255,184,0,.08);border-color:rgba(255,184,0,.4)}@media (max-width:760px){.wrap{padding:28px 0 60px}.chat,.content{padding:0 20px}.chat-card{padding:24px 22px 16px}.skills{grid-template-columns:1fr;gap:4px 0}.skills dt{padding-top:10px}.award{gap:4px}.award,.awards--bento{grid-template-columns:1fr}.hero-meta{grid-template-columns:repeat(2,1fr);gap:16px 24px}.chat-header-row{flex-direction:column;align-items:flex-start;gap:10px}.nav{height:auto;padding:10px 0}.nav-inner{padding:0 20px;flex-wrap:wrap;gap:10px 18px}.nav-links{gap:12px 14px;flex-wrap:wrap;font-size:11.5px}.nav-sep{display:none}.chat-input-row{flex-direction:column}.chat-send{align-self:stretch}.cinematic{padding:24px 14px}.cinematic-inner{width:100%}.intro-frame-bar{padding:8px 12px;font-size:10.5px}.intro-frame-title{display:none}.intro-terminal{padding:18px 18px 22px}.intro-boot{font-size:12.5px}.intro-name{font-size:clamp(28px,8vw,40px)}.intro-paragraph{font-size:14.5px;max-width:none}.intro-skip{bottom:16px;right:16px;padding:8px 12px;font-size:11px}}body.chat-mode .content,body.chat-mode .hero,body.chat-mode .nav,body.chat-mode>footer{display:none}body.chat-mode{overflow:hidden}.chat-hero-frame{transition:opacity .32s var(--ease-out),transform .32s var(--ease-out),filter .32s var(--ease-out);transform-origin:50% 35%;will-change:opacity,transform}.chat-hero-frame--hidden{opacity:0;transform:scale(.94) translateY(-20px);filter:blur(6px);pointer-events:none}.chat-takeover{position:fixed;inset:0;z-index:200;background:var(--color-bg-0);transform-origin:50% 100%;animation:chat-takeover-in .38s cubic-bezier(.2,.8,.2,1) both;will-change:opacity,transform,border-radius}@keyframes chat-takeover-in{0%{opacity:0;transform:translateY(8%) scale(.96);border-radius:28px 28px 0 0}60%{opacity:1}to{opacity:1;transform:translateY(0) scale(1);border-radius:0}}.chat-session{position:absolute;inset:0;display:grid;grid-template-rows:auto 1fr auto;height:100dvh;background:var(--color-bg-0);color:var(--color-fg-1)}.chat-session-header{position:-webkit-sticky;position:sticky;top:0;z-index:10;height:56px;background:rgba(10,10,10,.65);border-bottom:1px solid var(--color-bg-3);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.chat-session-header-inner{width:100%;max-width:880px;height:100%;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.chat-session-header .chat-back{font-family:var(--mono);font-weight:700;font-size:16px;text-decoration:none;display:inline-flex;align-items:baseline;min-height:44px;padding:10px 4px;transition:transform var(--dur-fast) var(--ease-out)}.chat-session-header .chat-back:hover{transform:translateY(-1px)}.chat-reset{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;background:transparent;color:var(--color-fg-2);border:1px solid var(--color-bg-3);border-radius:4px;padding:8px 14px;min-height:44px;cursor:pointer;transition:color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out)}.chat-reset:hover{color:var(--color-fg-0);border-color:var(--color-fg-3)}.chat-reset--confirming{color:var(--color-warning);border-color:var(--color-warning)}.chat-transcript{min-height:0;overflow-y:auto;padding:24px 0 32px;scrollbar-width:thin;scrollbar-color:var(--color-bg-3) transparent}.chat-transcript::-webkit-scrollbar{width:6px}.chat-transcript::-webkit-scrollbar-track{background:transparent}.chat-transcript::-webkit-scrollbar-thumb{background:var(--color-bg-3);border-radius:3px}.chat-transcript-inner{max-width:880px;margin:0 auto;padding:0 24px;gap:28px}.chat-transcript-inner,.turn{display:flex;flex-direction:column}.turn{gap:14px;padding-bottom:28px;border-bottom:1px dashed var(--color-bg-3)}.turn:last-child{border-bottom:none}.turn .turn-a,.turn .turn-q{display:flex;flex-direction:column;gap:6px}.turn .doan,.turn .you{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase}.turn .you{color:var(--color-fg-2)}.turn .doan{color:var(--color-accent-teal)}.turn .doan--error{color:var(--color-danger)}.turn .qtext{font-style:italic;color:var(--color-fg-2);font-size:16px;line-height:1.5}.turn .atext{color:var(--color-fg-1);font-size:17px;line-height:1.6;white-space:pre-wrap}.turn .aerr{color:var(--color-danger);font-size:15px;line-height:1.5}.turn .cursor{display:inline-block;width:8px;height:18px;background:var(--color-accent-teal);vertical-align:-2px;animation:blink 1s steps(2) infinite;margin-left:2px}.turn-retry{align-self:flex-start;margin-top:6px;font-family:var(--mono);font-size:12px;letter-spacing:.08em;background:transparent;color:var(--color-accent-teal);border:1px solid var(--color-accent-teal-dim);border-radius:4px;padding:8px 14px;min-height:44px;cursor:pointer;transition:background var(--dur-fast) var(--ease-out)}.turn-retry:hover{background:rgba(0,245,255,.08)}.chat-input-footer{display:block;font-family:var(--body);font-size:16px;text-transform:none;letter-spacing:normal;margin-top:0;position:-webkit-sticky;position:sticky;bottom:0;background:linear-gradient(180deg,transparent 0,var(--color-bg-0) 32px);padding:16px 0 calc(16px + env(safe-area-inset-bottom, 0));border-top:1px solid var(--color-bg-3)}.chat-input-inner{max-width:880px;margin:0 auto;padding:0 24px}.chat-input-footer .chat-input-row{display:flex;gap:12px;align-items:flex-end}.chat-input-footer .chat-input{flex:1 1;min-height:44px;max-height:240px;padding:12px 14px;background:var(--color-bg-1);color:var(--color-fg-1);border:1px solid rgba(0,245,255,.25);border-radius:8px;font-family:var(--body);font-size:16px;line-height:1.5;resize:none;overflow-y:auto;box-shadow:0 0 0 1px rgba(0,245,255,.08),0 0 24px rgba(0,245,255,.12),inset 0 1px 0 rgba(255,255,255,.03);transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}.chat-input-footer .chat-input:focus{outline:none;border-color:var(--color-accent-teal);box-shadow:0 0 0 2px rgba(0,245,255,.35),0 0 32px rgba(0,245,255,.35),0 0 60px rgba(0,245,255,.18),inset 0 1px 0 rgba(255,255,255,.04)}.chat-input-footer .chat-input::placeholder{color:var(--color-fg-2);font-style:italic}.chat-input-footer .chat-send{min-height:44px;padding:10px 18px;background:var(--color-accent-teal);color:var(--color-bg-0);border:none;border-radius:8px;font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.06em;cursor:pointer;transition:box-shadow var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}.chat-input-footer .chat-send:hover{box-shadow:0 0 0 1px rgba(0,245,255,.5),0 0 24px rgba(0,245,255,.4);transform:translateY(-1px)}.chat-input-footer .chat-send:active{transform:translateY(0)}.chat-input-footer .chat-send[disabled]{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.chat-input-footer .chat-foot{margin-top:10px;display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--color-fg-2)}.chat-session-header-left{display:flex;align-items:center;gap:16px;min-width:0}.chat-session-pill{font-size:10.5px;padding:4px 10px;border-radius:4px;border:1px solid transparent;white-space:nowrap;line-height:1}.chat-session-pill--idle{color:var(--color-fg-2);background:rgba(74,222,128,.06);border-color:rgba(74,222,128,.24)}.chat-session-pill--idle .sys-status-dot{background:var(--color-accent-green);box-shadow:0 0 6px rgba(74,222,128,.55);animation:none}.chat-session-pill--streaming{color:var(--color-accent-teal);background:rgba(0,245,255,.08);border-color:rgba(0,245,255,.35)}.chat-session-pill--streaming .sys-status-dot{background:var(--color-accent-teal);box-shadow:0 0 8px var(--color-accent-teal);animation:pulse 2s ease-in-out infinite}.chat-session-pill--error{color:var(--color-danger);background:rgba(255,59,48,.08);border-color:rgba(255,59,48,.4)}.chat-session-pill--error .sys-status-dot{background:var(--color-danger);box-shadow:0 0 6px rgba(255,59,48,.55);animation:none}.chat-session{isolation:isolate}.chat-session:before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 0);background-size:24px 24px;-webkit-mask-image:radial-gradient(ellipse at top,black 30%,transparent 70%);mask-image:radial-gradient(ellipse at top,black 30%,transparent 70%)}.chat-transcript{position:relative;z-index:1}.chat-input-footer{z-index:10}.chat-transcript-label{position:-webkit-sticky;position:sticky;top:0;z-index:5;display:block;margin:0 -24px;padding:14px 24px 10px;font-size:11px;background:linear-gradient(180deg,var(--color-bg-0) 0,var(--color-bg-0) 70%,transparent 100%)}.chat-transcript-empty{display:flex;align-items:center;justify-content:center;min-height:40vh;padding:0 24px;font-family:var(--mono);font-size:13px;letter-spacing:.14em;color:var(--color-fg-2);text-align:center}@media (prefers-reduced-motion:reduce){.chat-takeover{animation:none}.chat-hero-frame{transition:none}}@media (max-width:640px){.chat-input-inner,.chat-session-header-inner,.chat-transcript-inner{padding:0 16px}.chat-transcript-label{margin:0 -16px;padding:14px 16px 10px}}