@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&family=Noto+Sans+TC:wght@400;500;700;900&display=swap";:root{--bg:#05060a;--bg-soft:#0b0e16;--panel:#1418268c;--panel-solid:#111522;--line:#8ca0dc1f;--line-strong:#8ca0dc47;--txt:#eef1f8;--mut:#98a2bd;--dim:#6b7493;--cyan:#2de2e6;--violet:#a855f7;--blue:#4f7cff;--pink:#ff5db1;--grad:linear-gradient(110deg, #2de2e6 0%, #4f7cff 45%, #a855f7 100%);--grad-soft:linear-gradient(110deg, #2de2e62e, #a855f72e);--glow:0 0 40px #4f7cff59;--font:"Inter", "Noto Sans TC", -apple-system, "PingFang TC", system-ui, sans-serif;--mono:"JetBrains Mono", ui-monospace, monospace;--maxw:1120px}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--txt);-webkit-font-smoothing:antialiased;line-height:1.65;overflow-x:hidden}a{color:inherit;text-decoration:none}::selection{color:#fff;background:#a855f766}.bg-canvas{z-index:0;pointer-events:none;position:fixed;inset:0}.bg-grid{z-index:0;pointer-events:none;background-image:linear-gradient(#8ca0dc0d 1px,#0000 1px),linear-gradient(90deg,#8ca0dc0d 1px,#0000 1px);background-size:54px 54px;position:fixed;inset:0;-webkit-mask-image:radial-gradient(80% 60% at 50% 0,#000 30%,#0000 75%);mask-image:radial-gradient(80% 60% at 50% 0,#000 30%,#0000 75%)}.bg-blob{z-index:0;pointer-events:none;filter:blur(120px);opacity:.45;border-radius:50%;width:60vw;max-width:760px;height:60vw;max-height:760px;position:fixed}.bg-blob.a{background:radial-gradient(circle,#4f7cff8c,#0000 65%);top:-18%;left:-12%}.bg-blob.b{background:radial-gradient(circle,#a855f773,#0000 65%);animation:16s ease-in-out infinite float;top:30%;right:-18%}.bg-blob.c{background:radial-gradient(circle,#2de2e652,#0000 65%);animation:20s ease-in-out infinite reverse float;bottom:-20%;left:20%}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(40px,-40px)}}#root{z-index:1;position:relative}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}section{padding:110px 0;position:relative}.eyebrow{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);align-items:center;gap:8px;margin-bottom:16px;font-size:.8rem;display:inline-flex}.eyebrow:before{content:"";background:var(--cyan);opacity:.6;width:26px;height:1px}h2.title{letter-spacing:-.02em;margin-bottom:14px;font-size:clamp(1.9rem,4vw,2.9rem);font-weight:800;line-height:1.12}.sub{color:var(--mut);max-width:620px;font-size:1.05rem}.grad-text{background:var(--grad);-webkit-text-fill-color:transparent;color:#0000;-webkit-background-clip:text;background-clip:text}.nav{z-index:50;transition:all .3s;position:fixed;top:0;left:0;right:0}.nav-inner{max-width:var(--maxw);align-items:center;gap:20px;margin:0 auto;padding:16px 24px;display:flex}.nav.scrolled .nav-inner{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--line);background:#080a12b8;border-radius:16px;margin-top:10px;padding:12px 22px}.nav.scrolled{padding:0}.brand{letter-spacing:-.01em;align-items:center;gap:9px;font-size:1.05rem;font-weight:800;display:flex}.brand .dot{background:var(--grad);width:10px;height:10px;box-shadow:var(--glow);border-radius:50%}.nav-links{align-items:center;gap:6px;margin-left:auto;display:flex}.nav-links a{color:var(--mut);border-radius:9px;padding:8px 12px;font-size:.9rem;transition:color .2s,background .2s}.nav-links a:hover{color:var(--txt);background:#8ca0dc14}.lang-btn{font-family:var(--mono);border:1px solid var(--line-strong);color:var(--txt);cursor:pointer;background:0 0;border-radius:9px;align-items:center;gap:6px;padding:7px 12px;font-size:.8rem;font-weight:600;transition:all .2s;display:inline-flex}.lang-btn:hover{border-color:var(--cyan);color:var(--cyan)}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:12px;align-items:center;gap:9px;padding:14px 24px;font-size:.98rem;font-weight:600;transition:transform .18s,box-shadow .25s;display:inline-flex;position:relative}.btn:hover{transform:translateY(-2px)}.btn-primary{background:var(--grad);color:#061018;box-shadow:0 8px 30px #4f7cff59}.btn-primary:hover{box-shadow:0 12px 40px #a855f780}.btn-ghost{color:var(--txt);border:1px solid var(--line-strong);background:#8ca0dc0f}.btn-ghost:hover{border-color:var(--cyan);background:#2de2e614}.hero{align-items:center;min-height:100vh;padding-top:160px;padding-bottom:90px;display:flex}.hero-grid{grid-template-columns:1.15fr .85fr;align-items:center;gap:50px;width:100%;display:grid}.badge{color:var(--mut);border:1px solid var(--line);background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:30px;align-items:center;gap:9px;margin-bottom:26px;padding:7px 14px;font-size:.84rem;display:inline-flex}.badge .pulse{background:#2ee6a6;border-radius:50%;width:8px;height:8px;position:relative}.badge .pulse:after{content:"";opacity:.5;background:#2ee6a6;border-radius:50%;animation:1.8s ease-out infinite ping;position:absolute;inset:-4px}@keyframes ping{0%{opacity:.5;transform:scale(1)}to{opacity:0;transform:scale(2.6)}}.hero h1{letter-spacing:-.03em;margin-bottom:22px;font-size:clamp(2.3rem,5.4vw,4rem);font-weight:900;line-height:1.06}.hero-name{font-family:var(--mono);color:var(--cyan);letter-spacing:.05em;margin-bottom:18px;font-size:1rem;display:block}.hero p.lead{color:var(--mut);max-width:540px;margin-bottom:32px;font-size:1.12rem}.hero-cta{flex-wrap:wrap;gap:14px;margin-bottom:26px;display:flex}.hero-loc{color:var(--dim);align-items:center;gap:8px;font-size:.88rem;display:flex}.code-card{border:1px solid var(--line-strong);box-shadow:0 30px 80px #00000080, var(--glow);font-family:var(--mono);background:linear-gradient(160deg,#141826e6,#0a0c14e6);border-radius:18px;font-size:.82rem;overflow:hidden}.code-head{border-bottom:1px solid var(--line);align-items:center;gap:8px;padding:13px 16px;display:flex}.code-head .tl{border-radius:50%;width:12px;height:12px}.code-head .tl.r{background:#ff5f57}.code-head .tl.y{background:#febc2e}.code-head .tl.g{background:#28c840}.code-head .fname{color:var(--dim);margin-left:8px;font-size:.78rem}.code-body{white-space:pre;padding:18px 18px 22px;line-height:1.95;overflow-x:auto}.tk-key{color:var(--violet)}.tk-fn{color:var(--cyan)}.tk-str{color:#7ee787}.tk-num{color:#ffa657}.tk-cmt{color:var(--dim)}.tk-pl{color:var(--txt)}.cursor{background:var(--cyan);vertical-align:text-bottom;width:8px;height:1.05em;animation:1.1s step-end infinite blink;display:inline-block}@keyframes blink{50%{opacity:0}}.stats{grid-template-columns:repeat(4,1fr);gap:16px;margin-top:56px;display:grid}.stat{background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--line);text-align:center;border-radius:14px;padding:22px 18px}.stat .v{letter-spacing:-.02em;font-size:1.7rem;font-weight:800}.stat .l{color:var(--mut);margin-top:4px;font-size:.82rem}.about-body p{color:var(--mut);max-width:760px;margin-bottom:18px;font-size:1.08rem}.about-body p strong,.about-body b{color:var(--txt);font-weight:600}.cards{grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px;display:grid}.card{background:var(--panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:18px;padding:28px 24px;transition:transform .25s,border-color .25s,box-shadow .25s;position:relative;overflow:hidden}.card:before{content:"";background:var(--grad);-webkit-mask-composite:xor;opacity:0;border-radius:18px;padding:1px;transition:opacity .3s;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#000 0 0),linear-gradient(#000 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.card:hover{transform:translateY(-6px);box-shadow:0 24px 60px #00000073}.card:hover:before{opacity:1}.card .ico{background:var(--grad-soft);border:1px solid var(--line);border-radius:13px;place-items:center;width:52px;height:52px;margin-bottom:18px;font-size:1.5rem;display:grid}.card h3{margin-bottom:9px;font-size:1.18rem;font-weight:700}.card p{color:var(--mut);font-size:.95rem}.results-band{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:linear-gradient(#4f7cff0d,#0000)}.results-grid{grid-template-columns:repeat(4,1fr);gap:24px;margin-top:44px;display:grid}.result{text-align:center}.result .v{letter-spacing:-.03em;font-size:clamp(2.4rem,5vw,3.6rem);font-weight:900;line-height:1}.result .l{color:var(--mut);margin-top:12px;max-width:200px;margin-inline:auto;font-size:.92rem}.marquee{margin-top:40px;overflow:hidden;-webkit-mask:linear-gradient(90deg,#0000,#000 8% 92%,#0000);mask:linear-gradient(90deg,#0000,#000 8% 92%,#0000)}.marquee-track{gap:14px;width:max-content;animation:28s linear infinite scroll;display:flex}.marquee:hover .marquee-track{animation-play-state:paused}@keyframes scroll{to{transform:translate(-50%)}}.pill{font-family:var(--mono);color:var(--txt);white-space:nowrap;border:1px solid var(--line-strong);background:var(--panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:30px;align-items:center;gap:9px;padding:11px 20px;font-size:.92rem;display:inline-flex}.pill:before{content:"▹";color:var(--cyan)}.work-grid{grid-template-columns:repeat(2,1fr);gap:18px;margin-top:44px;display:grid}.proj{background:var(--panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:18px;padding:26px;transition:transform .25s,border-color .25s,box-shadow .25s;position:relative;overflow:hidden}.proj:hover{border-color:var(--line-strong);transform:translateY(-5px);box-shadow:0 24px 60px #00000073}.proj .glow{opacity:0;background:radial-gradient(circle,#a855f72e,#0000 70%);width:50%;height:80%;transition:opacity .3s;position:absolute;top:-40%;right:-20%}.proj:hover .glow{opacity:1}.proj h3{margin-bottom:10px;font-size:1.25rem;font-weight:700}.proj p{color:var(--mut);margin-bottom:16px;font-size:.96rem}.tags{flex-wrap:wrap;gap:8px;display:flex}.tag{font-family:var(--mono);color:var(--cyan);background:#2de2e60f;border:1px solid #2de2e64d;border-radius:7px;padding:4px 10px;font-size:.74rem}.work-note{color:var(--dim);margin-top:26px;font-size:.88rem;font-style:italic}.timeline{margin-top:44px;padding-left:28px;position:relative}.timeline:before{content:"";background:linear-gradient(var(--cyan), var(--violet), transparent);width:2px;position:absolute;top:6px;bottom:6px;left:6px}.tl-item{padding-bottom:36px;position:relative}.tl-item:last-child{padding-bottom:0}.tl-item:before{content:"";background:var(--bg);border:2px solid var(--cyan);border-radius:50%;width:14px;height:14px;position:absolute;top:5px;left:-28px;box-shadow:0 0 12px #2de2e699}.tl-period{font-family:var(--mono);color:var(--cyan);font-size:.8rem}.tl-role{margin:4px 0 2px;font-size:1.18rem;font-weight:700}.tl-company{color:var(--violet);margin-bottom:8px;font-size:.96rem;font-weight:600}.tl-desc{color:var(--mut);max-width:680px;font-size:.96rem}.contact-box{text-align:center;background:var(--panel);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--line-strong);box-shadow:var(--glow);border-radius:26px;padding:64px 32px;position:relative;overflow:hidden}.contact-box:before{content:"";background:var(--grad-soft);opacity:.4;position:absolute;inset:0}.contact-box>*{position:relative}.contact-box h2{letter-spacing:-.03em;margin-bottom:16px;font-size:clamp(2rem,4.5vw,3rem);font-weight:900}.contact-box p{color:var(--mut);max-width:560px;margin:0 auto 30px;font-size:1.08rem}.email-link{font-family:var(--mono);color:var(--cyan);margin-top:18px;font-size:1rem;display:inline-block}footer{border-top:1px solid var(--line);text-align:center;color:var(--dim);padding:36px 0;font-size:.85rem}footer .built{font-family:var(--mono);opacity:.7;margin-top:6px}@media (width<=900px){.hero-grid{grid-template-columns:1fr}.code-card{display:none}.cards{grid-template-columns:1fr 1fr}.results-grid{grid-template-columns:1fr 1fr;gap:36px 24px}.work-grid{grid-template-columns:1fr}.stats{grid-template-columns:1fr 1fr}}@media (width<=600px){section{padding:80px 0}.nav-links a{display:none}.cards{grid-template-columns:1fr}.results-grid{grid-template-columns:1fr 1fr}.hero{padding-top:130px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto;animation:none!important}}
