:root{--bg: #0b0612;--bg-2: #140a22;--ink: #f7ecff;--muted: #bba9d9;--pink: #ff5fbf;--pink-2: #ff9cd8;--lilac: #9b7cff;--cyan: #6ef2ff;--yellow: #ffe86a;--green: #7cffb2;--red: #ff6a6a;--card: rgba(255, 255, 255, .04);--card-border: rgba(255, 255, 255, .1);--shadow: 0 18px 60px -20px rgba(155, 124, 255, .55);--font-sans: "Noto Sans SC", "PingFang SC", -apple-system, system-ui, sans-serif;--font-meme: "ZCOOL KuaiLe", "Noto Sans SC", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);color:var(--ink);background:radial-gradient(1200px 800px at 20% -10%,#2a1252 0%,transparent 60%),radial-gradient(900px 700px at 90% 20%,#4a1163 0%,transparent 55%),radial-gradient(1400px 1000px at 50% 120%,#120733 0%,transparent 60%),var(--bg);min-height:100vh;overflow-x:hidden;cursor:default;position:relative}.bg-canvas{position:fixed;inset:0;z-index:0;pointer-events:none}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background-image:linear-gradient(rgba(155,124,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(155,124,255,.06) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(ellipse 90% 70% at 50% 30%,#000 35%,transparent 85%);-webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 30%,#000 35%,transparent 85%);animation:grid-drift 30s linear infinite}body:after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 60% 40% at 50% 100%,rgba(110,242,255,.08),transparent 70%);mix-blend-mode:screen}@keyframes grid-drift{0%{background-position:0 0,0 0}to{background-position:48px 48px,48px 48px}}.top-bar,.hero,.projects,.stats,.hobbies,.contact,.footer,.paw-cursor,.bgm-toggle{position:relative;z-index:1}.top-bar{z-index:100}.bgm-toggle{z-index:9997}.paw-cursor{z-index:9999}a{color:inherit;text-decoration:none}code{font-family:var(--font-mono);background:#ffffff0f;padding:0 6px;border-radius:4px;font-size:.92em}em{font-style:normal;color:var(--pink-2);font-weight:700}.bgm-toggle{position:fixed;right:18px;bottom:18px;z-index:9997;display:inline-flex;align-items:center;gap:10px;padding:10px 16px 10px 12px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:#140a22e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--ink);font-family:var(--font-meme);font-size:15px;cursor:pointer;box-shadow:0 12px 32px -8px #9b7cff8c;transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .3s,border-color .3s}.bgm-toggle:hover{transform:translateY(-2px) scale(1.04);border-color:#ff5fbf99;box-shadow:0 18px 40px -10px #ff5fbf8c}.bgm-toggle:active{transform:translateY(0) scale(.98)}.bgm-toggle__face{font-size:24px;display:inline-block;transition:transform .3s}.bgm-toggle.is-playing .bgm-toggle__face{animation:bgm-bob .9s ease-in-out infinite}@keyframes bgm-bob{0%,to{transform:rotate(-8deg) scale(1)}50%{transform:rotate(10deg) scale(1.08)}}.bgm-toggle__eq{display:none;align-items:flex-end;gap:3px;height:20px}.bgm-toggle__eq span{display:block;width:3px;background:linear-gradient(180deg,#ff5fbf,#9b7cff);border-radius:2px;animation:bgm-eq .9s ease-in-out infinite}.bgm-toggle__eq span:nth-child(1){animation-delay:-.2s;height:60%}.bgm-toggle__eq span:nth-child(2){animation-delay:-.4s;height:100%}.bgm-toggle__eq span:nth-child(3){animation-delay:-.1s;height:70%}.bgm-toggle__eq span:nth-child(4){animation-delay:-.3s;height:90%}.bgm-toggle.is-playing .bgm-toggle__eq{display:inline-flex}@keyframes bgm-eq{0%,to{transform:scaleY(.35)}50%{transform:scaleY(1)}}.bgm-toggle__label--paused,.bgm-toggle__label--playing{display:none}.bgm-toggle.is-paused .bgm-toggle__label--paused,.bgm-toggle.is-playing .bgm-toggle__label--playing{display:inline}.bgm-toggle.is-paused:after{content:"";position:absolute;inset:-6px;border-radius:999px;border:2px solid rgba(255,95,191,.5);animation:bgm-pulse 1.8s ease-out infinite;pointer-events:none}@keyframes bgm-pulse{0%{transform:scale(.9);opacity:.8}to{transform:scale(1.25);opacity:0}}@media (max-width: 520px){.bgm-toggle{right:10px;bottom:10px;padding:6px 12px 6px 8px;gap:6px;font-size:12px;background:#140a22b8}.bgm-toggle__face{font-size:18px}.bgm-toggle__eq{height:16px}.bgm-toggle.is-paused:after{inset:-4px}}.paw-cursor{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;font-size:22px;transform:translate(-50%,-50%) rotate(-15deg);transition:transform .12s ease-out;mix-blend-mode:screen;filter:drop-shadow(0 0 6px rgba(255,95,191,.8));opacity:.9}.top-bar{position:sticky;top:0;z-index:100;background:linear-gradient(90deg,#ff5fbf,#9b7cff,#6ef2ff);color:#15071f;font-weight:700;border-bottom:2px solid rgba(0,0,0,.25);overflow:hidden}.top-bar__marquee{display:flex;white-space:nowrap;padding:6px 0;font-family:var(--font-meme);letter-spacing:.02em;animation:marquee 36s linear infinite}.top-bar__marquee span{padding-right:40px}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.hero{position:relative;min-height:92vh;padding:60px 6vw 80px;overflow:hidden}.hero__noise{position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.03) 0 1px,transparent 1px 3px);mix-blend-mode:overlay;pointer-events:none}.hero__orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.65;pointer-events:none;animation:float 12s ease-in-out infinite;will-change:transform;transform:translateZ(0)}.hero__orb--a{width:420px;height:420px;background:#ff5fbf;top:-80px;left:-120px;animation-delay:0s}.hero__orb--b{width:360px;height:360px;background:#9b7cff;top:120px;right:-80px;animation-delay:-4s}.hero__orb--c{width:300px;height:300px;background:#6ef2ff;bottom:-120px;left:30%;animation-delay:-8s}@media (max-width: 520px){.hero__orb{filter:blur(40px);opacity:.5}.hero__orb--c{display:none}}@keyframes float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.08)}}.hero__inner{position:relative;display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start;max-width:1200px;margin:0 auto}@media (max-width: 900px){.hero__inner{grid-template-columns:1fr;gap:32px}}.hero__tag{font-family:var(--font-mono);color:var(--cyan);font-size:13px;letter-spacing:.05em;margin-bottom:18px;opacity:.8}.hero__title{font-family:var(--font-meme);font-weight:900;margin:0 0 22px;line-height:1.08;letter-spacing:-.01em}.hero__title-line{display:block;font-size:clamp(32px,5vw,56px)}.hero__title-line--big{font-size:clamp(56px,9vw,112px);margin-top:4px}.rainbow{background:linear-gradient(90deg,#ff5fbf,#ffe86a,#7cffb2,#6ef2ff,#9b7cff,#ff5fbf);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:rainbow 6s linear infinite}@keyframes rainbow{0%{background-position:0% 50%}to{background-position:300% 50%}}.cat-emoji{display:inline-block;margin-left:14px;filter:drop-shadow(0 6px 18px rgba(255,95,191,.6));animation:wiggle 2.4s ease-in-out infinite;transform-origin:50% 85%}@keyframes wiggle{0%,to{transform:rotate(-8deg) scale(1)}50%{transform:rotate(10deg) scale(1.08)}}.glitch{position:relative}.glitch:before,.glitch:after{content:attr(data-text);position:absolute;left:0;top:0;width:100%;overflow:hidden;mix-blend-mode:screen}.glitch:before{color:var(--cyan);transform:translate(-2px);clip-path:inset(0 0 55% 0)}.glitch:after{color:var(--pink);transform:translate(2px);clip-path:inset(55% 0 0 0)}.hero__sub{display:flex;flex-wrap:wrap;align-items:center;gap:10px;font-size:16px;color:var(--muted);margin:0 0 14px}.kbd{font-family:var(--font-mono);font-size:13px;padding:6px 10px;border-radius:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);box-shadow:inset 0 -2px #00000059;color:var(--ink)}.kbd--hot{background:linear-gradient(135deg,#ff5fbf,#9b7cff);border-color:transparent;color:#fff;box-shadow:0 4px 18px #ff5fbf73}.arrow{color:var(--pink-2);font-weight:700}.hero__joke{color:var(--muted);line-height:1.7;font-size:15px;margin:0 0 30px;max-width:540px}.bio-canvas-wrap{position:relative;width:100%;max-width:560px;min-height:180px;border-radius:18px;background:linear-gradient(135deg,#ff5fbf1a,#6ef2ff0f);border:1px solid rgba(255,255,255,.1);padding:20px 24px;overflow:hidden}.bio-canvas-wrap canvas{display:block;width:100%;height:auto}.bio-canvas-overlay{position:absolute;top:22px;right:24px;pointer-events:none}.floaty-avatar{position:relative;width:110px;height:110px;display:grid;place-items:center;animation:bob 4s ease-in-out infinite}@media (max-width: 520px){.bio-canvas-wrap{padding:18px 20px}.bio-canvas-overlay{top:20px;right:20px}.floaty-avatar{width:84px;height:84px}.floaty-avatar__img{width:74px;height:74px}}.floaty-avatar__ring{position:absolute;inset:-2px;border-radius:50%;background:conic-gradient(from 0deg,#ff5fbf,#ffe86a,#6ef2ff,#9b7cff,#ff5fbf);animation:spin 6s linear infinite;filter:blur(3px)}.floaty-avatar__img{position:relative;width:98px;height:98px;border-radius:50%;object-fit:cover;background:#14062a;box-shadow:0 0 0 3px #0b0612 inset,0 10px 30px #0006}@keyframes spin{to{transform:rotate(360deg)}}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.terminal{background:#0e0720;border:1px solid rgba(255,255,255,.08);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;transform:rotate(-.6deg);transition:transform .3s}.terminal:hover{transform:rotate(0) scale(1.01)}.terminal__bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.06);font-family:var(--font-mono);font-size:12px;color:var(--muted)}.dot{width:12px;height:12px;border-radius:50%;display:inline-block}.dot--r{background:#ff6a6a}.dot--y{background:#ffd06a}.dot--g{background:#7cffb2}.terminal__title{margin-left:10px}.terminal__body{margin:0;padding:18px 18px 22px;font-family:var(--font-mono);font-size:13.5px;line-height:1.85;color:var(--ink);white-space:pre-wrap}.t-prompt{color:var(--green)}.t-path{color:var(--cyan)}.t-k{color:var(--pink-2)}.t-fire{color:var(--yellow);font-weight:700}.t-cursor{display:inline-block;width:9px;height:16px;background:var(--ink);transform:translateY(2px);animation:blink 1s steps(2) infinite}@keyframes blink{50%{opacity:0}}.hero__scroll{position:absolute;bottom:26px;left:50%;transform:translate(-50%);display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:12px;color:var(--muted)}.hero__scroll-arrow{animation:bounce 1.4s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.section-title{font-family:var(--font-meme);font-size:clamp(28px,4vw,44px);margin:0 0 8px;display:inline-flex;align-items:baseline;gap:14px;letter-spacing:-.01em}.section-title__num{font-family:var(--font-mono);font-size:.5em;color:var(--pink);background:#ff5fbf1f;padding:4px 10px;border-radius:8px;border:1px solid rgba(255,95,191,.3)}.section-title__tail{color:var(--muted);font-size:.45em;font-family:var(--font-mono)}.section-sub{color:var(--muted);margin:0 0 30px;font-size:15px;max-width:720px}.section-sub--center{text-align:center;margin-left:auto;margin-right:auto}.blink{color:var(--yellow);animation:blinkText 2s infinite}@keyframes blinkText{50%{opacity:.4}}.projects{padding:80px 6vw;max-width:1200px;margin:0 auto}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px;perspective:1400px}.project-card{position:relative;background:var(--card);border:1px solid var(--card-border);border-radius:20px;padding:24px;min-height:300px;backdrop-filter:blur(10px);display:flex;flex-direction:column;transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));transform-style:preserve-3d;will-change:transform;transition:transform .2s cubic-bezier(.2,.8,.2,1),border-color .3s,box-shadow .3s;overflow:hidden;isolation:isolate}.project-card:before{content:"";position:absolute;inset:0;background:radial-gradient(400px 200px at var(--mx,50%) var(--my,20%),rgba(255,95,191,.28),transparent 60%);opacity:0;transition:opacity .3s;z-index:-1}.project-card:hover{transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(-6px);border-color:#ff5fbf80;box-shadow:var(--shadow)}.project-card:hover:before{opacity:1}.project-card:active{transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(-2px) scale(.99)}.project-card__head,.project-card__bubble,.project-card__links{transform:translateZ(20px)}@media (max-width: 520px){.project-card{transform:none!important;backdrop-filter:none;-webkit-backdrop-filter:none}.project-card:hover{transform:translateY(-4px)!important}.project-card__head,.project-card__bubble,.project-card__links{transform:none}}.project-card__head{display:flex;align-items:center;gap:10px;margin-bottom:14px}.project-card__badge{font-size:28px;background:#ffffff0f;width:48px;height:48px;display:grid;place-items:center;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.project-card__title{font-family:var(--font-meme);font-size:22px;color:var(--ink);margin:0}.project-card__tag{font-family:var(--font-mono);font-size:13px;color:var(--cyan);border:1px solid rgba(110,242,255,.35);padding:3px 10px;border-radius:7px;margin-left:auto;letter-spacing:.02em}.project-card__bubble{margin-top:auto;padding:12px 14px;background:#ff5fbf1a;border:1px solid rgba(255,95,191,.25);border-radius:14px;color:var(--ink);position:relative;font-size:14px;line-height:1.7;align-self:flex-start;max-width:100%}.project-card__bubble canvas{display:block;max-width:100%;height:auto}.project-card__bubble:after{content:"";position:absolute;left:18px;bottom:-8px;width:14px;height:14px;background:#ff5fbf1a;border-right:1px solid rgba(255,95,191,.25);border-bottom:1px solid rgba(255,95,191,.25);transform:rotate(45deg)}.project-card__links{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.project-card__link{font-family:var(--font-mono);font-size:13.5px;padding:6px 13px;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:var(--pink-2);transition:all .2s}.project-card__link:hover{background:var(--pink);color:#15071f;border-color:transparent}.stats{padding:80px 6vw;max-width:1200px;margin:0 auto}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-bottom:34px}.stat-card{position:relative;padding:26px 22px;border-radius:20px;border:1px solid var(--card-border);background:var(--card);overflow:hidden}.stat-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--g1, #ff5fbf),var(--g2, #9b7cff));opacity:.12;z-index:0}.stat-card--us{--g1: #6ef2ff;--g2: #7cffb2}.stat-card--cn{--g1: #ff6a6a;--g2: #ffe86a}.stat-card--meta{--g1: #ff5fbf;--g2: #9b7cff}.stat-card>*{position:relative}.stat-card__label{font-family:var(--font-meme);font-size:18px;color:var(--ink);margin-bottom:6px}.stat-card__num{font-family:var(--font-mono);font-size:76px;font-weight:700;line-height:1;background:linear-gradient(135deg,var(--g1),var(--g2));-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block}.stat-card__unit{display:inline-block;margin-left:6px;font-size:20px;color:var(--muted)}.stat-card__foot{margin-top:8px;color:var(--muted);font-size:13px}.stats-shots{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;max-width:860px;margin:0 auto;opacity:.88}.shot{margin:0;border-radius:14px;overflow:hidden;border:1px solid var(--card-border);background:var(--card);transform:rotate(-.6deg);transition:transform .3s,opacity .3s;width:380px;max-width:100%}.shot:nth-child(2n){transform:rotate(.6deg)}.shot:hover{transform:rotate(0) scale(1.02);opacity:1}.shot img{display:block;width:100%;height:auto}.shot figcaption{padding:9px 14px;font-size:12px;color:var(--muted);font-family:var(--font-mono);border-top:1px solid var(--card-border)}@media (max-width: 520px){.shot{width:100%}}.hobbies{padding:80px 6vw;max-width:1200px;margin:0 auto;text-align:center}.hobbies .section-title{margin-left:auto;margin-right:auto;display:inline-flex}.hobby-canvas-wrap{margin:24px auto 12px;max-width:960px;padding:30px 16px;border-radius:24px;background:radial-gradient(400px 220px at 20% 30%,rgba(255,95,191,.18),transparent 60%),radial-gradient(400px 220px at 80% 70%,rgba(110,242,255,.16),transparent 60%),#ffffff05;border:1px solid var(--card-border)}.hobby-canvas-wrap canvas{display:block;width:100%;height:auto}.contact{padding:80px 6vw 40px;max-width:1000px;margin:0 auto;text-align:center}.contact .section-title{display:inline-flex}.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin:30px 0 24px}.contact-card{padding:22px;border-radius:18px;background:var(--card);border:1px solid var(--card-border);transition:all .3s}.contact-card{position:relative;overflow:hidden;isolation:isolate}.contact-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--c1, #ff5fbf),var(--c2, #9b7cff));opacity:0;transition:opacity .3s;z-index:-1}.contact-card:hover{transform:translateY(-6px) rotate(-.5deg);border-color:transparent;box-shadow:0 18px 50px -14px var(--c1, rgba(255,95,191,.5))}.contact-card:hover:before{opacity:.22}.contact-card--bili{--c1: #fb7299;--c2: #00aeec}.contact-card--dy{--c1: #25f4ee;--c2: #fe2c55}.contact-card--xhs{--c1: #ff2442;--c2: #ff8a5b}.contact-card--yt{--c1: #ff0000;--c2: #ff6a6a}.contact-card--doc{--c1: #6ef2ff;--c2: #9b7cff}.contact-card__icon{font-size:36px;margin-bottom:8px;transition:transform .3s}.contact-card:hover .contact-card__icon{transform:scale(1.15) rotate(-8deg)}.contact-card__title{font-family:var(--font-meme);font-size:20px;margin-bottom:4px}.contact-card__sub{color:var(--muted);font-size:13px;font-family:var(--font-mono)}.wechat-row{display:grid;grid-template-columns:minmax(260px,320px) 1fr;gap:18px;align-items:stretch;margin:10px auto 0;max-width:820px;text-align:left}@media (max-width: 680px){.wechat-row{grid-template-columns:1fr}}.qr-card{position:relative;padding:18px;border-radius:20px;background:radial-gradient(220px 140px at 20% 0%,rgba(124,255,178,.2),transparent 60%),radial-gradient(220px 140px at 100% 100%,rgba(255,232,106,.16),transparent 60%),#ffffff0a;border:1px solid rgba(124,255,178,.25);overflow:hidden;display:flex;flex-direction:column;gap:12px;transition:transform .3s,box-shadow .3s}.qr-card:hover{transform:translateY(-4px) rotate(-.4deg);box-shadow:0 22px 50px -18px #7cffb273}.qr-card__header{display:flex;align-items:center;justify-content:space-between;gap:8px}.qr-card__tag{font-family:var(--font-mono);font-size:12px;color:#15071f;background:#7cffb2;padding:4px 10px;border-radius:999px;font-weight:700}.qr-card__name{font-family:var(--font-meme);font-size:18px;color:var(--ink)}.qr-card__frame{position:relative;background:#fff;padding:10px;border-radius:14px;box-shadow:inset 0 0 0 1px #00000014;overflow:hidden;aspect-ratio:1 / 1}.qr-card__frame img{display:block;width:100%;height:100%;object-fit:contain;image-rendering:pixelated}.qr-card__scan{position:absolute;inset:10px;pointer-events:none;overflow:hidden;border-radius:6px}.qr-card__scan-line{position:absolute;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,#7cffb2,transparent);box-shadow:0 0 18px 4px #7cffb2b3;animation:qr-scan 2.6s ease-in-out infinite}@keyframes qr-scan{0%,to{top:0%;opacity:.2}10%{opacity:1}50%{top:100%;opacity:1}60%{opacity:.2}}.qr-card__hint{font-family:var(--font-mono);font-size:12px;color:var(--muted);text-align:center;opacity:.85}.search-card{padding:20px 22px;border-radius:20px;background:linear-gradient(135deg,#ff5fbf1a,#6ef2ff14);border:1px dashed rgba(255,255,255,.25);text-align:left;display:flex;flex-direction:column;justify-content:center}.search-card__head{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:13px;color:var(--muted);margin-bottom:12px;letter-spacing:.05em}.search-card__icon{font-size:16px}.search-card__bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:14px 16px;background:#0e0720;border-radius:12px;border:1px solid rgba(255,255,255,.08);font-family:var(--font-mono);font-size:15px}.search-card__placeholder{color:var(--muted)}.search-card__query{font-family:var(--font-meme);font-size:22px;font-weight:700;background:linear-gradient(90deg,#ff5fbf,#ffe86a,#6ef2ff,#9b7cff,#ff5fbf);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:rainbow 6s linear infinite}.search-card__cursor{display:inline-block;width:10px;height:20px;background:var(--ink);transform:translateY(3px);animation:blink 1s steps(2) infinite}.search-card__hint{margin-top:10px;font-size:12px;color:var(--muted);font-family:var(--font-mono);opacity:.7}.contact-cta{font-family:var(--font-meme);font-size:22px;margin:30px 0 0}.footer{padding:24px 6vw 60px;text-align:center;color:var(--muted);font-size:12px;font-family:var(--font-mono);line-height:1.8;opacity:.7}.scroll-progress{position:fixed;top:0;left:0;width:100%;height:3px;transform:scaleX(0);transform-origin:0 50%;background:linear-gradient(90deg,#ff5fbf,#ffe86a,#6ef2ff,#9b7cff,#ff5fbf);background-size:200% 100%;animation:scroll-progress-sweep 6s linear infinite;box-shadow:0 0 10px #ff5fbf99,0 0 20px #6bf2ff59;z-index:999;pointer-events:none;will-change:transform}@keyframes scroll-progress-sweep{to{background-position:200% 0}}.floaty-avatar{cursor:pointer}.cat-quote{position:fixed;transform:translate(-50%,-130%);padding:10px 16px;background:linear-gradient(135deg,#ff5fbf,#9b7cff);color:#fff;font-family:var(--font-meme);font-weight:700;font-size:16px;border-radius:16px 16px 4px;box-shadow:0 12px 32px #ff5fbf8c;z-index:9998;pointer-events:none;white-space:nowrap;animation:cat-quote-pop 2.4s cubic-bezier(.2,.8,.2,1) forwards}.cat-quote:after{content:"";position:absolute;right:18px;bottom:-6px;width:14px;height:14px;background:linear-gradient(135deg,#ff5fbf,#9b7cff);border-bottom-right-radius:4px;transform:rotate(45deg);filter:blur(.2px);z-index:-1}@keyframes cat-quote-pop{0%{opacity:0;transform:translate(-50%,-90%) scale(.6) rotate(-4deg)}18%{opacity:1;transform:translate(-50%,-140%) scale(1.08) rotate(2deg)}32%{transform:translate(-50%,-132%) scale(1) rotate(0)}80%{opacity:1;transform:translate(-50%,-132%) scale(1) rotate(0)}to{opacity:0;transform:translate(-50%,-170%) scale(.9) rotate(-2deg)}}@media (prefers-reduced-motion: reduce){.scroll-progress{animation:none}.cat-quote{animation-duration:1.6s}}body.is-booting{overflow:hidden}body.is-booting .top-bar,body.is-booting .bgm-toggle,body.is-booting .paw-cursor,body.is-booting .paw-trail,body.is-booting .cat-collector,body.is-booting .scroll-progress,body.is-booting .speed-lines{visibility:hidden}.boot{position:fixed;inset:0;background:#050108;z-index:10000;color:#9be89a;font-family:var(--font-mono);font-size:14px;padding:6vh 6vw;overflow:hidden;transition:opacity .5s ease,transform .5s ease}.boot--done{opacity:0;transform:scale(1.02);pointer-events:none}.boot__crt{position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.04) 0 1px,transparent 1px 3px),radial-gradient(ellipse at 50% 50%,rgba(155,232,154,.06),transparent 60%);pointer-events:none;mix-blend-mode:screen}.boot__log{white-space:pre-wrap;line-height:1.55;margin:0;max-width:920px;text-shadow:0 0 6px rgba(155,232,154,.35)}.boot__line{opacity:0;animation:boot-line-in .24s forwards}.boot__line--ok{color:#c8f5c7}.boot__ok{color:#7cffb2;font-weight:700}.boot__warn{color:#ffd06a;font-weight:700}@keyframes boot-line-in{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}.boot__hint{position:absolute;right:6vw;bottom:6vh;color:#9be89a8c;font-size:12px;letter-spacing:.08em;transition:opacity .4s}.boot__hint--fade{opacity:.25}.terminal__clock{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:#7cffb2;opacity:.7;letter-spacing:.04em}.terminal__body{padding:18px 18px 16px;font-family:var(--font-mono);font-size:13.5px;line-height:1.7;color:#e8e4ff;max-height:340px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.18) transparent}.terminal__body::-webkit-scrollbar{width:6px}.terminal__body::-webkit-scrollbar-thumb{background:#ffffff2e;border-radius:3px}.term-log>*{white-space:pre-wrap;word-break:break-word}.term-out{padding:0}.term-out--prompt{margin-top:4px}.term-line--live{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding-top:4px}.term-line--live .t-prompt,.term-line--live .t-path,.term-line--live .t-dollar{flex-shrink:0}.term-input{flex:1 1 120px;outline:none;min-width:20px;caret-color:transparent;word-break:break-all}.t-dollar{color:var(--cyan)}.t-cursor--live{animation:term-caret 1s steps(2,end) infinite;color:var(--pink)}@keyframes term-caret{50%{opacity:0}}.t-echo{color:#fff}.t-err{color:#ff8aa5}.t-dim{color:#f7ecff66}.term-out kbd{display:inline-block;padding:0 6px;border-radius:4px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);font-size:11px;color:var(--pink-2);font-family:var(--font-mono)}.term-tip{margin-top:10px;font-size:11.5px;color:#f7ecff73}.term-tip kbd{display:inline-block;padding:1px 7px;border-radius:5px;background:#ffffff14;border:1px solid rgba(255,255,255,.18);font-size:11px;color:var(--pink-2)}section.hero,section.projects,section.stats,section.hobbies,section.contact{position:relative}.hidden-cat{position:absolute;left:var(--x, 50%);top:var(--y, 50%);font-size:30px;opacity:.18;filter:grayscale(.85);transform:scale(.9) rotate(-8deg);transition:opacity .6s,filter .6s,transform .6s cubic-bezier(.2,.8,.2,1);cursor:pointer;user-select:none;z-index:3}.hidden-cat:hover{opacity:.85}.hidden-cat--already{opacity:.55;filter:grayscale(0);transform:scale(1) rotate(0);cursor:default;pointer-events:none}.hidden-cat--revealed{opacity:1;filter:grayscale(0) drop-shadow(0 0 8px rgba(255,95,191,.7)) drop-shadow(0 0 18px rgba(107,242,255,.45));transform:scale(1.2) rotate(6deg);animation:cat-pulse 1.4s ease-in-out 1}.hidden-cat--found{animation:cat-found .6s cubic-bezier(.2,.8,.2,1) forwards}@keyframes cat-pulse{0%{transform:scale(1.2) rotate(6deg)}50%{transform:scale(1.5) rotate(-6deg)}to{transform:scale(1.2) rotate(6deg)}}@keyframes cat-found{0%{transform:scale(1.2)}50%{transform:scale(1.7) rotate(12deg);filter:brightness(1.6)}to{transform:scale(1.15) rotate(0)}}.cat-collector{position:fixed;bottom:20px;left:20px;z-index:500;display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#140a22d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:999px;font-family:var(--font-meme);font-size:14px;color:var(--ink);box-shadow:0 8px 24px -6px #00000080;will-change:transform,opacity;transition:opacity .6s ease,transform .6s cubic-bezier(.2,.8,.2,1)}.cat-collector__icon{font-size:16px}.cat-collector__count{color:var(--pink-2);font-weight:700;font-family:var(--font-mono);letter-spacing:.02em}.cat-collector__hint{color:var(--muted);font-size:11px;letter-spacing:.02em}.cat-collector--full{border-color:#ffe86a99;box-shadow:0 8px 24px -6px #ffe86a80,0 0 0 2px #ffe86a4d inset}.cat-collector--full .cat-collector__count,.cat-collector--full .cat-collector__hint{color:var(--yellow)}.cat-collector--hide{opacity:0;transform:translateY(20px) scale(.85);pointer-events:none}@media (max-width: 520px){.cat-collector{bottom:14px;left:14px;padding:6px 10px;font-size:12px}.cat-collector__hint{display:none}.hidden-cat{font-size:24px}}.cat-toast{position:fixed;transform:translate(-50%,-120%);padding:4px 10px;background:linear-gradient(135deg,#ffe86a,#ff9cd8);color:#15071f;font-family:var(--font-meme);font-size:13px;font-weight:700;border-radius:999px;z-index:9997;pointer-events:none;box-shadow:0 6px 18px #ffe86a8c;animation:cat-toast-pop 1.4s cubic-bezier(.2,.8,.2,1) forwards}@keyframes cat-toast-pop{0%{opacity:0;transform:translate(-50%,-60%) scale(.6)}20%{opacity:1;transform:translate(-50%,-140%) scale(1.1)}60%{opacity:1;transform:translate(-50%,-150%) scale(1)}to{opacity:0;transform:translate(-50%,-200%) scale(.9)}}.celebrate-layer{position:fixed;inset:0;pointer-events:none;z-index:9996}.celebrate-bit{position:absolute;font-size:24px;will-change:transform,opacity;animation:celebrate-arc 2.2s cubic-bezier(.2,.6,.2,1) forwards}@keyframes celebrate-arc{0%{transform:translate(-50%,-50%) scale(.3) rotate(0);opacity:0}15%{opacity:1}to{transform:translate(calc(-50% + var(--tx)),calc(-50% + var(--ty) + 200px)) scale(1) rotate(var(--r));opacity:0}}.celebrate-banner{position:fixed;left:50%;top:32%;transform:translate(-50%,-50%);z-index:9999;padding:26px 38px;background:linear-gradient(135deg,#ff5fbff5,#9b7cfff5);border-radius:24px;border:2px solid rgba(255,232,106,.7);color:#fff;text-align:center;box-shadow:0 20px 60px #ff5fbf99,0 0 0 4px #00000040;animation:banner-in .5s cubic-bezier(.2,.8,.2,1) forwards}.celebrate-banner--out{animation:banner-out .5s forwards}.celebrate-banner__title{font-family:var(--font-meme);font-size:34px;font-weight:900;letter-spacing:.02em;text-shadow:0 0 18px rgba(255,232,106,.8)}.celebrate-banner__sub{margin-top:8px;font-size:14px;opacity:.92}@keyframes banner-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.6)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes banner-out{to{opacity:0;transform:translate(-50%,-50%) scale(1.08)}}.paw-trail{position:fixed;inset:0;pointer-events:none;z-index:998;overflow:hidden}.paw-trail__bit{position:absolute;font-size:16px;transform:translate(-50%,-50%) rotate(var(--rot, 0deg));opacity:0;animation:paw-trail-fade .9s ease-out forwards;will-change:opacity,transform}@keyframes paw-trail-fade{0%{opacity:.85;transform:translate(-50%,-50%) rotate(var(--rot, 0deg)) scale(.6)}30%{opacity:.7}to{opacity:0;transform:translate(-50%,-50%) rotate(var(--rot, 0deg)) scale(1.3)}}@media (pointer: coarse){.paw-trail{display:none}}.speed-lines{position:fixed;inset:0;pointer-events:none;z-index:950;opacity:0;transition:opacity .12s}.speed-lines--on{opacity:1}.speed-lines__side{position:absolute;top:0;bottom:0;width:18vw;background:repeating-linear-gradient(12deg,transparent 0 8px,rgba(255,255,255,.85) 8px 9px,transparent 9px 28px);mix-blend-mode:screen;mask-image:linear-gradient(to right,#000 0%,transparent 100%);animation:speed-streak .24s linear}.speed-lines__side--l{left:0}.speed-lines__side--r{right:0;transform:scaleX(-1)}@keyframes speed-streak{0%{transform:translateY(-10%) scaleX(1)}to{transform:translateY(10%) scaleX(1)}}.speed-lines__side--r{animation-name:speed-streak-r}@keyframes speed-streak-r{0%{transform:translateY(-10%) scaleX(-1)}to{transform:translateY(10%) scaleX(-1)}}.project-card{transform-style:preserve-3d}.project-card.is-flipped{transform:rotateY(180deg)!important}.project-card{transition:transform .55s cubic-bezier(.2,.8,.2,1),border-color .3s,box-shadow .3s}.project-card.is-flipped .project-card__head,.project-card.is-flipped .project-card__bubble,.project-card.is-flipped .project-card__links{opacity:0;pointer-events:none;transition:opacity .18s .22s}.project-card__head,.project-card__bubble,.project-card__links{transition:opacity .18s 0ms}.project-card__back{position:absolute;inset:0;padding:22px 22px 18px;display:flex;flex-direction:column;gap:12px;background:linear-gradient(140deg,#230c38f5,#0c0416fa);border-radius:20px;transform:rotateY(180deg);opacity:0;pointer-events:none;transition:opacity .18s 0ms}.project-card.is-flipped .project-card__back{opacity:1;pointer-events:auto;transition:opacity .18s .22s}.project-card__back-title{font-family:var(--font-meme);font-size:18px;color:var(--yellow);letter-spacing:.02em}.project-card__back-stack{display:flex;flex-wrap:wrap;gap:6px}.project-card__chip{padding:3px 10px;font-family:var(--font-mono);font-size:11.5px;color:var(--cyan);background:#6ef2ff14;border:1px solid rgba(110,242,255,.28);border-radius:999px;white-space:nowrap}.project-card__back-note{font-size:13.5px;line-height:1.7;color:var(--ink);opacity:.92}.project-card__back-close{align-self:flex-start;margin-top:auto;padding:6px 14px;font-family:var(--font-mono);font-size:12px;color:var(--pink-2);background:#ffffff0f;border:1px solid rgba(255,255,255,.15);border-radius:999px;cursor:pointer;transition:all .2s}.project-card__back-close:hover{background:var(--pink);color:#15071f;border-color:transparent}.project-card__flip-btn{width:28px;height:28px;display:grid;place-items:center;border-radius:50%;border:1px solid rgba(110,242,255,.3);background:#6ef2ff0f;color:var(--cyan);font-size:14px;font-family:var(--font-mono);cursor:pointer;transition:all .2s;flex-shrink:0}.project-card__flip-btn:hover{background:var(--cyan);color:#15071f;transform:rotate(180deg)}@media (max-width: 520px){.project-card.is-flipped{transform:rotateY(180deg)!important}}
