*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#08090c;--bg-card:#0f1115;--bg-card-hover:#16181d;--bg-elevated:#15171c;--border:#22252b;--border-subtle:#191b1f;--text:#edf0f3;--text-muted:#7e8895;--text-dim:#596069;--primary:#b84f0a;--primary-light:#f58514;--primary-dim:#62270e;--accent:#e23670;--accent-blue:#258cf4;--accent-purple:#925cf0;--radius:16px;--radius-sm:10px;--radius-xs:6px;--font:"Plus Jakarta Sans", "Noto Sans JP", system-ui, -apple-system, sans-serif;--transition:.3s cubic-bezier(.25, .4, .25, 1);--transition-fast:.15s ease}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);letter-spacing:.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:1rem;line-height:1.6;overflow-x:hidden}a{color:var(--primary-light);transition:color var(--transition-fast);text-decoration:none}a:hover{color:#f38d3f}.container{max-width:1120px;margin:0 auto;padding:0 24px}.section{padding:100px 0;position:relative}@media (width>=768px){.section{padding:140px 0}}.gradient-text{background:linear-gradient(135deg,#ffc35c 0%,#f9761f 35%,#ec5184 65%,#9b6af1 100%) 0 0/200% 200%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;animation:6s ease-in-out infinite gradient-shift}@keyframes gradient-shift{0%,to{background-position:0%}50%{background-position:100%}}.section-label{color:var(--primary-light);letter-spacing:.15em;text-transform:uppercase;margin-bottom:12px;font-size:.8rem;font-weight:600}.glass-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:transform var(--transition), border-color var(--transition), box-shadow var(--transition)}.glass-card:hover{border-color:#b345054d;transform:translateY(-3px);box-shadow:0 8px 32px #0003}.nav{z-index:100;-webkit-backdrop-filter:blur(20px)saturate(120%);background:#09090ccc;border-bottom:1px solid #2022274d;padding:12px 0;transition:all .4s cubic-bezier(.25,.4,.25,1);position:fixed;top:0;left:0;right:0}.nav.scrolled{background:#09090ce6;border-bottom-color:#20222780;padding:6px 0}.nav-inner{justify-content:space-between;align-items:center;height:56px;display:flex}.nav-brand{letter-spacing:-.02em;font-size:1.15rem;font-weight:800}.nav-links{background:#14161a80;border:1px solid #2022274d;border-radius:9999px;align-items:center;gap:2px;padding:4px;display:flex}.nav-links a{color:var(--text-muted);transition:all var(--transition-fast);white-space:nowrap;border-radius:9999px;padding:7px 14px;font-size:.82rem;font-weight:500}.nav-links a:hover{color:var(--text);background:#b3450514}.nav-links a.active{color:var(--primary-light);background:#b345051f}.nav-lang-wrap{position:relative}.nav-lang{color:var(--text-muted);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:1px solid #20222780;border-radius:9999px;align-items:center;padding:7px 14px;font-family:inherit;font-size:.82rem;font-weight:500;display:inline-flex}.nav-lang:hover{border-color:var(--primary-dim);color:var(--primary-light)}.nav-lang-dropdown{border:1px solid var(--border);border-radius:var(--radius-sm);z-index:200;background:#14161a;min-width:140px;padding:4px;display:none;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 12px 40px #0006}.nav-lang-dropdown.open{display:block}.nav-lang-option{border-radius:var(--radius-xs);color:var(--text-muted);transition:all var(--transition-fast);padding:8px 14px;font-size:.85rem;font-weight:500;display:block}.nav-lang-option:hover{color:var(--text);background:#b3450514}.nav-lang-option.active{color:var(--primary-light);background:#b345051f}.nav:after{content:"";height:1px;width:var(--scroll-progress,0%);background:linear-gradient(90deg, var(--primary), var(--accent));transition:width .1s;position:absolute;bottom:0;left:0}.nav-toggle{color:var(--text);cursor:pointer;background:0 0;border:none;padding:8px;display:none}@media (width<=768px){.nav-toggle{display:block}.nav-links{-webkit-backdrop-filter:blur(40px);border:1px solid var(--border);border-radius:var(--radius);background:#101114fa;flex-direction:column;gap:0;padding:8px;display:none;position:absolute;top:72px;left:16px;right:16px;box-shadow:0 24px 80px #00000080}.nav-links.open{display:flex}.nav-links a{border-radius:var(--radius-sm);padding:16px 20px;font-size:1.1rem;font-weight:500;display:block}.nav-lang-wrap{padding:4px}.nav-lang{border-radius:var(--radius-sm);justify-content:center;width:100%;padding:14px 20px;font-size:1.05rem}.nav-lang-dropdown{box-shadow:none;background:#1b1d22;border:none;margin-top:4px;position:static}.nav-lang-option{padding:12px 20px;font-size:1rem}}.hero{text-align:center;justify-content:center;align-items:center;min-height:100vh;padding-top:64px;display:flex;position:relative;overflow:hidden}.hero:before{content:"";background:radial-gradient(at 30% 20%,#b84f0a12 0%,#0000 50%),radial-gradient(at 70% 60%,#e236700a 0%,#0000 50%),radial-gradient(at 50% 40%,#925cf008 0%,#0000 60%);position:absolute;inset:0}.hero-content{z-index:1;max-width:720px;padding:0 24px;position:relative}.hero-avatar-wrap{width:128px;height:128px;margin:0 auto 36px;position:relative}@media (width>=768px){.hero-avatar-wrap{width:158px;height:158px}}.hero-avatar-wrap:before{content:"";z-index:0;background:conic-gradient(#ffbe4c 0%,#f9761f 25%,#925cf0 50%,#e44479 75%,#ffbe4c 100%);border-radius:50%;animation:5s linear infinite ring-spin;position:absolute;inset:-4px}@media (prefers-reduced-motion:reduce){.hero-avatar-wrap:before{animation:none}}@keyframes ring-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hero-avatar{background:var(--bg-card);z-index:1;width:100%;height:100%;box-shadow:0 0 0 3px var(--bg);border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.hero-avatar-status{border:2.5px solid var(--bg);z-index:3;background:#21c45d;border-radius:50%;width:17px;height:17px;animation:2.5s ease-in-out infinite status-pulse;position:absolute;bottom:5px;right:5px}@keyframes status-pulse{0%,to{box-shadow:0 0 #21c45d80}50%{box-shadow:0 0 0 5px #21c45d00}}.hero h1{letter-spacing:-.03em;margin-bottom:20px;font-size:clamp(2.8rem,7vw,4.5rem);font-weight:800;line-height:1.1}@media (width>=768px){.hero h1{font-size:clamp(3.5rem,7vw,5rem)}}@media (width>=1024px){.hero h1{font-size:clamp(4rem,7vw,5.5rem)}}.hero-sub-name{color:var(--text-dim);letter-spacing:.05em;margin-bottom:20px;font-size:.95rem;font-weight:400}.hero-role{color:var(--text-muted);justify-content:center;align-items:center;min-height:2.2em;margin-bottom:20px;font-size:clamp(1.05rem,2.2vw,1.3rem);font-weight:400;display:flex;position:relative}.hero-role .cursor{background:var(--primary-light);border-radius:9999px;width:2px;height:1em;margin-left:2px;animation:1s infinite blink;display:inline-block}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.hero-subtitle{color:var(--text-muted);max-width:480px;margin:0 auto 40px;font-size:1rem;font-weight:400;line-height:1.65}@media (width>=768px){.hero-subtitle{font-size:1.1rem}}.hero-buttons{flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}@media (width>=640px){.hero-buttons{flex-direction:row}}.hero-cta{background:var(--primary);color:#fff;transition:transform var(--transition-fast), background var(--transition), box-shadow var(--transition);cursor:pointer;letter-spacing:.01em;border:none;border-radius:9999px;align-items:center;gap:10px;padding:14px 32px;font-size:1rem;font-weight:600;display:inline-flex}.hero-cta:hover{background:var(--primary-light);color:#fff;transform:translateY(-2px);box-shadow:0 8px 32px #b345054d}.hero-cta svg{width:18px;height:18px}.scroll-indicator{color:var(--text-dim);z-index:20;animation:2.5s ease-in-out infinite bounce;position:absolute;bottom:32px;left:50%;transform:translate(-50%)}@keyframes bounce{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(8px)}}.section-header{text-align:center;margin-bottom:64px}.section-header h2,.section-header-title{letter-spacing:-.03em;margin-bottom:12px;font-size:clamp(1.8rem,4.5vw,2.6rem);font-weight:700}.section-header p{color:var(--text-muted);max-width:520px;margin:0 auto;font-size:.95rem}.section-hint{color:var(--text-dim);letter-spacing:.03em;margin-top:10px;font-size:.82rem}.projects-grid{grid-template-columns:1fr;gap:16px;display:grid}@media (width>=640px){.projects-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:minmax(240px,auto)}.projects-grid .project-card:first-child,.projects-grid .project-card:nth-child(2){grid-column:span 2}}@media (width>=960px){.projects-grid{grid-template-columns:repeat(12,1fr);grid-auto-rows:260px}.projects-grid .project-card:first-child{grid-area:span 2/span 7}.projects-grid .project-card:nth-child(2){grid-area:span 2/span 5}.projects-grid .project-card:nth-child(3),.projects-grid .project-card:nth-child(4),.projects-grid .project-card:nth-child(5),.projects-grid .project-card:nth-child(6){grid-column:span 4}}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:inherit;text-decoration:none;display:block;position:relative;overflow:hidden}.project-card:hover{border-color:var(--card-accent,var(--primary));box-shadow:0 12px 40px #00000040}.project-card-inner{flex-direction:column;height:100%;padding:28px;display:flex;position:relative}.project-card-inner .project-links{margin-top:auto}.project-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.project-icon{color:#fff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.project-icon svg{width:24px;height:24px}.project-icon-logo{overflow:hidden;background:0 0!important}.project-icon-logo img{border-radius:12px;box-shadow:0 2px 8px #00000026}.project-badge{letter-spacing:.05em;text-transform:uppercase;border-radius:9999px;padding:4px 12px;font-size:.7rem;font-weight:700;display:inline-block}.project-title{color:var(--text);letter-spacing:-.01em;margin-bottom:8px;font-size:1.25rem;font-weight:700}.project-desc{color:var(--text-muted);margin-bottom:20px;font-size:.88rem;line-height:1.7}.project-links{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.project-link{color:var(--primary-light);transition:gap var(--transition);align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:flex}.project-card:hover .project-link{gap:10px}.project-link svg{width:14px;height:14px;transition:transform var(--transition)}.project-card:hover .project-link svg{transform:translate(3px)}.appstore-badge{transition:opacity var(--transition-fast);display:inline-flex}.appstore-badge:hover{opacity:.8}.appstore-badge img{width:auto;height:32px}.appstore-badge-modal img{height:40px}.project-modal-actions{flex-wrap:wrap;align-items:center;gap:16px;margin-top:24px;display:flex}.timeline{max-width:800px;margin:0 auto;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, var(--primary) 0%, var(--border) 100%);opacity:.4;width:1px;position:absolute;top:0;bottom:0;left:20px}@media (width>=769px){.timeline:before{left:50%;transform:translate(-50%)}}.timeline-item{padding:0 0 48px 56px;position:relative}@media (width>=769px){.timeline-item{padding:0 0 48px}.timeline-item:nth-child(odd){text-align:right;padding-right:calc(50% + 40px)}.timeline-item:nth-child(2n){padding-left:calc(50% + 40px)}}.timeline-dot{border:2px solid var(--primary-dim);background:var(--bg);z-index:1;width:16px;height:16px;transition:all var(--transition);border-radius:50%;position:absolute;top:6px;left:13px}.timeline-dot.highlight{background:var(--primary);border-color:var(--primary)}@media (width>=769px){.timeline-dot{left:50%;transform:translate(-50%)}}.timeline-card{padding:24px}.timeline-card-header{align-items:center;gap:16px;margin-bottom:8px;display:flex}.timeline-logo{object-fit:contain;background:var(--bg-elevated);border-radius:10px;flex-shrink:0;width:44px;height:44px;padding:4px;box-shadow:0 2px 8px #00000026}[data-theme=light] .timeline-logo{background:#f0f2f4}.timeline-card-info{flex:1;min-width:0}.timeline-year{color:var(--primary-light);letter-spacing:.05em;margin-bottom:6px;font-size:.8rem;font-weight:700}.timeline-title{color:var(--text);margin-bottom:2px;font-size:1.1rem;font-weight:700}.timeline-title a{color:var(--text);transition:color var(--transition-fast)}.timeline-title a:hover{color:var(--primary-light)}.timeline-role{color:var(--text-muted);margin-bottom:8px;font-size:.8rem;font-weight:500}.timeline-desc{color:var(--text-muted);font-size:.88rem;line-height:1.7}.blog-preview-header{justify-content:space-between;align-items:center;margin-bottom:48px;display:flex}.blog-preview-header .section-header{text-align:left;margin-bottom:0}.blog-view-all{color:var(--primary-light);white-space:nowrap;font-size:.9rem;font-weight:500}.blog-home-grid{background:var(--border-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius);grid-template-columns:1fr 1fr;gap:2px;display:grid;overflow:hidden}@media (width<=768px){.blog-home-grid{background:0 0;border:none;border-radius:0;grid-template-columns:1fr;gap:12px}}.blog-featured-card{color:inherit;background:var(--bg-card);transition:background var(--transition);flex-direction:column;grid-row:span 2;padding:36px 32px;text-decoration:none;display:flex;position:relative}.blog-featured-card:hover{background:var(--bg-card-hover)}@media (width<=768px){.blog-featured-card{border-radius:var(--radius);grid-row:auto}}.blog-featured-tags{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.blog-featured-badge{color:var(--primary-light);background:#b84f0a26;border-radius:20px;padding:4px 12px;font-size:.82rem;font-weight:600}.blog-featured-title{color:var(--text);letter-spacing:-.03em;margin-bottom:12px;font-size:clamp(1.35rem,2.5vw,1.75rem);font-weight:800;line-height:1.25}.blog-featured-desc{color:var(--text-muted);flex:1;margin-bottom:24px;line-height:1.7}.blog-featured-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:20px;display:flex}.blog-featured-meta{color:var(--text-muted);font-size:.85rem}.blog-featured-cta{color:var(--primary-light);font-size:.9rem;font-weight:600}.blog-side-list{background:var(--border-subtle);flex-direction:column;gap:2px;display:flex}.blog-side-card{color:inherit;background:var(--bg-card);transition:background var(--transition), border-left-color var(--transition);border-left:3px solid #0000;padding:24px 28px;text-decoration:none;display:block}.blog-side-card:hover{background:var(--bg-card-hover);border-left-color:var(--primary)}@media (width<=768px){.blog-side-list{background:0 0;gap:8px}.blog-side-card{border-radius:var(--radius-sm);border-left:none}}.blog-side-top{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;display:flex}.blog-side-date{color:var(--text-muted);font-size:.8rem}.blog-side-title{color:var(--text);letter-spacing:-.01em;margin-bottom:6px;font-size:1rem;font-weight:700;line-height:1.35}.blog-side-desc{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.85rem;line-height:1.5;display:-webkit-box;overflow:hidden}.chat-widget{z-index:1000;flex-direction:column;align-items:flex-end;gap:12px;display:flex;position:fixed;bottom:24px;right:24px}.chat-fab{background:var(--primary);color:#fff;cursor:pointer;width:56px;height:56px;box-shadow:0 4px 20px color-mix(in srgb, var(--primary) 40%, transparent);border:none;border-radius:50%;justify-content:center;align-items:center;transition:transform .2s,box-shadow .2s;display:flex}.chat-fab:hover{box-shadow:0 6px 28px color-mix(in srgb, var(--primary) 55%, transparent);transform:scale(1.1)}.chat-fab-icon{width:24px;height:24px;transition:opacity .2s,transform .2s;position:absolute}.chat-fab-open{opacity:1;transform:scale(1)}.chat-fab-close,.chat-fab.open .chat-fab-open{opacity:0;transform:scale(.5)}.chat-fab.open .chat-fab-close{opacity:1;transform:scale(1)}.chat-panel{background:var(--bg-elevated);border:1px solid var(--border);opacity:0;pointer-events:none;transform-origin:100% 100%;border-radius:20px;flex-direction:column;width:340px;height:480px;transition:transform .25s cubic-bezier(.34,1.56,.64,1),opacity .2s;display:flex;overflow:hidden;transform:scale(.85)translateY(20px);box-shadow:0 20px 60px #0000004d}.chat-panel.open{opacity:1;pointer-events:all;transform:scale(1)translateY(0)}.chat-header{border-bottom:1px solid var(--border);background:var(--bg);align-items:center;gap:12px;padding:16px 18px;display:flex}.chat-avatar{background:var(--primary-dim);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:.9rem;font-weight:700;display:flex}.chat-header-name{font-size:.95rem;font-weight:700}.chat-header-sub{color:var(--text-muted);font-size:.75rem}.chat-messages{scrollbar-width:thin;flex-direction:column;flex:1;gap:10px;padding:16px;display:flex;overflow-y:auto}.chat-msg{word-break:break-word;border-radius:16px;max-width:82%;padding:10px 14px;font-size:.88rem;line-height:1.5}.chat-msg.bot{background:var(--bg);border:1px solid var(--border);border-bottom-left-radius:4px;align-self:flex-start}.chat-msg.user{background:var(--primary);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.chat-typing{align-items:center;gap:5px;padding:12px 16px;display:flex}.chat-typing span{background:var(--text-muted);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite chat-bounce}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes chat-bounce{0%,80%,to{opacity:.5;transform:scale(.7)}40%{opacity:1;transform:scale(1)}}.chat-input-row{border-top:1px solid var(--border);align-items:flex-end;gap:8px;padding:12px 14px;display:flex}.chat-input{background:var(--bg);border:1px solid var(--border);resize:none;font:inherit;color:var(--text);border-radius:12px;outline:none;flex:1;max-height:100px;padding:10px 14px;font-size:.88rem;transition:border-color .2s;overflow-y:auto}.chat-input:focus{border-color:var(--primary)}.chat-send{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:background .2s,transform .15s;display:flex}.chat-send:hover{transform:scale(1.08)}.chat-send:disabled{opacity:.5;cursor:default;transform:none}@media (width<=480px){.chat-widget{bottom:12px;right:12px}.chat-fab{width:48px;height:48px}.chat-panel{width:calc(100vw - 32px);height:420px}.project-desc,.timeline-desc{padding-right:60px}}.footer{border-top:1px solid var(--border);background:var(--bg-card);padding:72px 0 36px;position:relative;overflow:hidden}.footer:before{content:"";background:linear-gradient(90deg, var(--primary), var(--accent));opacity:.5;height:1px;position:absolute;top:0;left:0;right:0}.footer-grid{grid-template-columns:2fr 1fr;gap:48px;margin-bottom:48px;display:grid}@media (width<=768px){.footer-grid{grid-template-columns:1fr}}.footer-brand h3{letter-spacing:-.01em;margin-bottom:4px;font-size:1.2rem;font-weight:800}.footer-brand .sub{color:var(--text-dim);margin-bottom:16px;font-size:.82rem}.footer-brand p{color:var(--text-muted);max-width:400px;margin-bottom:24px;font-size:.88rem;line-height:1.7}.social-links{flex-wrap:wrap;gap:10px;display:flex}.social-link{border:1px solid var(--border-subtle);width:38px;height:38px;color:var(--text-muted);transition:all var(--transition);background:#14161a;border-radius:10px;justify-content:center;align-items:center;display:flex}.social-link:hover{border-color:var(--primary-dim);color:var(--primary-light);transform:translateY(-2px)}.social-link svg{fill:currentColor;width:16px;height:16px}.footer-links h4{margin-bottom:16px;font-size:.9rem;font-weight:700}.footer-links ul{list-style:none}.footer-links li{margin-bottom:10px}.footer-links a{color:var(--text-muted);font-size:.88rem;font-weight:450}.footer-links a:hover{color:var(--primary-light)}.footer-bottom{border-top:1px solid var(--border-subtle);text-align:center;padding-top:24px}.footer-bottom p{color:var(--text-dim);font-size:.8rem}.blog-list{max-width:800px;margin:0 auto}.blog-card{color:inherit;margin-bottom:16px;padding:28px;text-decoration:none;display:block}.blog-card-date{color:var(--primary-light);letter-spacing:.02em;margin-bottom:8px;font-size:.78rem;font-weight:700}.blog-card-title{color:var(--text);margin-bottom:8px;font-size:1.15rem;font-weight:700;line-height:1.4}.blog-card-desc{color:var(--text-muted);margin-bottom:12px;font-size:.88rem;line-height:1.7}.blog-card-tags{flex-wrap:wrap;gap:6px;display:flex}.blog-tag{color:var(--primary-light);letter-spacing:.02em;background:#b3450514;border-radius:9999px;padding:3px 12px;font-size:.72rem;font-weight:600}.blog-card-read{color:var(--text-dim);margin-top:12px;font-size:.78rem}.article{max-width:780px;margin:0 auto;padding-top:100px;padding-left:24px;padding-right:24px}.article-header{margin-bottom:48px}.article-date{color:var(--primary-light);margin-bottom:12px;font-size:.82rem;font-weight:700}.article-title{letter-spacing:-.02em;margin-bottom:16px;font-size:clamp(1.8rem,4vw,2.4rem);font-weight:800;line-height:1.3}.article-meta{color:var(--text-muted);flex-wrap:wrap;gap:16px;font-size:.82rem;display:flex}.article-body{line-height:1.9}.article-body h2{letter-spacing:-.01em;margin:48px 0 16px;font-size:1.4rem;font-weight:700}.article-body h3{margin:32px 0 12px;font-size:1.15rem;font-weight:600}.article-body p{color:var(--text);margin-bottom:20px}.article-body ul,.article-body ol{margin:0 0 20px 24px}.article-body li{color:var(--text);margin-bottom:8px}.article-body strong{color:var(--text);font-weight:600}.article-body a{color:var(--primary-light);transition:border-color var(--transition-fast);border-bottom:1px solid #b3450540}.article-body a:hover{color:var(--accent);border-color:var(--accent)}.article-body code{border-radius:var(--radius-xs);border:1px solid var(--border-subtle);background:#16181d;padding:2px 8px;font-family:SF Mono,JetBrains Mono,Fira Code,monospace;font-size:.88em}.article-body pre{border:1px solid var(--border);border-radius:var(--radius-sm);background:#0d0e12;margin:24px 0;padding:20px;overflow-x:auto}.article-body pre code{background:0 0;border:none;padding:0}.article-body blockquote{border-left:3px solid var(--primary-dim);color:var(--text-muted);margin:24px 0;padding-left:20px;font-style:italic}.article-body table{border-collapse:collapse;width:100%;margin:24px 0;font-size:.88rem}.article-body th{text-align:left;border-bottom:2px solid var(--border);color:var(--text-muted);padding:10px;font-weight:600}.article-body td{border-bottom:1px solid var(--border-subtle);padding:10px}.article-body hr{border:none;border-top:1px solid var(--border-subtle);margin:40px 0}.music-list{max-width:800px;margin:0 auto}.music-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}.music-track{border-radius:var(--radius-sm);transition:border-color var(--transition), transform var(--transition);cursor:pointer;align-items:center;gap:16px;margin-bottom:8px;padding:14px 16px;display:flex}.music-track:hover{transform:translateY(-2px)}.music-artwork{border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;width:52px;height:52px}.music-info{flex:1;min-width:0}.music-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:600;overflow:hidden}.music-artist{color:var(--text-muted);font-size:.78rem}.music-play-btn{background:var(--primary);color:#fff;cursor:pointer;width:34px;height:34px;transition:transform var(--transition-fast);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.music-play-btn:hover{transform:scale(1.1)}.music-play-btn svg{width:14px;height:14px}.music-player{max-width:800px;transition:border-color var(--transition);margin:0 auto 40px;padding:24px}.player-inner{align-items:center;gap:24px;display:flex}.player-artwork{border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;width:72px;height:72px}.player-details{flex:1;min-width:0}.player-title{margin-bottom:2px;font-size:1.05rem;font-weight:700}.player-artist{color:var(--text-muted);margin-bottom:12px;font-size:.82rem}.player-progress{margin-bottom:12px}.player-seek{appearance:none;background:var(--border);cursor:pointer;border-radius:2px;outline:none;width:100%;height:4px}.player-seek::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary);cursor:pointer;border-radius:50%;width:14px;height:14px}.player-times{color:var(--text-dim);justify-content:space-between;margin-top:4px;font-size:.72rem;display:flex}.player-controls{justify-content:center;align-items:center;gap:16px;display:flex}.player-controls button{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.player-controls button:hover{color:var(--text)}.player-play-btn{background:var(--primary);color:#fff;cursor:pointer;width:46px;height:46px;transition:transform var(--transition-fast);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.player-play-btn:hover{transform:scale(1.06)}.player-play-btn svg{width:20px;height:20px}@media (width<=600px){.player-inner{text-align:center;flex-direction:column}.player-artwork{width:100px;height:100px}}.particle-canvas{pointer-events:auto;z-index:0;opacity:.5;width:100%;height:100%;position:absolute;inset:0}@media (prefers-reduced-motion:reduce){.particle-canvas{display:none}}.stats-section{border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);padding:48px 0}.stats-grid{text-align:center;grid-template-columns:repeat(4,1fr);gap:32px;display:grid}@media (width<=768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:24px}}.stat-item{flex-direction:column;align-items:center;gap:8px;display:flex}.stat-number{letter-spacing:-.03em;background:linear-gradient(135deg, var(--text) 0%, var(--text-muted) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;line-height:1}.stat-label{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;font-weight:500}.project-card:after{content:"";border-radius:inherit;opacity:.025;pointer-events:none;z-index:1;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:128px 128px;position:absolute;inset:0}.project-card{will-change:transform;transition:transform .5s cubic-bezier(.03, .98, .52, .99), border-color var(--transition), box-shadow var(--transition)}.projects-grid .project-card:first-child{transition-delay:0s}.projects-grid .project-card:nth-child(2){transition-delay:.1s}.projects-grid .project-card:nth-child(3){transition-delay:.2s}.projects-grid .project-card:nth-child(4){transition-delay:.3s}.projects-grid .project-card:nth-child(5){transition-delay:.4s}.projects-grid .project-card:nth-child(6){transition-delay:.5s}.projects-grid .project-card.fade-in:first-child{transition-delay:0s}.projects-grid .project-card.fade-in:nth-child(2){transition-delay:.1s}.projects-grid .project-card.fade-in:nth-child(3){transition-delay:.2s}.projects-grid .project-card.fade-in:nth-child(4){transition-delay:.3s}.projects-grid .project-card.fade-in:nth-child(5){transition-delay:.4s}.projects-grid .project-card.fade-in:nth-child(6){transition-delay:.5s}.timeline-item:first-child .fade-in{transition-delay:0s}.timeline-item:nth-child(2) .fade-in{transition-delay:.1s}.timeline-item:nth-child(3) .fade-in{transition-delay:.15s}.timeline-item:nth-child(4) .fade-in{transition-delay:.2s}.timeline-item:nth-child(5) .fade-in{transition-delay:.25s}.timeline-item:nth-child(6) .fade-in{transition-delay:.3s}.timeline-item:nth-child(7) .fade-in{transition-delay:.35s}.hero-cta:hover{box-shadow:0 8px 32px #b84f0a4d}.shader-canvas{pointer-events:none;z-index:-1;opacity:.25;width:100%;height:100%;image-rendering:pixelated;position:absolute;inset:0}@media (prefers-reduced-motion:reduce){.shader-canvas{display:none}}.mouse-trail-canvas{pointer-events:none;z-index:9998;width:100%;height:100%;position:fixed;inset:0}@media (width<=768px){.mouse-trail-canvas{display:none}}@media (prefers-reduced-motion:reduce){.mouse-trail-canvas{display:none}}.confetti-canvas{pointer-events:none;z-index:10000;width:100%;height:100%;position:fixed;inset:0}.konami-toast{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;z-index:10001;border-radius:9999px;padding:12px 32px;font-size:1.1rem;font-weight:700;animation:.5s cubic-bezier(.34,1.56,.64,1) toast-in;position:fixed;top:80px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #b3450566}.achievement-toast{background:var(--bg-elevated);border:1px solid var(--primary-dim);color:var(--text);border-radius:var(--radius);z-index:10001;padding:12px 24px;font-weight:600;animation:.5s cubic-bezier(.34,1.56,.64,1) toast-in;position:fixed;top:80px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #0006}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(-20px)scale(.9)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.achievement-badge{z-index:9999;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:default;align-items:center;gap:4px;padding:8px 16px;font-size:.82rem;font-weight:600;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 16px #0000004d}.achievement-count{color:var(--primary-light);font-weight:800}.skill-tree-section{padding:80px 0}.skill-tree-wrap{max-width:800px;margin:0 auto;position:relative}.skill-tree-canvas{cursor:crosshair;width:100%;height:400px}@media (width<=768px){.skill-tree-canvas{height:300px}}.skill-tooltip{background:var(--bg-elevated);border:1px solid var(--primary-dim);color:var(--text);border-radius:var(--radius-xs);pointer-events:none;padding:4px 12px;font-size:.82rem;font-weight:600;position:absolute;top:8px;right:8px}.skill-chips{flex-wrap:wrap;justify-content:center;gap:8px;padding:24px 0;display:flex}.skill-chip{background:0 0;border:1px solid;border-radius:999px;padding:4px 14px;font-size:.85rem;font-weight:600}.typing-game-overlay{z-index:10000;backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;animation:.3s fade-in-overlay;display:flex;position:fixed;inset:0}@keyframes fade-in-overlay{0%{opacity:0}to{opacity:1}}.typing-game-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:90%;max-width:600px;padding:40px;animation:.4s cubic-bezier(.34,1.56,.64,1) modal-in;position:relative}@keyframes modal-in{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.typing-game-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:1.2rem;position:absolute;top:16px;right:16px}.typing-game-modal h3{text-align:center;margin-bottom:24px;font-size:1.3rem;font-weight:700}.typing-target{word-break:break-all;text-align:center;margin-bottom:20px;font-family:SF Mono,JetBrains Mono,monospace;font-size:1.2rem;line-height:2}.char-correct{color:var(--primary-light)}.char-wrong{color:#ef4444;text-decoration:underline}.char-current{color:var(--text);background:#b3450533;border-radius:2px}.char-pending{color:var(--text-dim)}.typing-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text);transition:border-color var(--transition-fast);outline:none;padding:12px 16px;font-family:inherit;font-size:1rem}.typing-input:focus{border-color:var(--primary)}.typing-result{justify-content:center;gap:48px;padding:24px 0;display:flex}.typing-stat{text-align:center}.project-modal-overlay{z-index:10000;backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;animation:.3s fade-in-overlay;display:flex;position:fixed;inset:0}.project-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:90%;max-width:500px;animation:.4s cubic-bezier(.34,1.56,.64,1) modal-in;overflow:hidden}.project-modal-inner{padding:40px;position:relative}.project-modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:1.2rem;position:absolute;top:16px;right:16px}.project-modal-header{align-items:center;gap:16px;margin-bottom:20px;display:flex}.project-modal-icon{color:#fff;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.project-modal-icon svg{width:28px;height:28px}.project-modal-header h2{letter-spacing:-.02em;font-size:1.5rem;font-weight:800}.project-modal-desc{color:var(--text-muted);margin-bottom:8px;font-size:1rem;line-height:1.8}.project-expand-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-xs);color:var(--text-dim);cursor:pointer;transition:all var(--transition-fast);opacity:0;background:0 0;justify-content:center;align-items:center;padding:4px;display:flex}.project-card:hover .project-expand-btn{opacity:1}.project-expand-btn:hover{border-color:var(--primary-dim);color:var(--primary-light);background:#b3450514}.timeline-item{will-change:transform, opacity;transition:transform .2s ease-out,opacity .2s ease-out}.fade-in{opacity:0;transition:opacity .7s cubic-bezier(.25,.4,.25,1),transform .7s cubic-bezier(.25,.4,.25,1);transform:translateY(24px)}.fade-in.visible{opacity:1;transform:translateY(0)}@media (width<=768px){.container{padding:0 16px}.section{padding:64px 0}.section-header{margin-bottom:40px}.section-header h2{font-size:clamp(1.5rem,5vw,2rem)}.hero{min-height:90vh;padding-top:80px}.hero h1{margin-bottom:12px;font-size:clamp(2.2rem,8vw,3rem)}.hero-sub-name{margin-bottom:12px;font-size:.85rem}.hero-role{height:2em;margin-bottom:12px;font-size:clamp(1rem,4vw,1.4rem)}.hero-subtitle{margin-bottom:28px;font-size:.9rem}.hero-cta{padding:12px 24px;font-size:.9rem}.scroll-indicator{bottom:16px}.project-card-inner{padding:20px}.project-title{font-size:1.1rem}.project-desc{font-size:.85rem}.blog-home-grid{grid-template-columns:1fr!important}.blog-featured-card{grid-row:auto}.blog-featured-title{font-size:1.25rem}.blog-preview-header{flex-direction:column;align-items:flex-start;gap:12px}.music-grid{grid-template-columns:1fr}.footer{padding:48px 0 24px}.footer-grid{gap:32px}}@media (width<=480px){.container{padding:0 12px}.hero-avatar-wrap{width:100px;height:100px}}@media (prefers-reduced-motion:reduce){.fade-in{opacity:1;transition:none;transform:none}.scroll-indicator{animation:none}}.terminal-overlay{z-index:10000;backdrop-filter:blur(6px);background:#0009;justify-content:center;align-items:flex-start;padding-top:10vh;animation:.2s fade-in-overlay;display:flex;position:fixed;inset:0}.terminal-window{background:#0c0e12;border:1px solid #292c32;border-radius:12px;width:90%;max-width:720px;animation:.3s cubic-bezier(.34,1.56,.64,1) modal-in;overflow:hidden;box-shadow:0 24px 80px #0009,0 0 0 1px #1c1d22}.terminal-titlebar{-webkit-user-select:none;user-select:none;background:#16181d;border-bottom:1px solid #202227;align-items:center;gap:12px;padding:10px 16px;display:flex}.terminal-dots{gap:7px;display:flex}.terminal-dot{cursor:pointer;border-radius:50%;width:12px;height:12px}.dot-red{background:#ff5f57}.dot-yellow{background:#febc2e}.dot-green{background:#28c840}.terminal-title{text-align:center;color:var(--text-dim);flex:1;font-size:.78rem;font-weight:500}.terminal-output{cursor:text;height:400px;padding:16px;font-family:SF Mono,JetBrains Mono,Fira Code,monospace;font-size:.85rem;line-height:1.6;overflow-y:auto}.terminal-line{margin-bottom:4px}.terminal-prompt{color:#70c270;white-space:pre-wrap;word-break:break-all}.terminal-result{color:var(--text);font-family:inherit;font-size:inherit;white-space:pre-wrap;word-break:break-all;margin:0}.term-blue{color:#5ea6ed;font-weight:600}.term-bold{color:var(--text);font-weight:700}.term-green{color:#70c270}.terminal-input-line{align-items:center;padding-top:4px;display:flex}.terminal-prompt-text{color:#70c270;white-space:nowrap;font-family:inherit;font-size:.85rem}.terminal-input{color:var(--text);caret-color:var(--primary-light);background:0 0;border:none;outline:none;flex:1;margin:0;padding:0;font-family:SF Mono,JetBrains Mono,Fira Code,monospace;font-size:.85rem}.terminal-output::-webkit-scrollbar{width:6px}.terminal-output::-webkit-scrollbar-track{background:0 0}.terminal-output::-webkit-scrollbar-thumb{background:#2e3038;border-radius:3px}.blog-search-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);max-width:800px;transition:border-color var(--transition), box-shadow var(--transition);align-items:center;margin:0 auto 32px;padding:0 16px;display:flex;position:relative}.blog-search-wrap.focused{border-color:var(--primary-dim);box-shadow:0 0 0 3px #b345051a}.blog-search-icon{width:18px;height:18px;color:var(--text-dim);flex-shrink:0}.blog-search-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:14px 12px;font-family:inherit;font-size:.95rem}.blog-search-input::placeholder{color:var(--text-dim)}.blog-search-clear{color:var(--text-dim);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:4px;display:flex}.blog-search-clear:hover{color:var(--text)}.blog-search-empty{text-align:center;color:var(--text-muted);padding:48px 24px;font-size:.95rem}.theme-toggle{width:36px;height:36px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #20222780;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.theme-toggle:hover{border-color:var(--primary-dim);color:var(--primary-light);background:#b3450514}[data-theme=light]{--bg:#f6f7f9;--bg-card:#fff;--bg-card-hover:#f3f4f6;--bg-elevated:#f9fafb;--border:#dcdfe5;--border-subtle:#e8eaee;--text:#1a1d23;--text-muted:#636874;--text-dim:#8b919c;--primary:#9f3d04;--primary-light:#a5540d;--primary-dim:#812d0e;--accent:#7e1e07}[data-theme=light] .nav{background:#ffffffd9;border-bottom-color:#dcdfe580}[data-theme=light] .nav.scrolled{background:#ffffffeb}[data-theme=light] .nav-links{background:#f0f2f4b3;border-color:#dcdfe566}[data-theme=light] .nav-lang-dropdown{background:#fff}[data-theme=light] .glass-card{box-shadow:0 1px 3px #0000000f}[data-theme=light] .glass-card:hover{box-shadow:0 8px 32px #0000001a}[data-theme=light] .hero:before{background:radial-gradient(at 30% 20%,#b345050f 0%,#0000 50%),radial-gradient(at 70% 60%,#9123080a 0%,#0000 50%),radial-gradient(at 50% 40%,#3333cc08 0%,#0000 60%)}[data-theme=light] .footer{background:#f0f2f4}[data-theme=light] .social-link{background:#f6f7f8}[data-theme=light] .shader-canvas{opacity:.08}[data-theme=light] .particle-canvas{opacity:.25}[data-theme=light] .terminal-window{background:#fff;border-color:#d3d7de}[data-theme=light] .terminal-titlebar{background:#f3f4f6;border-bottom-color:#e2e4e9}[data-theme=light] .terminal-output,[data-theme=light] .terminal-result,[data-theme=light] .terminal-input{color:#21242c}[data-theme=light] .article-body code{background:#f0f2f4;border-color:#dcdfe5}[data-theme=light] .article-body pre{background:#f3f4f6;border-color:#dcdfe5}[data-theme=light] .blog-tag{background:#b345050f}[data-theme=light] .gradient-text{background:linear-gradient(135deg, var(--primary), #f39f3f);-webkit-background-clip:text;background-clip:text}