@keyframes spin{to{transform:rotate(360deg)}}@keyframes hologramFloat{0%,to{transform:translate(-50%,-50%) translateY(0)}50%{transform:translate(-50%,-50%) translateY(-3px)}}@keyframes hologramBreathe{0%,to{opacity:1}50%{opacity:.94}}@keyframes edgeShimmer{0%,to{opacity:0}50%{opacity:.12}}@keyframes hologramPulse{0%,to{opacity:.8;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}}@keyframes glitchCyan{0%,70%,78%,to{transform:translate(-3px,0);opacity:.08}15%{transform:translate(-2px,0);opacity:.12}30%{transform:translate(-4px,1px);opacity:.06}45%{transform:translate(-3px,0);opacity:.1}72%{transform:translate(-6px,2px);opacity:.25}74%{transform:translate(-2px,-1px);opacity:.15}76%{transform:translate(-5px,0);opacity:.2}}@keyframes glitchRed{0%,71%,79%,to{transform:translate(3px,0);opacity:.08}20%{transform:translate(2px,-1px);opacity:.1}40%{transform:translate(4px,0);opacity:.06}73%{transform:translate(6px,-2px);opacity:.25}75%{transform:translate(2px,1px);opacity:.15}77%{transform:translate(5px,0);opacity:.2}}:root{--color-bg-1:#1a1d2e;--color-bg-2:#1f2338;--color-bg-3:#252841;--color-card:#3d3740;--color-accent:#e67e22;--color-accent-hover:#ff9966;--color-text:#f0ebe5;--color-text-secondary:#b8b0a8;--color-pattern-1:#453842;--color-pattern-2:#221e1a;--opacity-subtle:0.05;--opacity-border:0.12;--opacity-overlay:0.15;--opacity-hover:0.3;--opacity-medium:0.5;--opacity-lightbox:0.9;--color-accent-alpha-10:rgba(230, 126, 34, 0.08);--color-accent-alpha-15:rgba(230, 126, 34, 0.15);--color-accent-alpha-30:rgba(230, 126, 34, 0.3);--color-accent-alpha-40:rgba(230, 126, 34, 0.4);--color-white-alpha-05:rgba(255, 255, 255, 0.05);--color-white-alpha-08:rgba(255, 255, 255, 0.08);--color-white-alpha-10:rgba(255, 255, 255, 0.1);--color-white-alpha-12:rgba(255, 255, 255, 0.12);--color-black-alpha-10:rgba(0, 0, 0, 0.1);--color-black-alpha-15:rgba(0, 0, 0, 0.15);--color-black-alpha-20:rgba(0, 0, 0, 0.2);--color-black-alpha-25:rgba(0, 0, 0, 0.25);--color-black-alpha-30:rgba(0, 0, 0, 0.3);--color-black-alpha-50:rgba(0, 0, 0, 0.5);--color-black-alpha-60:rgba(0, 0, 0, 0.6);--color-black-alpha-80:rgba(0, 0, 0, 0.8);--color-black-alpha-90:rgba(0, 0, 0, 0.9);--theme-bg:linear-gradient(135deg, var(--color-bg-1), var(--color-bg-2), var(--color-bg-3));--theme-card:var(--color-card);--theme-accent:var(--color-accent);--theme-text:var(--color-text);--theme-secondary:var(--color-text-secondary);--theme-link-hover:var(--color-accent-hover);--container-max-width:1200px;--container-padding:0 24px;--transition-fast:all 0.2s ease;--transition-normal:all 0.3s ease}*{box-sizing:border-box;margin:0;padding:0}body,html{font-family:"SF Pro Display","Inter","Hiragino Sans","Noto Sans JP",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,sans-serif;color:var(--theme-text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;overflow-x:hidden;position:relative;letter-spacing:.01em}body::after,body::before{content:"";position:fixed;top:0;left:0;width:100%;height:100lvh;pointer-events:none}body::before{background:var(--theme-bg);z-index:-2}body::after{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 60'%3E%3Cdefs%3E%3CradialGradient id='grad' cx='50%25' cy='50%25' r='50%25' fx='50%25' fy='50%25'%3E%3Cstop offset='9%25' stop-color='%23453842' /%3E%3Cstop offset='10%25' stop-color='%23221e1a' /%3E%3Cstop offset='19%25' stop-color='%23221e1a' /%3E%3Cstop offset='20%25' stop-color='%23453842' /%3E%3Cstop offset='29%25' stop-color='%23453842' /%3E%3Cstop offset='30%25' stop-color='%23221e1a' /%3E%3Cstop offset='39%25' stop-color='%23221e1a' /%3E%3Cstop offset='40%25' stop-color='%23453842' /%3E%3Cstop offset='49%25' stop-color='%23453842' /%3E%3Cstop offset='50%25' stop-color='%23221e1a' /%3E%3Cstop offset='59%25' stop-color='%23221e1a' /%3E%3Cstop offset='60%25' stop-color='%23453842' /%3E%3Cstop offset='69%25' stop-color='%23453842' /%3E%3Cstop offset='70%25' stop-color='%23221e1a' /%3E%3Cstop offset='79%25' stop-color='%23221e1a' /%3E%3Cstop offset='80%25' stop-color='%23453842' /%3E%3Cstop offset='89%25' stop-color='%23453842' /%3E%3Cstop offset='90%25' stop-color='%23221e1a' /%3E%3C/radialGradient%3E%3C/defs%3E%3Ccircle fill='url(%23grad)' cy='27' r='57' /%3E%3Ccircle fill='url(%23grad)' cx='100' cy='27' r='57' /%3E%3Ccircle fill='url(%23grad)' cx='50' cy='57' r='57' /%3E%3Ccircle fill='url(%23grad)' cy='87' r='57' /%3E%3Ccircle fill='url(%23grad)' cx='100' cy='87' r='57' /%3E%3C/svg%3E")center center/42rem auto;opacity:.15;z-index:-1}.container,.language-nav{max-width:var(--container-max-width);margin:0 auto;padding:var(--container-padding)}.language-nav{max-width:1200px;padding:0 24px;display:flex;justify-content:flex-end}header{padding:24px 0 12px;position:relative;z-index:100}.lang-selector{display:flex;align-items:center;gap:16px;font-size:14px;font-weight:500}.lang-btn,.nav-link{background:0 0;border:0;color:var(--theme-secondary);cursor:pointer;font-size:14px;font-weight:500;padding:4px 8px;border-radius:4px;transition:var(--transition-fast);font-family:inherit;text-decoration:none;position:relative}.lang-btn::after,.nav-link::after{content:"";position:absolute;bottom:-1px;left:50%;width:0;height:1px;background:linear-gradient(90deg,var(--theme-accent),var(--theme-link-hover));transition:var(--transition-normal);transform:translateX(-50%)}.lang-btn:hover,.nav-link:hover{color:var(--theme-text);background:var(--color-white-alpha-05)}.lang-btn.active::after,.lang-btn:hover::after,.nav-link:hover::after{width:70%}.lang-btn.active{color:var(--theme-accent);font-weight:600}.project-tabs{display:flex;gap:24px;margin:40px 0 32px;align-items:baseline}.nav-dot,.tab-btn{color:var(--theme-secondary)}.tab-btn,.tab-btn::after{transition:var(--transition-normal)}.tab-btn{background:0 0;border:0;cursor:pointer;font-size:32px;font-weight:600;padding:0;font-family:inherit;position:relative;letter-spacing:-.01em}.tab-btn::after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--theme-accent)}.main-title rt,.tab-btn:hover{color:var(--theme-text)}.tab-btn.active::after,.tab-btn:hover::after{width:100%}.tab-btn.active{color:var(--theme-accent)}.nav-dot{opacity:.5;font-size:12px}@media (max-width:768px){.language-nav{justify-content:center;padding:0 16px}.lang-selector{gap:12px}.main-title,h1{font-size:40px}.tab-btn,h2{font-size:28px}.project-tabs{gap:20px}.project-images-gallery,.projects-grid{grid-template-columns:1fr}.project-app-icon{width:60px;height:60px}}.hover-3d,.hover-slide{transition:var(--transition-normal)}.hover-slide:hover{transform:translateX(4px)}.hover-3d:hover{transform:scale(1.02) rotateY(5deg) rotateX(2deg);filter:brightness(1.1) saturate(1.2)}.project-link,.project-link.secondary{display:inline-flex;align-items:center;gap:8px;font-weight:400;padding:12px 24px;margin:6px 8px 6px 0;border-radius:20px;text-decoration:none;color:var(--theme-text);border:1px solid var(--color-accent-alpha-40);background:linear-gradient(135deg,var(--color-accent-alpha-10),var(--color-accent-alpha-15));cursor:pointer;font-size:15px;position:relative;overflow:hidden;transition:var(--transition-normal)}.project-link.secondary:hover,.project-link:hover{color:#fff;border-color:var(--theme-accent);background:var(--theme-accent);box-shadow:2px 0 12px var(--color-accent-alpha-30)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0}.spinner{width:36px;height:36px;border:3px solid var(--color-black-alpha-10);border-radius:50%;border-top-color:var(--accent);animation:spin 1s ease-in-out infinite;margin-bottom:16px}#content{padding:0 0 40px}.hero-section{display:flex;align-items:center;gap:20px;margin-bottom:20px}.hologram-container{position:relative;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:160px;height:160px;transform:perspective(400px) rotateY(-25deg);transform-style:preserve-3d}.hologram-aberration,.hologram-image{position:absolute;top:50%;left:50%;width:200px;height:200px;transform:translate(-50%,-50%)}.hologram-image{object-fit:contain;z-index:2;animation:hologramFloat 4s ease-in-out infinite,hologramBreathe 3s ease-in-out infinite;will-change:transform,opacity}.hologram-aberration{animation:hologramFloat 4s ease-in-out infinite;pointer-events:none;z-index:3;isolation:isolate;will-change:transform}.hologram-aberration::after,.hologram-aberration::before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:url(avatar.png)center/contain no-repeat;mix-blend-mode:screen;opacity:.2}.hologram-aberration::before{transform:translate(-3px,0);filter:hue-rotate(-50deg) saturate(2) brightness(1.1);animation:glitchCyan 6s ease-in-out infinite}.hologram-aberration::after{transform:translate(3px,0);filter:hue-rotate(50deg) saturate(2) brightness(1.1);animation:glitchRed 6s ease-in-out infinite .15s}.hologram-container::after,.hologram-glitch,.hologram-scanlines{position:absolute;top:50%;left:50%;width:200px;height:200px;transform:translate(-50%,-50%);pointer-events:none;-webkit-mask:url(avatar.png)center/contain no-repeat;mask:url(avatar.png)center/contain no-repeat;-webkit-mask-size:contain;mask-size:contain}.hologram-container::after{content:"";background:linear-gradient(135deg,rgba(255,255,255,.8),rgba(255,255,255,.6));z-index:6;opacity:0;filter:blur(1px) brightness(2);animation:edgeShimmer 4s ease-in-out infinite;will-change:opacity}.hologram-glitch,.hologram-scanlines{animation:hologramFloat 4s ease-in-out infinite;will-change:transform}.hologram-scanlines{background:repeating-linear-gradient(0deg,transparent,transparent 2px,var(--color-black-alpha-15) 2px,var(--color-black-alpha-15) 4px);z-index:5;opacity:.7}.hologram-glitch{overflow:hidden;z-index:4}.hero-content{flex:1;min-width:0}.hero-content .main-title{margin-top:0}#intro-content p{margin-bottom:0}@media (max-width:768px){.hero-section{flex-direction:column;align-items:flex-start;text-align:left;gap:20px}.hologram-container{display:none}}h1,p{margin-bottom:24px}h1,h2{font-weight:600}h1{font-size:56px;letter-spacing:-.015em;line-height:1.1}.main-title{font-size:50px;font-weight:700;margin:40px 0 12px;letter-spacing:-.02em;line-height:1;text-align:left;color:var(--color-accent);user-select:none;cursor:default;display:inline-block;width:fit-content;text-shadow:-1.5px 0 0 rgba(255,50,50,.4),1.5px 0 0 rgba(255,220,0,.4),1px 1px 0#d06820,2px 2px 0#c05f1e,3px 3px 0#b0551c,4px 4px 0#a04c1a,5px 5px 0#904218,6px 6px 0#803916,7px 7px 0#703014,8px 8px 0#602612,9px 9px 0#501d10,10px 10px 0#40140e;-webkit-text-stroke:1.5px var(--color-accent);paint-order:stroke fill}.main-title:hover{color:var(--color-accent);text-shadow:-2px 0 0 rgba(255,50,50,.5),2px 0 0 rgba(255,220,0,.5),1px 1px 0#d06820,2px 2px 0#c05f1e,3px 3px 0#b0551c,4px 4px 0#a04c1a,5px 5px 0#904218,6px 6px 0#803916,7px 7px 0#703014,8px 8px 0#602612,9px 9px 0#501d10,10px 10px 0#40140e,11px 11px 0#300a0c,12px 12px 0#20050a,8px 0 0 var(--color-accent-alpha-30),10px 0 0 var(--color-accent-alpha-15);opacity:.9}.main-title rt{font-size:16px;font-weight:400;letter-spacing:2px;opacity:.9;user-select:none;text-shadow:none;-webkit-text-stroke:0}.main-title:hover rt{opacity:.7;color:var(--theme-secondary)}h2{font-size:32px;margin:40px 0 24px;letter-spacing:-.01em}p{font-size:17px;line-height:1.5;color:var(--secondary-text)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:32px;margin:40px 0}.main-title ruby,.project-card,a{position:relative}.project-card{display:flex;flex-direction:column;background:rgba(61,55,64,.6);backdrop-filter:blur(80px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:16px;overflow:hidden;margin-bottom:32px;box-shadow:0 8px 32px rgba(0,0,0,.3),0 2px 8px rgba(0,0,0,.2),inset 0 1px 1px rgba(255,255,255,.15),inset 0-1px 1px rgba(0,0,0,.1);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease,background .3s ease;border:1px solid rgba(255,255,255,.18)}.project-card:hover{background:rgba(61,55,64,.5);box-shadow:0 12px 48px rgba(0,0,0,.4),0 4px 16px rgba(0,0,0,.3),0 0 0 1px rgba(230,126,34,.3),inset 0 1px 2px rgba(255,255,255,.2),inset 0-1px 2px rgba(0,0,0,.1);border-color:rgba(230,126,34,.5)}.project-header{display:flex;align-items:center;padding:16px;gap:16px;border-bottom:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.03)}.project-app-icon{width:64px;height:64px;border-radius:10px;object-fit:cover;box-shadow:0 2px 8px var(--color-black-alpha-20)}.project-title-section{flex-grow:1}.project-title{margin:0 0 4px;font-size:1.4rem;font-weight:600;letter-spacing:-.01em}.project-tech{display:flex;flex-wrap:wrap;gap:6px}.project-date,.tech-tag{color:var(--theme-secondary)}.tech-tag{font-size:.8rem;background:var(--color-white-alpha-10);border-radius:4px;padding:3px 8px}.project-date{font-size:1rem;font-weight:600;opacity:.8;white-space:nowrap}.project-media{padding:16px;border-bottom:1px solid rgba(255,255,255,.1);perspective:1000px;background:rgba(0,0,0,.1)}.project-images-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;width:100%;perspective:1000px}.project-screenshot{width:100%;border-radius:8px;object-fit:cover;aspect-ratio:16/9;box-shadow:0 2px 6px var(--color-black-alpha-15);border:2px solid var(--color-white-alpha-12);cursor:pointer}.project-screenshot:hover{box-shadow:0 8px 25px var(--color-black-alpha-30);border-color:var(--theme-accent)}.project-media>.project-screenshot{max-height:350px;width:100%;object-fit:contain;margin:0 auto;display:block}.project-content{padding:18px 20px;background:rgba(255,255,255,.02)}.project-description{color:var(--theme-text);line-height:1.6;margin:0 0 16px}.platform-icon{font-size:20px;flex-shrink:0;transition:var(--transition-normal);opacity:.8;filter:brightness(.9)}.project-link.secondary:hover .platform-icon,.project-link:hover .platform-icon{opacity:1;transform:scale(1.2);filter:brightness(1.2)}.project-link .platform-icon+*,.project-link.secondary .platform-icon+*{margin-left:0}.lightbox{display:none;position:fixed;z-index:1000;padding-top:50px;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:var(--color-black-alpha-90);backdrop-filter:blur(5px);opacity:0;transition:opacity .3s ease}.lightbox.active{display:block;opacity:1}.lightbox-content{position:relative;margin:auto;padding:0;width:90%;max-width:var(--container-max-width);display:flex;flex-direction:column;align-items:center}.lightbox-img{max-width:100%;max-height:80vh;object-fit:contain;box-shadow:0 4px 20px var(--color-black-alpha-30);border-radius:4px}.lightbox-close{position:absolute;top:-40px;right:0;color:#fff;font-size:35px;font-weight:700;cursor:pointer}.lightbox-controls{display:flex;justify-content:space-between;width:100%;position:absolute;top:50%;transform:translateY(-50%);pointer-events:none}.lightbox-nav{background:var(--color-black-alpha-50);color:#fff;border:0;border-radius:50%;width:50px;height:50px;font-size:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .3s;pointer-events:auto}.lightbox-nav:hover{background:var(--color-black-alpha-80)}.lightbox-caption{color:#fff;margin-top:16px;text-align:center;font-size:16px;padding:10px 0}a{color:var(--theme-accent);text-decoration:none;font-weight:500}a:hover{color:var(--theme-link-hover)}a:not(.project-link):not(.lang-button):not(.nav-link)::after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:linear-gradient(90deg,var(--theme-accent),var(--theme-link-hover));transition:width .3s ease}a:not(.project-link):not(.lang-button):not(.nav-link):hover::after{width:100%}@media (max-width:480px){.main-title,h1{font-size:32px}.container{padding:0 16px}.project-content{padding:16px}}.site-footer{width:100%;color:var(--theme-secondary);text-align:center;padding:10px 0 25px;z-index:2;user-select:none;font-weight:300}body.is-loading{overflow:hidden}body.is-loading #intro-content,body.is-loading .hologram-container,body.is-loading .main-title,body.is-loading .site-footer,body.is-loading header{opacity:0}