.app{min-height:100vh;display:flex}.content-hidden{opacity:0;pointer-events:none;visibility:hidden}.content-visible{visibility:visible;animation:content-fade-in .8s ease-out forwards}@keyframes content-fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.sidebar{position:fixed;left:0;top:0;height:100vh;width:260px;background:linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);padding:1.5rem 1rem;display:flex;flex-direction:column;z-index:100;box-shadow:2px 0 10px #0000000d}.sidebar-header{margin-bottom:3rem;padding-bottom:1.5rem}.sidebar-logo{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 50%,var(--primary-color) 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.75rem;animation:gradient-shift 3s ease infinite;filter:brightness(1.2) saturate(1.3)}.sidebar-subtitle{font-size:.9rem;color:var(--text-secondary);line-height:1.5;margin:0}.sidebar-subtitle{margin-top:.5rem;min-height:1.5rem;display:flex;align-items:center}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem;flex:1;overflow-x:hidden}.sidebar-link{color:var(--text-secondary);text-decoration:none;font-weight:500;padding:1rem 1.25rem;border-radius:8px;position:relative;overflow:hidden;transition:all .3s ease;display:flex;align-items:center;font-size:1rem}.sidebar-link:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);height:0;width:3px;background:linear-gradient(180deg,var(--primary-color),var(--secondary-color));border-radius:0 3px 3px 0;transition:all .3s ease}.sidebar-link:hover{color:var(--text-primary);transform:translate(8px)}.sidebar-link:hover:before{transform:translateY(-50%) scaleY(1);height:60%}.sidebar-link.active{color:var(--primary-color);font-weight:600;transform:translate(8px)}.sidebar-link.active:before{transform:translateY(-50%) scaleY(1);height:80%;width:4px}.sidebar-link-text{position:relative;z-index:1;transition:transform .3s ease}.sidebar-link:hover .sidebar-link-text{transform:translate(3px)}.content-wrapper{margin-left:260px;flex:1;display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:4rem 2rem}.footer{background-color:var(--bg-secondary);padding:2rem;text-align:center;color:var(--text-secondary);border-top:1px solid var(--border-color)}@media(max-width:768px){.sidebar{width:200px;padding:1rem .75rem}.sidebar-header{margin-bottom:1rem;padding-bottom:1rem}.sidebar-logo{font-size:1.1rem}.sidebar-subtitle{font-size:.75rem}.sidebar-link{padding:.6rem .75rem;font-size:.85rem}.sidebar-nav{gap:.25rem}.content-wrapper{margin-left:200px}.main-content{padding:2rem 1rem}}@media(max-width:640px){.sidebar{position:fixed;left:-200px;transition:left .3s ease}.sidebar.open{left:0}.content-wrapper{margin-left:0}}.about-section{margin-bottom:6rem;padding:2rem 0}.about-container,.about-content{width:100%}.section-title{font-size:2.5rem;font-weight:700;margin-bottom:2rem;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 50%,var(--primary-color) 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:brightness(1.2) saturate(1.3);animation:gradient-shift 3s ease infinite}.about-text{font-size:1.1rem;line-height:1.8;color:var(--text-primary)}.about-text p{margin-bottom:1.5rem}.about-text p:last-child{margin-bottom:0}.tech-stack{margin-top:2.5rem}.tech-stack-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.tech-stack-tags{display:flex;flex-wrap:wrap;gap:.75rem}.tech-tag{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;transition:transform .2s ease,box-shadow .2s ease}.tech-tag:hover{transform:translateY(-2px);box-shadow:0 4px 8px #3b82f64d}@media(max-width:768px){.about-section{margin-bottom:4rem;padding:1rem 0}.section-title{font-size:2rem}.about-text{font-size:1rem}.tech-stack{margin-top:2rem}.tech-stack-title{font-size:1.1rem}.tech-tag{font-size:.85rem;padding:.4rem .8rem}}.experience-section{margin-bottom:6rem;padding:4rem 0}.experience-list{display:flex;flex-direction:column;gap:2rem}.experience-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;padding:2rem;box-shadow:var(--shadow);transition:transform .3s ease,box-shadow .3s ease}.experience-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.experience-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.experience-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.experience-company{font-size:1.1rem;color:var(--primary-color);font-weight:500}.experience-meta{text-align:right}.experience-location{color:var(--text-secondary);font-size:.95rem;margin-bottom:.25rem}.experience-period{color:var(--text-secondary);font-size:.95rem;font-weight:500}.experience-description{list-style:none;padding-left:0}.experience-description li{position:relative;padding-left:1.5rem;margin-bottom:.75rem;color:var(--text-primary);line-height:1.6}.experience-description li:before{content:"▹";position:absolute;left:0;color:var(--primary-color);font-weight:700}.experience-description li:last-child{margin-bottom:0}@media(max-width:768px){.experience-section{margin-bottom:4rem;padding:2rem 0}.experience-card{padding:1.5rem}.experience-header{flex-direction:column}.experience-meta{text-align:left}.experience-title{font-size:1.25rem}}.projects-section{margin-bottom:6rem;padding:4rem 0}.projects-grid{display:grid;grid-template-columns:1fr;gap:2rem}.project-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;padding:2rem;box-shadow:var(--shadow);transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:row;gap:2rem}.project-image-container{flex-shrink:0;width:300px;display:flex;align-items:center;justify-content:center}.project-image{width:100%;height:auto;max-height:400px;object-fit:contain;border-radius:12px;border:1px solid var(--border-color)}.project-content{flex:1;display:flex;flex-direction:column}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.project-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.project-description{color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem;flex:1}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.tech-tag{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;padding:.4rem .8rem;border-radius:20px;font-size:.85rem;font-weight:500}.project-links{display:flex;gap:1rem;margin-top:auto;padding-top:1rem}.project-link{text-decoration:none;font-weight:500;padding:.6rem 1.2rem;border-radius:8px;transition:all .3s ease;font-size:.9rem;display:inline-flex;align-items:center;gap:.5rem}.project-link-primary{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;border:2px solid transparent}.project-link-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.project-link-secondary{color:var(--primary-color);border:2px solid var(--primary-color);background:transparent}.project-link-secondary:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px)}@media(max-width:768px){.projects-section{margin-bottom:4rem;padding:2rem 0}.projects-grid{grid-template-columns:1fr}.project-card{padding:1.5rem;flex-direction:column}.project-image-container{width:100%}.project-image{min-height:200px}}.resume-section{margin-bottom:6rem;padding:2rem 0}.resume-description{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.resume-container{width:100%}.resume-embed{width:100%;height:800px;margin-bottom:2rem;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--border-color)}.resume-pdf{width:100%;height:100%;border:none}.resume-download{display:flex;justify-content:center}.download-button{display:inline-block;padding:1rem 2rem;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:all .3s ease;box-shadow:var(--shadow)}.download-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);filter:brightness(1.1)}@media(max-width:768px){.resume-section{margin-bottom:4rem;padding:1rem 0}.resume-embed{height:600px}}.minigames-section{margin-bottom:6rem;padding:2rem 0}.minigames-intro{margin-bottom:2.5rem}.minigames-intro p{font-size:1.1rem;line-height:1.8;color:var(--text-secondary)}.minigames-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem}.minigame-link{text-decoration:none;color:inherit;display:block}.minigame-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;padding:2rem;box-shadow:var(--shadow);transition:transform .3s ease,box-shadow .3s ease;height:100%;display:flex;flex-direction:column}.minigame-link:hover .minigame-card{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}.minigame-image{width:100%;height:200px;object-fit:cover;border-radius:12px;margin-bottom:1.5rem;border:1px solid var(--border-color)}.minigame-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.minigame-description{font-size:1rem;line-height:1.6;color:var(--text-primary);margin-bottom:1.5rem;flex:1}.minigame-features{list-style:decimal;padding-left:1.5rem;margin:0}.minigame-features li{font-size:.9rem;line-height:1.6;color:var(--text-secondary);margin-bottom:.75rem}.minigame-features li:last-child{margin-bottom:0}@media(max-width:768px){.minigames-section{margin-bottom:4rem;padding:1rem 0}.minigames-grid{grid-template-columns:1fr;gap:1.5rem}.minigame-card{padding:1.5rem}.minigame-image{height:150px}.minigames-intro p{font-size:1rem}}.theme-toggle-container{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:auto;padding-top:1rem;padding-bottom:1rem;flex-shrink:0}.theme-label{font-size:.875rem;color:var(--text-secondary);font-weight:500;transition:color .3s ease}.theme-toggle{position:relative;width:50px;height:26px;background:var(--bg-accent);border:2px solid var(--border-color);border-radius:26px;cursor:pointer;transition:all .3s ease;outline:none;padding:0}.theme-toggle:hover{border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.theme-toggle.dark{background:transparent;border-color:var(--primary-color)}.theme-toggle-slider{position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .3s ease;box-shadow:0 2px 4px #0003;transform:translate(24px)}.theme-toggle.dark .theme-toggle-slider{transform:translate(0)}@media(max-width:640px){.theme-toggle-container{margin-top:1.5rem;padding-top:1.5rem}.theme-toggle{width:44px;height:24px}.theme-toggle-slider{width:16px;height:16px;transform:translate(20px)}.theme-toggle.dark .theme-toggle-slider{transform:translate(0)}}.typing-name{display:inline-block}.typing-cursor{display:inline-block;margin-left:2px;color:var(--primary-color);font-weight:300;animation:blink 1s infinite;opacity:0;transition:opacity .1s ease}.typing-cursor.visible{opacity:1}.splash-screen{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(180deg,#fdf6ff,#f0e6ff,#e8d5f5);display:flex;align-items:center;justify-content:center;z-index:9999;overflow:hidden}.splash-screen:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(224,64,251,.1) 0%,transparent 70%),radial-gradient(ellipse at 20% 80%,rgba(0,188,212,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(224,64,251,.08) 0%,transparent 50%);pointer-events:none}:root.dark .splash-screen{background:linear-gradient(180deg,#0a0a0a,#1a0a2e,#0a0a0a)}:root.dark .splash-screen:before{background:radial-gradient(ellipse at center,rgba(138,43,226,.15) 0%,transparent 70%),radial-gradient(ellipse at 20% 80%,rgba(0,255,255,.1) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(255,0,255,.1) 0%,transparent 50%)}.scanlines{position:absolute;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(0deg,rgba(0,0,0,.15),rgba(0,0,0,.15) 1px,transparent 1px,transparent 2px);pointer-events:none}.splash-content{text-align:center;z-index:1;padding:2rem;display:flex;flex-direction:column;align-items:center;justify-content:center}.splash-text{margin-bottom:3rem}.splash-greeting{font-family:"Press Start 2P",cursive;font-size:1.5rem;color:#00bcd4;text-shadow:0 0 10px rgba(0,188,212,.5),0 0 20px rgba(0,188,212,.3);margin-bottom:1.5rem;animation:flicker 3s infinite}.splash-question{font-family:"Press Start 2P",cursive;font-size:.9rem;color:#2d1b4e;line-height:2;margin-bottom:1rem}.splash-name{font-family:"Press Start 2P",cursive;font-size:2.5rem;background:linear-gradient(90deg,#e040fb,#00bcd4,#e040fb);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradient-shift 3s ease infinite,glow-pulse-light 2s ease-in-out infinite;filter:drop-shadow(0 0 15px rgba(224,64,251,.4));margin-bottom:.5rem}.splash-subtitle{font-family:"Press Start 2P",cursive;font-size:2rem;color:#2d1b4e}:root.dark .splash-greeting{color:#0ff;text-shadow:0 0 10px #00ffff,0 0 20px #00ffff,0 0 40px #00ffff}:root.dark .splash-question{color:#fff}:root.dark .splash-name{filter:drop-shadow(0 0 20px rgba(255,0,255,.5));animation:gradient-shift 3s ease infinite,glow-pulse 2s ease-in-out infinite}:root.dark .splash-subtitle{color:#fff}@keyframes glow-pulse-light{0%,to{filter:drop-shadow(0 0 15px rgba(224,64,251,.4))}50%{filter:drop-shadow(0 0 25px rgba(224,64,251,.6))}}@keyframes gradient-shift{0%,to{background-position:0% center}50%{background-position:100% center}}@keyframes glow-pulse{0%,to{filter:drop-shadow(0 0 20px rgba(255,0,255,.5))}50%{filter:drop-shadow(0 0 40px rgba(255,0,255,.8))}}@keyframes flicker{0%,to{opacity:1}92%{opacity:1}93%{opacity:.8}94%{opacity:1}95%{opacity:.9}96%{opacity:1}}.start-button{font-family:"Press Start 2P",cursive;background:linear-gradient(180deg,#f0e6ff,#e8d5f5);border:3px solid #e040fb;color:#2d1b4e;padding:1.5rem 3rem;cursor:pointer;position:relative;overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.5rem;box-shadow:0 0 10px #e040fb4d,0 0 20px #e040fb33,inset 0 0 20px #e040fb0d}.start-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(224,64,251,.2),transparent);transition:left .5s ease}.start-button:hover:before{left:100%}.start-button:hover{transform:scale(1.05);border-color:#00bcd4;box-shadow:0 0 20px #00bcd480,0 0 40px #00bcd44d,inset 0 0 30px #00bcd41a}.start-button:active{transform:scale(.98)}:root.dark .start-button{background:linear-gradient(180deg,#2a0a4a,#1a0a2e);border-color:#f0f;color:#fff;box-shadow:0 0 10px #ff00ff80,0 0 20px #ff00ff4d,inset 0 0 20px #ff00ff1a}:root.dark .start-button:hover{border-color:#0ff;box-shadow:0 0 20px #00ffffb3,0 0 40px #0ff6,inset 0 0 30px #0ff3}.button-text{font-size:1.2rem;letter-spacing:2px}.button-subtext{font-size:.6rem;opacity:.7;letter-spacing:1px}.splash-hint{font-family:"Press Start 2P",cursive;font-size:.7rem;color:#00bcd4;margin-top:2rem;opacity:.8}:root.dark .splash-hint{color:#0ff}.scanlines{opacity:.15}:root.dark .scanlines{opacity:.3}.blink{animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.splash-screen.fade-out{animation:splash-fade-out .8s ease-out forwards}@keyframes splash-fade-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.1)}}@media(max-width:768px){.splash-greeting{font-size:1rem}.splash-question{font-size:.7rem}.splash-name,.splash-subtitle{font-size:1.5rem}.button-text{font-size:.9rem}.start-button{padding:1rem 2rem}}@media(max-width:480px){.splash-greeting{font-size:.8rem}.splash-question{font-size:.6rem}.splash-name,.splash-subtitle{font-size:1.2rem}.button-text{font-size:.7rem}}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}:root{--primary-color: #e040fb;--secondary-color: #00bcd4;--text-primary: #2d1b4e;--text-secondary: #6b5b7a;--bg-primary: #fdf6ff;--bg-secondary: #f0e6ff;--bg-accent: #e8d5f5;--border-color: #d4b8e8;--shadow: 0 4px 6px -1px rgba(224, 64, 251, .15), 0 2px 4px -1px rgba(0, 188, 212, .1);--shadow-lg: 0 10px 15px -3px rgba(224, 64, 251, .15), 0 4px 6px -2px rgba(0, 188, 212, .1);--glow-primary: 0 0 8px rgba(224, 64, 251, .4), 0 0 16px rgba(224, 64, 251, .2);--glow-secondary: 0 0 8px rgba(0, 188, 212, .4), 0 0 16px rgba(0, 188, 212, .2)}:root.dark{--primary-color: #ff00ff;--secondary-color: #00ffff;--text-primary: #f1f5f9;--text-secondary: #a0a0c0;--bg-primary: #0a0a0a;--bg-secondary: #1a0a2e;--bg-accent: #2a1a4a;--border-color: #4a2a6a;--shadow: 0 4px 6px -1px rgba(255, 0, 255, .2), 0 2px 4px -1px rgba(0, 255, 255, .1);--shadow-lg: 0 10px 15px -3px rgba(255, 0, 255, .2), 0 4px 6px -2px rgba(0, 255, 255, .1);--glow-primary: 0 0 10px rgba(255, 0, 255, .5), 0 0 20px rgba(255, 0, 255, .3);--glow-secondary: 0 0 10px rgba(0, 255, 255, .5), 0 0 20px rgba(0, 255, 255, .3)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-primary);background-color:var(--bg-primary);line-height:1.6;transition:background-color .3s ease,color .3s ease}*{transition:background-color .3s ease,border-color .3s ease,color .3s ease}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.about-section,.experience-section,.projects-section,.minigames-section,.resume-section{opacity:0;transform:translate(-50px)}.about-section.zoom-in,.experience-section.zoom-in,.projects-section.zoom-in,.minigames-section.zoom-in,.resume-section.zoom-in{animation:slideInFromLeft .6s ease-out forwards}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}h1,h2,.section-title{font-family:"Press Start 2P",cursive;letter-spacing:1px}.section-title{text-shadow:var(--glow-primary)}body:after{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(0deg,rgba(0,0,0,.02),rgba(0,0,0,.02) 1px,transparent 1px,transparent 2px);pointer-events:none;z-index:9998;opacity:.3}:root.dark body:after{opacity:.5}
