:root{--bg-glass:#ffffff0f;--card-bg:#ffffff0f;--accent:#5a5980;--accent-2:#3c5899;--accent-3:#2a3855;--base-light:#363c5d;--text:#c9c8e4;--muted:#e6eef9b3;--glass-border:#ffffff14;--radius:14px}html,body{color:#c9c8e4;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Noto Sans KR,Helvetica Neue,Arial}#vanta-bg{z-index:0;pointer-events:none;background-color:#2a3855;width:100lvw;height:100lvh;position:fixed;inset:0}.page{z-index:1;box-sizing:border-box;flex-direction:column;gap:48px;min-height:100vh;padding:120px 48px 72px;display:flex;position:relative}header.site-header{z-index:100;-webkit-backdrop-filter:blur(8px)saturate(120%);backdrop-filter:blur(8px)saturate(120%);border-bottom:1px solid var(--glass-border);background:linear-gradient(#0c0c1473,#0c0c1426);justify-content:space-between;align-items:center;gap:16px;height:48px;padding:12px 28px;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 6px 20px #00000059}.header-left{align-items:center;gap:15px;display:flex}.header-list-button{cursor:pointer;background:0 0;border:none;padding:0;display:none}.header-list{width:40px;height:40px}.side-bar{text-align:left;-webkit-backdrop-filter:blur(8px)saturate(120%);backdrop-filter:blur(8px)saturate(120%);border-bottom:1px solid var(--glass-border);z-index:2;opacity:0;background:linear-gradient(#0c0c14b3,#0c0c144d);width:250px;height:100%;margin-top:73px;transition:transform .38s cubic-bezier(.4,.8,.2,1),opacity .38s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:0 6px 20px #00000059}.side-bar.side-bar-open{opacity:1;transform:translate(0)}.side-bar.side-bar-closed{pointer-events:none}.side-bar h2{text-align:center}.side-bar-item{padding-bottom:12px}.brand{cursor:pointer;align-items:center;gap:12px;text-decoration:none;display:flex}.brand .logo{border-radius:12px;width:44px;height:44px}.brand .title{letter-spacing:-.02em;font-size:16px;font-weight:700}nav.main-nav{flex:1;justify-content:center;align-items:center;gap:18px;display:flex}nav.main-nav a{border-radius:8px;padding:8px 10px;font-weight:600;text-decoration:none}nav.main-nav a:hover{background:#ffffff05;transform:translateY(-2px)}.socials{align-items:center;gap:12px;display:flex}.icon-btn{cursor:pointer;background:#ffffff08;border:1px solid #ffffff0a;border-radius:10px;place-items:center;width:40px;height:40px;text-decoration:none;display:inline-grid}.icon-btn img{width:18px;height:18px;display:block}.index-container{grid-template-columns:340px 1fr;align-items:start;gap:28px;width:100%;max-width:1200px;margin:0 auto;display:grid}.list-container{grid-template-columns:200px 1fr;align-items:start;gap:28px;width:100%;max-width:1200px;margin:0 auto;display:grid}.container{width:100%;max-width:1000px;margin:0 auto}.profile-parent{position:sticky;top:92px}.profile{border-radius:var(--radius);border:1px solid var(--glass-border);background:linear-gradient(#ffffff08,#ffffff05);align-self:start;min-height:200px;padding:20px;box-shadow:0 6px 24px #06081499}.meta-profile{align-items:center;gap:12px;display:flex}.filter-parent{border-radius:var(--radius);border:1px solid var(--glass-border);background:linear-gradient(#ffffff08,#ffffff05);align-self:start;min-height:300px;padding:10px 10px 15px;position:sticky;top:92px;box-shadow:0 6px 24px #06081499}.filter{padding-bottom:10px}.filter-list{flex-wrap:wrap;gap:6px;display:flex}.filter h3{text-align:center}.tag-select{gap:6px;width:100%;display:flex}.avatar{background:linear-gradient(135deg,var(--accent-2),var(--accent));color:#041022;border-radius:14px;place-items:center;width:84px;height:84px;margin-bottom:12px;font-size:28px;font-weight:800;display:inline-grid}.profile h2{margin:0 0 6px;font-size:20px}.profile p.muted{margin:0 0 12px;font-size:13px}.meta-list{flex-direction:column;gap:8px;margin-top:8px;display:flex}.meta-item{align-items:center;gap:10px;font-size:14px;display:flex}.meta-item b{min-width:88px;font-weight:600;display:inline-block}.main-col{flex-direction:column;gap:28px;display:flex}.section-title{align-items:center;gap:12px;font-size:18px;font-weight:800;display:flex}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.project-card{border:1px solid var(--glass-border);background:linear-gradient(#ffffff08,#ffffff05);border-radius:12px;flex-direction:column;gap:10px;min-height:140px;padding:16px;transition:transform .28s cubic-bezier(.2,.9,.2,1),box-shadow .28s;display:flex;box-shadow:0 10px 30px #06081473}.project-card:hover{transform:translateY(-8px)scale(1.01);box-shadow:0 20px 40px #06081499}.project-card h3{margin:0;font-size:16px}.project-card p.desc{min-height:36px;margin:0;font-size:13px}.project-links{align-items:center;gap:8px;margin-top:auto;display:flex}.project-links a{background:#ffffff05;border:1px solid #ffffff08;border-radius:8px;place-items:center;width:40px;height:40px;text-decoration:none;display:inline-grid}.project-links a img{width:22px;height:22px}.post-list{gap:12px;display:grid}.post-item{border:1px solid var(--glass-border);background:linear-gradient(#ffffff05,#ffffff03);border-radius:12px;align-items:stretch;gap:10px;padding:12px;transition:transform .18s;display:flex;box-shadow:0 6px 24px #06081499}.post-item:hover{transform:translateY(-8px)scale(1.01);box-shadow:0 20px 40px #06081499}.post-thumb{border-radius:8px;flex-shrink:0;place-items:center;display:grid;overflow:hidden}.post-thumb img{object-fit:cover;width:auto;display:block}.post-selection-thumb img{max-width:137px;max-height:72px}.post-content-thumb img{max-width:236px;max-height:124px}.post-info{flex-direction:column;gap:6px;display:flex}.post-info h4{margin:0;font-size:18px}.excerpt{-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:13px;line-height:1.4;display:-webkit-box;overflow:hidden}.blog-time{margin:0;font-size:11px;line-height:1.4}@media (max-width:980px){.index-container{flex-direction:column;display:flex}.profile-parent,.main-col{width:100%}.list-container{grid-template-columns:1fr;width:auto;padding:0 12px}.filter-parent{min-height:0;position:static}.filter-list{float:left;flex-flow:wrap;width:100%;margin-bottom:10px}.tag-select{width:auto}.profile-parent{position:relative;top:auto}.page{padding:110px 18px 48px}}@media (max-width:600px){nav.main-nav{display:none}.header-list-button{display:block}header.site-header{padding:12px}}@media (max-width:400px){.icon-btn,.header-list{width:30px;height:30px}.brand .logo{width:33px;height:33px}.header-left,.socials{gap:8px}header.site-header{padding:8px}.side-bar{margin-top:65px}}.fade-in{animation:.7s cubic-bezier(.2,.9,.2,1) fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.muted{font-size:13px}a,a:hover,a:focus,a:active,a:visited{color:inherit;text-decoration:none}article a{width:100%;height:100%}.ignore-mouse{cursor:default}.index-title{margin-left:6px}.index-more-box{flex:1;justify-content:end;display:flex}.index-more-button{border-radius:10px;width:auto;padding:0 8px;font-size:12px}.list-text{text-align:center}.list-title{justify-content:flex-start;align-items:center;gap:10px;display:flex}.list-title-tags{gap:5px;display:flex;position:relative}.list-title-tags p{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;place-items:center;margin:0;padding:5px;text-decoration:none;display:inline-grid}p.post-tag-icon{width:31px;height:31px;padding:0}.blog-description{width:100%}.blog-header{border:1px solid var(--glass-border);background:linear-gradient(#ffffff08,#ffffff05);border-radius:12px;padding:15px 20px 20px;transition:transform .18s;box-shadow:0 6px 24px #06081499}.blog-parent{padding-bottom:5px}.blog-title{align-items:stretch;gap:20px;padding-top:5px;display:flex}.blog-header .title{margin-top:0;margin-bottom:20px}.blog-header p{margin:0}.blog-header .list-title-tags{margin-bottom:10px}.list-title-button{gap:15px;padding-right:5px;display:flex;position:absolute;top:0;right:0}.list-title-button a{width:32px;height:32px}.prose a,.prose a:focus,.prose a:visited{color:#99d9ea;text-decoration:underline}.prose a:hover{color:#3282f6;text-decoration:underline}.prose a:active{color:#7e84f7;text-decoration:underline}.prose pre,code{border:1px solid var(--glass-border);background:linear-gradient(#7f7f7f0f,#7f7f7f08);transition:transform .18s}.prose pre{border-radius:12px;padding:15px}code{border-radius:8px;padding:5px}.prose pre code{background:0 0;border:none;padding:0}.prose .hljs-comment{color:#85c46c}.prose .hljs-keyword{color:#ff7b72}.prose .hljs-string{color:#c9a26d}.prose .hljs-number{color:#ed94c0}.prose .hljs-literal{color:#6c95eb}.prose .hljs-built_in{color:#c191ff}.prose .hljs-title{color:#6c95eb}.prose .hljs-tag{color:#4c97f8}.prose .hljs-subst{color:#c9c8e4}.prose .hljs-preprocessor .hljs-keyword{color:#4c97f8}.prose .hljs-doctag{color:#11bdad}.prose .hljs-attribute-name{color:#009dff}.prose .hljs-special-text1{color:#d688d4}.prose .hljs-special-text2{color:#66c3cc}.code-proxy{scrollbar-width:none;width:100%;line-height:18px;display:inline-block;overflow-x:scroll}.code-scroll{scrollbar-color:#fff3 #0000;width:100%;position:sticky;bottom:0;overflow-x:scroll}.code-scroll-inner{pointer-events:none;height:1px}.title-releaseType{border:1px solid var(--glass-border);border-color:inherit;border-radius:20px;align-items:center;padding:2px 7px;font-size:11px}.post-release-type{font-size:14px}.contribute-graph{width:100%}.contribute-graph-hider{margin-top:20px}.react-activity-calendar__scroll-container{scrollbar-width:none;width:100%}.about-content{flex-direction:column;gap:20px;display:flex}.about-content hr{width:100%}.about-content strong{color:#7e84f7;background:0 0;border:none;padding:0}.about-content .title{text-align:center}.about-more-contents{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));justify-content:space-between;gap:20px;display:grid}.about-more-content{box-sizing:border-box;border:1px solid var(--glass-border);background:linear-gradient(#ffffff08,#ffffff05);border-radius:12px;width:100%;height:100%;padding:15px 20px 20px;transition:transform .18s;box-shadow:0 6px 24px #06081499}.about-more-content #text{text-align:center}.about-more-content .title{margin-top:5px}.about-more-content:hover{transform:translateY(-8px)scale(1.01);box-shadow:0 20px 40px #06081499}ul{padding-left:25px}.timeline-title{text-align:center}.timeline{margin:0;padding:0;list-style:none;position:relative}.timeline:before{content:"";pointer-events:none;background:linear-gradient(#0000 0%,#c9c8e4 8% 92%,#0000 100%);width:3px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.timeline-item{width:50%;padding-block:1.2rem;transition:opacity .35s cubic-bezier(.4,0,.2,1);position:relative}.hide{opacity:0}.timeline-item:nth-child(odd){text-align:right;left:0}.timeline-item:nth-child(2n){left:50%}.timeline-item .content{box-shadow:var(--shadow);background:#4f46e5;border:1px solid #c9c8e4;border-radius:14px;max-width:440px;padding:1.1rem 1.25rem 1.15rem;transition:opacity .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1);display:inline-block;position:relative}.timeline-item .content:hover{border-color:#d0d7de;box-shadow:0 6px 18px #00000014}.timeline-item:before{content:"";z-index:2;background:#c9c8e4;border:3px solid #4f46e5;border-radius:50%;width:14px;height:14px;transition:background .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1);position:absolute;top:.75rem;box-shadow:0 0 0 3px #c9c8e4}.timeline-item:nth-child(odd):before{right:-10px}.timeline-item:nth-child(2n):before{left:-10px}.timeline-item:nth-child(odd) .content{margin-right:10px;transform:translate(10px)}.timeline-item:nth-child(2n) .content{margin-left:10px;transform:translate(-10px)}.timeline-item h3{margin-top:0}.timeline-item p{color:#27ff00;margin:0}.comment-section{flex-direction:column;gap:20px;margin-top:40px;display:flex}.comment-title{margin:0;font-size:20px;font-weight:700}.login-hint{opacity:.8;font-size:14px}.comment-form{flex-direction:column;gap:8px;display:flex}.comment-reply-form{padding:0 16px}.comment-area{border:1px solid var(--glass-border);resize:vertical;min-height:90px;color:var(--text);background:#ffffff0a;border-radius:8px;padding:10px 12px;font-family:inherit}.comment-form .comment-area{min-height:120px}.comment-area:focus{outline:2px solid var(--accent-2)}.comment-button{background:var(--accent-2);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:6px 14px;font-weight:600}.comment-button:disabled{opacity:.5;cursor:not-allowed}.comment-form-actions{justify-content:space-between;align-items:center;font-size:12px;display:flex}.len{opacity:.6}.comment-status{margin:0;font-size:14px}.comment-status.error{color:#ff6b6b}.comment-status.empty{opacity:.7}.comment-list{flex-direction:column;gap:16px;list-style:none;display:flex}.comment-item{position:relative}.comment-bubble{border:1px solid var(--glass-border);background:linear-gradient(#ffffff0d,#ffffff05);border-radius:12px;flex-direction:column;gap:16px;padding:12px 14px 12px 12px;display:flex;box-shadow:0 4px 14px #00000059}.comment-box{flex-direction:row;gap:12px;width:100%;display:flex}.comment-contents{flex-direction:column;gap:6px;width:100%;display:flex}.comment-meta{opacity:.85;align-items:baseline;gap:10px;font-size:12px;display:flex}.comment-profile{object-fit:cover;border-radius:50%;width:32px;height:32px}.comment-meta .comment-author{font-weight:600}.comment-content{white-space:pre-wrap;margin:0;font-size:14px;line-height:1.5}.comment-actions{gap:8px;display:flex}.comment-action-btn{color:#2af;background:0 0;border:1px solid #2af;border-radius:4px;padding:4px 10px;font-size:12px}.comment-action-btn:hover:not(:disabled){color:#fff;background:#7e84f7;border-color:#7e84f7}.comment-reply-form textarea{min-height:100px}.comment-delete-btn{color:#ff6b6b;border-color:#ff6b6b}.comment-delete-btn:hover:not(:disabled){background:#ff6b6b;border-color:#ff6b6b}@media (max-width:600px){.container{font-size:14px}.comment-title{font-size:17px}.comment-content{font-size:12px}.comment-meta{font-size:11px}.comment-action-btn{padding:3px 8px;font-size:11px}}.error-retryButton{color:#fff;background:#7e84f7;border:none;border-radius:8px;margin-top:12px;padding:6px 14px;font-weight:600}
