.quest-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;background:#000000d9;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.quest-card{background:var(--surface);border:1px solid var(--green-lt);border-radius:20px;width:100%;max-width:600px;padding:32px;position:relative;box-shadow:0 20px 80px #00000080}.quest-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.quest-title{font-family:var(--mono);color:var(--green-dk);font-size:18px;font-weight:700}.close-quest{cursor:pointer;opacity:.6;font-size:24px}.boss-container{margin-bottom:24px}.boss-label{font-family:var(--mono);color:var(--green-dk);justify-content:space-between;margin-bottom:6px;font-size:11px;font-weight:700;display:flex}.boss-hp-bg{background:#111;border:1px solid #6ec9b44d;border-radius:9px;height:18px;position:relative;overflow:hidden}.boss-hp-bar{background:linear-gradient(90deg,#991b1b,#ef4444);height:100%;transition:width .3s linear}.raid-grid{grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:24px;display:grid}.unit-frame{cursor:pointer;background:#222;border:2px solid #0000;border-radius:4px;height:60px;transition:border-color .1s;position:relative;overflow:hidden}.unit-frame.selected{border-color:#fff}.unit-frame.dead{opacity:.3;cursor:not-allowed}.hp-bar{background:#22c55e;transition:height .2s,background-color .3s;position:absolute;bottom:0;left:0;right:0}.hp-bar.low{background:#ef4444}.shield-bar{z-index:1;background:#fff6;border-top:1px solid #fff;transition:height .2s;position:absolute;bottom:0;left:0;right:0}.buff-bar{z-index:3;gap:2px;display:flex;position:absolute;top:4px;left:4px}.buff-echo{background:#fbbf24;border-radius:2px;width:8px;height:8px;box-shadow:0 0 4px #fbbf24}.buff-reversion{background:#60a5fa;border-radius:50%;width:8px;height:8px}.debuff-poison{z-index:3;background:#a855f7;border-radius:50%;width:12px;height:12px;animation:1s infinite pulse;position:absolute;top:4px;right:4px;box-shadow:0 0 8px #a855f7}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}to{opacity:1;transform:scale(1)}}.mana-container{background:#111;border-radius:4px;height:8px;margin-bottom:6px;position:relative;overflow:hidden}.mana-bar{background:#3b82f6;height:100%;transition:width .3s}.essence-container{gap:4px;margin-bottom:24px;display:flex}.essence-dot{background:#111;border:1px solid #fbbf2433;border-radius:4px;flex:1;height:8px;position:relative}.essence-dot.filled{background:#fbbf24;border-color:#fff;box-shadow:0 0 8px #fbbf24}.spell-bar{grid-template-columns:repeat(6,1fr);gap:8px;display:grid}.spell-btn{background:var(--bg2);border:1px solid var(--green-lt);cursor:pointer;border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:8px;transition:all .2s;display:flex;position:relative}.spell-btn:hover:not(:disabled){background:var(--green-lt);transform:translateY(-2px)}.spell-btn:disabled{opacity:.4;cursor:not-allowed}.spell-icon{font-size:18px}.spell-name{font-size:9px;font-family:var(--mono);text-align:center;font-weight:700;line-height:1.1}.spell-cost{opacity:.7;font-size:8px}.spell-cooldown-overlay{font-family:var(--mono);color:#fff;background:#0009;border-radius:8px;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex;position:absolute;inset:0}.effect-flash-green{animation:.4s ease-out flashGreen}.effect-flash-gold{animation:.4s ease-out flashGold}.effect-flash-blue{animation:.4s ease-out flashBlue}.effect-flash-white{animation:.4s ease-out flashWhite}.effect-flash-purple{animation:.4s ease-out flashPurple}@keyframes flashGreen{0%{border-color:#22c55e;box-shadow:inset 0 0 40px #22c55ecc}to{box-shadow:inset 0 0 #22c55e00}}@keyframes flashGold{0%{border-color:#fbbf24;box-shadow:inset 0 0 40px #fbbf24cc}to{box-shadow:inset 0 0 #fbbf2400}}@keyframes flashBlue{0%{border-color:#3b82f6;box-shadow:inset 0 0 40px #3b82f6cc}to{box-shadow:inset 0 0 #3b82f600}}@keyframes flashWhite{0%{border-color:#fff;box-shadow:inset 0 0 40px #fffc}to{box-shadow:inset 0 0 #fff0}}@keyframes flashPurple{0%{border-color:#a855f7;box-shadow:inset 0 0 40px #a855f7cc}to{box-shadow:inset 0 0 #a855f700}}.spell-charges{background:var(--green-dk);color:#fff;font-size:9px;font-family:var(--mono);z-index:10;border:1px solid #fff;border-radius:10px;padding:2px 5px;position:absolute;top:-5px;right:-5px}.quest-footer{text-align:center;margin-top:24px}.start-btn{background:var(--green-dk);color:#fff;cursor:pointer;font-weight:700;font-family:var(--mono);border:none;border-radius:20px;padding:10px 24px}@font-face{font-family:Space Grotesk;src:url(/fonts/space-grotesk-latin-400-normal.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Space Grotesk;src:url(/fonts/space-grotesk-latin-700-normal.woff2)format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:JetBrains Mono;src:url(/fonts/jetbrains-mono-latin-400-normal.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:JetBrains Mono;src:url(/fonts/jetbrains-mono-latin-700-normal.woff2)format("woff2");font-weight:700;font-style:normal;font-display:swap}*,:before,:after{box-sizing:border-box;margin:0;padding:0}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}:root{--bg:#edf7f4;--bg2:#ddf0ea;--surface:#fff;--green-lt:#a8ddd1;--green-md:#6ec9b4;--green-dk:#2e9e84;--text:#1a2e2a;--text-muted:#4a6b62;--mono:"JetBrains Mono", monospace;--sans:"Space Grotesk", sans-serif;--radius:16px;--card-shadow:0 8px 32px #2e9e841a;--footer-bg:#1a2e2a;--nav-bg:#edf7f4d9}[data-theme=dark]{--bg:#0d1110;--bg2:#1a1f1e;--surface:#151918;--green-lt:#2d4a44;--green-md:#3db89d;--green-dk:#6ec9b4;--text:#e0f2f0;--text-muted:#a3c2ba;--card-shadow:0 8px 32px #0000004d;--footer-bg:#050706;--nav-bg:#0d1110d9}[data-theme=dark] .skill-card img[alt=Perl],[data-theme=dark] .skill-card img[alt=Rust],[data-theme=dark] .skill-card img[alt=HTML\/CSS],[data-theme=dark] .skill-card img[alt=ChatGPT],[data-theme=dark] .skill-card img[alt=Wireless\/IoT],[data-theme=dark] .contact-link-item img[src*=github-icon]{filter:invert()brightness(1.5)}html{scroll-behavior:smooth}body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:17px;line-height:1.65;transition:background-color .3s,color .3s;overflow-x:hidden}nav{z-index:100;background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #6ec9b433;justify-content:space-between;align-items:center;padding:18px 48px;display:flex;position:fixed;top:0;left:0;right:0}.theme-toggle{background:var(--bg2);color:var(--green-dk);cursor:pointer;border:1px solid #6ec9b44d;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;margin-left:20px;font-size:18px;transition:all .2s;display:flex}.theme-toggle:hover{background:var(--green-lt);transform:translateY(-1px)}.nav-logo{font-family:var(--mono);color:var(--green-dk);font-size:14px;font-weight:500}.nav-links{gap:32px;list-style:none;display:flex}.nav-links a{color:var(--text-muted);font-size:14px;font-weight:500;text-decoration:none;transition:color .2s}.nav-links a:hover{color:var(--green-dk)}section{padding:96px 48px}.section-inner{max-width:960px;margin:0 auto}.section-label{font-family:var(--mono);color:var(--green-dk);opacity:.8;letter-spacing:.02em;margin-bottom:16px;font-size:13px}.section-title{margin-bottom:24px;font-size:clamp(28px,4vw,40px);font-weight:700;line-height:1.15}#hero{background:var(--bg);align-items:center;min-height:100vh;padding-top:96px;padding-left:48px;padding-right:48px;display:flex;position:relative;overflow:hidden}.hero-grid{opacity:.06;background-image:linear-gradient(var(--green-dk) 1px, transparent 1px), linear-gradient(90deg, var(--green-dk) 1px, transparent 1px);background-size:40px 40px;position:absolute;inset:0}.hero-inner{z-index:1;grid-template-columns:1fr auto;align-items:center;gap:64px;width:100%;max-width:1100px;margin:0 auto;display:grid;position:relative}.hero-eyebrow{font-family:var(--mono);color:var(--green-dk);margin-bottom:20px;font-size:13px}.hero-name{letter-spacing:-.03em;margin-bottom:16px;font-size:clamp(48px,7vw,80px);font-weight:700;line-height:1.05}.hero-name span{color:var(--green-dk)}.hero-title{color:var(--green-dk);font-size:clamp(20px,3vw,28px);font-weight:600;font-family:var(--mono);letter-spacing:-.01em;margin-bottom:12px}.hero-tagline{color:var(--text-muted);text-wrap:pretty;max-width:480px;margin-bottom:40px;font-size:clamp(17px,2vw,21px);font-weight:400}.hero-cta-row{flex-wrap:wrap;gap:16px;display:flex}.btn-primary{background:var(--green-dk);color:#fff;font-family:var(--sans);cursor:pointer;border:none;border-radius:10px;padding:14px 28px;font-size:15px;font-weight:600;text-decoration:none;transition:background .2s,transform .15s;display:inline-block}.btn-primary:hover{background:#1e7a63;transform:translateY(-1px)}.btn-secondary{color:var(--green-dk);font-family:var(--sans);border:2px solid var(--green-md);cursor:pointer;background:0 0;border-radius:10px;padding:14px 28px;font-size:15px;font-weight:600;text-decoration:none;transition:background .2s,transform .15s;display:inline-block}.btn-secondary:hover{background:var(--bg2);transform:translateY(-1px)}.avatar-wrap{flex-shrink:0}.avatar-placeholder{background:var(--bg2);width:240px;height:280px;color:var(--text-muted);font-family:var(--mono);text-align:center;border:2px dashed #2e9e8459;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:20px;font-size:12px;display:flex}.avatar-placeholder-icon{opacity:.4;font-size:48px}.avatar-svg{border-radius:20px;width:240px;height:280px;display:block}.timeline{flex-direction:column;gap:0;margin-top:8px;display:flex}.tl-item{grid-template-columns:14px 1fr;gap:16px;padding-bottom:24px;display:grid;position:relative}.tl-item:last-child{padding-bottom:0}.tl-line{flex-direction:column;align-items:center;display:flex}.tl-dot{background:var(--green-dk);border-radius:50%;flex-shrink:0;width:14px;height:14px;margin-top:4px}.tl-connector{background:linear-gradient(to bottom, var(--green-md), transparent);flex:1;width:2px;min-height:20px;margin-top:4px}.tl-item:last-child .tl-connector{display:none}.tl-year{font-family:var(--mono);color:var(--green-dk);margin-bottom:2px;font-size:11px}.tl-title{margin-bottom:2px;font-size:15px;font-weight:600}.tl-sub{color:var(--text-muted);font-size:13px}#about{background:var(--bg2)}.about-grid{grid-template-columns:1fr 1fr;align-items:start;gap:48px;display:grid}.about-text p{color:var(--text-muted);text-wrap:pretty;margin-bottom:16px}.about-text p:last-child{margin-bottom:0}.about-highlight{background:var(--surface);border-radius:var(--radius);border:1px solid #6ec9b44d;padding:28px}.about-highlight .code-comment{font-family:var(--mono);color:var(--green-dk);margin-bottom:12px;font-size:13px}.about-stat{flex-direction:column;margin-bottom:20px;display:flex}.about-stat:last-child{margin-bottom:0}.about-stat-label{font-family:var(--mono);color:var(--text-muted);font-size:12px}.about-stat-value{font-size:18px;font-weight:600}#skills{background:var(--bg)}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-top:40px;display:grid}.skill-card{background:var(--surface);cursor:default;border:1px solid #6ec9b440;border-radius:12px;padding:20px 22px;transition:transform .2s,box-shadow .2s,border-color .2s}.skill-card:hover{border-color:var(--green-md);transform:translateY(-3px);box-shadow:0 8px 24px #2e9e841f}.skill-icon{margin-bottom:10px;font-size:32px;line-height:1;display:block}.skill-lang{font-family:var(--mono);margin-bottom:4px;font-size:15px;font-weight:500}.skill-level{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px}.skill-dot-row{gap:4px;margin-top:10px;display:flex}.skill-dot{background:var(--bg2);border-radius:50%;width:8px;height:8px}.skill-dot.filled{background:var(--green-dk)}.skills-category{font-family:var(--mono);color:var(--green-dk);opacity:.8;margin-top:36px;margin-bottom:12px;font-size:12px}.skills-category:first-child{margin-top:0}#teaching{background:var(--bg2)}.teaching-grid{grid-template-columns:1fr 1fr;gap:24px;margin-top:40px;display:grid}.teaching-card{background:var(--surface);border-radius:var(--radius);border:1px solid #6ec9b440;padding:28px;transition:box-shadow .2s}.teaching-card:hover{box-shadow:0 8px 32px #2e9e841a}.teaching-card h3{margin-bottom:10px;font-size:18px;font-weight:600}.teaching-card p{color:var(--text-muted);text-wrap:pretty;font-size:15px}.teaching-tag{background:var(--bg2);font-family:var(--mono);color:var(--green-dk);border-radius:6px;margin-top:14px;padding:4px 10px;font-size:12px;display:inline-block}#facts{background:var(--bg)}.facts-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-top:40px;display:grid}.fact-card{background:var(--surface);border:1px solid #6ec9b433;border-radius:14px;padding:22px;transition:transform .2s,border-color .2s}.fact-card:hover{border-color:var(--green-md);transform:translateY(-2px)}.fact-icon{margin-bottom:10px;font-size:28px;display:block}.fact-title{margin-bottom:4px;font-size:15px;font-weight:600}.fact-desc{color:var(--text-muted);font-size:13px}#testimonials{background:var(--bg2)}.testi-carousel{margin-top:40px;position:relative}.testi-track-wrap{overflow:hidden}.testi-track{gap:20px;transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex}.testi-card{background:var(--surface);border-radius:var(--radius);border:1px solid #6ec9b433;flex:0 0 calc(33.333% - 14px);min-width:0;padding:28px;position:relative}@media (width<=900px){.testi-card{flex:0 0 calc(50% - 10px)}}@media (width<=600px){.testi-card{flex:0 0 100%}}.testi-quote{color:var(--green-lt);font-family:Georgia,serif;font-size:40px;line-height:1;position:absolute;top:16px;right:20px}.testi-text{color:var(--text-muted);text-wrap:pretty;margin-bottom:18px;font-size:15px;font-style:italic}.testi-name{font-size:14px;font-weight:600}.testi-role{font-family:var(--mono);color:var(--green-dk);font-size:12px}.testi-nav{align-items:center;gap:12px;margin-top:24px;display:flex}.testi-btn{background:var(--surface);cursor:pointer;width:38px;height:38px;color:var(--green-dk);border:1.5px solid #6ec9b466;border-radius:50%;justify-content:center;align-items:center;font-size:16px;transition:background .2s,border-color .2s;display:flex}.testi-btn:hover{background:var(--green-dk);color:#fff;border-color:var(--green-dk)}.testi-btn:disabled{opacity:.3;cursor:default}.testi-dots{gap:6px;display:flex}.testi-dot{background:var(--green-lt);cursor:pointer;border:none;border-radius:50%;width:7px;height:7px;padding:0;transition:background .2s,transform .2s}.testi-dot.active{background:var(--green-dk);transform:scale(1.3)}.testi-count{font-family:var(--mono);color:var(--text-muted);margin-left:4px;font-size:12px}#contact{background:var(--bg)}.contact-layout{grid-template-columns:1fr 1fr;align-items:start;gap:64px;display:grid}.contact-form{flex-direction:column;gap:14px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-muted);font-size:13px;font-weight:600}.form-group input,.form-group textarea{font-family:var(--sans);background:var(--surface);color:var(--text);resize:vertical;border:1.5px solid #6ec9b459;border-radius:10px;outline:none;padding:12px 16px;font-size:15px;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--green-md);box-shadow:0 0 0 3px #6ec9b433}.form-group textarea{min-height:120px}.contact-links{flex-direction:column;gap:16px;margin-top:40px;display:flex}.contact-link-item{color:var(--text);background:var(--surface);border:1px solid #6ec9b440;border-radius:12px;align-items:center;gap:14px;padding:16px 20px;text-decoration:none;transition:border-color .2s,transform .2s;display:flex}.contact-link-item:hover{border-color:var(--green-md);transform:translate(4px)}.contact-link-icon{text-align:center;width:32px;font-size:20px}.contact-link-label{font-size:14px;font-weight:600}.contact-link-value{font-family:var(--mono);color:var(--text-muted);font-size:12px}footer{background:var(--footer-bg);color:#ffffff80;text-align:center;font-family:var(--mono);padding:32px 48px;font-size:13px}footer span{color:var(--green-lt)}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.hero-inner>*{animation:.6s both fadeUp}.hero-inner>:nth-child(2){animation-delay:.1s}@media (width<=800px){nav{flex-wrap:nowrap;justify-content:space-between;padding:12px 20px}.nav-links{display:none}.nav-logo{font-size:13px}.theme-toggle{border-radius:8px;width:32px;height:32px;margin-left:auto;font-size:14px}section,#hero{padding-left:20px;padding-right:20px}#hero{min-height:auto;padding-top:60px;padding-bottom:40px}.hero-inner{grid-template-columns:1fr;gap:24px}.hero-name{margin-bottom:12px}.hero-title{margin-bottom:8px}.hero-tagline{margin-bottom:24px}.avatar-wrap{order:-1;justify-content:center;display:flex;transform:scale(.9)}.about-grid,.contact-layout,.teaching-grid,.testi-grid{grid-template-columns:1fr}}
