:root{--bg: #05060d;--fg: #e7edf7;--muted: #8a97ad;--accent: #9d4edd;--accent-2: #78c8ff;--border: rgba(157, 78, 221, .22);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang TC,Microsoft JhengHei,sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}html{scroll-behavior:smooth}body{background:radial-gradient(1100px 700px at 75% -10%,#1a1033 0%,transparent 60%),radial-gradient(900px 600px at 5% 110%,#0b1530 0%,transparent 55%),var(--bg);background-repeat:no-repeat;background-attachment:fixed;color:var(--fg);-webkit-font-smoothing:antialiased;overflow:hidden}.app{position:relative;width:100vw;height:100vh;overflow:hidden}.game-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block}.hud-top{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:18px clamp(16px,4vw,36px);pointer-events:none;z-index:5}.hud-brand{font-weight:800;letter-spacing:2px;font-size:1.05rem}.dotc{color:var(--accent)}.hud-hint{color:var(--muted);font-size:.82rem;font-family:ui-monospace,monospace}.enter-prompt{position:absolute;bottom:38px;left:50%;transform:translate(-50%);padding:12px 22px;border-radius:999px;background:#080a14cc;border:1px solid var(--c, var(--accent));box-shadow:0 0 26px color-mix(in srgb,var(--c, var(--accent)) 45%,transparent);font-size:.95rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:5;animation:rise .18s ease}@keyframes rise{0%{opacity:0;transform:translate(-50%,8px)}}.enter-prompt b{color:var(--c, var(--accent))}.key{display:inline-grid;place-items:center;width:26px;height:26px;margin-right:8px;border-radius:6px;border:1px solid var(--c, var(--accent));font-family:ui-monospace,monospace;font-weight:700;font-size:.85rem;vertical-align:middle}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:#04050cb8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20;animation:fade .2s ease}@keyframes fade{0%{opacity:0}}.intro{max-width:560px;text-align:center}.intro-kicker{font-family:ui-monospace,monospace;color:var(--accent-2);letter-spacing:3px;font-size:.82rem;margin-bottom:14px}.intro-title{font-size:clamp(2.2rem,7vw,3.6rem);font-weight:800}.glow{color:var(--accent);text-shadow:0 0 28px rgba(157,78,221,.65)}.intro-desc{margin:20px auto 24px;color:var(--muted);line-height:1.8;max-width:460px}.intro-keys{list-style:none;display:flex;flex-direction:column;gap:8px;color:var(--muted);font-size:.9rem;margin-bottom:30px}kbd{display:inline-block;min-width:22px;padding:2px 7px;margin:0 2px;border:1px solid var(--border);border-bottom-width:2px;border-radius:5px;background:#9d4edd1a;font-family:ui-monospace,monospace;font-size:.82rem;color:var(--fg)}.btn{display:inline-block;padding:12px 26px;border-radius:999px;font-weight:600;font-size:.95rem;text-decoration:none;border:1px solid transparent;cursor:pointer;transition:transform .16s,box-shadow .2s,border-color .2s}.btn:hover{transform:translateY(-2px)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{box-shadow:0 8px 30px #9d4edd80}.btn-ghost{color:var(--fg);border-color:var(--border);background:#9d4edd14}.btn-ghost:hover{border-color:var(--accent)}.panel{position:relative;width:min(640px,92vw);max-height:82vh;overflow-y:auto;padding:34px;border-radius:18px;border:1px solid var(--border);background:linear-gradient(160deg,#16102aeb,#080a16eb);box-shadow:0 30px 80px #0009;animation:pop .2s ease}@keyframes pop{0%{opacity:0;transform:scale(.96) translateY(10px)}}.panel-close,.terminal-close{position:absolute;top:16px;right:18px;width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;transition:color .2s,border-color .2s}.panel-close:hover,.terminal-close:hover{color:var(--fg);border-color:var(--accent)}.panel-head{display:flex;align-items:baseline;gap:12px;margin-bottom:22px}.panel-head h2{font-size:1.9rem;letter-spacing:1px}.panel-head span{color:var(--muted);letter-spacing:2px}.panel-p{color:var(--muted);line-height:1.85;margin-bottom:12px}.panel-foot{margin-top:22px;color:var(--muted);font-size:.8rem;font-family:ui-monospace,monospace}.tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:16px}.tag{padding:6px 13px;border:1px solid var(--border);border-radius:8px;font-size:.85rem;background:#9d4edd12}.cards{display:grid;grid-template-columns:1fr;gap:14px}.card{padding:20px;border:1px solid var(--border);border-radius:14px;background:#9d4edd0d;transition:border-color .2s,transform .2s}.card:hover{border-color:var(--accent);transform:translate(4px)}.card-top{display:flex;justify-content:space-between;margin-bottom:12px}.card-tag{font-family:ui-monospace,monospace;font-size:.7rem;letter-spacing:2px;color:var(--accent-2);border:1px solid var(--border);padding:3px 8px;border-radius:6px}.card-year{color:var(--muted);font-size:.8rem}.card-thumb{margin:-20px -20px 16px;border-radius:14px 14px 0 0;overflow:hidden;aspect-ratio:4 / 3;background:#9d4edd14;border-bottom:1px solid var(--border)}.card-thumb img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .35s ease}a.card-link:hover .card-thumb img{transform:scale(1.04)}.card h3{margin-bottom:6px}.card-desc{color:var(--muted);font-size:.92rem;line-height:1.5}a.card-link{display:block;text-decoration:none;color:inherit}a.card-link:hover{box-shadow:0 0 18px #9d4edd40}.card-go{display:inline-block;margin-top:12px;font-size:.82rem;font-weight:600;color:var(--accent-2);opacity:.85;transition:opacity .2s,transform .2s}a.card-link:hover .card-go{opacity:1;transform:translate(3px)}.contact-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}.terminal-wrap{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:#04050cc7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:60;animation:fade .2s ease}.terminal{width:min(760px,94vw);height:min(560px,80vh);display:flex;flex-direction:column;border-radius:12px;overflow:hidden;border:1px solid rgba(157,78,221,.4);box-shadow:0 30px 90px #000000b3,0 0 60px #9d4edd2e;animation:pop .2s ease}.terminal-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#12101f;border-bottom:1px solid rgba(157,78,221,.25)}.terminal-bar .dot{width:12px;height:12px;border-radius:50%}.dot.red{background:#ff5f57}.dot.yellow{background:#febc2e}.dot.green{background:#28c840}.terminal-title{margin-left:10px;color:var(--muted);font-size:.8rem;font-family:ui-monospace,monospace}.terminal-close{position:static;margin-left:auto}.terminal-body{flex:1;overflow-y:auto;padding:16px 18px;background:#0a0812;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.9rem;line-height:1.55}.tline{white-space:pre-wrap;word-break:break-word}.tline.sys{color:var(--accent)}.tline.cmd{color:var(--fg)}.tline.out{color:#b9c6da}.tline.err{color:#ff7a90}.tinput-row{display:flex;gap:8px;align-items:center;margin-top:4px}.prompt{color:#5ad1a5;white-space:nowrap}.tinput{flex:1;background:transparent;border:none;outline:none;color:var(--fg);font-family:inherit;font-size:inherit;caret-color:var(--accent)}@media(max-width:640px){.hud-hint{display:none}}.mode-toggle{position:fixed;top:16px;right:18px;z-index:50;padding:9px 16px;border-radius:999px;border:1px solid var(--border);background:#0c0a18d1;color:var(--fg);font-size:.85rem;font-weight:600;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color .2s,box-shadow .2s,transform .16s}.mode-toggle:hover{border-color:var(--accent);box-shadow:0 0 22px #9d4edd66;transform:translateY(-1px)}.term-btn{position:fixed;bottom:22px;right:22px;z-index:50;display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:12px;border:1px solid rgba(157,78,221,.5);background:#0c0a18d9;color:var(--fg);font-size:.9rem;font-weight:600;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 0 22px #9d4edd47;transition:border-color .2s,box-shadow .2s,transform .16s}.term-btn:hover{transform:translateY(-2px);box-shadow:0 0 30px #9d4edd80}.term-btn.is-open{border-color:var(--accent);background:#281846eb}.term-glyph{font-family:ui-monospace,monospace;font-weight:800;color:#5ad1a5;letter-spacing:-1px}.intro-note{margin:-10px auto 26px;max-width:440px;padding:12px 16px;border:1px dashed var(--border);border-radius:12px;color:var(--muted);font-size:.88rem;line-height:1.6}.intro-note b{color:var(--accent)}body.mode-classic{overflow-y:auto}body.mode-classic .app{height:auto;min-height:100vh;overflow:visible}.particle-canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.classic{position:relative;z-index:1}.classic main,.c-nav,.c-footer{position:relative;z-index:1}.c-nav{position:sticky;top:0;z-index:50;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:18px clamp(20px,5vw,48px);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(180deg,rgba(5,6,13,.78),transparent)}.c-brand{justify-self:start;font-weight:800;letter-spacing:2px;color:var(--fg);text-decoration:none}.c-links{justify-self:center;display:flex;gap:clamp(14px,3vw,32px)}.c-links a{color:var(--muted);text-decoration:none;font-size:.9rem;position:relative;transition:color .2s}.c-links a:hover{color:var(--fg)}.c-links a.is-active{color:var(--accent)}.c-links a.is-active:after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:2px;background:var(--accent);box-shadow:0 0 8px var(--accent)}.c-mode-toggle{justify-self:end;padding:9px 16px;border-radius:999px;border:1px solid var(--border);background:#9d4edd1f;color:var(--fg);font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .2s,border-color .2s,transform .1s}.c-mode-toggle:hover{background:#9d4edd3d;border-color:var(--accent);transform:translateY(-1px)}.c-section{max-width:1100px;margin:0 auto;padding:clamp(70px,12vh,140px) clamp(20px,5vw,48px);scroll-margin-top:80px}.c-head{display:flex;align-items:baseline;gap:14px;margin-bottom:40px}.c-head h2{font-size:clamp(1.6rem,4vw,2.4rem)}.c-head span{color:var(--muted);letter-spacing:2px;font-size:.95rem}.c-hero{min-height:92vh;display:flex;flex-direction:column;justify-content:center}.c-kicker{color:var(--accent-2);font-family:ui-monospace,monospace;letter-spacing:3px;font-size:.85rem;margin-bottom:20px}.c-hero-title{font-size:clamp(2.4rem,8vw,5rem);line-height:1.05;font-weight:800;letter-spacing:-1px}.c-hero-sub{font-size:clamp(1.2rem,3.5vw,2rem);color:var(--muted);font-weight:600}.c-hero-desc{margin-top:26px;max-width:560px;color:var(--muted);line-height:1.7}.c-actions{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap}.c-about{display:grid;grid-template-columns:1.6fr 1fr;gap:48px}.c-about-p{color:var(--muted);line-height:1.9;margin-bottom:12px}.c-skills-label{font-family:ui-monospace,monospace;color:var(--accent-2);font-size:.8rem;letter-spacing:2px;margin-bottom:16px}.c-skills ul{list-style:none;display:flex;flex-wrap:wrap;gap:10px}.c-skills li{padding:7px 14px;border:1px solid var(--border);border-radius:8px;font-size:.88rem;background:#9d4edd0f}.c-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}.c-cards .card{padding:26px;border-radius:16px}.c-cards .card:hover{transform:translateY(-6px)}.c-cards .card-thumb{margin:-26px -26px 18px;border-radius:16px 16px 0 0}.c-footer{max-width:1100px;margin:0 auto;padding:30px clamp(20px,5vw,48px) 60px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:.85rem;border-top:1px solid var(--border)}@media(max-width:720px){.c-about{grid-template-columns:1fr;gap:28px}.c-links{display:none}}
