*{margin:0;padding:0;box-sizing:border-box}:root{font-family:SF Mono,Fira Code,Cascadia Code,Consolas,monospace;font-size:16px;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}.app{--bg-sky: linear-gradient(180deg, #e8f4f8 0%, #b8dff0 60%, #a8d4e6 100%);--bg-ground: #c8e6f0;--card-bg: #ffffffdd;--card-border: #e0e0e0;--header-bg: #4a4a4a;--header-text: #fff;--text-primary: #4a4a4a;--text-secondary: #7a7a7a;--accent: #f5a623;--faq-item-bg: #fdf5e6;--faq-item-hover: #fcecd0;--overlay-bg: rgba(0, 0, 0, .3);--shadow: 0 4px 20px rgba(0, 0, 0, .1)}.app.dark-mode{--bg-sky: linear-gradient(180deg, #1a1a2e 0%, #16213e 60%, #0f3460 100%);--bg-ground: #1a1a2e;--card-bg: #2a2a3edd;--card-border: #3a3a4e;--header-bg: #2a2a3e;--header-text: #e0e0e0;--text-primary: #e0e0e0;--text-secondary: #a0a0b0;--accent: #f5a623;--faq-item-bg: #2e2e40;--faq-item-hover: #3a3a50;--overlay-bg: rgba(0, 0, 0, .5);--shadow: 0 4px 20px rgba(0, 0, 0, .3)}.app{width:100vw;height:100vh;background:url(/assets/background-_8syOwd8.jpeg) center/cover no-repeat;position:relative;overflow:hidden}.app.dark-mode{background:url(/assets/darkmode_background-BNmCPGZV.jpeg) center/cover no-repeat}.top-controls{position:absolute;top:2vh;left:2vw;display:flex;gap:1.2vw;z-index:10}.icon-btn{background:none;border:none;cursor:pointer;font-size:28px;color:var(--text-primary);transition:transform .2s,color .3s;padding:4px;line-height:1}.icon-btn:hover{transform:scale(1.15)}.theme-icon{width:48px;height:48px;object-fit:contain}.star-character{position:absolute;top:calc(48% - 44vh);left:calc(53% - 28vw);animation:mascot-bounce 2s ease-in-out infinite;z-index:6;filter:drop-shadow(0 .6vh 1vh rgba(0,0,0,.12))}.mascot-img{width:15vw;max-width:160px;min-width:90px;height:auto;object-fit:contain}@keyframes mascot-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-1.5vh)}}.home-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54vw;max-width:90vw;height:65vh;background:var(--card-bg);border:2px solid #999;border-radius:10px;box-shadow:var(--shadow);overflow:hidden;z-index:5;transition:background .4s ease,border-color .4s ease}.home-header{background:var(--header-bg);color:var(--header-text);padding:2vh 2vw;font-size:1.1rem;font-weight:600;letter-spacing:.5px;text-transform:lowercase;border-bottom:2px solid #999;transition:background .4s ease,color .4s ease;display:flex;justify-content:space-between;align-items:center}.home-body{padding:11vh 4vw 6vh;text-align:center}.home-body h1{font-size:clamp(28px,4.5vw,56px);color:var(--text-primary);margin-bottom:6px;font-weight:400;transition:color .4s ease}.home-body h1 .name{font-weight:700;color:#94acdc}.home-body .subtitle{color:var(--text-secondary);font-size:clamp(14px,1.6vw,18px);margin-bottom:4vh;transition:color .4s ease}.nav-buttons{display:flex;justify-content:center;gap:32px;flex-wrap:wrap}.nav-btn{display:flex;flex-direction:column;align-items:center;gap:.9vh;background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:14px;transition:color .2s,transform .2s;padding:.2vh}.nav-btn:hover{color:var(--text-primary);transform:translateY(-2px)}.nav-btn .nav-icon{font-size:32px;line-height:1}.nav-icon-img{width:6vw;max-width:68px;height:auto;max-height:68px;object-fit:contain;transition:filter .4s ease}.app.dark-mode .nav-icon-img{filter:invert(1)}.nav-icon-skills{width:7vw;max-width:80px;height:auto;margin-bottom:0vh;margin-left:-1vw}.nav-icon-about{width:14vw;max-width:160px;margin-bottom:-.8vh;margin-top:-2.2vh;margin-left:-1vw}.nav-icon-img.nav-icon-about{width:clamp(56px,7.5vw,160px);max-width:none;max-height:none;height:auto;margin-bottom:-2vh;margin-top:-2.9vh;display:block;margin-left:-1vw}.nav-btn span:last-child{font-weight:500;font-size:16px;margin-left:-1vw}.terminal-toggle{background:none;border:1px solid #b0b8c8;color:#b0b8c8;font-family:inherit;font-size:12px;padding:2px 8px;border-radius:4px;cursor:pointer;transition:all .2s ease}.terminal-toggle{background:none;border:1px solid #b0b8c8;color:#b0b8c8;font-family:inherit;font-size:.9rem;padding:.3vh .8vw;border-radius:4px;cursor:pointer;transition:all .2s ease}.terminal-toggle:hover{color:#d0d8e8;border-color:#d0d8e8}.cli-body{padding:0!important;text-align:left!important;height:calc(100% - 55px)}.home-card.terminal-active{background:#1a1a2e}.home-card.terminal-active .home-header{background:#16213e;color:#0f0;border-bottom-color:#0f03}.home-card.terminal-active .terminal-toggle{color:#0f0;border-color:#0f06}.home-card.terminal-active .terminal-toggle:hover{border-color:#0f0}.cli-container{height:100%;display:flex;flex-direction:column;padding:16px;cursor:text;overflow:hidden}.cli-container{height:100%;display:flex;flex-direction:column;padding:1.2vh 1.2vw;cursor:text;overflow:hidden}.cli-output{flex:1;overflow-y:auto;padding-bottom:8px}.cli-line{margin-bottom:6px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.cli-input{color:#0f0;font-family:inherit;font-size:14px}.cli-output .cli-text{font-size:14px}.cli-prompt{color:#0f0;font-weight:700}.cli-input-line .cli-text,.cli-line.cli-input .cli-text{color:#0f0}.cli-line.cli-output .cli-text{color:#a8b2d1}.cli-line.cli-error .cli-text{color:#ff6b6b}.cli-input-row{display:flex;align-items:center;gap:0;border-top:1px solid #0f03;padding-top:8px}.cli-input{background:none;border:none;outline:none;color:#0f0;font-family:inherit;font-size:14px;flex:1;caret-color:#0f0}.popup-panel{position:fixed;width:70%;max-width:90vw;max-height:80vh;background:var(--card-bg);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;animation:pop-in .2s ease;display:flex;flex-direction:column;border:2px solid #999;transition:background .4s ease,border-color .4s ease;z-index:50}@keyframes pop-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.popup-header{background:var(--header-bg);color:var(--header-text);padding:12px 20px;border-bottom:2px solid #999;display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:600;letter-spacing:.5px;text-transform:lowercase;transition:background .4s ease,color .4s ease;cursor:grab;-webkit-user-select:none;user-select:none}.popup-header{border-bottom:2px solid #999}.popup-header:active{cursor:grabbing}.close-btn{background:none;border:none;color:var(--header-text);cursor:pointer;font-size:14px;font-weight:700;font-family:monospace;padding:2px 6px;transition:opacity .2s,color .4s ease}.close-btn:hover{opacity:.7}.popup-body{padding:24px;overflow-y:auto;color:var(--text-primary);transition:color .4s ease}.popup-body{padding:2.5vh 2vw;overflow-y:auto;color:var(--text-primary);transition:color .4s ease}.about-content{text-align:center}.skill-group{margin-bottom:16px}.skill-group:last-child{margin-bottom:0}.projects-content{padding:6px 4px}.projects-table{display:flex;flex-direction:column;gap:1.2vh}.project-row{background:var(--card-bg);border:1px solid rgba(0,0,0,.06);border-radius:10px;padding:1vh;display:flex;flex-direction:column;gap:.8vh}.project-top{display:flex;align-items:center;gap:1vw}.project-left{display:flex;flex-direction:column}.project-title{font-weight:700;font-size:16px;color:var(--text-primary)}.project-tech{font-size:13px;color:var(--text-secondary)}.project-right{margin-left:auto;display:flex;align-items:center;gap:10px}.project-period{font-size:clamp(12px,1.2vw,14px);color:var(--text-secondary)}.github-btn{background:#cfc0d1;color:#2a2a2a;padding:6px 10px;border-radius:6px;text-decoration:none;font-weight:600;font-size:13px}.github-btn:hover{opacity:.9}.project-desc{color:var(--text-secondary);font-size:clamp(13px,1.2vw,14px)}.experience-content{display:flex;flex-direction:column;gap:10px}.experience-item{background:var(--card-bg);border-radius:10px;padding:1vh;border:1px solid var(--card-border)}.exp-toggle{width:100%;background:none;border:none;display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:0}.exp-main{display:flex;gap:.6vh;align-items:baseline;flex-wrap:wrap}.exp-index{font-weight:700;color:var(--text-secondary);margin-right:1vw}.exp-company{font-weight:400;color:var(--text-secondary)}.exp-role{font-weight:800;color:var(--text-primary);margin-left:6px}.exp-period{margin-left:1vw;color:var(--text-secondary);font-size:clamp(12px,1.1vw,13px)}.exp-chevron{transition:transform .25s}.exp-chevron.open{transform:rotate(180deg)}.exp-details{margin-top:1vh;color:var(--text-secondary)}.exp-details ul{margin:6px 0 0 3vw}.exp-location{font-size:13px;color:var(--text-secondary)}.about-content .about-avatar{font-size:5vw;margin-bottom:1.2vh}.about-content h2{font-size:clamp(18px,2.2vw,22px);margin-bottom:1.2vh;color:var(--text-primary)}.about-content p{color:var(--text-secondary);line-height:1.7;font-size:15px}.links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:20px;padding:10px}.link-item{display:flex;flex-direction:column;align-items:center;gap:10px;text-decoration:none;color:var(--text-primary);padding:16px 8px;border-radius:12px;transition:background .2s,transform .2s,color .4s ease}.link-item:hover{background:var(--faq-item-bg);transform:translateY(-2px)}.link-item .link-icon{font-size:40px}.link-item img.link-icon{width:10vw;max-width:100px;height:auto;object-fit:contain;transition:filter .4s ease}.app.dark-mode .link-item img.link-icon{filter:invert(1)}.link-item span:last-child{font-size:13px;font-weight:500}.faq-list{display:flex;flex-direction:column;gap:8px}.faq-item{background:var(--faq-item-bg);border-radius:10px;overflow:hidden;transition:background .4s ease}.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:none;border:none;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-primary);text-align:left;transition:background .2s,color .4s ease}.faq-question:hover{background:var(--faq-item-hover)}.faq-chevron{font-size:18px;transition:transform .3s ease;flex-shrink:0;color:var(--text-secondary)}.faq-chevron.open{transform:rotate(180deg)}.faq-answer{padding:0 18px 14px;font-size:14px;color:var(--text-secondary);line-height:1.6;animation:expand .2s ease;transition:color .4s ease}@keyframes expand{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.gallery-item{background:var(--faq-item-bg);border-radius:12px;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:48px;transition:transform .2s,background .4s ease;cursor:pointer}.gallery-item:hover{transform:scale(1.03)}.footer{position:absolute;bottom:2vh;left:50%;transform:translate(-50%);text-align:center;z-index:6}.footer-icons{display:flex;gap:16px;justify-content:center;margin-bottom:6px}.footer-icons a{text-decoration:none;opacity:.7;transition:opacity .2s}.footer-icons a:hover{opacity:1}.footer-icon-img{width:4vw;max-width:44px;height:auto;object-fit:contain;transition:filter .4s ease}.app.dark-mode .footer-icon-img{filter:invert(1)}.footer-icon-img.footer-icon-sm{width:3vw;max-width:30px;height:auto;position:relative;top:.6vh}.footer p{font-size:12px;color:var(--text-secondary);transition:color .4s ease}.frog-character{position:absolute;bottom:0;right:3vw;z-index:4;filter:drop-shadow(0 .4vh .8vh rgba(0,0,0,.1))}.frog-img{width:12vw;max-width:170px;height:auto;object-fit:contain}@media(max-width:500px){.home-card{width:90vw}.popup-panel{width:95vw}.links-grid,.gallery-grid{grid-template-columns:repeat(2,1fr)}}
