:root{--bg: #0d0a08;--bg-soft: #15110d;--surface: #1a1510;--surface-2: #221b15;--line: #2f271f;--text: #f2ece4;--muted: #9a8f84;--faint: #6a6058;--accent: #d2855e;--accent-dim: #b06c48;--green: #7ee787;--blue: #6ea8fe;--radius: 14px;--maxw: 1180px;--display: "Syne", sans-serif;--body: "Sora", sans-serif;--mono: "JetBrains Mono", ui-monospace, monospace}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--body);font-weight:300;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}::selection{background:var(--accent);color:#0a0a0c}a{color:inherit}.bg-grid{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);background-size:64px 64px;-webkit-mask-image:radial-gradient(circle at 50% 25%,#000 0%,transparent 80%);mask-image:radial-gradient(circle at 50% 25%,#000 0%,transparent 80%)}.bg-glow{position:fixed;top:-22vh;right:-12vw;width:60vw;height:60vw;z-index:-2;background:radial-gradient(circle,rgba(210,133,94,.12) 0%,transparent 62%);filter:blur(8px);pointer-events:none}.bg-glow.two{top:auto;bottom:-28vh;left:-16vw;right:auto;width:55vw;height:55vw;background:radial-gradient(circle,rgba(120,120,255,.06) 0%,transparent 62%)}.grain{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E")}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}section{padding:120px 0;position:relative}.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500;display:inline-flex;align-items:center;gap:10px;margin-bottom:22px}.eyebrow:before{content:"";width:26px;height:1px;background:var(--accent);opacity:.7}.eyebrow.center{justify-content:center}.eyebrow.center:after{content:"";width:26px;height:1px;background:var(--accent);opacity:.7}.section-title{font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,4vw,3rem);line-height:1.05;letter-spacing:-.02em;margin-bottom:14px}.section-sub{color:var(--muted);max-width:560px;margin-bottom:54px;font-size:1.02rem}.section-sub.center{margin-left:auto;margin-right:auto}.accent-text{color:var(--accent);font-style:normal}.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}.reveal.in{opacity:1;transform:none}nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:18px 28px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0a0a0c8c;border-bottom:1px solid transparent;transition:border-color .4s,background .4s}nav.scrolled{border-bottom-color:var(--line);background:#0a0a0cd1}.logo{font-family:var(--mono);font-weight:600;font-size:.95rem;letter-spacing:.04em;color:var(--text);text-decoration:none;display:flex;align-items:center;gap:9px}.logo .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px var(--accent);animation:pulse 2.6s infinite}.logo-mark{height:30px;width:auto;display:block}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.82)}}.nav-links{display:flex;gap:30px;align-items:center}.nav-links a{font-family:var(--mono);font-size:.82rem;color:var(--muted);text-decoration:none;letter-spacing:.02em;transition:color .2s;position:relative}.nav-links a:hover{color:var(--text)}.nav-links a:after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;background:var(--accent);transition:width .25s}.nav-links a:hover:after{width:100%}.nav-links a.term-link,.nav-links a.active{color:var(--accent)}.nav-toggle{display:none;background:none;border:none;color:var(--text);font-family:var(--mono);font-size:1.4rem;cursor:pointer}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding-top:90px;padding-bottom:60px}.hero .status{font-family:var(--mono);font-size:.78rem;color:var(--muted);display:inline-flex;align-items:center;gap:9px;margin-bottom:30px;border:1px solid var(--line);border-radius:100px;padding:7px 15px;width:fit-content;background:var(--surface)}.hero .status .blip{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:pulse 2s infinite}.hero h1{font-family:var(--display);font-weight:800;font-size:clamp(2.9rem,9vw,6.4rem);line-height:.94;letter-spacing:-.03em;margin-bottom:26px}.hero h1 .ln{display:block;overflow:hidden}.hero h1 .ln span{display:block;transform:translateY(110%);animation:rise .9s cubic-bezier(.16,1,.3,1) forwards}.hero h1 .ln:nth-child(2) span{animation-delay:.12s}@keyframes rise{to{transform:translateY(0)}}.hero h1 em{font-style:normal;color:var(--accent)}.roles{font-family:var(--mono);font-size:clamp(.95rem,2.4vw,1.25rem);color:var(--text);margin-bottom:30px;height:1.5em;opacity:0;animation:fadeUp .8s ease .5s forwards}.roles .cursor{color:var(--accent);font-weight:600;animation:blink 1s steps(2) infinite}@keyframes blink{50%{opacity:0}}.hero p.blurb{max-width:600px;color:var(--muted);font-size:1.08rem;margin-bottom:40px;opacity:0;animation:fadeUp .8s ease .65s forwards}@keyframes fadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.hero .cta{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fadeUp .8s ease .8s forwards}.scroll-hint{position:absolute;bottom:34px;left:50%;transform:translate(-50%);font-family:var(--mono);font-size:.68rem;letter-spacing:.2em;color:var(--faint);text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0;animation:fadeUp 1s ease 1.1s forwards}.scroll-hint .bar{width:1px;height:38px;background:linear-gradient(var(--accent),transparent);animation:drop 1.8s ease-in-out infinite}@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}to{transform:scaleY(0);transform-origin:bottom}}.btn{font-family:var(--mono);font-size:.85rem;letter-spacing:.02em;padding:14px 26px;border-radius:100px;text-decoration:none;cursor:pointer;border:1px solid var(--line);transition:.25s;display:inline-flex;align-items:center;gap:9px;background:none;color:var(--text)}.btn.primary{background:var(--accent);color:#0a0a0c;border-color:var(--accent);font-weight:600}.btn.primary:hover{box-shadow:0 0 28px #d2855e66;transform:translateY(-2px)}.btn.ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.about-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:60px;align-items:start}.about-text p{color:var(--muted);font-size:1.1rem;margin-bottom:20px}.about-text strong{color:var(--text);font-weight:500}.about-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:28px;font-family:var(--mono);font-size:.85rem}.about-card .row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line);gap:16px}.about-card .row:last-child{border-bottom:none}.about-card .k{color:var(--faint)}.about-card .v{color:var(--text);text-align:right}.about-card .v.accent{color:var(--accent)}.about-card .v.green{color:var(--green)}.skill-block{margin-bottom:34px}.skill-block h3{font-family:var(--mono);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:16px;display:flex;align-items:center;gap:10px}.skill-block h3 .num{color:var(--accent)}.chips{display:flex;flex-wrap:wrap;gap:10px}.chip{font-family:var(--mono);font-size:.82rem;color:var(--muted);border:1px solid var(--line);border-radius:8px;padding:8px 14px;background:var(--surface);transition:.2s;cursor:default}.chip:hover{color:var(--text);border-color:var(--accent-dim);transform:translateY(-2px);background:var(--surface-2)}.timeline{border-left:1px solid var(--line);margin-left:8px}.tl-item{position:relative;padding:0 0 46px 36px}.tl-item:last-child{padding-bottom:0}.tl-item:before{content:"";position:absolute;left:-5px;top:6px;width:9px;height:9px;border-radius:50%;background:var(--bg);border:2px solid var(--accent)}.tl-date{font-family:var(--mono);font-size:.75rem;color:var(--accent);letter-spacing:.05em;margin-bottom:6px}.tl-item h4{font-family:var(--display);font-weight:600;font-size:1.25rem;margin-bottom:3px}.tl-item .org{color:var(--muted);font-size:.95rem;margin-bottom:10px}.tl-item p{color:var(--faint);font-size:.96rem}.placeholder-tag{font-family:var(--mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:#0a0a0c;background:var(--accent-dim);padding:2px 8px;border-radius:5px;margin-left:10px;vertical-align:middle}.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}.proj{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:30px;transition:.3s;position:relative;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit}.proj:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius);border:1px solid transparent;transition:.3s;pointer-events:none}.proj:hover{transform:translateY(-5px);background:var(--surface-2)}.proj:hover:after{border-color:var(--accent-dim)}.proj .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.proj .idx{font-family:var(--mono);font-size:.72rem;color:var(--faint)}.proj .arrow{font-family:var(--mono);color:var(--muted);transition:.3s;font-size:1.1rem}.proj:hover .arrow{color:var(--accent);transform:translate(3px,-3px)}.proj h4{font-family:var(--display);font-weight:600;font-size:1.4rem;margin-bottom:12px;letter-spacing:-.01em}.proj p{color:var(--muted);font-size:.96rem;margin-bottom:20px;flex:1}.proj .tags{display:flex;flex-wrap:wrap;gap:7px}.proj .tags span{font-family:var(--mono);font-size:.72rem;color:var(--faint);border:1px solid var(--line);padding:4px 9px;border-radius:6px}.term-shell{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#0d0d10;box-shadow:0 30px 80px #00000080;max-width:880px;margin:0 auto}.term-bar{display:flex;align-items:center;gap:8px;padding:13px 16px;background:var(--surface-2);border-bottom:1px solid var(--line)}.term-bar .dots{display:flex;gap:7px}.term-bar .dots i{width:11px;height:11px;border-radius:50%;display:block}.term-bar .dots i:nth-child(1){background:#ff5f57}.term-bar .dots i:nth-child(2){background:#febc2e}.term-bar .dots i:nth-child(3){background:#28c840}.term-bar .title{font-family:var(--mono);font-size:.78rem;color:var(--muted);margin-left:8px}.term-body{font-family:var(--mono);font-size:.88rem;line-height:1.7;padding:20px;height:420px;overflow-y:auto;cursor:text;color:#ededf0}.term-body::-webkit-scrollbar{width:8px}.term-body::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}.term-line{white-space:pre-wrap;word-break:break-word}.term-line .prompt{color:#d2855e}.term-out{color:#9a9aa5;white-space:pre-wrap;margin-bottom:4px}.term-out .g{color:var(--green)}.term-out .a{color:#d2855e}.term-out .b{color:var(--blue)}.term-out .dim{color:var(--faint)}.term-input-line{display:flex;align-items:center;gap:8px}.term-input-line .prompt{color:#d2855e;white-space:nowrap}.term-input-line input{flex:1;background:none;border:none;outline:none;color:#ededf0;font-family:var(--mono);font-size:.88rem;caret-color:#d2855e}.term-hint{text-align:center;font-family:var(--mono);font-size:.78rem;color:var(--faint);margin-top:18px}.term-hint b{color:var(--accent);font-weight:500}.contact{text-align:center}.contact h2{font-family:var(--display);font-weight:800;font-size:clamp(2.2rem,7vw,4.5rem);line-height:1;letter-spacing:-.03em;margin-bottom:26px}.contact h2 a{color:var(--accent);text-decoration:none;border-bottom:2px solid transparent;transition:.25s}.contact h2 a:hover{border-bottom-color:var(--accent)}.contact .links{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:34px}footer{border-top:1px solid var(--line);padding:34px 0}.foot-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.foot-inner .meta{font-family:var(--mono);font-size:.76rem;color:var(--faint)}.foot-inner .meta b{color:var(--accent);font-weight:500}.secure-badge{font-family:var(--mono);font-size:.74rem;color:var(--muted);display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);padding:7px 14px;border-radius:100px;background:var(--surface)}.secure-badge .lock{color:var(--green)}.lab-hero{padding:150px 0 30px;text-align:center}.lab-hero h1{font-family:var(--display);font-weight:800;font-size:clamp(2.6rem,8vw,5rem);line-height:.95;letter-spacing:-.03em;margin-bottom:18px}.lab-hero h1 em{font-style:normal;color:var(--accent)}.lab-hero p{color:var(--muted);max-width:560px;margin:0 auto;font-size:1.05rem}.filters{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:36px 0 10px}.filters button{font-family:var(--mono);font-size:.78rem;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:100px;padding:8px 18px;cursor:pointer;transition:.2s}.filters button:hover{color:var(--text);border-color:var(--accent-dim)}.filters button.active{background:var(--accent);color:#0a0a0c;border-color:var(--accent);font-weight:600}.lab-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:18px;padding:40px 0 100px}.tile{position:relative;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:28px 20px;text-align:center;cursor:pointer;transition:.28s;overflow:hidden;display:flex;flex-direction:column;align-items:center;gap:14px;text-decoration:none;color:inherit}.tile:hover{transform:translateY(-6px);background:var(--surface-2);border-color:var(--accent-dim);box-shadow:0 18px 50px #0006}.tile .ico{width:54px;height:54px;border-radius:13px;display:grid;place-items:center;background:#d2855e14;border:1px solid var(--line);transition:.28s}.tile:hover .ico{background:#d2855e24;box-shadow:0 0 22px #d2855e40}.tile .ico svg{width:26px;height:26px;stroke:var(--accent);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}.tile.g .ico svg{stroke:var(--green)}.tile.g .ico{background:#7ee78712}.tile.b .ico svg{stroke:var(--blue)}.tile.b .ico{background:#6ea8fe12}.tile .name{font-family:var(--mono);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text)}.tile .tag{font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}.tile .badge{position:absolute;top:10px;right:10px;font-family:var(--mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:6px;background:var(--surface-2);color:var(--faint);border:1px solid var(--line)}.tile.soon{opacity:.62;cursor:default}.tile.soon:hover{transform:none;box-shadow:none;border-color:var(--line);background:var(--surface)}.tile.soon .badge{color:var(--accent);border-color:var(--accent-dim)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#060608c7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:24px}.modal{width:100%;max-width:600px;max-height:88vh;overflow:hidden;display:flex;flex-direction:column;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 40px 100px #0009;animation:pop .25s cubic-bezier(.16,1,.3,1)}@keyframes pop{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:none}}.modal-bar{display:flex;align-items:center;gap:8px;padding:14px 18px;background:var(--surface-2);border-bottom:1px solid var(--line)}.modal-bar .dots{display:flex;gap:7px}.modal-bar .dots i{width:11px;height:11px;border-radius:50%;display:block}.modal-bar .dots i:nth-child(1){background:#ff5f57}.modal-bar .dots i:nth-child(2){background:#febc2e}.modal-bar .dots i:nth-child(3){background:#28c840}.modal-bar .ttl{font-family:var(--mono);font-size:.8rem;color:var(--muted);margin-left:6px;flex:1}.modal-bar .x{background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer;font-family:var(--mono);line-height:1;transition:.2s}.modal-bar .x:hover{color:var(--accent)}.modal-body{padding:24px;overflow-y:auto}.modal-body::-webkit-scrollbar{width:8px}.modal-body::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}.tool-h{font-family:var(--display);font-weight:600;font-size:1.3rem;margin-bottom:6px}.tool-d{color:var(--muted);font-size:.9rem;margin-bottom:20px}.fld{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);display:block;margin-bottom:8px}textarea,input[type=text],input[type=password],select{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:10px;color:var(--text);font-family:var(--mono);font-size:.86rem;padding:12px 14px;outline:none;transition:.2s;resize:vertical}textarea:focus,input:focus,select:focus{border-color:var(--accent-dim)}textarea{min-height:90px}.row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px;align-items:center}.row.center{justify-content:center}.out{margin-top:18px;background:#08080a;border:1px solid var(--line);border-radius:10px;padding:14px;font-family:var(--mono);font-size:.82rem;color:var(--green);white-space:pre-wrap;word-break:break-all;min-height:20px}.out .k{color:var(--blue)}.out .err{color:#ff7b72}.out .dim{color:var(--faint)}.meter{height:8px;border-radius:5px;background:var(--surface);overflow:hidden;margin-top:14px}.meter span{display:block;height:100%;width:0;border-radius:5px;transition:width .3s,background .3s}.pw-label{font-family:var(--mono);font-size:.8rem;margin-top:10px;color:var(--muted)}canvas{display:block;margin:0 auto;background:#08080a;border:1px solid var(--line);border-radius:10px;touch-action:none;width:100%;max-width:320px;height:auto;aspect-ratio:1 / 1}.game-info{display:flex;justify-content:space-between;font-family:var(--mono);font-size:.82rem;color:var(--muted);margin-bottom:12px}.game-info b{color:var(--accent)}.react-box{height:200px;border-radius:12px;display:grid;place-items:center;cursor:pointer;font-family:var(--mono);font-size:1rem;color:#0a0a0c;font-weight:600;-webkit-user-select:none;user-select:none;transition:background .1s}.hint{font-family:var(--mono);font-size:.72rem;color:var(--faint);margin-top:12px;text-align:center}@media (max-width: 860px){.about-grid{grid-template-columns:1fr;gap:34px}.proj-grid{grid-template-columns:1fr}.nav-links{position:fixed;top:0;right:0;bottom:0;left:0;flex-direction:column;justify-content:center;background:#0a0a0cf7;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);gap:34px;transform:translate(100%);transition:transform .35s;z-index:99}.nav-links.open{transform:none}.nav-links a{font-size:1.3rem}.nav-toggle{display:block;z-index:100}section{padding:90px 0}}@media (max-width: 560px){.lab-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media (prefers-reduced-motion: reduce){*{animation-duration:1ms!important;transition-duration:1ms!important}.hero h1 .ln span{transform:none}}html[data-theme=light]{--bg: #faf6f1;--bg-soft: #f1ebe3;--surface: #ffffff;--surface-2: #f4efe8;--line: #e7ddd2;--text: #1f1b18;--muted: #6f655c;--faint: #a99e93;--accent: #c26b4a;--accent-dim: #a85738}html[data-theme=light] .bg-grid{background-image:linear-gradient(rgba(0,0,0,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.045) 1px,transparent 1px)}html[data-theme=light] .bg-glow{background:radial-gradient(circle,rgba(210,133,94,.16) 0%,transparent 60%)}html[data-theme=light] .bg-glow.two{background:radial-gradient(circle,rgba(120,120,255,.08) 0%,transparent 60%)}html[data-theme=light] .grain{opacity:.3}html[data-theme=light] nav{background:#faf9f699}html[data-theme=light] nav.scrolled{background:#faf9f6d9}@media (max-width: 860px){html[data-theme=light] .nav-links{background:#faf9f6f7}}.nav-right{display:flex;align-items:center;gap:18px}.theme-toggle{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:var(--surface);color:var(--muted);cursor:pointer;display:grid;place-items:center;flex:0 0 auto}.theme-toggle:hover{color:var(--accent);border-color:var(--accent-dim)}.theme-toggle svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}body{transition:background-color .35s ease,color .35s ease}.about-card,.status,.secure-badge,.modal,.modal-bar,.theme-toggle{transition:background-color .3s ease,border-color .3s ease,color .3s ease}
