:root{--bg:#0e0c12;--surface:#161420;--card:#1e1c28;--border:#2e2c3a;--border-glow:#5c4f8a;--accent:#7a6ac0;--accent-dim:#3d3464;--glow:#5a6aad;--text:#d4d0c8;--text-muted:#a09c98;--text-dim:#706c68;--bg-lt:#ccc8c0;--surface-lt:#d8d4cc;--card-lt:#e8e4dc;--border-lt:#8a8680;--border-glow-lt:#6857a8;--accent-lt:#5c4f8a;--accent-dim-lt:#ddd8f0;--glow-lt:#4a5aad;--text-lt:#1a1816;--text-muted-lt:#5a5450;--text-dim-lt:#8a8480;--font-heading:"Press Start 2P", system-ui, sans-serif;--font-ui:"Silkscreen", system-ui, sans-serif;--font-body:"Pixelify Sans", system-ui, sans-serif;--font-stat:"VT323", monospace;--ui-xs:.55rem;--ui-sm:.75rem;--ui-md:1rem;--ui-lg:1.2rem;--h-sm:.8rem;--h-md:1.1rem;--h-lg:1.5rem;--body-sm:.9rem;--body-md:1rem;--body-lg:1.15rem;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-6:24px;--space-8:32px;--space-12:48px;--space-16:64px;--chamfer-lg:polygon(10px 0%, calc(100% - 10px) 0%, 100% 10px, 100% calc(100% - 10px), calc(100% - 10px) 100%, 10px 100%, 0% calc(100% - 10px), 0% 10px);--chamfer-md:polygon(6px 0%, calc(100% - 6px) 0%, 100% 6px, 100% calc(100% - 6px), calc(100% - 6px) 100%, 6px 100%, 0% calc(100% - 6px), 0% 6px);--chamfer-sm:polygon(4px 0%, calc(100% - 4px) 0%, 100% 4px, 100% calc(100% - 4px), calc(100% - 4px) 100%, 4px 100%, 0% calc(100% - 4px), 0% 4px);--ease:cubic-bezier(.4, 0, .2, 1);--ease-pop:cubic-bezier(.34, 1.56, .64, 1);--dur:.22s}[data-theme=dark]{--c-bg:var(--bg);--c-surface:var(--surface);--c-card:var(--card);--c-border:var(--border);--c-border-glow:var(--border-glow);--c-accent:var(--accent);--c-accent-dim:var(--accent-dim);--c-glow:var(--glow);--c-text:var(--text);--c-text-muted:var(--text-muted);--c-text-dim:var(--text-dim)}[data-theme=light]{--c-bg:var(--bg-lt);--c-surface:var(--surface-lt);--c-card:var(--card-lt);--c-border:var(--border-lt);--c-border-glow:var(--border-glow-lt);--c-accent:var(--accent-lt);--c-accent-dim:var(--accent-dim-lt);--c-glow:var(--glow-lt);--c-text:var(--text-lt);--c-text-muted:var(--text-muted-lt);--c-text-dim:var(--text-dim-lt)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}.loader{z-index:5;opacity:1;background:#020617d1;justify-content:center;align-items:center;padding:60px 2rem;transition:opacity .5s;display:flex;position:fixed;inset:0}.loader--out{opacity:0;pointer-events:none}.loader-scanlines{display:none}[data-theme=light] .loader{background:0 0}.loader-content{z-index:2;text-align:center;padding:2rem;font-family:"Press Start 2P",monospace;position:relative}.loader-title{letter-spacing:.14em;color:#e8e4dc;text-shadow:4px 4px #7c3aed8c;margin:0;font-size:clamp(1.4rem,5vw,2.8rem);line-height:1.9}[data-theme=light] .loader-title{color:#6d28d9;text-shadow:4px 4px #6d28d933}@keyframes crt-flicker{0%{opacity:1;transform:none}4.9%{opacity:1;transform:none}5%{opacity:.15;transform:translate(2px)}5.2%{opacity:1;transform:none}18%{opacity:1;transform:none}18.1%{opacity:.55;transform:none}18.3%{opacity:1;transform:none}54.9%{opacity:1;transform:none}55%{opacity:.1;transform:translate(-3px)}55.2%{opacity:1;transform:none}72%{opacity:1;transform:none}72.1%{opacity:.45;transform:translate(1px)}72.3%{opacity:1;transform:none}88%{opacity:.9;transform:none}88.1%{opacity:.2;transform:none}88.3%{opacity:1;transform:none}to{opacity:.95;transform:none}}.loader-title{animation:5s linear infinite crt-flicker}html{font-size:16px}body.loader-active{touch-action:none;overflow:hidden}body{font-family:var(--font-body);color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased;scrollbar-width:thin;scrollbar-color:#94a3b826 transparent;min-height:100vh;font-size:1rem;overflow:hidden scroll}.section{scroll-margin-top:60px}.font-heading{font-family:var(--font-heading);letter-spacing:.02em;line-height:1.6}.font-ui{font-family:var(--font-ui);letter-spacing:.08em;text-transform:uppercase}.font-body{font-family:var(--font-body);line-height:1.7}.font-stat{font-family:var(--font-stat);letter-spacing:.04em;font-size:1.4em;line-height:1.2}.text-xs{font-size:.65rem}.text-sm{font-size:.8rem}.text-base{font-size:1rem}.text-lg{font-size:1.25rem}.text-xl{font-size:1.5rem}.text-2xl{font-size:2rem}.text-3xl{font-size:2.5rem}canvas{image-rendering:pixelated;image-rendering:crisp-edges}.header{z-index:10;border-bottom:3px solid var(--c-accent);-webkit-backdrop-filter:none;background:#d8d4cc;align-items:center;gap:2rem;height:60px;padding:0 2rem;display:flex;position:fixed;top:0;left:0;right:0}[data-theme=dark] .header{border-bottom:2px solid var(--c-accent);background:#020617}.header-name{color:var(--c-text);letter-spacing:.04em;text-shadow:0 0 12px #6366f14d;flex-direction:column;flex-shrink:0;gap:.2rem;font-size:.52rem;line-height:1.4;display:flex}.header-controls{align-items:center;gap:.75rem;margin-left:auto;display:flex}.header-nav{z-index:9;background:#d8d4cc;border-bottom:1px solid #6366f11f;flex-direction:column;align-items:flex-start;gap:0;padding:.5rem 2rem 1rem;display:none;position:fixed;top:60px;left:0;right:0}[data-theme=dark] .header-nav{background:#020617;border-bottom-color:#94a3b814}.header-nav--open{display:flex}.header-nav .nav-link{border-bottom:1px solid #6366f10f;width:100%;padding:.65rem 0}.header-nav .nav-link:last-child{border-bottom:none}.nav-link{color:var(--c-text-muted);letter-spacing:.1em;cursor:pointer;transition:color var(--dur) var(--ease);font-size:.6rem}.nav-link:hover{color:var(--c-accent)}.theme-btn{color:var(--c-text-muted);letter-spacing:.08em;clip-path:none;cursor:pointer;background:#dedad2;border:2px solid #8a8680;border-color:#f0ece4 #8a8680 #8a8680 #f0ece4;flex-shrink:0;align-items:center;gap:.35rem;padding:.3rem .65rem;font-size:.6rem;transition:transform 80ms,box-shadow 80ms;display:flex;box-shadow:2px 2px #8a7440}[data-theme=dark] .theme-btn{background:#1e1c28;border-color:#2e2c3a #08060e #08060e #2e2c3a;box-shadow:2px 2px #2a1e08}.theme-btn:hover{color:var(--c-accent);transform:translate(1px,1px);box-shadow:1px 1px #5a5450}.theme-btn:active{box-shadow:none;transform:translate(2px,2px)}.bookmarks-wrap{flex-shrink:0;position:relative}.bookmarks-btn{color:var(--c-text-muted);letter-spacing:.08em;cursor:pointer;background:#dedad2;border:2px solid #8a8680;border-color:#f0ece4 #8a8680 #8a8680 #f0ece4;flex-shrink:0;align-items:center;gap:.35rem;padding:.3rem .6rem;font-size:.6rem;transition:transform 80ms,box-shadow 80ms;display:flex;box-shadow:2px 2px #8a7440}[data-theme=dark] .bookmarks-btn{background:#1e1c28;border-color:#2e2c3a #08060e #08060e #2e2c3a;box-shadow:2px 2px #2a1e08}.bookmarks-btn:hover{color:var(--c-accent);transform:translate(1px,1px);box-shadow:1px 1px #5a5450}.bookmarks-btn:active{box-shadow:none;transform:translate(2px,2px)}.bm-arrow{font-size:.45rem}.bookmarks-dropdown{z-index:20;min-width:190px;max-width:calc(100vw - 1rem);animation:popIn .15s var(--ease-pop) both;flex-direction:column;display:flex;position:absolute;top:calc(100% + 6px);left:auto;right:0;overflow:hidden}.bookmark-link{letter-spacing:.08em;color:var(--c-text-muted);border-bottom:1px solid var(--c-border);white-space:nowrap;padding:.6rem 1rem;font-size:.52rem;text-decoration:none;transition:color .12s,background .12s;display:block}.bookmark-link:last-child{border-bottom:none}.bookmark-link:hover{color:var(--c-accent);background:#7c3aed0f}.bookmark-divider{color:var(--c-text-dim);letter-spacing:.18em;border-bottom:1px solid var(--c-border);align-items:center;gap:.5rem;padding:.35rem 1rem;font-size:.42rem;display:flex}.bookmark-divider:before,.bookmark-divider:after{content:"";background:var(--c-border);flex:1;height:1px}.resume-btn{color:var(--c-text-muted);letter-spacing:.08em;cursor:pointer;background:#dedad2;border:2px solid #8a8680;border-color:#f0ece4 #8a8680 #8a8680 #f0ece4;flex-shrink:0;align-items:center;gap:.35rem;padding:.3rem .6rem;font-size:.6rem;text-decoration:none;transition:transform 80ms,box-shadow 80ms;display:flex;box-shadow:2px 2px #8a7440}[data-theme=dark] .resume-btn{background:#1e1c28;border-color:#2e2c3a #08060e #08060e #2e2c3a;box-shadow:2px 2px #2a1e08}.resume-btn:hover{color:var(--c-accent);transform:translate(1px,1px);box-shadow:1px 1px #5a5450}.resume-btn:active{box-shadow:none;transform:translate(2px,2px)}@keyframes popIn{0%{opacity:0;transform:scale(.88)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.pop-in{animation:popIn .32s var(--ease-pop) both}.footer{z-index:10;border-top:3px solid var(--c-accent);-webkit-backdrop-filter:none;background:#d8d4cc;align-items:center;gap:1rem;height:60px;padding:0 2rem;display:flex;position:fixed;bottom:0;left:0;right:0}[data-theme=dark] .footer{border-top:3px solid var(--c-accent);background:#0e0c12}.footer-copy{color:var(--c-text-muted);letter-spacing:.1em;margin-left:auto;font-size:.45rem}.menu-btn{color:var(--c-text-muted);clip-path:none;cursor:pointer;background:#dedad2;border:2px solid #8a8680;border-color:#f0ece4 #8a8680 #8a8680 #f0ece4;flex-shrink:0;align-items:center;padding:.3rem .6rem;font-size:.6rem;transition:transform 80ms,box-shadow 80ms;display:flex;box-shadow:2px 2px #8a7440}[data-theme=dark] .menu-btn{background:#1e1c28;border-color:#2e2c3a #08060e #08060e #2e2c3a;box-shadow:2px 2px #2a1e08}.menu-btn:hover{color:var(--c-accent);transform:translate(1px,1px);box-shadow:1px 1px #5a5450}.menu-btn:active{box-shadow:none;transform:translate(2px,2px)}@media (width<=860px){.header-name{font-size:.44rem}.footer-copy,.bm-label,.rv-label{display:none}}@media (width<=480px){.header{gap:.6rem;padding:0 1rem}.header-name{font-size:.36rem}.theme-text{display:none}.theme-btn{padding:.3rem .5rem}.bookmarks-dropdown{min-width:unset;max-width:unset;width:auto;position:fixed;top:60px;left:.5rem;right:.5rem}}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#94a3b826;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#94a3b84d}.page{z-index:1;padding-top:60px;padding-bottom:100px;padding-right:0;position:relative}.hero{flex-direction:column;justify-content:center;align-items:center;height:calc(100vh - 60px);padding-bottom:3rem;display:flex;position:relative}.hero-content{flex-direction:column;align-items:center;gap:2rem;display:flex}.hero-terminal{overflow:hidden}.terminal-bar{background:#00000014;border-bottom:1px solid #6366f11a;align-items:center;gap:.4rem;padding:.55rem .9rem;display:flex}[data-theme=dark] .terminal-bar{background:#00000040}.terminal-title{color:var(--c-text-muted);letter-spacing:.1em;margin-left:.4rem;font-size:.45rem}.terminal-body{letter-spacing:.02em;flex-direction:column;flex:1;justify-content:center;gap:.5rem;padding:1.5rem;font-family:JetBrains Mono,monospace;font-size:.9rem;display:flex}.terminal-line{color:var(--c-accent);white-space:pre-wrap;margin:0;line-height:1.5}.terminal-line.done{color:var(--c-text-muted)}.hero-roles{color:var(--c-text-dim);letter-spacing:.06em;align-items:center;gap:.8rem;font-size:1.5rem;display:flex}.role-sep{color:var(--c-accent);font-size:1.2rem}.hero-cursor{color:var(--c-accent);animation:.7s step-end infinite blink;display:inline-block}.hero-hint{text-align:center;color:var(--c-text-muted);letter-spacing:.15em;white-space:nowrap;font-size:.55rem;animation:1.8s ease-in-out infinite blink;position:absolute;bottom:calc(60px + 1.5rem);left:50%;transform:translate(-50%)}@keyframes blink{0%,to{opacity:.3}50%{opacity:1}}.hero-beaver{flex-direction:row;align-items:stretch;gap:1.75rem;width:min(780px,90vw);display:flex}.hero-beaver-sprite{background:#dedad2;border:3px solid #7a7670;border-color:#f4f0e8 #7a7670 #7a7670 #f4f0e8;flex-shrink:0;width:260px;height:260px;overflow:hidden;box-shadow:5px 5px #8a7440}[data-theme=dark] .hero-beaver-sprite{background:#1e1c28;border-color:#2e2c3a #08060e #08060e #2e2c3a;box-shadow:5px 5px #2a1e08}.hero-beaver-sprite img{object-fit:cover;object-position:center top;width:100%;height:100%;image-rendering:crisp-edges;image-rendering:pixelated}.hero-beaver-frame{flex:1}.hero-beaver-bubble{flex-direction:column;height:260px;display:flex;overflow:hidden}@media (width<=860px){.hero-beaver{gap:1.25rem;width:min(600px,92vw)}.hero-beaver-sprite{width:180px;height:180px}.hero-beaver-bubble{height:180px}.terminal-body{padding:1.25rem;font-size:.82rem}}@media (width<=560px){.hero-beaver{flex-direction:column;align-items:center;gap:1rem;width:90vw}.hero-beaver-sprite{width:130px;height:130px}.hero-beaver-frame{width:100%}.hero-beaver-bubble{height:auto;min-height:130px}.terminal-body{flex:none;padding:1.25rem;font-size:.75rem}}.section{justify-content:center;width:100%;padding:6rem 2rem;display:flex}.section-inner{width:100%;min-width:0;max-width:900px;overflow-x:hidden}.section-tag{font-size:var(--ui-md);color:var(--c-accent);letter-spacing:.12em;border-left:3px solid var(--c-accent);align-items:center;gap:.6rem;margin-bottom:1.25rem;padding-left:.75rem;display:inline-flex}.section-heading{font-size:var(--h-md);color:var(--c-text);word-break:break-word;overflow-wrap:break-word;margin-bottom:3rem;line-height:1.8}.glass-frame{clip-path:none;background:0 0;padding:0;transition:transform .15s,box-shadow .15s;display:grid}.hero-terminal-frame{width:min(560px,90vw)}.section .glass-frame{opacity:0;transition:opacity .9s,transform .9s cubic-bezier(.22,1,.36,1),box-shadow .15s;transform:translate(-40px)}.section .glass-frame.is-visible{opacity:1;transform:translate(0)}.project-frame:hover{transform:translateY(-3px)}.project-frame:hover .glass{box-shadow:7px 7px #8a7440}[data-theme=dark] .project-frame:hover .glass{box-shadow:7px 7px #3a2a10}.blog-frame:hover{transform:translateY(-3px)}.blog-frame:hover .glass{box-shadow:7px 7px #8a7440}[data-theme=dark] .blog-frame:hover .glass{box-shadow:7px 7px #3a2a10}.contact-frame{height:100%;text-decoration:none;display:block}.contact-frame--link{cursor:pointer}.contact-frame .contact-card{height:100%}.contact-frame:hover{transform:translateY(-3px)}.contact-frame:hover .glass{box-shadow:7px 7px #8a7440}[data-theme=dark] .contact-frame:hover .glass{box-shadow:7px 7px #3a2a10}.glass{clip-path:none;-webkit-backdrop-filter:none;background:#e8e4dc;border:2px solid #7a7670;border-color:#f4f0e8 #7a7670 #7a7670 #f4f0e8;box-shadow:4px 4px #8a7440}[data-theme=dark] .glass{background:#1e1c28;border-color:#2e2c3a #08060e #08060e #2e2c3a;box-shadow:4px 4px #2a1e08}.about-frame{width:100%}.about-card{min-width:0;padding:2rem 2.5rem;overflow:hidden}.about-header{justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:1.5rem;display:flex}.about-header-text{flex-direction:column;display:flex}.avatar-box{border:2px solid var(--c-accent);flex-shrink:0;width:140px;height:140px;position:relative;overflow:hidden}.avatar-box img{object-fit:cover;object-position:center top;width:100%;height:100%;position:absolute;inset:0}.about-name{font-size:var(--h-sm);color:var(--c-text);margin-bottom:.5rem;line-height:2}.about-tagline{color:var(--c-accent);margin-bottom:1.5rem;font-size:1.4rem;display:block}.about-bio{font-size:var(--body-md);color:var(--c-text-muted);text-align:justify;word-break:break-word;overflow-wrap:break-word;max-width:560px;margin-bottom:2.5rem;line-height:1.8}.about-stats{flex-wrap:wrap;gap:2.5rem;display:flex}.stat-item{flex-direction:column;gap:.2rem;display:flex}.stat-num{font-family:var(--font-stat);color:var(--c-text);font-size:2.4rem;line-height:1}.stat-label{font-family:var(--font-ui);font-size:var(--ui-xs);color:var(--c-text-muted);letter-spacing:.12em}.projects-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem;display:grid}@media (width<=900px){.section{padding:4rem 1.5rem}.about-card{padding:1.5rem 1.75rem}}@media (width<=560px){.projects-grid,.contact-grid{gap:.75rem}.section{padding:3rem 1rem}.section-inner{width:100%}.about-card{padding:1.25rem}.about-header{flex-direction:column-reverse;align-items:flex-start}.about-header .avatar-box{width:90px;height:90px}.blog-excerpt{display:none}.blog-card{padding:.9rem 1rem}.blog-date{font-size:1.2rem}.blog-title{margin-bottom:0}.contact-card{padding:1rem .5rem}}.project-card{cursor:default;flex-direction:column;gap:.75rem;padding:2rem 2rem 1.75rem;transition:transform .2s,box-shadow .2s;display:flex}.project-card-top{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.project-title-row{align-items:center;gap:.6rem;min-width:0;display:flex}.project-icon{flex-shrink:0;font-size:1.2rem}.project-status{letter-spacing:.08em;white-space:nowrap;border:1px solid;padding:.18rem .5rem;font-size:.42rem;line-height:1}.project-status--completed,.project-status--in-maintenance{color:#4ade80;border-color:#4ade8059}.project-status--in-progress{color:#fbbf24;border-color:#fbbf2459}.project-status--in-research{color:#c084fc;border-color:#c084fc59}.project-status--shelved,.project-status--in-shelves{color:var(--c-text-dim);border-color:var(--c-border)}.project-title{font-family:var(--font-ui);font-size:var(--ui-sm);color:var(--c-text);letter-spacing:.08em}.project-desc{font-family:var(--font-body);font-size:var(--body-sm);color:var(--c-text-muted);flex:1;line-height:1.7}.project-tags{flex-wrap:wrap;gap:.4rem;margin-top:auto;display:flex}.tag{font-family:var(--font-ui);font-size:var(--ui-xs);color:var(--c-accent);border:1px solid var(--c-border-glow);clip-path:none;letter-spacing:.1em;padding:.2rem .5rem}.blog-list{flex-direction:column;gap:1rem;display:flex}.blog-empty{text-align:center;padding:4rem 2.5rem}.blog-empty-title{font-size:var(--h-sm);color:var(--c-text);margin-bottom:.75rem}.blog-empty-sub{font-size:var(--body-md);color:var(--c-text-muted)}.blog-card{cursor:default;grid-template-columns:120px 1fr;align-items:center;gap:1.5rem;padding:2rem 2.5rem;transition:transform .2s;display:grid}.blog-card:hover{transform:translate(4px)}.blog-date{font-family:var(--font-stat);color:var(--c-text-dim);font-size:1.1rem;line-height:1.3}.blog-title{font-family:var(--font-ui);font-size:var(--ui-sm);color:var(--c-text);letter-spacing:.06em;margin-bottom:.4rem}.blog-excerpt{font-family:var(--font-body);font-size:var(--body-sm);color:var(--c-text-muted);line-height:1.6}.contact-intro{font-family:var(--font-body);font-size:var(--body-md);color:var(--c-text-muted);max-width:520px;margin-bottom:3rem;line-height:1.8}.contact-grid{grid-template-columns:repeat(3,1fr);justify-items:stretch;gap:1rem;display:grid}.contact-card{text-align:center;cursor:pointer;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 1.5rem;transition:transform .2s,box-shadow .2s;display:flex}.contact-icon{font-size:1.6rem}.contact-label{font-family:var(--font-ui);font-size:var(--ui-xs);color:var(--c-text);letter-spacing:.1em;white-space:nowrap}.contact-handle{font-family:var(--font-body);font-size:var(--body-sm);color:var(--c-text-muted)}.beaver-alert{z-index:15;opacity:0;pointer-events:none;flex-direction:row;align-items:flex-start;gap:.75rem;transition:transform .42s cubic-bezier(.34,1.56,.64,1),opacity .2s;display:flex;position:fixed;top:70px;left:50%;transform:translate(-50%)translateY(calc(-100% - 80px))}.beaver-alert--in{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)}.beaver-alert-bubble{min-width:200px;max-width:min(320px,100vw - 2rem)}@media (width<=600px){.beaver-alert-bubble{width:calc(88vw - 2rem);max-width:calc(88vw - 2rem)}}@media (width<=425px){.beaver-alert-bubble{width:calc(100vw - 2.5rem);max-width:calc(100vw - 2.5rem)}.hint-joystick-base{width:40px;height:40px}.hint-swipe-track{width:20px;height:40px}}.beaver-alert-bubble{aspect-ratio:5/1.5;flex-direction:row;align-items:stretch;width:min(380px,100vw - 2rem);display:flex;overflow:hidden}.alert-box-ship{background:#7c3aed0f;border-right:1px solid #7c3aed33;flex-shrink:0;justify-content:center;align-self:stretch;align-items:center;width:30%;display:flex}.alert-box-hint{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.35rem;min-width:0;padding:.5rem .7rem;display:flex}.alert-hint-text{color:var(--c-accent);letter-spacing:.08em;text-align:center;font-size:.44rem;line-height:1.5}.alert-box-hint .hint-graphic{gap:2px;padding:0}.alert-box-hint .hint-graphic--cols{gap:18px}.alert-box-hint .hint-key{border-width:2px 2px 6px;width:22px;height:20px;font-size:.34rem}.alert-box-hint .hint-key--active{border-bottom-width:2px;transform:translateY(4px)}.alert-box-hint .hint-key-row{gap:3px}.alert-box-hint .hint-key-row--center{padding-left:0}.alert-box-hint .hint-mouse{width:22px;height:42px}.alert-box-hint .hint-mouse-buttons{height:48%}.alert-box-hint .hint-graphic--cols{max-height:70%}.alert-box-hint .hint-joystick-base{width:36px;height:36px}.alert-box-hint .hint-joystick-thumb{width:14px;height:14px}.alert-box-hint .hint-joy-arrow{font-size:.32rem}.alert-box-hint .hint-swipe-track{width:20px;height:36px}.alert-box-hint .hint-swipe-dot{width:12px;height:12px}.alert-box-hint .hint-col{gap:2px}.alert-box-hint .hint-phone{border-radius:5px;width:24px;height:36px}.alert-box-hint .hint-phone-zone{height:14px}.alert-box-hint .hint-phone-notch{height:4px}.alert-box-hint .hint-phone-notch:after{width:8px;height:2px}.alert-box-hint .hint-ship{width:4px;height:6px}.alert-box-hint .hint-swipe-finger-phone{width:7px;height:7px}.alert-box-hint .hint-joystick-mini{width:11px;height:11px}.alert-box-hint .hint-joystick-thumb--sm{width:4px!important;height:4px!important}.alert-box-hint .hint-joy-arrow--sm{font-size:.18rem!important}.alert-box-hint .hint-scroll-line{height:1px;margin-bottom:3px}.alert-box-hint .hint-graphic--phones{justify-content:center;gap:8px;width:auto}.alert-ship-sprite{background:#020617bf;border:2px solid #7c3aed73;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;box-shadow:0 0 8px #7c3aed40}.alert-ship-wrap{justify-content:center;align-items:center;display:flex}.beaver-alert-bubble.glass{-webkit-backdrop-filter:blur(8px);background:#e8e4dca6}[data-theme=dark] .beaver-alert-bubble.glass{background:#1e1c28a6}.beaver-alert-msg{color:var(--c-text);margin:0;font-size:.88rem;line-height:1.65}.hint-graphic{flex-direction:column;align-items:flex-start;gap:4px;padding:.25rem 0;display:flex}.hint-graphic--cols{flex-direction:row;align-items:flex-end;gap:20px}.hint-col{flex-direction:column;align-items:center;gap:4px;display:flex}.hint-col--center{justify-content:flex-end;align-self:flex-end;align-items:center}.hint-col-label{color:var(--c-accent);letter-spacing:.12em;text-align:center;margin-top:3px;font-size:.38rem}.hint-key-row{align-items:center;gap:4px;display:flex}.hint-key-row--center{justify-content:flex-start;padding-left:30px}.hint-label{color:var(--c-text-dim);letter-spacing:.08em;text-align:center;text-transform:uppercase;margin-top:4px;font-size:.48rem}.hint-key{width:26px;height:24px;color:var(--c-text-muted);box-shadow:none;background:#d8d4cc;border-top:4px solid #c8c4c0;border-bottom:9px solid #4a4540;border-left:4px solid #c8c4c0;border-right:4px solid #5a5550;justify-content:center;align-items:center;font-size:.38rem;transition:transform 80ms,border-bottom-width 80ms;display:flex}[data-theme=dark] .hint-key{box-shadow:none;background:#252838;border-top:4px solid #3c3e52;border-bottom:9px solid #0a0812;border-left:4px solid #3c3e52;border-right:4px solid #12101c}.hint-key--active{color:var(--c-accent);background:#c8c4bc;border-bottom-width:6px;transform:translateY(3px)}[data-theme=dark] .hint-key--active{background:#1a1c2a;border-bottom-width:6px;transform:translateY(3px)}.hint-mouse{background:#d8d4cc;border:2px solid #8a8680;border-color:#c8c4c0 #8a8680 #8a8680 #c8c4c0;flex-direction:column;width:28px;height:46px;margin:0 auto;display:flex;overflow:hidden}.hint-mouse-buttons{border-bottom:1px solid #8a8680;flex-direction:row;flex-shrink:0;align-items:center;height:50%;display:flex}.hint-mouse-btn{flex:1;align-self:stretch}.hint-mouse-btn:first-child{border-right:1px solid #8a8680}.hint-mouse-btn:last-child{border-left:1px solid #8a8680}.hint-mouse-body{flex:1}[data-theme=dark] .hint-mouse{background:#252838;border-color:#4a4c62 #3c3e52 #3c3e52 #4a4c62}[data-theme=dark] .hint-mouse-buttons{border-bottom-color:#3c3e52}[data-theme=dark] .hint-mouse-btn:first-child{border-right-color:#3c3e52}[data-theme=dark] .hint-mouse-btn:last-child{border-left-color:#3c3e52}.hint-mouse--active .hint-mouse-body{background:#7c3aed14}.hint-scroll-wheel{background:repeating-linear-gradient(#7c3aede6 0 2px,#7c3aed26 2px 4px) 0 0/3px 4px;width:3px;height:10px;animation:.4s linear infinite scrollWheel}@keyframes scrollWheel{0%{background-position:0 0}to{background-position:0 4px}}.hint-joystick-base{background:#7c3aed14;border:2px solid #7c3aed8c;border-radius:50%;justify-content:center;align-items:center;width:54px;height:54px;margin:0 auto;display:flex;position:relative}.hint-joy-arrow{color:#7c3aed;pointer-events:none;font-size:.4rem;line-height:1;transition:opacity .15s;position:absolute}.hint-joy-arrow:first-child{top:4px;left:50%;transform:translate(-50%)}.hint-joy-arrow:nth-child(2){top:50%;right:4px;transform:translateY(-50%)}.hint-joy-arrow:nth-child(3){bottom:4px;left:50%;transform:translate(-50%)}.hint-joy-arrow:nth-child(4){top:50%;left:4px;transform:translateY(-50%)}.hint-joystick-thumb{background:#7c3aed8c;border:2px solid #a5b4fcd9;border-radius:50%;width:20px;height:20px;position:absolute}.hint-swipe-track{width:28px;height:54px;margin:0 auto;position:relative;overflow:hidden}.hint-swipe-track:before{content:"";background:linear-gradient(#0000,#7c3aed73);border-radius:1px;width:2px;animation:1.1s cubic-bezier(.4,0,.2,1) infinite swipe-trail;position:absolute;left:50%;transform:translate(-50%)}@keyframes swipe-trail{0%{opacity:0;height:0;bottom:14px}30%{opacity:1}80%{opacity:.6}to{opacity:0;height:30px;bottom:14px}}.hint-swipe-dot{background:#7c3aed8c;border:2px solid #a5b4fce6;border-radius:50%;width:16px;height:16px;animation:1.1s cubic-bezier(.4,0,.2,1) infinite swipe-finger;position:absolute;left:50%;transform:translate(-50%)}@keyframes swipe-finger{0%{opacity:.3;bottom:4px;transform:translate(-50%)scale(.85)}15%{opacity:1;transform:translate(-50%)scale(1)}85%{opacity:1;transform:translate(-50%)scale(1)}to{opacity:0;bottom:34px;transform:translate(-50%)scale(.85)}}.hint-phone{border:2px solid var(--c-border);background:var(--c-bg);border-radius:8px;flex-direction:column;flex-shrink:0;width:46px;height:60px;display:flex;position:relative;overflow:hidden}.hint-phone-notch{flex-shrink:0;justify-content:center;align-items:center;height:6px;display:flex}.hint-phone-notch:after{content:"";background:var(--c-border);border-radius:1px;width:12px;height:2px}.hint-phone-fly{border-bottom:1px solid #7c3aed40;flex:1;position:relative}.hint-phone-zone{background:#7c3aed0f;flex-shrink:0;justify-content:center;align-items:center;height:26px;display:flex}.hint-phone-scroll-area{flex:1;position:relative;overflow:hidden}.hint-ship{clip-path:polygon(50% 0%,100% 100%,50% 72%,0% 100%);background:#7c3aedd9;width:5px;height:8px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.hint-ship--scroll{animation:1.1s cubic-bezier(.4,0,.2,1) infinite shipScrollUp}@keyframes shipScrollUp{0%,to{top:62%}50%{top:28%}}.hint-scroll-lines{flex-direction:column;gap:5px;animation:1.1s cubic-bezier(.4,0,.2,1) infinite linesScrollUp;display:flex;position:absolute;bottom:0;left:5px;right:5px}@keyframes linesScrollUp{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.hint-scroll-line{background:#7c3aed33;border-radius:1px;height:1px}.hint-swipe-finger-phone{pointer-events:none;background:#7c3aed8c;border:1.5px solid #a5b4fce6;border-radius:50%;width:10px;height:10px;animation:1.1s cubic-bezier(.4,0,.2,1) infinite swipePhoneFinger;position:absolute;left:50%;transform:translate(-50%)}@keyframes swipePhoneFinger{0%{opacity:.2;bottom:6px}15%{opacity:1}85%{opacity:1}to{opacity:0;bottom:50%}}.hint-joystick-mini{background:#7c3aed14;border:1.5px solid #7c3aed8c;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;display:flex;position:relative}.hint-joy-arrow--sm{font-size:.22rem!important}.hint-joystick-thumb--sm{border-radius:50%!important;width:6px!important;height:6px!important}.beaver-wrap{opacity:0;pointer-events:none;align-items:center;gap:8px;display:flex;position:relative}body.stage-ready .beaver-wrap{opacity:1;pointer-events:auto;transition:opacity .7s 2.2s}.beaver-sprite{width:52px;height:52px;image-rendering:pixelated;cursor:default;background:#dedad2;border:2px solid #7a7670;border-color:#f4f0e8 #7a7670 #7a7670 #f4f0e8;flex-shrink:0;place-items:center;display:grid}[data-theme=dark] .beaver-sprite{background:#1e1c28;border-color:#2e2c3a #08060e #08060e #2e2c3a}.beaver-emoji{font-size:1.5rem;line-height:1}.beaver-bubble-frame{clip-path:none;background:0 0;padding:0;position:relative}.beaver-bubble-frame:before{content:"";border-top:5px solid #0000;border-bottom:5px solid #0000;border-right:5px solid #f4f0e8;width:0;height:0;position:absolute;top:50%;right:100%;transform:translateY(-50%)}.beaver-bubble{clip-path:none;background:#e8e4dc;border:2px solid #7a7670;border-color:#f4f0e8 #7a7670 #7a7670 #f4f0e8;align-items:center;width:210px;height:52px;padding:.3rem 1.6rem .3rem .75rem;display:flex;position:relative;overflow:hidden;box-shadow:none!important}[data-theme=dark] .beaver-bubble{background:#1e1c28;border-color:#2e2c3a #08060e #08060e #2e2c3a}.beaver-refresh{color:var(--c-text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:.75rem;line-height:1;transition:color .15s,transform .15s;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.beaver-refresh:hover{color:var(--c-accent);transform:translateY(-50%)rotate(180deg)}.beaver-msg{color:var(--c-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.78rem;line-height:1.35;display:-webkit-box;overflow:hidden}.beaver-cursor{color:var(--c-accent);vertical-align:middle;margin-left:1px;font-size:.5rem;animation:.7s step-end infinite blink;display:inline-block}.skills-frame{width:100%}.skills-graph{padding:2rem 2rem 3rem}.skills-plot{width:100%;height:460px;margin-top:1.5rem;position:relative}.skills-axis-x{background:var(--c-accent);opacity:.6;height:2px;position:absolute;top:50%;left:0;right:0}.skills-axis-y{background:var(--c-accent);opacity:.6;width:2px;position:absolute;top:0;bottom:0;left:50%}.skills-label{letter-spacing:.12em;color:var(--c-accent);white-space:nowrap;pointer-events:none;background:var(--c-bg);padding:0 .3rem;font-size:.65rem;position:absolute}.skills-label-top{bottom:calc(100% + .3rem);left:50%;transform:translate(-50%)}.skills-label-bottom{top:calc(100% + .3rem);left:50%;transform:translate(-50%)}.skills-label-left{top:calc(50% + .4rem);left:.5rem}.skills-label-right{top:calc(50% + .4rem);right:.5rem}.skills-grid-h,.skills-grid-v{pointer-events:none;background:#6366f112;position:absolute}.skills-grid-h{height:1px;left:0;right:0}.skills-grid-v{width:1px;top:0;bottom:0}.skill-node{cursor:default;z-index:1;flex-direction:column;align-items:center;gap:.25rem;transition:transform .15s,filter .15s;display:flex;position:absolute;transform:translate(-50%,50%)}.skill-node:hover{filter:drop-shadow(0 0 6px #7c3aedb3);z-index:2;transform:translate(-50%,50%)scale(1.2)}.skill-dot{background:var(--c-accent);border:2px solid var(--c-accent);opacity:.9;width:12px;height:12px}.skill-name{color:var(--c-text);letter-spacing:.08em;white-space:nowrap;background:rgba(var(--c-bg), .7);font-size:.55rem}@media (width<=560px){.skills-plot{height:320px}.skill-dot{width:9px;height:9px}}.skills-top{align-items:stretch;gap:1rem;width:100%;margin-bottom:1.25rem;display:flex}.skills-cat-frame{flex-direction:column;flex:2;gap:.4rem;min-width:0;display:flex;overflow:visible}.skills-cat-list{background:0 0;border:none;flex-direction:column;flex:1;gap:.5rem;display:flex;overflow:visible}.cat-scroll-btn{text-align:center!important;flex:0 0 28px!important;justify-content:center!important;align-items:center!important;height:28px!important;min-height:0!important}.skill-cat-btn{letter-spacing:.1em;color:var(--c-text-muted);cursor:pointer;text-align:left;background:#dedad2;border:2px solid #8a8680;border-color:#f0ece4 #8a8680 #8a8680 #f0ece4;flex:1;justify-content:space-between;align-items:center;gap:.5rem;min-height:80px;padding:0 1rem;font-size:.65rem;transition:transform 80ms,box-shadow 80ms;display:flex;box-shadow:3px 3px #8a7440}[data-theme=dark] .skill-cat-btn{background:#1e1c28;border-color:#2e2c3a #08060e #08060e #2e2c3a;box-shadow:3px 3px #2a1e08}.skill-cat-btn:hover{color:var(--c-accent);box-shadow:2px 2px #8a7440}[data-theme=dark] .skill-cat-btn:hover{box-shadow:2px 2px #2a1e08}.skill-cat-btn.active{color:var(--c-accent);background:#c4c0b8;border-color:#6a6660 #e8e4dc #e8e4dc #6a6660;transform:none;box-shadow:1px 1px #8a7440}[data-theme=dark] .skill-cat-btn.active{background:#12101a;border-color:#06040a #3a3848 #3a3848 #06040a;box-shadow:1px 1px #2a1e08}.cat-btn-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.cat-btn-tag{letter-spacing:.1em;color:var(--c-accent);border:1px solid var(--c-accent);white-space:nowrap;opacity:.85;flex-shrink:0;padding:.15rem .4rem;font-size:.38rem}.skill-cat-btn:hover{color:var(--c-accent);border-color:var(--c-border-glow);z-index:1}.skill-cat-btn.active{color:var(--c-accent);border-color:var(--c-accent);z-index:1;background:#7c3aed14}.spider-frame{flex:3;min-width:0}.spider-wrap{justify-content:center;align-items:center;height:100%;padding:1rem;display:flex}.spider-wrap canvas{max-width:340px;max-height:340px;width:100%!important;height:100%!important}@media (width<=560px){.skills-top{flex-direction:column;height:auto}.skill-cat-btn{font-size:.6rem}}.skills-bottom-row{grid-template-columns:1fr 1fr;gap:1.25rem;margin-top:1.25rem;display:grid}@media (width<=600px){.skills-bottom-row{grid-template-columns:1fr}}.learning-frame{width:100%;margin-top:0}.learning-card{flex-wrap:wrap;align-items:center;gap:1.5rem;padding:1.75rem 2rem;display:flex}.learning-title{font-size:var(--ui-xs);color:var(--c-text-muted);letter-spacing:.12em;white-space:nowrap;flex-shrink:0}.learning-tags{flex-wrap:wrap;gap:.5rem;display:flex}.learning-tag{font-size:var(--ui-xs);color:var(--c-accent);border:1px solid var(--c-border-glow);letter-spacing:.1em;opacity:.85;padding:.25rem .65rem}.learning-tag--trend{color:var(--c-text-muted);border-color:var(--c-border);opacity:.7}.section-divider{background:linear-gradient(90deg,#0000 0%,#6366f133 30% 70%,#0000 100%);width:100%;max-width:900px;height:1px;margin:0 auto}@media (width<=900px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.contact-grid{grid-template-columns:repeat(2,1fr)}.contact-card{padding:1.5rem 1rem}}@media (width<=400px){.contact-grid{grid-template-columns:1fr}}@media (width<=560px){.projects-grid{grid-template-columns:1fr}.blog-card{grid-template-columns:1fr;gap:.25rem}}@media (width<=300px){.projects-grid,.contact-grid{grid-template-columns:1fr}}.exp-timeline{padding-left:2rem;position:relative}.exp-timeline-item{padding-bottom:2rem;position:relative}.exp-timeline-item:last-child{padding-bottom:0}.exp-timeline:before{content:"";background:var(--c-border);width:2px;position:absolute;top:12px;bottom:12px;left:7px}.exp-timeline-dot{background:var(--c-accent);border:2px solid var(--c-bg);width:12px;height:12px;box-shadow:0 0 0 2px var(--c-border-glow);z-index:1;border-radius:50%;position:absolute;top:6px;left:calc(2px - 2rem)}.exp-frame{width:100%}.exp-card{padding:2rem 2.5rem}.exp-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.exp-period{flex-shrink:0}.exp-role{font-size:var(--h-sm);color:var(--c-text)}.exp-designation{font-size:var(--ui-sm);color:var(--c-text-muted);letter-spacing:.08em;margin-top:.25rem}.exp-company{font-size:var(--ui-sm);color:var(--c-accent);letter-spacing:.1em;margin-top:.2rem}.exp-period{color:var(--c-text-muted);white-space:nowrap;flex-shrink:0;font-size:1.2rem}.exp-desc{font-size:var(--body-md);color:var(--c-text-muted);text-align:justify;line-height:1.7}.exp-bullets{flex-direction:column;gap:.75rem;margin-top:.5rem;list-style:none;display:flex}.exp-bullet{font-size:var(--body-md);color:var(--c-text-muted);gap:.6rem;line-height:1.7;display:flex}.exp-bullet-star{color:var(--c-accent);flex-shrink:0;margin-top:.3rem;font-size:.7rem}.certs-category-label{font-size:var(--ui-md);color:var(--c-accent);letter-spacing:.12em;margin-top:2rem;margin-bottom:1rem}.certs-category-label:first-of-type{margin-top:0}.certs-grid{grid-template-columns:repeat(auto-fill,minmax(min(260px,100%),1fr));gap:2rem;display:grid}.cert-card{grid-template-rows:3.8rem auto 1fr;padding:2rem 2.5rem;display:grid}.cert-name{font-size:var(--h-sm);color:var(--c-text);align-self:start;line-height:1.6;overflow:hidden}.cert-issuer{font-size:var(--ui-sm);color:var(--c-accent);letter-spacing:.1em;align-self:start;margin-top:.5rem}.cert-year{color:var(--c-text-muted);align-self:end;font-size:1.3rem}
