@font-face{font-family:a;src:url();font-display:swap}@font-face{font-family:b;src:url();font-display:swap}:root{--main-bg-color: #f5f7fa;--main-text-color: #222831;--gradient-start: #4f8cff;--gradient-middle: #7d6ee7;--gradient-end: #f0a858;--purple-text-color: #5f62d8;--text-bg-color: #e3e8f0;--icon-bg-color: #f8fafc;--pop-up-box-shadow: #e6e6e6;--tab-button-bg-color: #ffffff;--tab-button-hover-bg-color: #f0f4fa;--tab-button-selected-bg-color: #5f62d8;--tab-button-text-color: #222831;--project-item-bg-color: #ffffff;--project-item-hover-color: #f7f9fc;--project-item-left-title-color: #222831;--project-item-left-text-color: #6c757d;--footer-text-color: #8a99b3;--footer-text-hover-color: #6f84b7;--icon-1-hover-color: #e3e8f0;--icon-2-hover-color: #e3e8f0;--icon-3-hover-color: #e3e8f0;--icon-4-hover-color: #e3e8f0;--icon-5-hover-color: #e3e8f0;--icon-6-hover-color: #e3e8f0;--surface-border: #e6ebf2}*{font-family:b,a,sans-serif;margin:0;padding:0;box-sizing:border-box;-webkit-user-select:none;user-select:none;transition:color .18s ease,background-color .18s ease,border-color .18s ease,box-shadow .18s ease,transform .18s ease}a:hover,a:link,a:visited,a:active,a:focus{text-decoration:none;outline:none;color:inherit;border:none;-webkit-tap-highlight-color:rgba(0,0,0,0)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-thumb{background-color:gray;border-radius:8px;height:20%}::-webkit-scrollbar-thumb:hover{background-color:#707070}::-webkit-scrollbar-track{background-color:var(--main-bg-color, linear-gradient(50deg, #a2d0ff, #ffffff))}body{display:flex;height:100%;min-height:100vh;width:100%;background:var(--main-bg-color);overflow-x:hidden;justify-content:center;color:var(--main-text-color)}#PageLoading{background:radial-gradient(#fff);background-size:100%;background-position:center;background-color:#fff;height:100%;width:100%;position:fixed;z-index:999999;margin-top:0;top:0;pointer-events:none;opacity:1;transition:all .5s ease}.object{-moz-border-radius:50% 50% 50% 50%;-webkit-border-radius:50% 50% 50% 50%;border-radius:50%;position:absolute;border-left:5px solid #8887fa;border-right:5px solid #FFC0CB;border-top:5px solid transparent;border-bottom:5px solid transparent;-webkit-animation:animate 2.5s infinite;animation:animate 2.5s infinite}#object_one{width:20%;height:20%}#object_two{width:35%;height:35%;-webkit-animation-delay:.1s;animation-delay:.1s}#object_three{width:45%;height:45%;-webkit-animation-delay:.2s;animation-delay:.2s}#object_four{width:55%;height:55%;-webkit-animation-delay:.3s;animation-delay:.3s}@-webkit-keyframes animate{}@keyframes animate{}#root{width:92%;display:flex;justify-content:center}.main{width:100%;max-width:98%;position:relative;flex-direction:row}.left{width:250px;height:100vh;display:flex;padding:0 15px;position:fixed;align-items:center;flex-direction:column}.left-main{width:100%;height:100vh;overflow-y:scroll;display:flex;align-items:center;flex-direction:column}.left-main::-webkit-scrollbar{display:none}.logo{flex-shrink:0;width:90%;position:relative;aspect-ratio:1/1;margin-top:50px;background-size:cover;border-radius:50%;border:4px solid #ffffff;box-shadow:0 8px 20px #2a324614;transition:all .8s ease-in-out}.left-div{flex-shrink:0;width:100%;border-radius:13px;margin-top:15px;padding:18px;background:var(--project-item-bg-color);border:1px solid var(--surface-border);box-shadow:none}.left-div:hover{box-shadow:0 0 16px var(--pop-up-box-shadow)}.left-des{display:flex;flex-direction:column;justify-content:center;gap:10px}.left-div-item{display:flex;align-items:center;line-height:20px;font-size:15px;gap:8px;overflow:hidden}.left-tag{display:flex;flex-direction:row;flex-wrap:wrap;gap:10px;padding:14px}.left-tag-item{display:flex;justify-content:center;align-items:center;height:28px;padding:10px;font-size:13px;border-radius:999px;background:var(--main-bg-color);color:inherit;font-weight:400}#line{width:100%;height:200px;font-size:13px;padding-left:10px;scroll-snap-type:y mandatory;overflow-y:scroll}#line li{list-style:none;position:relative;padding:15px 0 0 15px;border-left:2px solid #adbeff;border-radius:0;scroll-snap-align:end;color:#82888a}.focus{width:15px;height:15px;border-radius:22px;background-color:#8da1ff;border:2px solid #fff;position:absolute;left:-9px;top:50%}#line li:first-child .focus:first-child{background-color:#2ecc71;animation:focus 1.8s ease infinite}#line::-webkit-scrollbar{display:none}.left-title{font-size:20px;margin-top:30px}.right{width:calc(100% - 250px);display:flex;padding:25px;position:relative;float:right;flex-direction:column}.hero{position:relative;padding:0;border-radius:0;background:transparent;border:none;box-shadow:none;overflow:visible}.hero-kicker{width:fit-content;padding:0;border:none;border-radius:0;color:#8a99b3;background:transparent;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.welcome{font-size:55px;font-weight:800;margin:24px 0 22px;line-height:1.08;letter-spacing:0}.description{font-size:20px;margin-top:8px;color:var(--main-text-color);max-width:none;line-height:1.6}.quote-line{font-size:18px}.activity-section{margin:20px 0 26px}.gradientText{-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-size:200%;background-position:0%;animation:none;background-image:linear-gradient(120deg,var(--gradient-start, #bd34fe),var(--gradient-middle, #e0321b) 30%,var(--gradient-end, #41d1ff) 60%)}@keyframes backgroundSizeAnimation{0%{background-position:100%}25%{background-position:50%}50%{background-position:0%}75%{background-position:50%}to{background-position:100%}}.purpleText{color:var(--purple-text-color);font-weight:800}.textBackground{font-weight:800;background:var(--text-bg-color);border-radius:5px;font-size:15px;padding:3px 5px;margin:0 2px}.iconContainer{width:100%;gap:10px;min-height:60px;display:flex;align-items:center;overflow-x:scroll;margin-top:22px}.iconContainer::-webkit-scrollbar{display:none}.iconItem{width:44px;height:40px;box-sizing:border-box;background:var(--icon-bg-color);border-radius:7px;display:flex;gap:5px;align-items:center;justify-content:center;border:1px solid transparent;box-shadow:none;flex-shrink:0;cursor:pointer}.iconItemLong{width:80px;height:40px;box-sizing:border-box;background:var(--icon-bg-color);border-radius:7px;display:flex;gap:5px;align-items:center;justify-content:center;border:1px solid transparent;box-shadow:none;flex-shrink:0}.iconItem:hover,.iconItemLong:hover{transform:translateY(-1px);box-shadow:none}.switch{width:55px;display:flex}.iconTip{white-space:nowrap;display:flex}.iconItemLong:nth-child(1):hover{background:var(--icon-1-hover-color)}.iconItem:nth-child(2):hover{background:var(--icon-2-hover-color)}.iconItem:nth-child(3):hover{background:var(--icon-3-hover-color)}.iconItem:nth-child(4):hover{background:var(--icon-4-hover-color)}.iconItem:nth-child(5):hover{background:var(--icon-5-hover-color)}.iconItem:hover .iconTip{display:block}.switch:hover{width:55px;background:var(--icon-6-hover-color)}.title{display:flex;gap:10px;align-items:center;font-size:26px;font-weight:800;margin:26px 0 14px;transition:all .4s ease}.title .icon{padding:0;border-radius:0;background:transparent}.button-container{display:flex;gap:12px;margin:22px 0 20px;align-items:center;padding:8px;background:var(--project-item-bg-color);border-radius:14px;border:1px solid var(--surface-border);box-shadow:none}.tab-button{flex:1;padding:12px 24px;border:none;border-radius:10px;background:transparent;color:var(--project-item-left-text-color);font-size:15px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;min-height:44px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.tab-button:not(.but-active):hover{background:var(--tab-button-hover-bg-color);color:var(--tab-button-text-color)}.but-active{background:var(--purple-text-color);color:#fff;box-shadow:none}.but-active:before{content:"";position:absolute;inset:0;background:#ffffff1a;border-radius:12px;pointer-events:none}.tab-content{display:none;animation:fadeIn .3s ease-in-out}.content-active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.intro-content,.about-content{background:var(--project-item-bg-color);border-radius:12px;padding:24px;margin:20px 0;box-shadow:none;border:1px solid var(--surface-border)}.faq-container{margin:20px 0}.faq-item{background:var(--project-item-bg-color);border-radius:12px;margin-bottom:12px;box-shadow:none;overflow:hidden;transition:all .3s ease;border:1px solid var(--surface-border)}.faq-item:hover{background:var(--project-item-hover-color);box-shadow:none;transform:none}.faq-question{display:flex;justify-content:space-between;align-items:center;padding:20px;cursor:pointer;color:var(--main-text-color);font-weight:500;transition:all .3s ease;-webkit-user-select:none;user-select:none}.faq-question span{flex:1;margin-right:15px}.faq-arrow{transition:transform .3s ease;color:var(--main-text-color)}.faq-item.active .faq-arrow{transform:rotate(180deg)}.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;background:var(--project-item-color)}.faq-item.active .faq-answer{max-height:200px;padding:0 20px 20px}.faq-answer p{margin:0;line-height:1.6;color:var(--project-item-left-text-color)}.intro-content p,.about-content p{margin:12px 0;font-size:16px;line-height:1.6;color:var(--project-item-left-text-color)}.intro-content p:first-child,.about-content p:first-child{margin-top:0}.intro-content p:last-child,.about-content p:last-child{margin-bottom:0}.intro-ul{padding-left:20px;margin:12px 0;font-size:16px;line-height:2;color:var(--project-item-left-text-color);list-style-type:disc}.reward-list{display:grid;grid-template-columns:1fr;gap:8px;padding-left:0;list-style:none}.reward-list li{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;padding:8px 10px;border:1px solid var(--surface-border);border-radius:10px;background:#fafbfe}.reward-badge{min-width:52px;padding:3px 8px;border-radius:999px;background:#eef2ff;border:1px solid #dce3ff;color:#5058bd;text-align:center;font-size:12px;font-weight:700;line-height:1.4}.highlight-text{color:var(--purple-text-color);font-weight:500}.highlight-link{color:var(--purple-text-color)!important;text-decoration:underline!important;transition:all .25s ease}.highlight-link:hover{color:#b0b4f7!important}.projectList{display:flex;flex-wrap:wrap;gap:16px;padding:4px 0}.projectItem{display:flex;background-color:var(--project-item-bg-color);border-radius:8px;padding:18px;min-height:105px;width:calc(50% - 8px);border:1px solid var(--surface-border);box-shadow:none}.projectItem:hover{box-shadow:0 8px 16px -4px #2c2d300c;background-color:var(--project-item-hover-color);transform:translateY(-1px)}.projectItemLeft p{font-size:13px;margin-top:5px;color:var(--project-item-left-text-color)}.projectItemLeft h1{font-weight:400;font-size:18px;margin:0;transition:all .4s ease;color:var(--project-item-left-title-color)}.projectItemLeft{transition:all .4s ease;height:100%;width:80%}.projectItemRight{overflow:hidden;display:flex;justify-content:center;align-items:center;width:20%;height:100%}.projectItemLogoWrapLarge{overflow:visible}.projectItemRight img{height:44px;width:44px}.projectItemRight .projectItemLogoLarge{height:78px;width:78px;border-radius:0;object-fit:contain}.skill{padding:25px;width:100%;background:var(--project-item-bg-color);border:1px solid var(--surface-border);border-radius:12px;box-shadow:none}.skill img{width:100%;height:100%;object-fit:cover}.skill #skillWap{display:none}footer{padding:5px;color:var(--footer-text-color);font-size:13px;margin-top:22px;margin-bottom:8px}.footer-links{color:var(--footer-text-color)}.footer-links:hover{color:var(--footer-text-hover-color);transition:.3}@media(max-width:1000px){.projectItem{width:100%}}@media(max-width:800px){.right{width:100%;padding:25px}.description{font-size:16px}.welcome{font-size:48px}.hero{padding:0;border-radius:0}.button-container{margin:20px 0;padding:6px;gap:8px}.reward-list li{align-items:start}.tab-button{padding:10px 16px;font-size:14px;min-height:40px}.projectItemLeft p{font-size:14px}.projectItemLeft h1{font-size:15px}.projectList{display:flex;justify-content:center;align-items:center}.skill #skillWap{display:block}.skill #skillPc{display:none}.faq-question{padding:16px;font-size:14px}.faq-answer{font-size:14px}.faq-item.active .faq-answer{padding:0 16px 16px}.left{position:fixed;z-index:9999;padding:0;width:100%;height:100%;pointer-events:none;background:none;transition:all .3s linear}.left-main{position:absolute;float:left;width:60vw;left:-60vw;padding:15px;box-sizing:border-box;background:var(--main-bg-color);transition:all .25s ease-out}.left-open{pointer-events:auto;background:#64646480}.left-main-open{left:0}}.pop-up{position:fixed;display:flex;visibility:hidden;width:100vw;height:100vh;background:#fff0;z-index:99999;align-items:center;justify-content:center;flex-direction:column}.pop-up-main{z-index:100000;width:80%;max-width:300px;min-height:200px;background-color:#fff;border-radius:12px;opacity:0;display:flex;transition:all .15s linear;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 4px 16px var(--pop-up-box-shadow)}.pop-up-img{width:100%;height:100%}.pop-up.active{visibility:visible}.pop-up-main.active{opacity:1}.pop-up-close{display:flex;justify-content:center;align-items:center;height:40px;width:40px;box-shadow:0 4px 16px var(--pop-up-box-shadow);background-color:var(--project-item-bg-color);margin-top:30px;border-radius:50%;cursor:pointer;opacity:0;transition:opacity .15s linear}.pop-up-close.active{opacity:1}.tab-button,.button-container button{-webkit-tap-highlight-color:transparent}.heatmap-card{width:100%;display:grid;grid-template-columns:210px minmax(0,1fr);gap:18px;align-items:stretch;padding:16px;border:1px solid #e5eaf2;border-radius:12px;background:#fff}.heatmap-header{display:flex;flex-direction:column;justify-content:space-between;gap:16px;min-width:0;padding:2px 0}.heatmap-heading{display:flex;flex-direction:column;gap:4px}.heatmap-title{font-size:17px;font-weight:700;color:#222831;line-height:1.35}.heatmap-subtitle{font-size:13px;color:#7a8798;line-height:1.45}.heatmap-year-selector{width:fit-content;padding:4px 10px;border:1px solid #dfe6f0;border-radius:999px;font-size:12px;color:#5f6d7e;background:#f8fafc;cursor:default;font-weight:700;line-height:1.4}.heatmap-body{min-width:0;padding-left:16px;border-left:1px solid #edf1f6}.heatmap-scroll-wrapper{width:100%;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.heatmap-scroll-wrapper::-webkit-scrollbar{height:6px}.heatmap-scroll-wrapper::-webkit-scrollbar-track{background:transparent}.heatmap-scroll-wrapper::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:3px}.heatmap-loading{min-height:180px;display:flex;align-items:center;justify-content:center;color:#6b7280;font-size:14px}#heatmap-container{width:950px;max-width:none;padding:0;height:132px!important}.heatmap-legend{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:8px;font-size:11px;color:#7b8798;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.legend-row-1{display:flex;align-items:center;gap:6px;flex-shrink:0}.legend-row-2{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px 10px;align-items:center}.color-blocks{display:flex;gap:2px}.color-block{width:10px;height:10px;border-radius:2px}.legend-item{display:flex;align-items:center;gap:4px;white-space:nowrap}@media(max-width:1000px){.heatmap-card{grid-template-columns:1fr;gap:12px}.heatmap-header{flex-direction:row;align-items:flex-start}.heatmap-body{padding-left:0;border-left:0}}@media(max-width:800px){.heatmap-card{padding:12px}.heatmap-header{align-items:center}.heatmap-legend{display:block}.legend-row-1{margin-bottom:6px}.legend-row-2{justify-content:flex-start}#heatmap-container{height:128px!important}}
