*{margin:0;padding:0;box-sizing:border-box}body{background:#0b0b0c;color:#e0e0e0;font-family:Courier New,monospace;overflow-x:hidden}*{scrollbar-width:thin;scrollbar-color:rgba(0,170,255,.3) transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:transparent;border-left:1px solid rgba(0,170,255,.1)}*::-webkit-scrollbar-thumb{background:#0af3;border:1px solid rgba(0,170,255,.4);border-radius:2px;transition:all .3s ease}*::-webkit-scrollbar-thumb:hover{background:#0af6;border-color:#0af9;box-shadow:0 0 8px #00aaff4d}*::-webkit-scrollbar-thumb:active{background:#00aaff80}.hero{min-height:100vh;display:flex;align-items:center;justify-content:flex-start;position:relative;z-index:10;transition:opacity .3s ease;padding-left:20vw;padding-right:5vw;pointer-events:auto}.text-area{max-width:500px;padding:0;text-align:left;position:relative;z-index:20}.name{font-family:Courier New,monospace;font-size:clamp(2.5rem,5vw,4rem);font-weight:400;letter-spacing:.02em;margin-bottom:1rem;color:#fff;text-shadow:0 0 20px rgba(0,170,255,.2);position:relative;cursor:pointer;transition:all .3s ease}.korean-name-tooltip{position:fixed;pointer-events:none;font-family:Courier New,Consolas,Monaco,monospace;font-size:clamp(1.2rem,2.5vw,1.8rem);font-weight:400;letter-spacing:.1em;color:#fff;text-shadow:0 0 20px rgba(0,170,255,.4);z-index:1000;transform:translate(-50%,-100%);white-space:nowrap;opacity:1;transition:opacity .2s ease;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges}.tagline{font-size:clamp(.95rem,1.5vw,1.1rem);line-height:1.8;color:#a0a0a0;margin-bottom:2.5rem;font-weight:400;font-family:Times New Roman,serif}.description{font-size:clamp(.9rem,1.3vw,1rem);line-height:2;color:#a0a0a0;margin-bottom:2.5rem;font-family:Times New Roman,serif}.description p{margin-bottom:.3rem;position:relative;padding-left:1.2rem}.description p:before{content:"▸";position:absolute;left:0;color:#a0a0a0;font-size:.85em}.description a{color:#e0e0e0;text-decoration:underline;text-decoration-color:#00aaff4d;text-underline-offset:4px;position:relative;transition:color .3s ease,text-decoration-color .3s ease}.description a:hover{color:#0af;text-decoration-color:#0afc}.links{display:flex;gap:1.5rem;justify-content:flex-start;flex-wrap:wrap;font-family:Courier New,monospace}.links a{color:#e0e0e0;text-decoration:underline;text-decoration-color:#00aaff4d;text-underline-offset:4px;position:relative;transition:color .3s ease,text-decoration-color .3s ease;font-size:clamp(.9rem,1.2vw,1rem)}.links a:hover{color:#0af;text-decoration-color:#0afc}.projects-section{min-height:100vh;padding:8rem 8vw;position:relative;z-index:10;opacity:0;transform:translateY(50px);transition:opacity .8s ease,transform .8s ease}.projects-section.visible{opacity:1;transform:translateY(0)}.projects-title{font-family:Times New Roman,Times,serif;font-size:clamp(2.5rem,5vw,3.5rem);margin-bottom:3rem;color:#fff;text-align:center;text-shadow:0 0 30px rgba(0,170,255,.3);font-weight:400;letter-spacing:.05em}.projects-tabs{display:flex;justify-content:center;align-items:center;gap:0;margin-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.1);max-width:1400px;margin-left:auto;margin-right:auto;padding:0 2rem}.projects-tab{flex:0 0 auto;padding:1rem 2.5rem;background:transparent;border:none;border-bottom:2px solid transparent;color:#fff9;font-family:Times New Roman,Times,serif;font-size:clamp(1rem,2vw,1.2rem);font-weight:400;cursor:pointer;transition:all .3s ease;position:relative;letter-spacing:.05em;text-transform:uppercase}.projects-tab:hover{color:#ffffffe6}.projects-tab.active{color:#fff;border-bottom-color:#0afc;text-shadow:0 0 20px rgba(0,170,255,.4)}.projects-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:#0afc;box-shadow:0 0 10px #0af9}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;max-width:1400px;margin:0 auto}.project-card-thumbnail{width:100%;aspect-ratio:1;overflow:hidden;background:#14141966;border:none;transition:all .3s ease;cursor:pointer;position:relative}.project-card-thumbnail:hover{border-color:#00aaff80;transform:scale(1.02);box-shadow:0 4px 16px #0055ff4d;z-index:1}.project-gif-thumbnail{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.project-card-thumbnail:hover .project-gif-thumbnail{transform:scale(1.05)}.project-gif-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#0000004d;color:#a0a0a0;font-size:.9rem}.project-card-title-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#0009;opacity:0;transition:all .3s ease;pointer-events:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.project-card-thumbnail:hover .project-card-title-overlay{opacity:1}.project-card-overlay-content{text-align:center;padding:1.5rem;max-width:90%}.project-card-title-overlay h3{font-family:Times New Roman,Times,serif;font-size:clamp(1.1rem,2.5vw,1.5rem);color:#fff;margin:0 0 .8rem;text-align:center;font-weight:400;letter-spacing:.05em;text-shadow:0 2px 10px rgba(0,0,0,.8);line-height:1.3}.project-card-title-overlay p{font-family:Times New Roman,Times,serif;font-size:clamp(.75rem,1.5vw,.95rem);color:#ffffffe6;margin:0;text-align:center;line-height:1.4;text-shadow:0 1px 5px rgba(0,0,0,.8);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card{background:#14141966;border:1px solid rgba(0,85,255,.2);border-radius:8px;padding:2.5rem;margin-bottom:2rem;display:flex;flex-direction:column;transition:all .4s ease;position:relative;overflow:visible;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.project-card-header{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;width:100%;position:relative;overflow:hidden}.project-header-right{display:flex;align-items:center;gap:1rem}.project-card-header:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(0,85,255,.15),transparent 60%);opacity:0;transition:opacity .3s ease;pointer-events:none}.project-card-header:hover:before{opacity:1}.project-card:not(.expanded):hover{border-color:#00aaff80;transform:translateY(-4px);box-shadow:0 8px 32px #05f3;background:#14141999}.project-card.expanded{border-color:#00aaff80;background:#14141999;box-shadow:0 8px 32px #05f3;overflow:visible}.project-card-expanded{margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(0,170,255,.2);animation:expandDown .4s ease;opacity:1}@keyframes expandDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.project-content h3{font-family:Georgia,serif;font-size:1.8rem;margin-bottom:.8rem;color:#fff}.project-content p{color:#a0a0a0;line-height:1.6}.project-icon{width:80px;height:80px}.project-expand-toggle{width:36px;height:36px;border-radius:50%;background:#00aaff14;border:1px solid rgba(0,170,255,.25);color:#0af;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0;position:relative;z-index:10;animation:subtlePulse 3s ease-in-out infinite}@keyframes subtlePulse{0%,to{opacity:.7;box-shadow:0 0 #0af3}50%{opacity:1;box-shadow:0 0 0 4px #0af0}}.project-expand-toggle:hover{background:#00aaff26;border-color:#00aaff80;color:#0cf;transform:scale(1.05);box-shadow:0 2px 8px #00aaff40}.project-expand-toggle:active{transform:scale(.98)}.project-card.expanded .project-expand-toggle{background:#00aaff1f;border-color:#0af6;animation:none}.project-card.expanded .project-expand-toggle:hover{background:#00aaff2e;transform:scale(1.05)}.project-expand-toggle svg{width:20px;height:20px;transition:transform .3s ease}.project-expand-toggle svg.expanded{transform:rotate(180deg)}.mindmap-section{width:85%;max-width:90vw;height:100vh;margin:0 auto;position:relative;overflow:hidden}.mindmap-title{font-size:2.5rem;font-weight:700;color:#e0e0e0;margin-bottom:1.5rem;text-align:left;font-family:Courier New,monospace;opacity:1!important;visibility:visible!important;display:block!important;position:relative;z-index:100}.mindmap-subtitle{margin-bottom:2rem;text-align:left;opacity:1!important;visibility:visible!important;display:block!important;position:relative;z-index:100}.mindmap-subtitle p{font-size:1.3rem;line-height:1.5;color:#94a3b8;margin-bottom:.3rem;font-weight:300;font-family:Times New Roman,serif;letter-spacing:.3px;opacity:.85;transition:opacity .3s ease}.mindmap-subtitle p:hover{opacity:1;color:#cbd5e1}.mindmap-container{position:relative;width:100%;height:100vh;margin:0;padding:0;cursor:grab;transition:opacity .8s ease;z-index:15;background:transparent;opacity:0;transform:translateY(30px);overflow:hidden}.mindmap-container.visible{opacity:1;transform:translateY(0)}.mindmap-container.visible:hover{transform:translateY(0) scale(1.02)}.mindmap-image{width:100%;max-width:1000px;height:auto;max-height:80vh;object-fit:contain;border-radius:8px;box-shadow:0 8px 32px #05f3;border:1px solid rgba(0,170,255,.3)}.mindmap-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0000004d;border-radius:8px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.mindmap-container:hover .mindmap-overlay{opacity:1}.mindmap-hint{color:#fff;font-family:Courier New,monospace;font-size:1.2rem;text-shadow:0 0 10px rgba(0,170,255,.8)}.mindmap-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000fa;z-index:1000;display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;animation:fadeIn .3s ease;overflow:hidden}.mindmap-modal-content{position:relative;width:100vw;height:100vh;cursor:default;display:flex;align-items:center;justify-content:center}.mindmap-modal-image{width:100vw;height:100vh;object-fit:contain;box-shadow:0 8px 64px #0af6}.mindmap-close{position:fixed;top:2rem;right:2rem;background:#00000080;border:1px solid rgba(0,170,255,.5);border-radius:50%;color:#fff;font-size:2.5rem;cursor:pointer;width:50px;height:50px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;text-shadow:0 0 10px rgba(0,170,255,.8);z-index:1001;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mindmap-close:hover{transform:scale(1.2);background:#00aaff4d;border-color:#0afc}.project-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000f2;z-index:1001;display:flex;align-items:center;justify-content:center;padding:2rem;cursor:pointer;animation:fadeIn .3s ease;overflow-y:auto}.project-modal-content{position:relative;width:90vw;max-width:1200px;max-height:90vh;cursor:default;background:#141419f2;border-radius:12px;padding:3rem;border:1px solid rgba(0,170,255,.3);box-shadow:0 8px 64px #0af3;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(0,170,255,.5) transparent}.project-modal-content::-webkit-scrollbar{width:12px}.project-modal-content::-webkit-scrollbar-track{background:transparent;border-left:1px solid rgba(0,170,255,.2)}.project-modal-content::-webkit-scrollbar-thumb{background:transparent;border:1px solid rgba(0,170,255,.5);border-radius:0;box-shadow:inset 0 0 0 1px #00aaff4d,0 0 8px #0af3;transition:all .3s ease}.project-modal-content::-webkit-scrollbar-thumb:hover{border-color:#0afc;box-shadow:inset 0 0 0 1px #00aaff80,0 0 12px #0af6}.project-modal-content::-webkit-scrollbar-thumb:active{background:#00aaff1a}.project-modal::-webkit-scrollbar{width:12px}.project-modal::-webkit-scrollbar-track{background:transparent;border-left:1px solid rgba(0,170,255,.2)}.project-modal::-webkit-scrollbar-thumb{background:transparent;border:1px solid rgba(0,170,255,.5);border-radius:0;box-shadow:inset 0 0 0 1px #00aaff4d,0 0 8px #0af3;transition:all .3s ease}.project-modal::-webkit-scrollbar-thumb:hover{border-color:#0afc;box-shadow:inset 0 0 0 1px #00aaff80,0 0 12px #0af6}.project-modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:#fff;font-size:3rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease;text-shadow:0 0 10px rgba(0,170,255,.8);z-index:10}.project-modal-close:hover{transform:scale(1.2)}.project-modal-header{margin-bottom:2rem}.project-modal-header h2{font-family:Times New Roman,serif;font-size:2.5rem;color:#fff;margin-bottom:1rem;text-shadow:0 0 20px rgba(0,170,255,.3)}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.tech-tag{padding:.4rem 1rem;background:#0af3;border:1px solid rgba(0,170,255,.4);border-radius:20px;color:#0af;font-family:Courier New,monospace;font-size:.9rem;transition:all .3s ease}.tech-tag:hover{background:#00aaff4d;border-color:#0af9}.project-card-technologies{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1rem}.tech-tag-small{padding:.3rem .8rem;background:#00aaff26;border:1px solid rgba(0,170,255,.3);border-radius:15px;color:#0af;font-family:Courier New,monospace;font-size:.75rem}.project-long-description,.project-long-description-markdown{font-family:Times New Roman,serif;font-size:1.1rem;line-height:1.8;color:#a0a0a0;margin-bottom:2rem}.project-long-description-markdown p{margin-bottom:1rem;color:#a0a0a0}.project-long-description-markdown h2{font-family:Times New Roman,serif;font-size:1.5rem;color:#fff;margin-top:2rem;margin-bottom:1rem;font-weight:400}.project-long-description-markdown h3{font-family:Times New Roman,serif;font-size:1.3rem;color:#e0e0e0;margin-top:1.5rem;margin-bottom:.8rem;font-weight:400}.project-long-description-markdown ul,.project-long-description-markdown ol{margin-left:2rem;margin-bottom:1rem;color:#a0a0a0}.project-long-description-markdown li{margin-bottom:.5rem}.project-long-description-markdown code{font-family:Courier New,monospace;background:#00aaff1a;padding:.2rem .4rem;border-radius:3px;color:#0af;font-size:.9em}.project-long-description-markdown pre{background:#14141999;padding:1rem;border-radius:5px;overflow-x:auto;margin-bottom:1rem;border:1px solid rgba(0,170,255,.2)}.project-long-description-markdown pre code{background:transparent;padding:0;color:#a0a0a0}.project-long-description-markdown strong{color:#e0e0e0;font-weight:600}.project-long-description-markdown em{font-style:italic;color:#b0b0b0}.project-long-description-markdown a{color:#0af;text-decoration:none;border-bottom:1px solid rgba(0,170,255,.3);transition:all .3s ease}.project-long-description-markdown a:hover{color:#0cf;border-bottom-color:#0af9}.project-long-description-markdown table{width:100%;border-collapse:collapse;margin:1.5rem 0;border:1px solid rgba(0,170,255,.2);display:table;table-layout:fixed}.project-long-description-markdown table thead{display:table-header-group}.project-long-description-markdown table tbody{display:table-row-group}.project-long-description-markdown table tr{display:table-row}.project-long-description-markdown table th{background:#00aaff1a;color:#fff;padding:.8rem;text-align:center;font-weight:600;border:1px solid rgba(0,170,255,.3);display:table-cell}.project-long-description-markdown table td{padding:0;text-align:center;border:1px solid rgba(0,170,255,.2);color:#a0a0a0;display:table-cell;vertical-align:middle}.project-long-description-markdown table td img{width:100%;height:auto;border-radius:0;border:1px solid rgba(0,170,255,.2);display:block;margin:0 auto}.project-long-description-markdown table td>em,.project-long-description-markdown table td>p{display:block;padding:.9rem 1rem;margin:0}.project-long-description-markdown table tr:nth-child(2n){background:#00aaff0d}.project-long-description-markdown .flowchart-container{margin:30px 0;padding:25px;background:#00aaff0d;border:1px solid rgba(0,170,255,.2);border-radius:8px;font-family:Courier New,monospace;position:relative;overflow-x:auto}.project-long-description-markdown .flowchart-phase{margin-bottom:30px}.project-long-description-markdown .flowchart-header{background:linear-gradient(135deg,#00aaff4d,#00aaff1a);border-left:3px solid #00aaff;color:#fff;padding:12px 16px;border-radius:4px;margin-bottom:15px;font-weight:700;font-size:1.1em}.project-long-description-markdown .flowchart-step{background:#ff649626;border-left:3px solid #ff6496;color:#ffb3c6;padding:10px 14px;border-radius:4px;margin-bottom:12px;font-weight:700}.project-long-description-markdown .flowchart-code-block{background:#00aaff1a;border:1px solid rgba(0,170,255,.3);color:#0af;padding:8px 12px;border-radius:4px;margin:6px 0;font-size:.9em}.project-long-description-markdown .flowchart-code-block code{background:transparent;padding:0;color:#0af}.project-long-description-markdown .flowchart-material-box{background:#00aaff26;border:1px solid rgba(0,170,255,.4);color:#fff;padding:12px;border-radius:6px}.project-long-description-markdown .flowchart-material-box strong{color:#0af;display:block;margin-bottom:10px}.project-long-description-markdown .flowchart-material-item{background:#0000004d;padding:6px 8px;border-radius:3px;margin:4px 0;font-size:.85em;color:#a0a0a0}.project-long-description-markdown .flowchart-material-item code{background:transparent;padding:0;color:#a0a0a0}.project-long-description-markdown .flowchart-arrow{text-align:center;margin:15px 0;color:#00aaff80;font-size:1.5em}.project-long-description-markdown .flowchart-divider{border-top:2px dashed rgba(0,170,255,.3);margin:25px 0}.project-long-description-markdown .flowchart-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-bottom:15px}.project-long-description-markdown .flowchart-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:15px;margin-bottom:20px}.project-long-description-markdown .flowchart-highlight-box{background:#0af3;border:1px solid rgba(0,170,255,.5);color:#fff;padding:12px 16px;border-radius:6px;margin-bottom:20px}.project-long-description-markdown .flowchart-highlight-box code{background:transparent;padding:0;color:#0af}.project-long-description-markdown .flowchart-indent{margin-left:20px;margin-bottom:15px}@media (max-width: 768px){.project-long-description-markdown .flowchart-grid-2,.project-long-description-markdown .flowchart-grid-3{grid-template-columns:1fr}}.project-media-container{display:flex;flex-direction:column;gap:2rem}.project-video h3,.project-gifs h3{font-family:Courier New,monospace;font-size:1.5rem;color:#fff;margin-bottom:1rem;text-shadow:0 0 10px rgba(0,170,255,.3)}.project-youtube-iframe{width:100%;aspect-ratio:16 / 9;border-radius:8px;border:1px solid rgba(0,170,255,.3)}.gif-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:1rem}.project-gif{width:100%;height:auto;border-radius:8px;border:1px solid rgba(0,170,255,.3);box-shadow:0 4px 16px #0af3;transition:transform .3s ease}.project-gif:hover{transform:scale(1.02)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hologram-container{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:1;pointer-events:none}.hologram-canvas{width:100%;height:100%}.r3f-container{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:5;pointer-events:none;filter:blur(2px);opacity:.7}.about-section{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:6rem 8vw;position:relative;z-index:10;opacity:0;transform:translateY(50px);transition:opacity .8s ease,transform .8s ease}.about-section.visible{opacity:1;transform:translateY(0)}.about-container{max-width:1400px;width:100%}.about-content{display:grid;grid-template-columns:1fr 1.5fr;gap:6rem;align-items:stretch;margin-bottom:4rem}.about-image-wrapper{width:100%;max-width:500px;display:flex;flex-direction:column;gap:1.5rem;height:100%;justify-content:space-between}.about-main-image{width:100%;flex:1;min-height:0;overflow:hidden;position:relative;display:flex;align-items:stretch}.about-profile-image{width:100%;height:100%;object-fit:contain;object-position:center;border-radius:0;display:block;transition:transform .3s ease,opacity .5s ease;animation:fadeInImage .5s ease;position:absolute;top:0;left:0;background:#0b0b0c80}@keyframes fadeInImage{0%{opacity:0}to{opacity:1}}.about-main-image:hover .about-profile-image{transform:scale(1.02)}.about-thumbnails{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;width:100%;flex-shrink:0}.about-thumbnail{aspect-ratio:1;overflow:hidden;cursor:pointer;transition:all .3s ease;opacity:.7;position:relative}.about-thumbnail:hover{opacity:1;transform:scale(1.05)}.about-thumbnail img{width:100%;height:100%;object-fit:contain;object-position:center;display:block;position:absolute;top:0;left:0;background:#0b0b0c80}.about-text-content{display:flex;flex-direction:column;gap:2rem}.about-intro{font-family:Times New Roman,serif;font-size:1.3rem;line-height:1.8;color:#e0e0e0;margin-bottom:1rem}.about-description{font-family:Times New Roman,serif;font-size:1.1rem;line-height:1.9;color:#a0a0a0}.about-description em{font-style:italic;color:silver}.highlight{text-decoration:underline;text-decoration-color:gold;text-underline-offset:3px;text-decoration-thickness:2px;color:#e0e0e0;transition:color .3s ease}.highlight:hover{color:#fff;text-decoration-color:#ffed4e}.about-contact{font-family:Times New Roman,serif;font-size:1.1rem;color:#a0a0a0;margin-top:1rem}.about-link{text-decoration:underline;text-decoration-color:gold;text-underline-offset:3px;text-decoration-thickness:2px;color:#e0e0e0;transition:color .3s ease,text-decoration-color .3s ease}.about-link:hover{color:#fff;text-decoration-color:#ffed4e}.about-social{display:flex;gap:1.5rem;margin-top:2rem}.social-icon{color:#a0a0a0;transition:color .3s ease,transform .3s ease;display:flex;align-items:center;justify-content:center}.social-icon:hover{color:#0af;transform:scale(1.1)}.site-footer{width:100%;padding:2rem 8vw;text-align:center;border-top:1px solid rgba(255,255,255,.1);position:relative;z-index:10;background:#0b0b0c}.footer-content{max-width:1400px;margin:0 auto}.footer-copyright{display:flex;align-items:center;justify-content:center;gap:.75rem}.footer-favicon{width:18px;height:18px;object-fit:contain}.footer-content p{font-family:Times New Roman,serif;font-size:.85rem;color:gray;margin:0}@media (max-width: 768px){.site-footer{padding:1.5rem 5vw}.footer-content p{font-size:.75rem}.footer-favicon{width:16px;height:16px}.footer-copyright{gap:.5rem}.hero{padding-left:5vw;padding-right:5vw}.project-card{grid-template-columns:1fr}.text-area{max-width:100%}.about-section{padding:4rem 5vw}.about-content{grid-template-columns:1fr;gap:3rem}.about-image-wrapper{max-width:100%;margin:0 auto;height:auto;min-height:300px}.about-main-image{min-height:250px;height:250px;flex:0 0 250px}.about-profile-image{position:relative;height:100%;width:100%}.about-thumbnails{gap:.5rem;margin-top:1rem}.about-thumbnail{min-height:60px}.about-intro{font-size:1.1rem}.about-description{font-size:1rem}.about-social{justify-content:center}.project-modal{padding:1rem}.project-modal-content{width:95vw;max-width:none;padding:1.5rem;max-height:95vh;border-radius:8px}.project-modal-close{top:.5rem;right:.5rem;font-size:2rem;width:35px;height:35px}.project-modal-header h2{font-size:1.5rem}.project-modal-header{margin-bottom:1.5rem}.project-technologies{gap:.4rem}.tech-tag{font-size:.8rem;padding:.3rem .8rem}.project-long-description,.project-long-description-markdown{font-size:.95rem;line-height:1.6}.project-long-description-markdown h2{font-size:1.3rem;margin-top:1.5rem}.project-long-description-markdown h3{font-size:1.1rem;margin-top:1.2rem}.project-long-description-markdown table{margin:1rem 0}.project-long-description-markdown table th{padding:.5rem}.project-long-description-markdown table td{padding:0}.project-long-description-markdown table td img{width:100%;height:auto;display:block;border-radius:0}.project-media-container{gap:1.5rem}.project-video,.project-gifs{margin-bottom:1.5rem}.project-video h3,.project-gifs h3{font-size:1.2rem;margin-bottom:.8rem}.project-video iframe{height:200px}.project-gif{margin-bottom:1rem;border-radius:6px}.gif-grid{grid-template-columns:1fr;gap:1rem;margin-top:.8rem}}.portfolio-meaning-section{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;z-index:10;padding:5vh 5vw;margin-top:-5vh}.portfolio-meaning-content{max-width:900px;text-align:center;position:relative;z-index:20;font-style:italic}.portfolio-meaning-text{opacity:0;transform:translateY(30px);transition:opacity 1.2s ease,transform 1.2s ease}.portfolio-meaning-text.visible{opacity:1;transform:translateY(0)}.meaning-line{font-family:Times New Roman,serif;font-size:clamp(1.2rem,2.2vw,1.6rem);line-height:2.2;color:#e0e0e0;margin:.8rem 0;letter-spacing:.03em;opacity:0;transform:translateY(20px);transition:opacity .3s ease,transform .3s ease}.portfolio-meaning-text.visible .meaning-line{opacity:1;transform:translateY(0)}.portfolio-meaning-text.visible .meaning-line-1{transition-delay:0s}.portfolio-meaning-text.visible .meaning-line-2{transition-delay:.2s}.portfolio-meaning-text.visible .meaning-line-3{transition-delay:.4s}.portfolio-meaning-text.visible .meaning-line-4{transition-delay:.6s}.portfolio-meaning-text.visible .meaning-line-5{transition-delay:.8s}@media (max-width: 768px){.portfolio-meaning-section{padding:5vh 5vw}.portfolio-meaning-text{font-size:1.1rem;line-height:1.8}}.background-music-control-container{position:fixed;bottom:2rem;right:2rem;display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:#141419cc;border:1px solid rgba(0,170,255,.3);border-radius:4px;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 16px #0af3;transition:all .3s ease}.background-music-control-container:hover{background:#141419f2;border-color:#0af9;box-shadow:0 6px 24px #0af6}.background-music-control{width:32px;height:32px;border-radius:2px;background:transparent;border:none;color:#0af;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.background-music-control:hover{color:#0cf;transform:scale(1.1)}.background-music-control:active{transform:scale(.95)}.background-music-control svg{width:16px;height:16px}.background-music-volume-control{display:flex;align-items:center;gap:.5rem;min-width:120px}.volume-icon{width:14px;height:14px;color:#0af;flex-shrink:0}.volume-slider{flex:1;height:3px;background:#0af3;border-radius:2px;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:10px;height:10px;background:#0af;border-radius:2px;cursor:pointer;transition:all .2s ease}.volume-slider::-webkit-slider-thumb:hover{background:#0cf;transform:scale(1.2)}.volume-slider::-moz-range-thumb{width:10px;height:10px;background:#0af;border-radius:2px;cursor:pointer;border:none;transition:all .2s ease}.volume-slider::-moz-range-thumb:hover{background:#0cf;transform:scale(1.2)}.background-music-credit{font-family:Courier New,monospace;font-size:.75rem;color:#a0a0a0;white-space:nowrap;padding-left:.5rem;border-left:1px solid rgba(0,170,255,.2)}@media (max-width: 768px){.background-music-control-container{top:1rem;bottom:auto;right:auto;left:50%;transform:translate(-50%);padding:.4rem .8rem;gap:.6rem}.background-music-control{width:28px;height:28px}.background-music-control svg{width:14px;height:14px}.background-music-volume-control{min-width:100px}.background-music-credit{font-size:.75rem;padding-left:.4rem}.projects-tabs{padding:0 1rem;margin-bottom:2rem}.projects-tab{padding:.8rem 1.5rem;font-size:clamp(.9rem,3vw,1.1rem)}.projects-grid{grid-template-columns:repeat(2,1fr);gap:2px}}@media (max-width: 480px){.projects-section{padding-left:0;padding-right:0}.projects-tabs{padding:0 .5rem;margin-bottom:1.5rem}.projects-tab{padding:.7rem 1rem;font-size:.9rem}.projects-grid{grid-template-columns:1fr;gap:1px;max-width:100%}.project-card-thumbnail{border-left:none;border-right:none;border-radius:0}.project-card-title-overlay{opacity:0;background:#0009}.project-card-thumbnail:active .project-card-title-overlay,.project-card-thumbnail:hover .project-card-title-overlay{opacity:1}.project-card-overlay-content{padding:1rem}.project-card-title-overlay h3{font-size:clamp(1rem,4vw,1.3rem);margin-bottom:.5rem}.project-card-title-overlay p{font-size:clamp(.7rem,2vw,.85rem)}}@media (max-width: 768px){.mindmap-section{width:95%;padding:.5rem;height:auto;min-height:auto}.mindmap-subtitle{margin-bottom:.8rem}.mindmap-subtitle p{font-size:1.1rem;line-height:1.5;margin-bottom:.3rem;font-family:Times New Roman,serif;color:#94a3b8;opacity:.85}.mindmap-subtitle p:hover{opacity:1;color:#cbd5e1}.mindmap-container{height:70vh;min-height:400px;touch-action:none;-webkit-overflow-scrolling:touch;margin-bottom:.5rem}.ui-panel{position:absolute;top:10px;left:10px;right:auto;max-width:250px;font-size:.85rem;padding:15px;z-index:20}.panel-title{font-size:10px}.panel-main{font-size:14px;margin-bottom:15px}.tag{font-size:9px;padding:3px 6px}}
