/*
  PaperMod v8+
  License: MIT https://github.com/adityatelange/hugo-PaperMod/blob/master/LICENSE
  Copyright (c) 2020 nanxiaobei and adityatelange
  Copyright (c) 2021-2026 adityatelange
*/
:root{--gap:24px;--content-gap:20px;--nav-width:1024px;--main-width:720px;--header-height:60px;--footer-height:60px;--radius:8px;--theme:rgb(255, 255, 255);--entry:rgb(255, 255, 255);--primary:rgb(30, 30, 30);--secondary:rgb(108, 108, 108);--tertiary:rgb(214, 214, 214);--content:rgb(31, 31, 31);--code-block-bg:rgb(28, 29, 33);--code-bg:rgb(245, 245, 245);--border:rgb(238, 238, 238);color-scheme:light}:root[data-theme=dark]{--theme:rgb(29, 30, 32);--entry:rgb(46, 46, 51);--primary:rgb(218, 218, 219);--secondary:rgb(155, 156, 157);--tertiary:rgb(65, 66, 68);--content:rgb(196, 196, 197);--code-block-bg:rgb(46, 46, 51);--code-bg:rgb(55, 56, 62);--border:rgb(51, 51, 51);color-scheme:dark}.list{background:var(--code-bg)}[data-theme=dark] .list{background:var(--theme)}*,::after,::before{box-sizing:border-box}html{-webkit-tap-highlight-color:transparent;overflow-y:scroll;-webkit-text-size-adjust:100%;text-size-adjust:100%}a,button,body,h1,h2,h3,h4,h5,h6{color:var(--primary)}body{font-family:-apple-system,BlinkMacSystemFont,segoe ui,Roboto,Oxygen,Ubuntu,Cantarell,open sans,helvetica neue,sans-serif;font-size:18px;line-height:1.6;word-break:break-word;background:var(--theme)}article,aside,figcaption,figure,footer,header,hgroup,main,nav,section,table{display:block}h1,h2,h3,h4,h5,h6{line-height:1.2}h1,h2,h3,h4,h5,h6,p{margin-top:0;margin-bottom:0}ul{padding:0}a{text-decoration:none}body,figure,ul{margin:0}table{width:100%;border-collapse:collapse;border-spacing:0;overflow-x:auto;word-break:keep-all}button,input,textarea{padding:0;font:inherit;background:0 0;border:0}input,textarea{outline:0}button,input[type=button],input[type=submit]{cursor:pointer}input:-webkit-autofill,textarea:-webkit-autofill{box-shadow:0 0 0 50px var(--theme)inset}img{display:block;max-width:100%}.not-found{position:absolute;left:0;right:0;display:flex;align-items:center;justify-content:center;height:80%;font-size:160px;font-weight:700}.archive-posts{width:100%;font-size:16px}.archive-year{margin-top:40px}.archive-year:not(:last-of-type){border-bottom:2px solid var(--border)}.archive-month{display:flex;align-items:flex-start;padding:10px 0}.archive-month-header{margin:25px 0;width:200px}.archive-month:not(:last-of-type){border-bottom:1px solid var(--border)}.archive-entry{position:relative;padding:5px;margin:10px 0}.archive-entry-title{margin:5px 0;font-weight:400}.archive-count,.archive-meta{color:var(--secondary);font-size:14px}.footer,.top-link{font-size:12px;color:var(--secondary)}.footer{max-width:calc(var(--main-width) + var(--gap) * 2);margin:auto;padding:calc((var(--footer-height) - var(--gap))/2)var(--gap);text-align:center;line-height:24px}.footer span{margin-inline-start:1px;margin-inline-end:1px}.footer span:last-child{white-space:nowrap}.footer a{color:inherit;border-bottom:1px solid var(--secondary)}.footer a:hover{border-bottom:1px solid var(--primary)}.top-link{visibility:hidden;position:fixed;bottom:60px;right:30px;z-index:99;background:var(--tertiary);width:42px;height:42px;padding:12px;border-radius:64px;transition:visibility .5s,opacity .8s linear}.top-link,.top-link svg{filter:drop-shadow(0 0 0 var(--theme))}.footer a:hover,.top-link:hover{color:var(--primary)}.top-link:focus,#theme-toggle:focus{outline:0}.nav{display:flex;flex-wrap:wrap;justify-content:space-between;max-width:calc(var(--nav-width) + var(--gap) * 2);margin-inline-start:auto;margin-inline-end:auto;line-height:var(--header-height)}.nav a{display:block}.logo,#menu{display:flex;margin:auto var(--gap)}.logo{flex-wrap:inherit}.logo a{font-size:24px;font-weight:700}.logo a img,.logo a svg{display:inline;vertical-align:middle;pointer-events:none;transform:translate(0,-10%);border-radius:6px;margin-inline-end:8px}button#theme-toggle{font-size:26px;margin:auto 4px}[data-theme=dark] #moon{display:none}[data-theme=light] #sun{display:none}#menu{list-style:none;word-break:keep-all;overflow-x:auto;white-space:nowrap}#menu li+li{margin-inline-start:var(--gap)}#menu a{font-size:16px}#menu .active{font-weight:500;border-bottom:2px solid}.lang-switch li,.lang-switch ul,.logo-switches{display:inline-flex;margin:auto 4px}.lang-switch{display:flex;flex-wrap:inherit}.lang-switch a{margin:auto 3px;font-size:16px;font-weight:500}.logo-switches{flex-wrap:inherit}.main{position:relative;min-height:calc(100vh - var(--header-height) - var(--footer-height));max-width:calc(var(--main-width) + var(--gap) * 2);margin:auto;padding:var(--gap)}.page-header h1{font-size:40px}.pagination{display:flex}.pagination a{color:var(--theme);font-size:13px;line-height:36px;background:var(--primary);border-radius:calc(36px/2);padding:0 16px}.pagination .next{margin-inline-start:auto}.social-icons a{display:inline-flex;padding:10px}.social-icons a svg{height:26px;width:26px}code{direction:ltr}div.highlight,pre{position:relative}.copy-code{display:none;position:absolute;top:4px;right:4px;color:rgba(255,255,255,.8);background:rgba(78,78,78,.8);border-radius:var(--radius);padding:0 5px;font-size:14px;user-select:none}div.highlight:hover .copy-code,pre:hover .copy-code{display:block}.first-entry{position:relative;display:flex;flex-direction:column;justify-content:center;min-height:320px;margin:var(--gap)0 calc(var(--gap) * 2)}.first-entry .entry-header{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.first-entry .entry-header h1{font-size:34px;line-height:1.3}.first-entry .entry-content{margin:14px 0;font-size:16px;-webkit-line-clamp:3}.first-entry .entry-footer{font-size:14px}.home-info .entry-content{-webkit-line-clamp:unset}.post-entry{position:relative;margin-bottom:var(--gap);padding:var(--gap);background:var(--entry);border-radius:var(--radius);transition:transform .1s;border:1px solid var(--border)}.post-entry:active{transform:scale(.96)}.tag-entry .entry-cover{display:none}.entry-header h2{font-size:24px;line-height:1.3}.entry-content{margin:8px 0;color:var(--secondary);font-size:14px;line-height:1.6;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.entry-footer{color:var(--secondary);font-size:13px}.entry-link{position:absolute;left:0;right:0;top:0;bottom:0}.entry-hint{color:var(--secondary)}.entry-hint-parent{display:flex;justify-content:space-between}.entry-cover{font-size:14px;margin-bottom:var(--gap);text-align:center}.entry-cover img{border-radius:var(--radius);width:100%;height:auto}.entry-cover a{box-shadow:0 1px 0 var(--primary)}.page-header,.post-header{margin:24px auto var(--content-gap)}.post-title{margin-bottom:2px;font-size:40px}.post-description{margin-top:10px;margin-bottom:5px}.post-meta,.breadcrumbs{color:var(--secondary);font-size:14px}.breadcrumbs{display:flex;flex-wrap:wrap;align-items:center}.i18n_list{display:inline-flex}.post-meta .i18n_list li{list-style:none;margin:auto 3px}.breadcrumbs a{font-size:16px}.post-content{color:var(--content);margin:30px 0}.post-content h3,.post-content h4,.post-content h5,.post-content h6{margin:24px 0 16px}.post-content h1{margin:40px auto 32px;font-size:40px}.post-content h2{margin:32px auto 24px;font-size:32px}.post-content h3{font-size:24px}.post-content h4{font-size:16px}.post-content h5{font-size:14px}.post-content h6{font-size:12px}.post-content a,.post-meta .i18n_list li a,.toc a:hover{box-shadow:0 1px;box-decoration-break:clone;-webkit-box-decoration-break:clone}.post-content a code{margin:auto 0;border-radius:0;box-shadow:0 -1px 0 var(--primary)inset}.post-content del{text-decoration:line-through}.post-content dl,.post-content ol,.post-content p,.post-content figure,.post-content ul{margin-bottom:var(--content-gap)}.post-content ol,.post-content ul{padding-inline-start:20px}.post-content li{margin-top:5px}.post-content li p{margin-bottom:0}.post-content dl{display:flex;flex-wrap:wrap;margin:0}.post-content dt{width:25%;font-weight:700}.post-content dd{width:75%;margin-inline-start:0;padding-inline-start:10px}.post-content dd~dd,.post-content dt~dt{margin-top:10px}.post-content table{margin-bottom:var(--content-gap)}.post-content table th,.post-content table:not(.highlighttable,.highlight table,.gist .highlight) td{min-width:80px;padding:8px 5px;line-height:1.5;border-bottom:1px solid var(--border)}.post-content table th{text-align:start}.post-content table:not(.highlighttable) td code:only-child{margin:auto 0}.post-content .highlight table{border-radius:var(--radius)}.post-content .highlight:not(table){margin:10px auto;background:var(--code-block-bg)!important;border-radius:var(--radius);direction:ltr}.post-content li>.highlight{margin-inline-end:0}.post-content ul pre{margin-inline-start:calc(var(--gap) * -2)}.post-content .highlight pre{margin:0}.post-content .highlighttable{table-layout:fixed}.post-content .highlighttable td:first-child{width:40px}.post-content .highlighttable td .linenodiv{padding-inline-end:0!important}.post-content .highlighttable td .highlight,.post-content .highlighttable td .linenodiv pre{margin-bottom:0}.post-content code{margin:auto 4px;padding:4px 6px;font-size:.78em;line-height:1.5;background:var(--code-bg);border-radius:2px}.post-content pre code{display:grid;margin:auto 0;padding:10px;color:#d5d5d6;background:var(--code-block-bg)!important;border-radius:var(--radius);overflow-x:auto;word-break:break-all}.post-content blockquote{margin:20px 0;padding:0 14px;border-inline-start:3px solid var(--primary)}.post-content hr{margin:30px 0;height:2px;background:var(--tertiary);border:0}.post-content iframe{max-width:100%}.post-content img{border-radius:4px;margin:1rem 0}.post-content img[src*="#center"]{margin:1rem auto}.post-content figure.align-center{text-align:center}.post-content figure>figcaption{color:var(--primary);font-size:16px;font-weight:700;margin:8px 0 16px}.post-content figure>figcaption>p{color:var(--secondary);font-size:14px;font-weight:400}.toc{margin-bottom:var(--content-gap);border:1px solid var(--border);background:var(--code-bg);border-radius:var(--radius);padding:.4em}[data-theme=dark] .toc{background:var(--entry)}.toc details summary{cursor:zoom-in;margin-inline-start:10px;user-select:none}.toc details[open] summary{cursor:zoom-out}.toc .details{display:inline;font-weight:500}.toc .inner{margin:5px 20px;padding:0 10px;opacity:.9}.toc li ul{margin-inline-start:var(--gap)}.toc summary:focus{outline:0}.post-footer{margin-top:var(--content-gap)}.post-footer>*{margin-bottom:10px}.post-tags{display:flex;flex-wrap:wrap;gap:10px}.post-tags li{display:inline-block}.post-tags a,.share-buttons,.paginav{border-radius:var(--radius);background:var(--code-bg);border:1px solid var(--border)}.post-tags a{display:block;padding:0 14px;color:var(--secondary);font-size:14px;line-height:34px;background:var(--code-bg)}.post-tags a:hover,.paginav a:hover{background:var(--border)}.share-buttons{padding:10px;display:flex;justify-content:center;overflow-x:auto;gap:10px}.share-buttons li,.share-buttons a{display:inline-flex}.share-buttons a:not(:last-of-type){margin-inline-end:12px}h1:hover .anchor,h2:hover .anchor,h3:hover .anchor,h4:hover .anchor,h5:hover .anchor,h6:hover .anchor{display:inline-flex;color:var(--secondary);margin-inline-start:8px;font-weight:500;user-select:none}.paginav{display:flex;line-height:30px}.paginav a{padding-inline-start:14px;padding-inline-end:14px;border-radius:var(--radius)}.paginav .title{letter-spacing:1px;text-transform:uppercase;font-size:small;color:var(--secondary)}.paginav .prev,.paginav .next{width:50%}.paginav span:hover:not(.title){box-shadow:0 1px}.paginav .next{margin-inline-start:auto;text-align:right}[dir=rtl] .paginav .next{text-align:left}h1>a>svg{display:inline}img.in-text{display:inline;margin:auto}.buttons,.main .profile{display:flex;justify-content:center}.main .profile{align-items:center;min-height:calc(100vh - var(--header-height) - var(--footer-height) - (var(--gap) * 2));text-align:center}.profile .profile_inner{display:flex;flex-direction:column;align-items:center;gap:10px}.profile img{border-radius:50%}.buttons{flex-wrap:wrap;max-width:400px}.button{background:var(--tertiary);border-radius:var(--radius);margin:8px;padding:6px;transition:transform .1s}.button-inner{padding:0 8px}.button:active{transform:scale(.96)}#searchbox input{padding:4px 10px;width:100%;color:var(--primary);font-weight:700;border:2px solid var(--tertiary);border-radius:var(--radius)}#searchbox input:focus{border-color:var(--secondary)}#searchResults li{list-style:none;border-radius:var(--radius);padding:10px;margin:10px 0;position:relative;font-weight:500}#searchResults{margin:10px 0;width:100%}#searchResults li:active{transition:transform .1s;transform:scale(.98)}#searchResults a{position:absolute;width:100%;height:100%;top:0;left:0;outline:none}#searchResults .focus{transform:scale(.98);border:2px solid var(--tertiary)}.terms-tags li{display:inline-block;margin:10px;font-weight:500}.terms-tags a{display:block;padding:3px 10px;background:var(--tertiary);border-radius:6px;transition:transform .1s}.terms-tags a:active{background:var(--tertiary);transform:scale(.96)}.bg{color:#cad3f5;background-color:#24273a}.chroma{color:#cad3f5;background-color:#24273a}.chroma .x{}.chroma .err{color:#ed8796}.chroma .cl{}.chroma .lnlinks{outline:none;text-decoration:none;color:inherit}.chroma .lntd{vertical-align:top;padding:0;margin:0;border:0}.chroma .lntable{border-spacing:0;padding:0;margin:0;border:0}.chroma .hl{background-color:#474733}.chroma .lnt{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#8087a2}.chroma .ln{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#8087a2}.chroma .line{display:flex}.chroma .k{color:#c6a0f6}.chroma .kc{color:#f5a97f}.chroma .kd{color:#ed8796}.chroma .kn{color:#8bd5ca}.chroma .kp{color:#c6a0f6}.chroma .kr{color:#c6a0f6}.chroma .kt{color:#ed8796}.chroma .n{}.chroma .na{color:#8aadf4}.chroma .nb{color:#91d7e3}.chroma .bp{color:#91d7e3}.chroma .nc{color:#eed49f}.chroma .no{color:#eed49f}.chroma .nd{color:#8aadf4;font-weight:700}.chroma .ni{color:#8bd5ca}.chroma .ne{color:#f5a97f}.chroma .nf{color:#8aadf4}.chroma .fm{color:#8aadf4}.chroma .nl{color:#91d7e3}.chroma .nn{color:#f5a97f}.chroma .nx{}.chroma .py{color:#f5a97f}.chroma .nt{color:#c6a0f6}.chroma .nv{color:#f4dbd6}.chroma .vc{color:#f4dbd6}.chroma .vg{color:#f4dbd6}.chroma .vi{color:#f4dbd6}.chroma .vm{color:#f4dbd6}.chroma .l{}.chroma .ld{}.chroma .s{color:#a6da95}.chroma .sa{color:#ed8796}.chroma .sb{color:#a6da95}.chroma .sc{color:#a6da95}.chroma .dl{color:#8aadf4}.chroma .sd{color:#6e738d}.chroma .s2{color:#a6da95}.chroma .se{color:#8aadf4}.chroma .sh{color:#6e738d}.chroma .si{color:#a6da95}.chroma .sx{color:#a6da95}.chroma .sr{color:#8bd5ca}.chroma .s1{color:#a6da95}.chroma .ss{color:#a6da95}.chroma .m{color:#f5a97f}.chroma .mb{color:#f5a97f}.chroma .mf{color:#f5a97f}.chroma .mh{color:#f5a97f}.chroma .mi{color:#f5a97f}.chroma .il{color:#f5a97f}.chroma .mo{color:#f5a97f}.chroma .o{color:#91d7e3;font-weight:700}.chroma .ow{color:#91d7e3;font-weight:700}.chroma .p{}.chroma .c{color:#6e738d;font-style:italic}.chroma .ch{color:#6e738d;font-style:italic}.chroma .cm{color:#6e738d;font-style:italic}.chroma .c1{color:#6e738d;font-style:italic}.chroma .cs{color:#6e738d;font-style:italic}.chroma .cp{color:#6e738d;font-style:italic}.chroma .cpf{color:#6e738d;font-weight:700;font-style:italic}.chroma .g{}.chroma .gd{color:#ed8796;background-color:#363a4f}.chroma .ge{font-style:italic}.chroma .gr{color:#ed8796}.chroma .gh{color:#f5a97f;font-weight:700}.chroma .gi{color:#a6da95;background-color:#363a4f}.chroma .go{}.chroma .gp{}.chroma .gs{font-weight:700}.chroma .gu{color:#f5a97f;font-weight:700}.chroma .gt{color:#ed8796}.chroma .gl{text-decoration:underline}.chroma .w{}.chroma{background-color:unset!important}.chroma .hl{display:flex}.chroma .lnt{padding:0 0 0 12px}.highlight pre.chroma code{padding:8px 0}.highlight pre.chroma .line .cl,.chroma .ln{padding:0 10px}.chroma .lntd:last-of-type{width:100%}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--tertiary);border:5px solid var(--theme);border-radius:var(--radius)}[data-theme=light] .list::-webkit-scrollbar-thumb{border:5px solid var(--code-bg)}::-webkit-scrollbar-thumb:hover{background:var(--secondary)}::-webkit-scrollbar:not(.highlighttable,.highlight table,.gist .highlight){background:var(--theme)}.post-content .highlighttable td .highlight pre code::-webkit-scrollbar{display:none}.post-content :not(table) ::-webkit-scrollbar-thumb{border:2px solid var(--code-block-bg);background:#717175}.post-content :not(table) ::-webkit-scrollbar-thumb:hover{background:#a3a3a5}.gist table::-webkit-scrollbar-thumb{border:2px solid #fff;background:#adadad}.gist table::-webkit-scrollbar-thumb:hover{background:#707070}.post-content table::-webkit-scrollbar-thumb{border-width:2px}@media screen and (min-width:768px){::-webkit-scrollbar{width:19px;height:11px}}@media screen and (max-width:768px){:root{--gap:14px}.profile img{transform:scale(.85)}.first-entry{min-height:260px}.archive-month{flex-direction:column}.archive-year{margin-top:20px}.footer{padding:calc((var(--footer-height) - var(--gap) - 10px)/2)var(--gap)}}@media screen and (max-width:900px){.list .top-link{transform:translateY(-5rem)}}@media screen and (max-width:340px){.share-buttons{justify-content:unset}}@media(prefers-reduced-motion){.terms-tags a:active,.button:active,.post-entry:active,.top-link,#searchResults .focus,#searchResults li:active{transform:none}}:root{--gap:24px;--content-gap:20px;--nav-width:1024px;--main-width:720px;--header-height:60px;--footer-height:60px;--radius:8px;--theme:rgb(255, 255, 255);--entry:rgb(255, 255, 255);--primary:rgb(30, 30, 30);--secondary:rgb(108, 108, 108);--tertiary:rgb(214, 214, 214);--content:rgb(31, 31, 31);--code-block-bg:rgb(28, 29, 33);--code-bg:rgb(245, 245, 245);--border:rgb(238, 238, 238);color-scheme:light}:root[data-theme=dark]{--theme:rgb(29, 30, 32);--entry:rgb(46, 46, 51);--primary:rgb(218, 218, 219);--secondary:rgb(155, 156, 157);--tertiary:rgb(65, 66, 68);--content:rgb(196, 196, 197);--code-block-bg:rgb(46, 46, 51);--code-bg:rgb(55, 56, 62);--border:rgb(51, 51, 51);color-scheme:dark}.list{background:var(--code-bg)}[data-theme=dark] .list{background:var(--theme)}*,::after,::before{box-sizing:border-box}html{-webkit-tap-highlight-color:transparent;overflow-y:scroll;-webkit-text-size-adjust:100%;text-size-adjust:100%}a,button,body,h1,h2,h3,h4,h5,h6{color:var(--primary)}body{font-family:-apple-system,BlinkMacSystemFont,segoe ui,Roboto,Oxygen,Ubuntu,Cantarell,open sans,helvetica neue,sans-serif;font-size:18px;line-height:1.6;word-break:break-word;background:var(--theme)}article,aside,figcaption,figure,footer,header,hgroup,main,nav,section,table{display:block}h1,h2,h3,h4,h5,h6{line-height:1.2}h1,h2,h3,h4,h5,h6,p{margin-top:0;margin-bottom:0}ul{padding:0}a{text-decoration:none}body,figure,ul{margin:0}table{width:100%;border-collapse:collapse;border-spacing:0;overflow-x:auto;word-break:keep-all}button,input,textarea{padding:0;font:inherit;background:0 0;border:0}input,textarea{outline:0}button,input[type=button],input[type=submit]{cursor:pointer}input:-webkit-autofill,textarea:-webkit-autofill{box-shadow:0 0 0 50px var(--theme)inset}img{display:block;max-width:100%}.not-found{position:absolute;left:0;right:0;display:flex;align-items:center;justify-content:center;height:80%;font-size:160px;font-weight:700}.archive-posts{width:100%;font-size:16px}.archive-year{margin-top:40px}.archive-year:not(:last-of-type){border-bottom:2px solid var(--border)}.archive-month{display:flex;align-items:flex-start;padding:10px 0}.archive-month-header{margin:25px 0;width:200px}.archive-month:not(:last-of-type){border-bottom:1px solid var(--border)}.archive-entry{position:relative;padding:5px;margin:10px 0}.archive-entry-title{margin:5px 0;font-weight:400}.archive-count,.archive-meta{color:var(--secondary);font-size:14px}.footer,.top-link{font-size:12px;color:var(--secondary)}.footer{max-width:calc(var(--main-width) + var(--gap) * 2);margin:auto;padding:calc((var(--footer-height) - var(--gap))/2)var(--gap);text-align:center;line-height:24px}.footer span{margin-inline-start:1px;margin-inline-end:1px}.footer span:last-child{white-space:nowrap}.footer a{color:inherit;border-bottom:1px solid var(--secondary)}.footer a:hover{border-bottom:1px solid var(--primary)}.top-link{visibility:hidden;position:fixed;bottom:60px;right:30px;z-index:99;background:var(--tertiary);width:42px;height:42px;padding:12px;border-radius:64px;transition:visibility .5s,opacity .8s linear}.top-link,.top-link svg{filter:drop-shadow(0 0 0 var(--theme))}.footer a:hover,.top-link:hover{color:var(--primary)}.top-link:focus,#theme-toggle:focus{outline:0}.nav{display:flex;flex-wrap:wrap;justify-content:space-between;max-width:calc(var(--nav-width) + var(--gap) * 2);margin-inline-start:auto;margin-inline-end:auto;line-height:var(--header-height)}.nav a{display:block}.logo,#menu{display:flex;margin:auto var(--gap)}.logo{flex-wrap:inherit}.logo a{font-size:24px;font-weight:700}.logo a img,.logo a svg{display:inline;vertical-align:middle;pointer-events:none;transform:translate(0,-10%);border-radius:6px;margin-inline-end:8px}button#theme-toggle{font-size:26px;margin:auto 4px}[data-theme=dark] #moon{display:none}[data-theme=light] #sun{display:none}#menu{list-style:none;word-break:keep-all;overflow-x:auto;white-space:nowrap}#menu li+li{margin-inline-start:var(--gap)}#menu a{font-size:16px}#menu .active{font-weight:500;border-bottom:2px solid}.lang-switch li,.lang-switch ul,.logo-switches{display:inline-flex;margin:auto 4px}.lang-switch{display:flex;flex-wrap:inherit}.lang-switch a{margin:auto 3px;font-size:16px;font-weight:500}.logo-switches{flex-wrap:inherit}.main{position:relative;min-height:calc(100vh - var(--header-height) - var(--footer-height));max-width:calc(var(--main-width) + var(--gap) * 2);margin:auto;padding:var(--gap)}.page-header h1{font-size:40px}.pagination{display:flex}.pagination a{color:var(--theme);font-size:13px;line-height:36px;background:var(--primary);border-radius:calc(36px/2);padding:0 16px}.pagination .next{margin-inline-start:auto}.social-icons a{display:inline-flex;padding:10px}.social-icons a svg{height:26px;width:26px}code{direction:ltr}div.highlight,pre{position:relative}.copy-code{display:none;position:absolute;top:4px;right:4px;color:rgba(255,255,255,.8);background:rgba(78,78,78,.8);border-radius:var(--radius);padding:0 5px;font-size:14px;user-select:none}div.highlight:hover .copy-code,pre:hover .copy-code{display:block}.first-entry{position:relative;display:flex;flex-direction:column;justify-content:center;min-height:320px;margin:var(--gap)0 calc(var(--gap) * 2)}.first-entry .entry-header{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.first-entry .entry-header h1{font-size:34px;line-height:1.3}.first-entry .entry-content{margin:14px 0;font-size:16px;-webkit-line-clamp:3}.first-entry .entry-footer{font-size:14px}.home-info .entry-content{-webkit-line-clamp:unset}.post-entry{position:relative;margin-bottom:var(--gap);padding:var(--gap);background:var(--entry);border-radius:var(--radius);transition:transform .1s;border:1px solid var(--border)}.post-entry:active{transform:scale(.96)}.tag-entry .entry-cover{display:none}.entry-header h2{font-size:24px;line-height:1.3}.entry-content{margin:8px 0;color:var(--secondary);font-size:14px;line-height:1.6;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.entry-footer{color:var(--secondary);font-size:13px}.entry-link{position:absolute;left:0;right:0;top:0;bottom:0}.entry-hint{color:var(--secondary)}.entry-hint-parent{display:flex;justify-content:space-between}.entry-cover{font-size:14px;margin-bottom:var(--gap);text-align:center}.entry-cover img{border-radius:var(--radius);width:100%;height:auto}.entry-cover a{box-shadow:0 1px 0 var(--primary)}.page-header,.post-header{margin:24px auto var(--content-gap)}.post-title{margin-bottom:2px;font-size:40px}.post-description{margin-top:10px;margin-bottom:5px}.post-meta,.breadcrumbs{color:var(--secondary);font-size:14px}.breadcrumbs{display:flex;flex-wrap:wrap;align-items:center}.i18n_list{display:inline-flex}.post-meta .i18n_list li{list-style:none;margin:auto 3px}.breadcrumbs a{font-size:16px}.post-content{color:var(--content);margin:30px 0}.post-content h3,.post-content h4,.post-content h5,.post-content h6{margin:24px 0 16px}.post-content h1{margin:40px auto 32px;font-size:40px}.post-content h2{margin:32px auto 24px;font-size:32px}.post-content h3{font-size:24px}.post-content h4{font-size:16px}.post-content h5{font-size:14px}.post-content h6{font-size:12px}.post-content a,.post-meta .i18n_list li a,.toc a:hover{box-shadow:0 1px;box-decoration-break:clone;-webkit-box-decoration-break:clone}.post-content a code{margin:auto 0;border-radius:0;box-shadow:0 -1px 0 var(--primary)inset}.post-content del{text-decoration:line-through}.post-content dl,.post-content ol,.post-content p,.post-content figure,.post-content ul{margin-bottom:var(--content-gap)}.post-content ol,.post-content ul{padding-inline-start:20px}.post-content li{margin-top:5px}.post-content li p{margin-bottom:0}.post-content dl{display:flex;flex-wrap:wrap;margin:0}.post-content dt{width:25%;font-weight:700}.post-content dd{width:75%;margin-inline-start:0;padding-inline-start:10px}.post-content dd~dd,.post-content dt~dt{margin-top:10px}.post-content table{margin-bottom:var(--content-gap)}.post-content table th,.post-content table:not(.highlighttable,.highlight table,.gist .highlight) td{min-width:80px;padding:8px 5px;line-height:1.5;border-bottom:1px solid var(--border)}.post-content table th{text-align:start}.post-content table:not(.highlighttable) td code:only-child{margin:auto 0}.post-content .highlight table{border-radius:var(--radius)}.post-content .highlight:not(table){margin:10px auto;background:var(--code-block-bg)!important;border-radius:var(--radius);direction:ltr}.post-content li>.highlight{margin-inline-end:0}.post-content ul pre{margin-inline-start:calc(var(--gap) * -2)}.post-content .highlight pre{margin:0}.post-content .highlighttable{table-layout:fixed}.post-content .highlighttable td:first-child{width:40px}.post-content .highlighttable td .linenodiv{padding-inline-end:0!important}.post-content .highlighttable td .highlight,.post-content .highlighttable td .linenodiv pre{margin-bottom:0}.post-content code{margin:auto 4px;padding:4px 6px;font-size:.78em;line-height:1.5;background:var(--code-bg);border-radius:2px}.post-content pre code{display:grid;margin:auto 0;padding:10px;color:#d5d5d6;background:var(--code-block-bg)!important;border-radius:var(--radius);overflow-x:auto;word-break:break-all}.post-content blockquote{margin:20px 0;padding:0 14px;border-inline-start:3px solid var(--primary)}.post-content hr{margin:30px 0;height:2px;background:var(--tertiary);border:0}.post-content iframe{max-width:100%}.post-content img{border-radius:4px;margin:1rem 0}.post-content img[src*="#center"]{margin:1rem auto}.post-content figure.align-center{text-align:center}.post-content figure>figcaption{color:var(--primary);font-size:16px;font-weight:700;margin:8px 0 16px}.post-content figure>figcaption>p{color:var(--secondary);font-size:14px;font-weight:400}.toc{margin-bottom:var(--content-gap);border:1px solid var(--border);background:var(--code-bg);border-radius:var(--radius);padding:.4em}[data-theme=dark] .toc{background:var(--entry)}.toc details summary{cursor:zoom-in;margin-inline-start:10px;user-select:none}.toc details[open] summary{cursor:zoom-out}.toc .details{display:inline;font-weight:500}.toc .inner{margin:5px 20px;padding:0 10px;opacity:.9}.toc li ul{margin-inline-start:var(--gap)}.toc summary: focus{outline:0}.post-footer{margin-top:var(--content-gap)}.post-footer>*{margin-bottom:10px}.post-tags{display:flex;flex-wrap:wrap;gap:10px}.post-tags li{display:inline-block}.post-tags a,.share-buttons,.paginav{border-radius:var(--radius);background:var(--code-bg);border:1px solid var(--border)}.post-tags a{display:block;padding:0 14px;color:var(--secondary);font-size:14px;line-height:34px;background:var(--code-bg)}.post-tags a:hover,.paginav a:hover{background:var(--border)}.share-buttons{padding:10px;display:flex;justify-content:center;overflow-x:auto;gap:10px}.share-buttons li,.share-buttons a{display:inline-flex}.share-buttons a:not(:last-of-type){margin-inline-end:12px}h1:hover .anchor,h2:hover .anchor,h3:hover .anchor,h4:hover .anchor,h5:hover .anchor,h6:hover .anchor{display:inline-flex;color:var(--secondary);margin-inline-start:8px;font-weight:500;user-select:none}.paginav{display:flex;line-height:30px}.paginav a{padding-inline-start:14px;padding-inline-end:14px;border-radius:var(--radius)}.paginav .title{letter-spacing:1px;text-transform:uppercase;font-size:small;color:var(--secondary)}.paginav .prev,.paginav .next{width:50%}.paginav span:hover:not(.title){box-shadow:0 1px}.paginav .next{margin-inline-start:auto;text-align:right}[dir=rtl] .paginav .next{text-align:left}h1>a>svg{display:inline}img.in-text{display:inline;margin:auto}.buttons,.main .profile{display:flex;justify-content:center}.main .profile{align-items:center;min-height:calc(100vh - var(--header-height) - var(--footer-height) - (var(--gap) * 2));text-align:center}.profile .profile_inner{display:flex;flex-direction:column;align-items:center;gap:10px}.profile img{border-radius:50%}.buttons{flex-wrap:wrap;max-width:400px}.button{background:var(--tertiary);border-radius:var(--radius);margin:8px;padding:6px;transition:transform .1s}.button-inner{padding:0 8px}.button:active{transform:scale(.96)}#searchbox input{padding:4px 10px;width:100%;color:var(--primary);font-weight:700;border:2px solid var(--tertiary);border-radius:var(--radius)}#searchbox input:focus{border-color:var(--secondary)}#searchResults li{list-style:none;border-radius:var(--radius);padding:10px;margin:10px 0;position:relative;font-weight:500}#searchResults{margin:10px 0;width:100%}#searchResults li:active{transition:transform .1s;transform:scale(.98)}#searchResults a{position:absolute;width:100%;height:100%;top:0;left:0;outline:none}#searchResults .focus{transform:scale(.98);border:2px solid var(--tertiary)}.terms-tags li{display:inline-block;margin:10px;font-weight:500}.terms-tags a{display:block;padding:3px 10px;background:var(--tertiary);border-radius:6px;transition:transform .1s}.terms-tags a:active{background:var(--tertiary);transform:scale(.96)}.bg{color:#cad3f5;background-color:#24273a}.chroma{color:#cad3f5;background-color:#24273a}.chroma .x{}.chroma .err{color:#ed8796}.chroma .cl{}.chroma .lnlinks{outline:none;text-decoration:none;color:inherit}.chroma .lntd{vertical-align:top;padding:0;margin:0;border:0}.chroma .lntable{border-spacing:0;padding:0;margin:0;border:0}.chroma .hl{background-color:#474733}.chroma .lnt{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#8087a2}.chroma .ln{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#8087a2}.chroma .line{display:flex}.chroma .k{color:#c6a0f6}.chroma .kc{color:#f5a97f}.chroma .kd{color:#ed8796}.chroma .kn{color:#8bd5ca}.chroma .kp{color:#c6a0f6}.chroma .kr{color:#c6a0f6}.chroma .kt{color:#ed8796}.chroma .n{}.chroma .na{color:#8aadf4}.chroma .nb{color:#91d7e3}.chroma .bp{color:#91d7e3}.chroma .nc{color:#eed49f}.chroma .no{color:#eed49f}.chroma .nd{color:#8aadf4;font-weight:700}.chroma .ni{color:#8bd5ca}.chroma .ne{color:#f5a97f}.chroma .nf{color:#8aadf4}.chroma .fm{color:#8aadf4}.chroma .nl{color:#91d7e3}.chroma .nn{color:#f5a97f}.chroma .nx{}.chroma .py{color:#f5a97f}.chroma .nt{color:#c6a0f6}.chroma .nv{color:#f4dbd6}.chroma .vc{color:#f4dbd6}.chroma .vg{color:#f4dbd6}.chroma .vi{color:#f4dbd6}.chroma .vm{color:#f4dbd6}.chroma .l{}.chroma .ld{}.chroma .s{color:#a6da95}.chroma .sa{color:#ed8796}.chroma .sb{color:#a6da95}.chroma .sc{color:#a6da95}.chroma .dl{color:#8aadf4}.chroma .sd{color:#6e738d}.chroma .s2{color:#a6da95}.chroma .se{color:#8aadf4}.chroma .sh{color:#6e738d}.chroma .si{color:#a6da95}.chroma .sx{color:#a6da95}.chroma .sr{color:#8bd5ca}.chroma .s1{color:#a6da95}.chroma .ss{color:#a6da95}.chroma .m{color:#f5a97f}.chroma .mb{color:#f5a97f}.chroma .mf{color:#f5a97f}.chroma .mh{color:#f5a97f}.chroma .mi{color:#f5a97f}.chroma .il{color:#f5a97f}.chroma .mo{color:#f5a97f}.chroma .o{color:#91d7e3;font-weight:700}.chroma .ow{color:#91d7e3;font-weight:700}.chroma .p{}.chroma .c{color:#6e738d;font-style:italic}.chroma .ch{color:#6e738d;font-style:italic}.chroma .cm{color:#6e738d;font-style:italic}.chroma .c1{color:#6e738d;font-style:italic}.chroma .cs{color:#6e738d;font-style:italic}.chroma .cp{color:#6e738d;font-style:italic}.chroma .cpf{color:#6e738d;font-weight:700;font-style:italic}.chroma .g{}.chroma .gd{color:#ed8796;background-color:#363a4f}.chroma .ge{font-style:italic}.chroma .gr{color:#ed8796}.chroma .gh{color:#f5a97f;font-weight:700}.chroma .gi{color:#a6da95;background-color:#363a4f}.chroma .go{}.chroma .gp{}.chroma .gs{font-weight:700}.chroma .gu{color:#f5a97f;font-weight:700}.chroma .gt{color:#ed8796}.chroma .gl{text-decoration:underline}.chroma .w{}.chroma{background-color:unset!important}.chroma .hl{display:flex}.chroma .lnt{padding:0 0 0 12px}.highlight pre.chroma code{padding:8px 0}.highlight pre.chroma .line .cl,.chroma .ln{padding:0 10px}.chroma .lntd:last-of-type{width:100%}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--tertiary);border:5px solid var(--theme);border-radius:var(--radius)}[data-theme=light] .list::-webkit-scrollbar-thumb{border:5px solid var(--code-bg)}::-webkit-scrollbar-thumb:hover{background:var(--secondary)}::-webkit-scrollbar:not(.highlighttable,.highlight table,.gist .highlight){background:var(--theme)}.post-content .highlighttable td .highlight pre code::-webkit-scrollbar{display:none}.post-content :not(table) ::-webkit-scrollbar-thumb{border:2px solid var(--code-block-bg);background:#717175}.post-content :not(table) ::-webkit-scrollbar-thumb:hover{background:#a3a3a5}.gist table::-webkit-scrollbar-thumb{border:2px solid #fff;background:#adadad}.gist table::-webkit-scrollbar-thumb:hover{background:#707070}.post-content table::-webkit-scrollbar-thumb{border-width:2px}@media screen and (min-width:768px){::-webkit-scrollbar{width:19px;height:11px}}@media screen and (max-width:768px){:root{--gap:14px}.profile img{transform:scale(.85)}.first-entry{min-height:260px}.archive-month{flex-direction:column}.archive-year{margin-top:20px}.footer{padding:calc((var(--footer-height) - var(--gap) - 10px)/2)var(--gap)}}@media screen and (max-width:900px){.list .top-link{transform:translateY(-5rem)}}@media screen and (max-width:340px){.share-buttons{justify-content:unset}}@media(prefers-reduced-motion){.terms-tags a:active,.button:active,.post-entry:active,.top-link,#searchResults .focus,#searchResults li:active{transform:none}}:root{--primary:#4f46e5;--primary-light:#6366f1;--primary-dark:#4338ca;--accent:#06b6d4;--bg-white:#ffffff;--bg-gray-50:#f8fafc;--bg-gray-100:#f1f5f9;--text-900:#0f172a;--text-700:#334155;--text-500:#64748b;--text-400:#94a3b8;--border:#e2e8f0;--shadow:0 4px 6px -1px rgba(0, 0, 0, 0.1);--shadow-lg:0 10px 15px -3px rgba(0, 0, 0, 0.1)}body{background:linear-gradient(180deg,var(--bg-gray-50) 0%,var(--bg-white) 100%)!important;font-family:pretendard,-apple-system,BlinkMacSystemFont,segoe ui,Roboto,sans-serif!important;color:var(--text-700)!important}.main{max-width:900px!important;margin:0 auto!important;padding:2rem 1.5rem!important}.header{background:rgba(255,255,255,.95)!important;backdrop-filter:blur(20px)!important;border-bottom:1px solid var(--border)!important;position:sticky!important;top:0!important;z-index:100!important}.logo a{font-size:1.35rem!important;font-weight:700!important;color:var(--text-900)!important}#menu a{padding:.5rem 1rem!important;color:var(--text-500)!important;font-weight:500!important;border-radius:8px!important;transition:all .2s ease!important}#menu a:hover,#menu a.active{color:var(--primary)!important;background:rgba(79,70,229,8%)!important}.first-entry{background:linear-gradient(135deg,var(--bg-white) 0%,var(--bg-gray-100) 100%)!important;border:1px solid var(--border)!important;border-radius:20px!important;padding:3rem!important;margin-bottom:3rem!important;box-shadow:var(--shadow-lg)!important;text-align:center!important}.first-entry .entry-header h1{font-size:2.5rem!important;font-weight:800!important;color:var(--text-900)!important}.post-entry{background:var(--bg-white)!important;border:1px solid var(--border)!important;border-radius:16px!important;padding:1.75rem!important;margin-bottom:1.25rem!important;transition:all .3s ease!important}.post-entry:hover{border-color:var(--primary-light)!important;transform:translateY(-4px)!important;box-shadow:0 12px 40px rgba(79,70,229,.12)!important}.post-entry .entry-header h2{font-size:1.35rem!important;font-weight:700!important;color:var(--text-900)!important}.post-tags a{padding:.35rem .85rem!important;font-size:.8rem!important;color:var(--primary)!important;background:rgba(79,70,229,8%)!important;border-radius:20px!important}.post-tags a:hover{background:var(--primary)!important;color:#fff!important}.social-icons a{width:48px!important;height:48px!important;background:var(--bg-white)!important;border:1px solid var(--border)!important;border-radius:12px!important;color:var(--text-500)!important;transition:all .3s ease!important}.social-icons a:hover{background:var(--primary)!important;border-color:var(--primary)!important;color:#fff!important;transform:translateY(-3px)!important}.post-single{background:var(--bg-white)!important;border-radius:20px!important;padding:3rem!important;box-shadow:var(--shadow-lg)!important;border:1px solid var(--border)!important}.post-title{font-size:2.25rem!important;font-weight:800!important;color:var(--text-900)!important}.post-content a{color:var(--primary)!important}.footer{background:var(--bg-white)!important;border-top:1px solid var(--border)!important;color:var(--text-400)!important}#top-link{background:var(--primary)!important;color:#fff!important;border-radius:12px!important}.portfolio-section,.recent-posts{margin:3rem 0!important}.section-title{font-size:1.5rem!important;font-weight:700!important;color:var(--text-900)!important;margin-bottom:1.5rem!important;padding-bottom:.5rem!important;border-bottom:2px solid var(--border)!important}.portfolio-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))!important;gap:1.25rem!important}.portfolio-card{background:var(--bg-white)!important;border:1px solid var(--border)!important;border-radius:16px!important;padding:1.75rem!important;text-decoration:none!important;transition:all .3s ease!important;display:block!important}.portfolio-card:hover{border-color:var(--primary-light)!important;transform:translateY(-4px)!important;box-shadow:0 12px 40px rgba(79,70,229,.12)!important}.portfolio-card .card-icon{font-size:2.5rem!important;margin-bottom:1rem!important}.portfolio-card h3{font-size:1.25rem!important;font-weight:700!important;color:var(--text-900)!important;margin-bottom:.5rem!important}.portfolio-card p{font-size:.9rem!important;color:var(--text-500)!important;margin-bottom:1rem!important;line-height:1.5!important}.portfolio-card .card-tag{display:inline-block!important;padding:.25rem .75rem!important;font-size:.75rem!important;font-weight:500!important;color:var(--primary)!important;background:rgba(79,70,229,8%)!important;border-radius:20px!important}:root[data-theme=dark]{--theme:#1e2a4a !important;--entry:#243154 !important;--primary:#e2e8f0 !important;--secondary:#94a3b8 !important;--tertiary:#3d4f7a !important;--content:#cbd5e1 !important;--code-block-bg:#2d3a5c !important;--code-bg:#2d3a5c !important;--border:#3d4f7a !important}[data-theme=dark] body{background:#1e2a4a!important}[data-theme=dark] .main{background:#1e2a4a!important}[data-theme=dark] .header{background:#172038!important;border-bottom:1px solid #3d4f7a!important}[data-theme=dark] .logo a{color:#f1f5f9!important}[data-theme=dark] #menu a{color:#94a3b8!important}[data-theme=dark] #menu a:hover,[data-theme=dark] #menu a.active{color:#818cf8!important;background:rgba(129,140,248,.15)!important}[data-theme=dark] .first-entry{background:linear-gradient(135deg,#172038 0%,#243154 100%)!important;border-color:#3d4f7a!important}[data-theme=dark] .first-entry .entry-header h1{color:#f1f5f9!important}[data-theme=dark] .first-entry .entry-content{color:#cbd5e1!important}[data-theme=dark] .post-entry{background:#243154!important;border-color:#3d4f7a!important}[data-theme=dark] .post-entry:hover{border-color:#818cf8!important}[data-theme=dark] .post-entry .entry-header h2{color:#f1f5f9!important}[data-theme=dark] .post-entry .entry-content{color:#94a3b8!important}[data-theme=dark] .post-tags a{background:#2d3a5c!important;color:#818cf8!important}[data-theme=dark] .post-tags a:hover{background:#818cf8!important;color:#fff!important}[data-theme=dark] .social-icons a{background:#2d3a5c!important;border-color:#3d4f7a!important;color:#94a3b8!important}[data-theme=dark] .social-icons a:hover{background:#818cf8!important;color:#fff!important}[data-theme=dark] .post-single{background:#243154!important;border-color:#3d4f7a!important}[data-theme=dark] .post-title{color:#f1f5f9!important}[data-theme=dark] .post-content{color:#cbd5e1!important}[data-theme=dark] .post-content a{color:#818cf8!important}[data-theme=dark] .footer{background:#172038!important;border-top-color:#3d4f7a!important;color:#64748b!important}[data-theme=dark] #top-link{background:#818cf8!important}[data-theme=dark] .section-title{color:#f1f5f9!important;border-bottom-color:#3d4f7a!important}[data-theme=dark] .portfolio-card{background:#243154!important;border-color:#3d4f7a!important}[data-theme=dark] .portfolio-card:hover{border-color:#818cf8!important;box-shadow:0 12px 40px rgba(129,140,248,.15)!important}[data-theme=dark] .portfolio-card h3{color:#f1f5f9!important}[data-theme=dark] .portfolio-card p{color:#94a3b8!important}[data-theme=dark] .portfolio-card .card-tag{background:#2d3a5c!important;color:#818cf8!important}[data-theme=dark] *{color:rgba(241,245,249,.9)!important}[data-theme=dark] h1,[data-theme=dark] h2,[data-theme=dark] h3,[data-theme=dark] h4,[data-theme=dark] .post-title,[data-theme=dark] .entry-header h2{color:#fff!important;opacity:1!important}[data-theme=dark] .post-meta,[data-theme=dark] .post-description,[data-theme=dark] .entry-footer{color:rgba(241,245,249,.7)!important}[data-theme=dark] a{color:#818cf8!important}[data-theme=dark] a:hover{color:#a5b4fc!important}code{background:#e8eaed!important;color:#e06c75!important;padding:.2em .4em!important;border-radius:4px!important;font-family:fira code,jetbrains mono,Consolas,monospace!important;font-size:.9em!important}pre{background:#282c34!important;border-radius:8px!important;padding:1rem!important;overflow-x:auto!important}pre code{background:0 0!important;color:#abb2bf!important;padding:0!important;font-size:.85em!important;line-height:1.6!important}[data-theme=dark] code{background:#3e4451!important;color:#e06c75!important}[data-theme=dark] pre{background:#282c34!important;border:1px solid #3e4451!important}[data-theme=dark] pre code{background:0 0!important}.highlight pre,.highlight code,.highlight{background:#282c34!important}.highlight .chroma{background:#282c34!important;color:#abb2bf!important}.highlight .c,.highlight .ch,.highlight .cm,.highlight .c1,.highlight .cs{color:#8b949e!important;font-style:italic!important}.highlight .k,.highlight .kc,.highlight .kd,.highlight .kn,.highlight .kp,.highlight .kr,.highlight .kv{color:#c678dd!important}.highlight .kt{color:#e5c07b!important}.highlight .nf,.highlight .fm{color:#61afef!important}.highlight .nc,.highlight .nn{color:#e5c07b!important}.highlight .s,.highlight .sa,.highlight .sb,.highlight .sc,.highlight .dl,.highlight .sd,.highlight .s2,.highlight .se,.highlight .sh,.highlight .si,.highlight .sx,.highlight .sr,.highlight .s1,.highlight .ss{color:#98c379!important}.highlight .m,.highlight .mb,.highlight .mf,.highlight .mh,.highlight .mi,.highlight .il,.highlight .mo{color:#d19a66!important}.highlight .o,.highlight .ow{color:#56b6c2!important}.highlight .p{color:#abb2bf!important}.highlight .n,.highlight .na,.highlight .nb,.highlight .ni,.highlight .nl,.highlight .no,.highlight .nv,.highlight .bp,.highlight .vc,.highlight .vg,.highlight .vi,.highlight .vm{color:#e06c75!important}.highlight .nx{color:#e06c75!important}.highlight .nb{color:#56b6c2!important}.highlight .err{color:#e06c75!important;background:0 0!important}.highlight .si{color:#e06c75!important}.highlight .ln,.highlight .lnt{color:#4b5363!important}[data-theme=dark] .highlight pre,[data-theme=dark] .highlight code,[data-theme=dark] .highlight,[data-theme=dark] .highlight .chroma{background:#282c34!important}[data-theme=dark] #searchInput{background:#243154!important;border-color:#3d4f7a!important}[data-theme=dark] #searchInput::placeholder{color:#94a3b8!important}[data-theme=dark] .post-entry,[data-theme=dark] .post-single,[data-theme=dark] .first-entry,[data-theme=dark] .toc,[data-theme=dark] .portfolio-card{border-color:#4f5f8a!important}[data-theme=dark] .header{border-bottom-color:#4f5f8a!important}[data-theme=dark] .footer{border-top-color:#4f5f8a!important}[data-theme=dark] hr{border-color:#4f5f8a!important;background:#4f5f8a!important}[data-theme=dark] blockquote{border-left-color:#818cf8!important}.post-content .anchor{display:inline!important;visibility:visible!important;opacity:.5!important}.post-content h1:hover .anchor,.post-content h2:hover .anchor,.post-content h3:hover .anchor,.post-content h4:hover .anchor{opacity:1!important}[data-theme=dark] .post-content .anchor{color:#fff!important;display:inline!important;visibility:visible!important;opacity:1!important}.portfolio-page{max-width:900px;margin:0 auto}.portfolio-hero{text-align:center;padding:3rem 2rem;background:linear-gradient(135deg,var(--bg-white) 0%,var(--bg-gray-100) 100%);border:1px solid var(--border);border-radius:20px;margin-bottom:2rem;box-shadow:var(--shadow-lg)}.portfolio-hero h1{font-size:2.5rem;font-weight:800;color:var(--text-900);margin-bottom:.5rem}.portfolio-hero .subtitle{font-size:1.1rem;color:var(--primary);font-weight:600;margin-bottom:1rem}.portfolio-hero .description{font-size:1rem;color:var(--text-500);line-height:1.6;margin-bottom:1.5rem}.hero-links{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.hero-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--bg-white);border:1px solid var(--border);border-radius:12px;color:var(--text-700);font-weight:500;text-decoration:none;transition:all .3s ease}.hero-btn:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px rgba(79,70,229,.15)}.hero-btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.hero-btn.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.hero-btn svg{width:20px;height:20px}.tech-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.tech-category{background:var(--bg-white);border:1px solid var(--border);border-radius:16px;padding:1.5rem}.tech-category h3{font-size:1rem;font-weight:600;color:var(--text-700);margin-bottom:1rem}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{display:inline-block;padding:.35rem .75rem;font-size:.8rem;font-weight:500;background:var(--bg-gray-100);color:var(--text-700);border-radius:20px;transition:all .2s ease}.tech-tag.java{background:#fef3c7;color:#92400e}.tech-tag.python{background:#dbeafe;color:#1e40af}.tech-tag.spring{background:#d1fae5;color:#065f46}.tech-tag.fastapi{background:#e0e7ff;color:#3730a3}.tech-tag.redis{background:#fee2e2;color:#991b1b}.tech-tag.kafka{background:#f3e8ff;color:#6b21a8}.tech-tag.mysql{background:#cffafe;color:#0e7490}.tech-tag.react{background:#e0f2fe;color:#0369a1}.tech-tag.js{background:#fef9c3;color:#a16207}.tech-tag.docker{background:#dbeafe;color:#1d4ed8}.tech-tag.aws{background:#ffedd5;color:#c2410c}.cert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.cert-card{display:flex;align-items:center;gap:1rem;background:var(--bg-white);border:1px solid var(--border);border-radius:12px;padding:1.25rem;transition:all .3s ease}.cert-card:hover{border-color:var(--primary-light);transform:translateY(-2px);box-shadow:0 4px 12px rgba(79,70,229,.1)}.cert-icon{font-size:2rem}.cert-info h4{font-size:1rem;font-weight:600;color:var(--text-900);margin-bottom:.25rem}.cert-info p{font-size:.85rem;color:var(--text-500)}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.project-card{display:block;background:var(--bg-white);border:1px solid var(--border);border-radius:16px;padding:1.75rem;text-decoration:none;transition:all .3s ease}.project-card:hover{border-color:var(--primary-light);transform:translateY(-4px);box-shadow:0 12px 40px rgba(79,70,229,.12)}.project-icon{font-size:2.5rem;margin-bottom:1rem}.project-card h3{font-size:1.25rem;font-weight:700;color:var(--text-900);margin-bottom:.5rem}.project-desc{font-size:.9rem;color:var(--text-500);margin-bottom:1rem;line-height:1.5}.project-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.project-tech span{padding:.25rem .6rem;font-size:.75rem;font-weight:500;color:var(--primary);background:rgba(79,70,229,8%);border-radius:12px}.project-live{display:inline-block;font-size:.85rem;color:var(--accent);font-weight:500}.project-cards{display:flex;flex-direction:column;gap:1.5rem}.project-card-detail{background:var(--bg-white);border:1px solid var(--border);border-radius:20px;padding:2rem;transition:all .3s ease;position:relative;overflow:hidden}.project-card-detail::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);opacity:0;transition:opacity .3s ease}.project-card-detail:hover{border-color:var(--primary-light);box-shadow:0 12px 40px rgba(79,70,229,.12);transform:translateY(-2px)}.project-card-detail:hover::before{opacity:1}.project-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}.project-icon-wrapper{width:56px;height:56px;background:linear-gradient(135deg,var(--bg-gray-100) 0%,var(--bg-white) 100%);border:1px solid var(--border);border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.project-icon-wrapper .project-icon{font-size:1.75rem}.project-title-area{flex:1}.project-title-area h3{font-size:1.35rem;font-weight:700;color:var(--text-900);margin-bottom:.25rem}.project-period{font-size:.85rem;color:var(--text-400);font-weight:500}.project-badge{padding:.35rem .85rem;font-size:.75rem;font-weight:600;border-radius:20px;white-space:nowrap}.project-badge.work{background:#dbeafe;color:#1e40af}.project-badge.live{background:#d1fae5;color:#065f46}.project-badge.team{background:#f3e8ff;color:#6b21a8}.project-summary{font-size:1.05rem;color:var(--text-700);margin-bottom:1rem;line-height:1.5}.project-role{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.5rem 1rem;background:var(--bg-gray-50);border-radius:8px}.role-label{font-size:.8rem;color:var(--text-400);font-weight:500}.role-value{font-size:.9rem;color:var(--text-700);font-weight:600}.project-highlights{list-style:none;padding:0;margin:0 0 1.25rem}.project-highlights li{position:relative;padding-left:1.5rem;margin-bottom:.5rem;font-size:.9rem;color:var(--text-600);line-height:1.5}.project-highlights li::before{content:'▸';position:absolute;left:0;color:var(--primary);font-weight:600}.project-tech-stack{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.project-tech-stack .tech{padding:.35rem .75rem;font-size:.8rem;font-weight:500;background:var(--bg-gray-100);color:var(--text-600);border-radius:6px;transition:all .2s ease}.project-tech-stack .tech.spring{background:#d1fae5;color:#065f46}.project-tech-stack .tech.kafka{background:#f3e8ff;color:#6b21a8}.project-tech-stack .tech.redis{background:#fee2e2;color:#991b1b}.project-tech-stack .tech.react{background:#e0f2fe;color:#0369a1}.project-tech-stack .tech.fastapi{background:#e0e7ff;color:#3730a3}.project-tech-stack .tech.python{background:#dbeafe;color:#1e40af}.project-links{display:flex;gap:.75rem;flex-wrap:wrap}.project-link{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:var(--bg-gray-50);border:1px solid var(--border);border-radius:8px;font-size:.85rem;font-weight:500;color:var(--text-600);text-decoration:none;transition:all .2s ease}.project-link:hover{background:var(--primary);border-color:var(--primary);color:#fff}.project-link.live-link{background:rgba(6,182,212,.1);border-color:rgba(6,182,212,.3);color:#0891b2}.project-link.live-link:hover{background:#06b6d4;border-color:#06b6d4;color:#fff}.project-link svg{width:16px;height:16px}.access-section{margin:2rem 0}.access-card{background:var(--bg-white);border:1px solid var(--border);border-radius:16px;padding:2rem;text-align:center}.access-card p{color:var(--text-500);margin-bottom:1.5rem}.access-form{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}.access-form input{padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;width:200px;background:var(--bg-white);color:var(--text-700)}.access-form input:focus{outline:none;border-color:var(--primary)}.access-btn{padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.access-btn:hover{background:var(--primary-dark)}.access-hint{font-size:.85rem;margin-top:1rem}.currently-list{list-style:none;padding:0}.currently-list li{display:flex;align-items:center;gap:.5rem;padding:.75rem 0;border-bottom:1px solid var(--border);color:var(--text-700)}.currently-list li:last-child{border-bottom:none}.study-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem}.study-card{display:block;background:var(--bg-white);border:1px solid var(--border);border-radius:16px;padding:1.5rem;text-align:center;text-decoration:none;transition:all .3s ease}.study-card:hover{border-color:var(--primary-light);transform:translateY(-4px);box-shadow:0 12px 40px rgba(79,70,229,.12)}.study-icon{font-size:2rem;margin-bottom:.75rem}.study-card h3{font-size:1.1rem;font-weight:700;color:var(--text-900);margin-bottom:.5rem}.study-card p{font-size:.85rem;color:var(--text-500)}.archive-portfolio{margin-bottom:3rem}.archive-section-title{font-size:1.5rem;font-weight:700;color:var(--text-900);margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--border)}.archive-profile{background:var(--bg-white);border:1px solid var(--border);border-radius:16px;padding:2rem;margin-bottom:1.5rem}.profile-info h3{font-size:1.5rem;font-weight:700;color:var(--text-900);margin-bottom:.5rem}.profile-role{font-size:1rem;color:var(--primary);font-weight:600;margin-bottom:1rem}.profile-desc{font-size:.95rem;color:var(--text-500);line-height:1.6;margin-bottom:1.5rem}.profile-links{display:flex;gap:1rem;flex-wrap:wrap}.profile-links a{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:rgba(79,70,229,8%);color:var(--primary);border-radius:8px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s ease}.profile-links a:hover{background:var(--primary);color:#fff}.profile-badges{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.badge-group{background:var(--bg-white);border:1px solid var(--border);border-radius:12px;padding:1.25rem}.badge-label{display:block;font-size:.85rem;font-weight:600;color:var(--text-700);margin-bottom:.75rem}.badges{display:flex;flex-wrap:wrap;gap:.5rem}.badge{display:inline-block;padding:.35rem .75rem;font-size:.8rem;font-weight:500;border-radius:20px}.badge.cert{background:#dbeafe;color:#1e40af}.badge.award{background:#fef3c7;color:#92400e}.badge.edu{background:#d1fae5;color:#065f46}.archive-timeline-tabs{margin-top:2rem}.timeline-tab-buttons{display:flex;gap:.5rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-btn{padding:.75rem 1.25rem;background:var(--bg-gray-100);border:1px solid var(--border);border-radius:8px;font-size:.9rem;font-weight:500;color:var(--text-500);cursor:pointer;white-space:nowrap;transition:all .2s ease}.tab-btn:hover{background:var(--bg-white);border-color:var(--primary-light);color:var(--primary)}.tab-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.timeline-tab-content{display:none}.timeline-tab-content.active{display:block}.unified-timeline{position:relative}.timeline-year{margin-bottom:2.5rem}.timeline-year-header{font-size:1.5rem;font-weight:700;color:var(--primary);margin-bottom:1.5rem;padding:.5rem 1rem;background:linear-gradient(90deg,rgba(79,70,229,.1) 0%,transparent 100%);border-left:4px solid var(--primary);border-radius:0 8px 8px 0}.timeline-events{position:relative;padding-left:2rem}.timeline-events::before{content:'';position:absolute;left:6px;top:0;bottom:0;width:2px;background:var(--border)}.timeline-event{position:relative;display:flex;gap:1rem;margin-bottom:1.5rem}.event-dot{position:absolute;left:-2rem;top:.25rem;width:14px;height:14px;border-radius:50%;background:var(--border);border:3px solid var(--bg-white);z-index:1}.timeline-event.work .event-dot{background:#3b82f6}.timeline-event.cert .event-dot{background:#10b981}.timeline-event.project .event-dot{background:#8b5cf6}.timeline-event.award .event-dot{background:#f59e0b}.timeline-event.education .event-dot{background:#ec4899}.timeline-event.blog .event-dot{background:#6366f1}.event-content{flex:1;background:var(--bg-white);border:1px solid var(--border);border-radius:12px;padding:1.25rem;transition:all .2s ease}.event-content:hover{border-color:var(--primary-light);box-shadow:0 4px 12px rgba(79,70,229,.1)}.event-date{display:inline-block;font-size:.8rem;font-weight:500;color:var(--text-400);margin-bottom:.5rem}.event-content h4{font-size:1rem;font-weight:600;color:var(--text-900);margin-bottom:.25rem}.event-content h4 a{color:var(--text-900);text-decoration:none;transition:color .2s ease}.event-content h4 a:hover{color:var(--primary)}.event-content p{font-size:.9rem;color:var(--text-500);line-height:1.5}.career-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.career-section{background:var(--bg-white);border:1px solid var(--border);border-radius:16px;padding:1.5rem}.career-section-title{font-size:1.1rem;font-weight:700;color:var(--text-900);margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--border)}.career-list{display:flex;flex-direction:column;gap:1rem}.career-item{display:flex;align-items:flex-start;gap:1rem;padding:.75rem;border-radius:8px;transition:background .2s ease}.career-item:hover{background:var(--bg-gray-50)}.career-date{font-size:.8rem;font-weight:500;color:var(--text-400);white-space:nowrap;min-width:100px}.career-info h4{font-size:.95rem;font-weight:600;color:var(--text-900);margin-bottom:.25rem}.career-info p{font-size:.85rem;color:var(--text-500)}.career-item.education{border-left:3px solid #ec4899}.career-item.cert{border-left:3px solid #10b981}.career-item.award{border-left:3px solid #f59e0b}.career-item.project{border-left:3px solid #8b5cf6}[data-theme=dark] .portfolio-hero{background:linear-gradient(135deg,#172038 0%,#243154 100%);border-color:#3d4f7a}[data-theme=dark] .portfolio-hero h1{color:#f1f5f9}[data-theme=dark] .portfolio-hero .subtitle{color:#818cf8}[data-theme=dark] .portfolio-hero .description{color:#94a3b8}[data-theme=dark] .hero-btn{background:#243154;border-color:#3d4f7a;color:#e2e8f0}[data-theme=dark] .hero-btn:hover{border-color:#818cf8;color:#818cf8}[data-theme=dark] .hero-btn.primary{background:#818cf8;border-color:#818cf8;color:#fff}[data-theme=dark] .tech-category,[data-theme=dark] .cert-card,[data-theme=dark] .project-card,[data-theme=dark] .access-card,[data-theme=dark] .study-card{background:#243154;border-color:#3d4f7a}[data-theme=dark] .tech-category:hover,[data-theme=dark] .cert-card:hover,[data-theme=dark] .project-card:hover,[data-theme=dark] .study-card:hover{border-color:#818cf8}[data-theme=dark] .tech-category h3,[data-theme=dark] .cert-info h4,[data-theme=dark] .project-card h3,[data-theme=dark] .study-card h3{color:#f1f5f9}[data-theme=dark] .tech-tag{background:#3d4f7a;color:#e2e8f0}[data-theme=dark] .project-tech span{background:#2d3a5c;color:#818cf8}[data-theme=dark] .access-form input{background:#243154;border-color:#3d4f7a;color:#e2e8f0}[data-theme=dark] .access-form input:focus{border-color:#818cf8}[data-theme=dark] .access-btn{background:#818cf8}[data-theme=dark] .access-btn:hover{background:#6366f1}[data-theme=dark] .currently-list li{border-bottom-color:#3d4f7a;color:#cbd5e1}[data-theme=dark] .project-card-detail{background:#243154;border-color:#3d4f7a}[data-theme=dark] .project-card-detail:hover{border-color:#818cf8}[data-theme=dark] .project-card-detail::before{background:linear-gradient(90deg,#818cf8 0%,#06b6d4 100%)}[data-theme=dark] .project-icon-wrapper{background:linear-gradient(135deg,#2d3a5c 0%,#243154 100%);border-color:#3d4f7a}[data-theme=dark] .project-title-area h3{color:#f1f5f9}[data-theme=dark] .project-period{color:#64748b}[data-theme=dark] .project-badge.work{background:#1e3a5f;color:#60a5fa}[data-theme=dark] .project-badge.live{background:#064e3b;color:#34d399}[data-theme=dark] .project-badge.team{background:#4c1d95;color:#c4b5fd}[data-theme=dark] .project-summary{color:#cbd5e1}[data-theme=dark] .project-role{background:#2d3a5c}[data-theme=dark] .role-label{color:#64748b}[data-theme=dark] .role-value{color:#e2e8f0}[data-theme=dark] .project-highlights li{color:#94a3b8}[data-theme=dark] .project-highlights li::before{color:#818cf8}[data-theme=dark] .project-tech-stack .tech{background:#3d4f7a;color:#e2e8f0}[data-theme=dark] .project-tech-stack .tech.spring{background:#064e3b;color:#34d399}[data-theme=dark] .project-tech-stack .tech.kafka{background:#4c1d95;color:#c4b5fd}[data-theme=dark] .project-tech-stack .tech.redis{background:#7f1d1d;color:#fca5a5}[data-theme=dark] .project-tech-stack .tech.react{background:#0c4a6e;color:#7dd3fc}[data-theme=dark] .project-tech-stack .tech.fastapi{background:#312e81;color:#a5b4fc}[data-theme=dark] .project-tech-stack .tech.python{background:#1e3a5f;color:#60a5fa}[data-theme=dark] .project-link{background:#2d3a5c;border-color:#3d4f7a;color:#94a3b8}[data-theme=dark] .project-link:hover{background:#818cf8;border-color:#818cf8;color:#fff}[data-theme=dark] .project-link.live-link{background:rgba(6,182,212,.15);border-color:rgba(6,182,212,.3);color:#22d3ee}[data-theme=dark] .project-link.live-link:hover{background:#06b6d4;border-color:#06b6d4;color:#fff}[data-theme=dark] .archive-section-title{color:#f1f5f9;border-bottom-color:#3d4f7a}[data-theme=dark] .archive-profile,[data-theme=dark] .badge-group,[data-theme=dark] .event-content,[data-theme=dark] .career-section{background:#243154;border-color:#3d4f7a}[data-theme=dark] .profile-info h3,[data-theme=dark] .event-content h4,[data-theme=dark] .career-info h4{color:#f1f5f9}[data-theme=dark] .profile-role{color:#818cf8}[data-theme=dark] .profile-desc,[data-theme=dark] .event-content p,[data-theme=dark] .career-info p{color:#94a3b8}[data-theme=dark] .profile-links a{background:#2d3a5c;color:#818cf8}[data-theme=dark] .profile-links a:hover{background:#818cf8;color:#fff}[data-theme=dark] .badge.cert{background:#1e3a5f;color:#60a5fa}[data-theme=dark] .badge.award{background:#451a03;color:#fbbf24}[data-theme=dark] .badge.edu{background:#064e3b;color:#34d399}[data-theme=dark] .tab-btn{background:#2d3a5c;border-color:#3d4f7a;color:#94a3b8}[data-theme=dark] .tab-btn:hover{background:#243154;border-color:#818cf8;color:#818cf8}[data-theme=dark] .tab-btn.active{background:#818cf8;border-color:#818cf8;color:#fff}[data-theme=dark] .timeline-tab-buttons{border-bottom-color:#3d4f7a}[data-theme=dark] .timeline-year-header{color:#818cf8;background:linear-gradient(90deg,rgba(129,140,248,.15) 0%,transparent 100%);border-left-color:#818cf8}[data-theme=dark] .timeline-events::before{background:#3d4f7a}[data-theme=dark] .event-dot{border-color:#1e2a4a}[data-theme=dark] .event-content:hover{border-color:#818cf8}[data-theme=dark] .event-date,[data-theme=dark] .career-date{color:#64748b}[data-theme=dark] .event-content h4 a{color:#f1f5f9}[data-theme=dark] .event-content h4 a:hover{color:#818cf8}[data-theme=dark] .career-section-title{color:#f1f5f9;border-bottom-color:#3d4f7a}[data-theme=dark] .career-item:hover{background:#2d3a5c}@media(max-width:768px){.portfolio-hero{padding:2rem 1.5rem}.portfolio-hero h1{font-size:2rem}.hero-links{flex-direction:column;align-items:center}.hero-btn{width:100%;max-width:250px;justify-content:center}.tech-grid,.cert-grid,.project-grid,.study-grid,.profile-badges,.career-sections{grid-template-columns:1fr}.timeline-tab-buttons{justify-content:flex-start;padding-right:1rem}.tab-btn{padding:.6rem 1rem;font-size:.85rem}.timeline-events{padding-left:1.5rem}.event-dot{left:-1.5rem;width:12px;height:12px}.event-content{padding:1rem}.career-date{min-width:80px;font-size:.75rem}.access-form{flex-direction:column;align-items:center}.access-form input{width:100%;max-width:250px}.project-card-detail{padding:1.5rem}.project-header{flex-wrap:wrap}.project-icon-wrapper{width:48px;height:48px}.project-icon-wrapper .project-icon{font-size:1.5rem}.project-title-area h3{font-size:1.15rem}.project-badge{order:3;margin-top:.5rem;width:100%;text-align:center}.project-summary{font-size:.95rem}.project-highlights li{font-size:.85rem}.project-links{flex-direction:column}.project-link{justify-content:center}}.career-timeline{display:flex;flex-direction:column;gap:1rem}.career-timeline .career-item{display:flex;align-items:flex-start;gap:1.5rem;padding:1.5rem;background:var(--bg-white);border:1px solid var(--border);border-radius:12px;border-left:4px solid var(--primary);transition:all .3s ease}.career-timeline .career-item:hover{border-color:var(--primary-light);box-shadow:0 4px 12px rgba(79,70,229,.1);transform:translateX(4px)}.career-timeline .career-item.work{border-left-color:#3b82f6}.career-timeline .career-item.education{border-left-color:#10b981}.career-timeline .career-date{min-width:140px;font-size:.9rem;font-weight:600;color:var(--primary);white-space:nowrap}.career-timeline .career-info h4{font-size:1.1rem;font-weight:700;color:var(--text-900);margin-bottom:.25rem}.career-timeline .career-info p{font-size:.9rem;color:var(--text-500)}.awards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.award-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;background:var(--bg-white);border:1px solid var(--border);border-radius:16px;transition:all .3s ease}.award-card:hover{border-color:var(--primary-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(79,70,229,.12)}.award-icon{font-size:2.5rem;flex-shrink:0}.award-info h4{font-size:1.05rem;font-weight:700;color:var(--text-900);margin-bottom:.25rem}.award-info p{font-size:.85rem;color:var(--text-500)}[data-theme=dark] .career-timeline .career-item,[data-theme=dark] .award-card{background:#243154;border-color:#3d4f7a}[data-theme=dark] .career-timeline .career-item:hover,[data-theme=dark] .award-card:hover{border-color:#818cf8}[data-theme=dark] .career-timeline .career-date{color:#818cf8}[data-theme=dark] .career-timeline .career-info h4,[data-theme=dark] .award-info h4{color:#f1f5f9}[data-theme=dark] .career-timeline .career-info p,[data-theme=dark] .award-info p{color:#94a3b8}@media(max-width:768px){.career-timeline .career-item{flex-direction:column;gap:.5rem}.career-timeline .career-date{min-width:auto}.awards-grid{grid-template-columns:1fr}}.cert-hint{font-size:.85rem;color:var(--text-400);margin-bottom:1rem;text-align:center}.cert-card.clickable{cursor:pointer}.cert-card.clickable:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 8px 24px rgba(79,70,229,.15)}.cert-card.clickable::after{content:'👁️ 보기';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--primary);color:#fff;padding:.5rem 1rem;border-radius:8px;font-size:.85rem;font-weight:600;opacity:0;transition:opacity .2s ease}.cert-card.clickable:hover::after{opacity:1}.cert-card.clickable{position:relative;overflow:hidden}.cert-card.clickable:hover>*{opacity:.3}.section-hint{text-align:center;color:var(--text-500);margin-bottom:1.5rem;font-size:.9rem}.document-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.document-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;background:var(--bg-white);border:2px solid var(--border);border-radius:16px;cursor:pointer;transition:all .3s ease}.document-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 12px 32px rgba(79,70,229,.2)}.document-icon{font-size:3rem;line-height:1}.document-info h4{font-size:1.25rem;font-weight:700;color:var(--text-900);margin:0 0 .25rem}.document-info p{font-size:.9rem;color:var(--text-500);margin:0}[data-theme=dark] .document-card{background:#243154;border-color:#3d4f7a}[data-theme=dark] .document-card:hover{border-color:#818cf8;box-shadow:0 12px 32px rgba(129,140,248,.2)}[data-theme=dark] .document-info h4{color:#f1f5f9}[data-theme=dark] .document-info p{color:#94a3b8}.pdf-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.9);z-index:10000;justify-content:center;align-items:center;animation:fadeIn .2s ease}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.pdf-modal-content{background:var(--bg-white);border-radius:20px;width:95vw;height:95vh;max-width:1400px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 80px rgba(0,0,0,.5);animation:slideUp .3s ease}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pdf-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg-gray-50)}.pdf-header h3{font-size:1.25rem;font-weight:700;color:var(--text-900);margin:0}.pdf-close{width:12px;height:12px;border:none;background:#ff5f57;border-radius:50%;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 1px 2px rgba(0,0,0,.2)}.pdf-close::before{content:"×";font-size:8px;color:rgba(0,0,0,.3);font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.pdf-close:hover{background:#ff3b30;transform:scale(1.1);box-shadow:0 2px 4px rgba(0,0,0,.3)}.pdf-viewer-container{display:flex;align-items:center;justify-content:center;padding:1.5rem;gap:1rem;background:var(--bg-gray-100);flex:1;min-height:400px}#pdf-canvas{max-width:100%;max-height:85vh;box-shadow:0 8px 32px rgba(0,0,0,.2);border-radius:4px;background:#fff}.pdf-nav{width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;border:none;font-size:1.5rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pdf-nav:hover:not(:disabled){background:var(--primary-dark);transform:scale(1.1)}.pdf-nav:disabled{background:var(--bg-gray-100);color:var(--text-400);cursor:not-allowed}.pdf-footer{text-align:center;padding:1rem 1.5rem;border-top:1px solid var(--border);background:var(--bg-gray-50)}#page-info{font-size:1rem;font-weight:600;color:var(--text-700)}.pdf-footer .pdf-hint{font-size:.8rem;color:var(--text-400);margin:.5rem 0 0}[data-theme=dark] .pdf-modal-content{background:#1e2a4a}[data-theme=dark] .pdf-header,[data-theme=dark] .pdf-footer{background:#172038;border-color:#3d4f7a}[data-theme=dark] .pdf-header h3{color:#f1f5f9}[data-theme=dark] .pdf-close{background:#3d4f7a;color:#94a3b8}[data-theme=dark] .pdf-close:hover{background:#ef4444;color:#fff}[data-theme=dark] .pdf-viewer-container{background:#243154}[data-theme=dark] .pdf-nav{background:#818cf8}[data-theme=dark] .pdf-nav:hover:not(:disabled){background:#6366f1}[data-theme=dark] .pdf-nav:disabled{background:#3d4f7a;color:#64748b}[data-theme=dark] #page-info{color:#e2e8f0}[data-theme=dark] .cert-card.clickable:hover{border-color:#818cf8}[data-theme=dark] .cert-card.clickable::after{background:#818cf8}@media(max-width:768px){.pdf-modal-content{max-width:100%;max-height:100%;border-radius:0}.pdf-header{padding:.75rem 1rem}.pdf-header h3{font-size:1rem}.pdf-viewer-container{padding:.5rem;gap:.5rem}.pdf-nav{width:44px;height:44px;font-size:1.25rem}#pdf-canvas{max-height:60vh}.pdf-footer{padding:.75rem 1rem}.cert-card.clickable::after{font-size:.75rem;padding:.35rem .75rem}}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top:4px solid var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.pdf-zoom-controls{position:absolute;top:20px;right:20px;display:flex;gap:5px;background:rgba(255,255,255,.9);border-radius:8px;padding:8px;box-shadow:0 2px 10px rgba(0,0,0,.1);z-index:1000}.pdf-zoom-controls button{width:40px;height:40px;border:none;background:var(--primary);color:#fff;border-radius:6px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.pdf-zoom-controls button:hover{background:var(--primary-dark);transform:scale(1.05)}.pdf-zoom-controls button:active{transform:scale(.95)}[data-theme=dark] .pdf-zoom-controls{background:rgba(30,42,74,.9)}[data-theme=dark] .pdf-zoom-controls button{background:#818cf8}[data-theme=dark] .pdf-zoom-controls button:hover{background:#6366f1}