body{margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@tailwind base;@tailwind components;@tailwind utilities;.main{height:100vh;transform:transale3d(0,0,0)}@media(max-width:768px){.main{background:#fff!important}}.custom-indent p:nth-child(n+2){text-indent:2em}.custom-indent p:first-child{text-indent:0!important}.no-min-width.MuiButton-root{min-width:0!important}.section-title,h1,h2,h3,h4,h5{color:#394852}@media(min-width:1200px){.container,.container-lg,.container-md,.container-sm,.container-xl{max-width:960px!important}}.MuiTimelineOppositeContent-root{padding-left:0!important;white-space:nowrap}.App{position:relative}.App a{color:inherit!important}@media(max-width:768px){.App{background:#fff!important}}.main-content{flex:1 1;padding:0 40px;transition:margin-left .3s ease-in-out;background-repeat:no-repeat;background-size:cover;color:#2a2e36}@media screen and (max-width:991px){.main-content{overflow-x:hidden!important;width:100%;max-width:100vw;padding-left:0!important;padding-right:0!important;background:#fff!important}.main-content .os-viewport{overflow:hidden!important;overflow-y:scroll!important}.main-content .os-scrollbar-horizontal{display:none!important}}@media screen and (max-width:768px){.main-content{background:#fff!important}.main-content .top-spacer{height:0!important;min-height:0!important;display:none!important}}@media screen and (max-width:576px){.main-content{padding-left:0;padding-right:0}}.main-content a{color:#394852}.main-content .total-container{min-width:0!important;height:100vh;display:flex}.main-content .total-container .right{flex:1 1;min-width:0;transition:padding-left .3s ease-in-out}.main-content .total-container.unlimited{transition:width .1s ease-in-out;margin:0;max-width:unset!important}.site-top-menu{background-color:hsla(0,0%,100%,.5);border-bottom:1px solid rgba(0,0,0,.1);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.site-top-menu .container,.site-top-menu .container-lg,.site-top-menu .container-md,.site-top-menu .container-sm,.site-top-menu .container-xl{max-width:960px!important}.site-top-menu .container{height:100%}.site-top-menu .button-row{height:100%;display:flex;justify-content:flex-end;align-items:center;flex-wrap:nowrap;overflow:hidden}.site-top-menu .button-row a{text-decoration:none;flex-shrink:1;min-width:0}.site-top-menu .button-row .menu-button{margin-left:10px;min-width:0;text-transform:none;font-feature-settings:"smcp";font-variant:small-caps;font-size:.9rem;color:unset}.site-top-menu .button-row .menu-button button{padding:0 20px}.site-top-menu .button-row .menu-button.MuiButton-text{padding:0;margin-top:3px;margin-bottom:3px}.site-top-menu .button-row .menu-button .title-container{padding:4px 6px 0;border-bottom:3px solid transparent;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}@media(max-width:768px){.site-top-menu .button-row .menu-button .title-container{padding:4px 3px}}@media(max-width:400px){.site-top-menu .button-row .menu-button .title-container{max-width:70px;padding:4px 2px}}@media(max-width:345px){.site-top-menu .button-row .menu-button .title-container{max-width:55px;padding:4px 2px}}.site-top-menu .button-row .menu-button.active .title-container{width:100%;border-top-right-radius:3px;border-bottom:3px solid #7bb9d1;color:#286197}.message-block-container{transition:all .3s ease-in-out!important;width:100%}.message-block-container.message-collapsed{position:absolute;right:-10px;transform:translateX(100%);width:60px}.message-block-container .title-row p{margin-bottom:0}.message-block-container .title-row{display:flex;background:linear-gradient(90deg,hsla(0,0%,100%,.5),hsla(0,0%,100%,0) 29%);padding:10px 20px 8px;border-top-left-radius:10px;border-top-right-radius:10px;-webkit-backdrop-filter:saturate(10%) blur(3px);backdrop-filter:saturate(10%) blur(3px);box-shadow:0 7px 29px 0 rgba(100,100,111,.3);justify-content:space-between;align-items:center}.message-block-container .title-row .title{position:relative;padding-left:30px;margin-left:20px}.message-block-container .title-row .title:before{content:"";position:absolute;left:-20px;top:10%;bottom:10%;width:10px;background-color:#e4e4f1;border-radius:5px}.message-block-container .title-row button{min-width:0}.message-block-container .title-row,.message-block-container .title-row button{color:#394852;font-weight:700;font-size:30px}.message-block-container .message-block a,.message-block-container .message-block div,.message-block-container .message-block p{word-break:break-word}.message-block-container .left-triangle{width:0;height:0;border-top:10px solid transparent;border-bottom:10px solid transparent;border-right:20px solid #fff;margin-top:20px}.message-block-container .box{background-color:#fff;box-shadow:0 7px 15px 0 rgba(100,100,111,.3);padding:30px 44px;border-radius:10px;flex:1 1;z-index:1;max-width:100%;box-sizing:border-box}@media(max-width:991px){.message-block-container>div,.message-block-container>div>div,.message-block-container>div>div>div{width:100%!important;max-width:100%!important;box-sizing:border-box;padding-left:0!important;padding-right:0!important;overflow:visible!important}.message-block-container>div>div>div{min-width:0!important}.message-block-container .title-row{box-sizing:border-box!important;box-shadow:none!important;padding:12px 12px 12px 0!important;border-radius:0!important;background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important}.message-block-container .title-row .title{margin-left:20px!important;padding-left:15px!important}.message-block-container .box{padding:16px 0!important;box-shadow:none!important;border-radius:0!important;background:transparent!important}.message-block-container .message-block{width:100%}.message-block-container .message-block *{max-width:100%;box-sizing:border-box}.message-block-container .message-block div,.message-block-container .message-block li,.message-block-container .message-block p{word-wrap:break-word;overflow-wrap:break-word}.message-block-container .message-block pre{max-width:100%!important;overflow-x:auto!important}.message-block-container .message-block img:not(.portfolio-timeline img){max-width:100%!important;height:auto!important}.message-block-container .message-block table{display:block;overflow-x:auto;max-width:100%}}@media(max-width:991px){.message-block-container .os-host-overflow-x .os-scrollbar-horizontal{display:none!important}}@media(max-width:991px)and (min-width:769px){.message-block-container .title-row{background:linear-gradient(90deg,hsla(0,0%,100%,.85),hsla(0,0%,100%,.3) 29%)!important;padding-left:75px!important;padding-right:75px!important}}@media(max-width:768px){.message-block-container>div{padding-left:0!important;padding-right:0!important;overflow:visible!important}.message-block-container>div>div,.message-block-container>div>div>div{overflow:visible!important}.message-block-container .title-row{box-sizing:border-box!important;box-shadow:none!important;padding:12px 12px 12px 0!important}.message-block-container .title-row .title{margin-left:20px!important;padding-left:15px!important}.message-block-container .box{padding:16px 0!important;box-shadow:none!important}}@media(max-width:576px){.message-block-container>div{padding-left:0!important;padding-right:0!important}.message-block-container .title-row{box-sizing:border-box!important;box-shadow:none!important;padding:10px 10px 10px 0!important}.message-block-container .title-row .title{margin-left:20px!important;padding-left:15px!important}.message-block-container .box{padding:12px 0!important;box-shadow:none!important}}.custom-collapse-button{color:inherit;transform:rotate(180deg)}.custom-collapse-button.collapsed{transform:rotate(1turn)}.custom-collapse-button.MuiButtonBase-root{min-width:10px;color:#394852;margin:0}.custom-timeline.MuiTimeline-root{padding-left:0!important;padding-right:0!important}.custom-timeline .MuiTimelineItem-content{padding-right:0}.custom-timeline .MuiTimelineOppositeContent-root{width:150px;flex:unset}@media screen and (max-width:768px){.custom-timeline .MuiTimelineOppositeContent-root{display:none}}.custom-timeline .timeline-card{position:relative;border-radius:5px;padding:10px 15px 13px;margin-right:16px}@media screen and (max-width:768px){.custom-timeline .timeline-card{margin-right:0}.custom-timeline .timeline-card>div{display:flex;flex-direction:column}.custom-timeline .timeline-card .job-summary-container{order:1}.custom-timeline .timeline-card .skill-block-container{order:2}}.custom-timeline .timeline-card .overlay-detail-button{position:absolute;top:0;left:0;width:100%;height:100%}.custom-timeline .timeline-card .title{font-weight:700;color:#394852}.custom-timeline .timeline-card .description{font-size:14px;color:#8a9aad;font-style:italic}.custom-timeline .timeline-card .description2{font-size:14px;color:#424e5c}.custom-timeline .timeline-card .description2 a{color:#989fc3!important}.custom-timeline .timeline-card .description2>ul>li{margin-top:10px}.custom-timeline .timeline-card .description2>ul>li li{margin-top:4px}.custom-timeline .timeline-card .url-link{font-size:14px}.custom-timeline .timeline-card .detail-button{text-transform:none;transform:translateY(-5px)}.custom-timeline .timeline-card .description-row{display:flex;justify-content:space-between;align-items:center;margin-top:-8px}.custom-timeline .timeline-card .description-row button{color:#8a9aad!important}.custom-timeline .timeline-card .description-row button .expanded{transition:transform .3s ease-in-out;transform:rotate(180deg)}.custom-timeline .timeline-card .description-row button .collapsed{transition:transform .3s ease-in-out;transform:rotate(0deg)}@media screen and (max-width:768px){.custom-timeline .skill-block-wrapper .skill-block-inner{flex-direction:column!important;align-items:flex-start!important;margin-top:4px!important;margin-bottom:4px!important}.custom-timeline .skill-block-wrapper .skills-label{margin-bottom:10px}.custom-timeline .skill-block-wrapper .skills-list{margin-left:0!important;width:100%}}.skills-custom-list-row{align-items:center;margin-bottom:12px}.skills-custom-list-row ul li:before{content:"•";color:#7bb9d1;font-weight:700;display:inline-block;width:.85rem}.skills-custom-list-row .category{border:1px solid hsla(0,0%,86.7%,.8352941176);border-radius:4px;box-shadow:0 2px 8px 0 rgba(99,99,99,.17);margin-bottom:20px}.skills-custom-list-row .category>div{margin-top:-14px}.skills-custom-list-row ul{margin-top:0;list-style:none;margin-left:-20px;margin-bottom:0}.skills-custom-list-row ul.flex{display:flex;flex-wrap:wrap}.skills-custom-list-row ul.flex li{margin-left:10px;white-space:nowrap}.skills-custom-list-row .custom-list-dot{height:100%;width:25px;display:flex;align-items:center;justify-content:flex-start}.skills-custom-list-row .custom-list-dot svg{height:15px;color:#9898de}.skills-custom-list-row .custom-list-item{display:block;margin-left:10px}.skills-custom-list-row .category-row{display:flex;margin-bottom:8px}.skills-custom-list-row .category-row .title{font-weight:500;width:155px;padding-top:5px;padding-bottom:5px;text-align:right;padding-right:15px}.skills-custom-list-row .category-row .list{flex:1 1;border-left:4px solid rgba(147,169,195,.3)}.skills-custom-list-row .category-row .list .list-container{margin-left:-10px;padding-top:5px;padding-bottom:5px}@media(max-width:768px){.skills-custom-list-row .category-row{flex-direction:column;margin-bottom:16px}.skills-custom-list-row .category-row .title{width:100%;text-align:left;padding-right:0;padding-left:0;padding-bottom:8px;font-weight:600}.skills-custom-list-row .category-row .list{border-left:none;border-top:none;padding-top:8px}.skills-custom-list-row .category-row .list .list-container{margin-left:0;padding-top:0}}.about-me .about-img-hover{opacity:.5}.about-me .about-img-hover:hover{opacity:1;transform:scale(1.03);box-shadow:0 8px 20px rgba(0,0,0,.15);border-color:rgba(152,159,195,.4)}.about-me .about-img-hover:active{transform:scale(.98)}.about-me .avatar-clickable{cursor:pointer;perspective:1000px;box-shadow:0 2px 4px 0 rgba(14,30,37,.1),0 2px 8px 0 rgba(14,30,37,.2);transition:box-shadow .2s ease}.about-me .avatar-clickable:hover:not(.flipping){box-shadow:0 4px 8px 0 rgba(14,30,37,.15),0 4px 16px 0 rgba(14,30,37,.3)}.about-me .avatar-clickable.flipping{animation:flip3DContainer .6s ease-in-out}.about-me .avatar-clickable.flipping img{animation:flip3D .6s ease-in-out}.about-me .avatar-clickable img{-webkit-backface-visibility:hidden;backface-visibility:hidden}.about-me .mode-switch-button{position:absolute;top:-5px;right:-25px;min-width:40px;height:40px;border-radius:20px;background:hsla(0,0%,100%,.3);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:2px solid hsla(0,0%,100%,.5);cursor:pointer;display:flex;align-items:center;justify-content:center;grid-gap:6px;gap:6px;padding:0 12px;transition:all .2s ease;box-shadow:0 2px 8px rgba(0,0,0,.15);z-index:10}.about-me .mode-switch-button svg{color:#989fc3;font-size:1.2rem;transition:transform .3s ease;flex-shrink:0}.about-me .mode-switch-button .switch-text{color:#989fc3;font-size:.85rem;font-weight:600;white-space:nowrap;transition:color .2s ease}.about-me .mode-switch-button:hover{background:hsla(0,0%,100%,.5);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transform:scale(1.05);box-shadow:0 4px 12px rgba(0,0,0,.25);border-color:hsla(0,0%,100%,.7)}.about-me .mode-switch-button:hover .switch-text,.about-me .mode-switch-button:hover svg{color:#7d84a8}.about-me .mode-switch-button:active svg{transform:rotate(180deg)}.about-me .mode-switch-button.spinning svg{animation:spin360 .6s ease-in-out}@keyframes spin360{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.about-me .contact-links-left{display:flex;flex-direction:column;grid-gap:12px;gap:12px;width:100%}@media(max-width:768px){.about-me .contact-links-left{display:grid;grid-gap:10px;gap:10px;justify-items:center}}@media(max-width:768px){.about-me .contact-links-left.programmer-mode{grid-template-columns:repeat(4,1fr)}.about-me .contact-links-left.programmer-mode .artstation-link{display:none}}@media(max-width:768px){.about-me .contact-links-left.artist-mode{grid-template-columns:repeat(5,1fr)}}.about-me .contact-icon-item{display:flex;align-items:center;grid-gap:8px;gap:8px;color:#5d5d86;text-decoration:none;transition:opacity .2s;font-size:14px}.about-me .contact-icon-item:hover{opacity:.7}.about-me .contact-icon-item svg{flex-shrink:0;width:30px!important;height:22px!important;display:flex;justify-content:center;align-items:center}.about-me .contact-icon-item span{word-break:break-word;text-align:left;flex:1 1}@media(max-width:768px){.about-me .contact-icon-item{flex-direction:column;grid-gap:4px;gap:4px;justify-content:center;font-size:12px}.about-me .contact-icon-item span{display:none}}.about-me .name-row{text-align:center;perspective:1000px;min-height:110px;display:flex;align-items:center;justify-content:center}.about-me .name-row .name-container{-webkit-backface-visibility:hidden;backface-visibility:hidden}.about-me .name-row .name-box{display:flex;flex-direction:column;align-items:center;justify-content:center;grid-gap:4px;gap:4px;padding:12px 20px;border-radius:12px;background:rgba(152,159,195,.05);border:1px solid rgba(152,159,195,.25);box-shadow:0 2px 8px rgba(0,0,0,.05);transition:all .3s ease;height:110px;width:240px}.about-me .name-row .name-box:hover{background:rgba(152,159,195,.12);border-color:rgba(152,159,195,.3);box-shadow:0 4px 12px rgba(0,0,0,.08)}.about-me .name-row .name-box .name-divider{width:80%;height:12px;margin:4px 0;position:relative;display:flex;align-items:center;justify-content:center}.about-me .name-row .name-box .name-divider:after{content:"";position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:1px;background:linear-gradient(90deg,rgba(152,159,195,.5) 0,rgba(152,159,195,.5) 7%,rgba(152,159,195,.5) 93%,rgba(152,159,195,.5));z-index:1}.about-me .name-row .name-box .name-subtitle{font-size:.85rem;color:rgba(93,93,134,.8);font-style:italic}.about-me .name-row.flipping-name .name-container{animation:flipName3D .6s ease-in-out}@keyframes fadeInSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes flipName3D{0%{transform:rotateX(0deg);opacity:1}45%{opacity:.3}55%{opacity:.3}to{transform:rotateX(1turn);opacity:1}}.about-me .job-title-row{text-align:center}.about-me .job-title-row .software-engineer{color:#989fc3;font-weight:600}.about-me .self-intro{display:flex}.about-me .self-intro .left{max-width:300px;margin-right:45px;display:flex;flex-direction:column;justify-content:flex-start}.about-me .self-intro .right{flex:1 1;position:relative}.about-me .self-intro .right .section:not(:last-child){margin-bottom:12px;padding-bottom:12px}.about-me .self-intro .right .section.section-primary{opacity:1}.about-me .self-intro .right .section.section-enter-top{animation:enterFromTop .5s ease-out forwards;opacity:0}.about-me .self-intro .right .section.section-enter-right{animation:enterFromRight .5s ease-out forwards;animation-delay:.1s;opacity:0}.about-me .self-intro .right .section.section-secondary{pointer-events:none;opacity:.2}.about-me .self-intro .right .section.section-secondary.section-enter-right{animation:enterFromRightFaded .5s ease-out forwards}.about-me .self-intro .right h5{margin-bottom:8px;padding-left:20px;position:relative;color:#5d5d86}.about-me .self-intro .right h5:nth-child(n+2){margin-top:30px}.about-me .self-intro .right h5:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:80%;background-color:#989fc3;border-radius:999px}@media(max-width:991px){.about-me .self-intro .left{padding:0 20px}}@media(max-width:768px){.about-me .self-intro{flex-direction:column}.about-me .self-intro .left{max-width:100%;margin-right:0;margin-bottom:20px}.about-me .self-intro .right{border-left:none!important;padding-left:0!important;margin-top:20px}}@keyframes fadeInContent{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes switchIn{0%{opacity:0;transform:translateX(30px) scale(.95)}to{opacity:1;transform:translateX(0) scale(1)}}@keyframes flip3D{0%{transform:rotateY(0deg);opacity:1}45%{opacity:.3}55%{opacity:.3}to{transform:rotateY(1turn);opacity:1}}@keyframes flip3DContainer{0%{box-shadow:0 2px 4px 0 rgba(14,30,37,.1),0 2px 8px 0 rgba(14,30,37,.2)}20%{box-shadow:0 1px 2px 0 rgba(14,30,37,.03),0 1px 4px 0 rgba(14,30,37,.06)}60%{box-shadow:0 1px 2px 0 rgba(14,30,37,.03),0 1px 4px 0 rgba(14,30,37,.06)}to{box-shadow:0 2px 4px 0 rgba(14,30,37,.1),0 2px 8px 0 rgba(14,30,37,.2)}}@keyframes enterFromTop{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes enterFromRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@keyframes enterFromRightFaded{0%{opacity:0;transform:translateX(30px)}to{opacity:.2;transform:translateX(0)}}.contact .linkedin-git{margin-left:-9px;display:flex}.contact .contact-item{display:flex;align-items:center;font-size:14px}.contact .contact-item .key,.contact .contact-item a{align-items:center;width:36px}.contact .contact-item .key svg,.contact .contact-item a svg{color:#5d5d86}.contact .contact-item .value{flex:1 1}.portfolio-cards-grid{display:flex;flex-direction:column;grid-gap:24px;gap:24px;padding:0}@media(max-width:768px){.portfolio-cards-grid{grid-gap:16px;gap:16px;padding:0}}.portfolio-card{background:#fff;border-radius:6px;border:1px solid #cbd5e0;box-shadow:0 4px 12px -2px rgba(0,0,0,.05),0 2px 4px -1px rgba(0,0,0,.03);transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;min-height:150px;display:flex;flex-direction:row;align-items:stretch;position:relative;cursor:pointer}.portfolio-card:hover{box-shadow:0 12px 24px -4px rgba(0,0,0,.1),0 6px 12px -2px rgba(0,0,0,.05)}.portfolio-card .portfolio-card-link{text-decoration:none;color:inherit;display:flex;flex-direction:row;height:100%;width:100%}.portfolio-card .portfolio-card-date-section{margin-bottom:12px}.portfolio-card .portfolio-card-date-section .portfolio-card-date-inline{margin-bottom:0}.portfolio-card .portfolio-card-date-section .portfolio-card-date-inline .portfolio-card-date-main{display:flex;align-items:center;grid-gap:4px;gap:4px;font-size:.9rem;color:#6b7280;font-style:italic}.portfolio-card .portfolio-card-date-section .portfolio-card-date-inline .portfolio-card-date-main span:first-child{font-weight:500}.portfolio-card .portfolio-card-date-section .portfolio-card-intro{font-size:.9rem;line-height:1.5;color:#4a5568;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.portfolio-card .portfolio-card-image-container{position:relative;width:30%;overflow:hidden;flex-shrink:0;background-color:#f7fafc;border-radius:0;align-self:stretch}.portfolio-card .portfolio-card-title-section{margin-bottom:12px}.portfolio-card .portfolio-card-title-section .portfolio-card-title{color:#1a202c;font-size:1.3rem;font-weight:600;line-height:1.3;margin-bottom:0}.portfolio-card .portfolio-card-content-area{flex:1 1;display:flex;flex-direction:column;padding:20px;min-width:0}.portfolio-card .portfolio-card-image{position:absolute;top:-20px;left:-20px;right:-20px;bottom:-20px}.portfolio-card .portfolio-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease,-webkit-filter .3s ease;transition:transform .3s ease,filter .3s ease;transition:transform .3s ease,filter .3s ease,-webkit-filter .3s ease;border-radius:0;transform-origin:center center;-webkit-filter:blur(2px);filter:blur(2px)}.portfolio-card .portfolio-card-image:hover img{transform:scale(1)}.portfolio-card:hover .portfolio-card-image img{-webkit-filter:blur(0);filter:blur(0)}.portfolio-card .portfolio-card-content{display:flex;flex-direction:column;flex:1 1}.portfolio-card .portfolio-card-content .portfolio-card-tech-list{margin-bottom:12px}.portfolio-card .portfolio-card-content .portfolio-card-tech-list .portfolio-card-tech-tags{display:flex;flex-wrap:wrap;grid-gap:6px;gap:6px}.portfolio-card .portfolio-card-content .portfolio-card-tech-list .portfolio-card-tech-tags .tech-tag{background-color:transparent;color:#2d3748;padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:500;border:1px solid #cbd5e0}.portfolio-card .portfolio-card-decorator{position:absolute;top:50%;left:40px;z-index:4;transform:translateY(-50%);pointer-events:none;opacity:.2}@media(max-width:768px){.portfolio-card{height:auto;box-shadow:none!important}.portfolio-card .portfolio-card-link{flex-direction:column}.portfolio-card .portfolio-card-image-container{display:none!important}.portfolio-card .portfolio-card-content-area{padding:16px 20px;display:flex;flex-direction:column}.portfolio-card .portfolio-card-title-section{order:1;margin-bottom:8px}.portfolio-card .portfolio-card-date-section{order:2;margin-bottom:8px}.portfolio-card .portfolio-card-content{order:3}.portfolio-card .portfolio-card-intro{display:none!important}.portfolio-card .portfolio-card-decorator{left:20px}}.portfolio-timeline{width:100%;min-height:100vh;background:#fff;overflow:hidden}@media(max-width:768px){.portfolio-timeline{padding:0 0 60px}}.portfolio-timeline .timeline-header{text-align:center;margin-bottom:60px;padding:0 20px}.portfolio-timeline .timeline-header h2{font-size:2.5rem;font-weight:700;color:#1a202c;margin-bottom:10px;letter-spacing:2px;text-transform:uppercase;background:linear-gradient(135deg,#00bcd4,#00e5ff);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}@media(max-width:768px){.portfolio-timeline .timeline-header h2{font-size:2rem}}.portfolio-timeline .timeline-header .timeline-subtitle{font-size:1.2rem;color:#64748b}@media(max-width:768px){.portfolio-timeline .timeline-header .timeline-subtitle{font-size:1rem}}.portfolio-timeline .timeline-container{max-width:100%;margin:0 auto;padding:0;position:relative}@media(max-width:768px){.portfolio-timeline .timeline-container{padding:0 20px}}.portfolio-timeline .timeline-line{position:absolute;left:95px;top:0;bottom:0;width:4px;background:#cbd5e1}@media(max-width:768px){.portfolio-timeline .timeline-line{display:none}}.portfolio-timeline .timeline-item{position:relative;margin-bottom:30px;padding-left:120px}@media(max-width:768px){.portfolio-timeline .timeline-item{padding-left:0;margin-bottom:40px}}.portfolio-timeline .timeline-date-left{position:absolute;left:0;top:18px;width:80px;text-align:right;padding-right:10px}@media(max-width:768px){.portfolio-timeline .timeline-date-left{display:none}}.portfolio-timeline .timeline-date-left .year{font-size:1rem;font-weight:400;color:#1a202c;display:inline-block;line-height:1.2;margin-bottom:2px;padding-bottom:4px;border-bottom:1px solid #cbd5e1;width:50px}.portfolio-timeline .timeline-date-left .day-month{font-size:.85rem;color:#64748b;display:block;font-weight:500;padding-top:2px;font-style:italic}.portfolio-timeline .timeline-dot{position:absolute;left:97px;top:24px;width:14px;height:14px;background:#fff;border:2px solid #00bcd4;border-radius:50%;z-index:2;transition:all .3s ease;transform:translateX(-50%);box-shadow:0 0 0 5px #fff}@media(max-width:768px){.portfolio-timeline .timeline-dot{display:none}}.portfolio-timeline .timeline-dot .dot-inner{display:none}.portfolio-timeline .timeline-content{background:#fff;border:1px solid #ebebeb;border-radius:4px;opacity:.7;overflow:hidden;display:flex;flex-direction:row;position:relative;cursor:pointer;z-index:1;transition:all .3s ease;box-shadow:0 1px 3px rgba(0,0,0,.1)}@media(max-width:768px){.portfolio-timeline .timeline-content{flex-direction:column}}.portfolio-timeline .timeline-content .timeline-thumbnail img{transition:-webkit-filter .3s ease;transition:filter .3s ease;transition:filter .3s ease,-webkit-filter .3s ease}.portfolio-timeline .timeline-content:hover{border-color:#c7c7c7;opacity:1}.portfolio-timeline .timeline-content:hover .timeline-thumbnail img{-webkit-filter:blur(0);filter:blur(0)}.portfolio-timeline .timeline-item:hover .timeline-dot{transform:translateX(-50%) scale(1.15);border-color:#00e5ff;box-shadow:0 0 0 5px #fff,0 0 0 8px rgba(0,188,212,.2)}.portfolio-timeline .timeline-thumbnail{width:30%;min-width:200px;max-width:300px;min-height:200px;flex-shrink:0;overflow:hidden;position:relative;background:#f3f4f6;align-self:stretch}@media(max-width:768px){.portfolio-timeline .timeline-thumbnail{width:100%;min-width:100%;max-width:100%;height:140px;min-height:auto;align-self:auto}}@media(max-width:576px){.portfolio-timeline .timeline-thumbnail{height:120px}}.portfolio-timeline .timeline-thumbnail img{position:absolute;top:0;left:0;width:100%;height:100%;display:block;object-fit:cover;object-position:center;transition:-webkit-filter .3s ease;transition:filter .3s ease;transition:filter .3s ease,-webkit-filter .3s ease;-webkit-filter:blur(2px);filter:blur(2px);border:0;border-radius:0}@media(max-width:768px){.portfolio-timeline .timeline-thumbnail img{object-fit:cover;object-position:center top}}.portfolio-timeline .timeline-text{flex:1 1;width:70%;padding:10px 24px 0;display:flex;flex-direction:column;position:relative;min-width:0}@media(max-width:768px){.portfolio-timeline .timeline-text{width:100%;padding:14px 18px}}.portfolio-timeline .timeline-date{font-size:1.2rem;font-weight:700;color:#1a202c;margin-bottom:10px;letter-spacing:.3px}@media(max-width:768px){.portfolio-timeline .timeline-date{font-size:1rem;margin-bottom:6px}}.portfolio-timeline .timeline-date-mobile{display:none;font-size:.85rem;color:#64748b;font-weight:500;font-style:italic;margin-bottom:10px}@media(max-width:768px){.portfolio-timeline .timeline-date-mobile{display:block}}.portfolio-timeline .timeline-subtitle-text{font-size:.95rem;color:#64748b;line-height:1.7;margin-bottom:14px;font-style:italic}@media(max-width:768px){.portfolio-timeline .timeline-subtitle-text{font-size:.9rem;margin-bottom:12px}}.portfolio-timeline .timeline-tech-stack{display:flex;flex-wrap:wrap;grid-gap:6px;gap:6px;margin-bottom:14px}@media(max-width:768px){.portfolio-timeline .timeline-tech-stack{grid-gap:5px;gap:5px;margin-bottom:12px}}.portfolio-timeline .timeline-tech-stack .tech-badge{background:#e0f7fa;border:1px solid #b2ebf2;color:#004d54;padding:4px 10px;border-radius:4px;font-size:.75rem;font-weight:500;transition:all .2s ease;white-space:nowrap}@media(max-width:768px){.portfolio-timeline .timeline-tech-stack .tech-badge{padding:3px 8px;font-size:.7rem}}.portfolio-timeline .timeline-tech-stack .tech-badge:hover{background:#b2ebf2;border-color:#00bcd4;transform:translateY(-2px)}.portfolio-timeline .timeline-tech-stack .tech-badge.more{background:#f3f4f6;border-color:#d1d5db;color:#64748b}.portfolio-timeline .timeline-date-label{display:none}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.math-material ul{margin-left:-20px;list-style:none}.math-material ul li:before{content:"•";color:#7bb9d1;font-weight:700;display:inline-block;width:.85rem}.math-material .notes{display:flex}@media(max-width:768px){.math-material .notes{flex-direction:column}}.math-material .notes .button-column{margin-right:10px;width:180px;display:block;align-items:flex-end}@media(max-width:768px){.math-material .notes .button-column{width:100%;margin-right:0;margin-bottom:20px;display:flex;flex-direction:row;justify-content:flex-start;flex-wrap:wrap;grid-gap:8px;gap:8px}}.math-material .notes .button-column button{border-top-right-radius:2px;border-bottom-right-radius:2px;width:100%;padding:4px 10px 4px 0;display:flex;justify-content:flex-end;margin-bottom:4px}@media(max-width:768px){.math-material .notes .button-column button{width:auto;flex:0 0 auto;margin-bottom:0;padding:6px 12px;justify-content:center;border-radius:3px}}.math-material .notes .notes-column{flex:1 1}.math-material .notes .topic-button{border-radius:0;padding:0 4px;margin-right:10px;border-left:3px solid transparent;text-transform:capitalize;font-feature-settings:"smcp";font-variant:small-caps}@media(max-width:768px){.math-material .notes .topic-button{border-left:none;border-bottom:3px solid transparent;margin-right:0}}.math-material .notes .active{border-left-color:#7bb9d1;background-color:#deeaee}@media(max-width:768px){.math-material .notes .active{border-left-color:transparent;border-bottom-color:#7bb9d1}}.math-material .notes .tutorial-notes{font-size:.9}.math-material .notes .tutorial-notes .tutorial-title-row{width:100%;display:flex}.math-material .notes .tutorial-notes .tutorial-title-row .title{font-size:.95rem;flex:1 1}@media(max-width:768px){.math-material .notes .tutorial-notes .tutorial-title-row{flex-direction:column}}.math-material .notes .link-row{display:flex}.math-material .notes .link-row .link-detail{flex:1 1}.math-material .notes .title{color:#33353f}.math-material .notes .topic{font-weight:500;width:80px;text-align:right;border-right:4px solid rgba(0,0,0,.1);font-size:.9rem;padding-right:15px;margin-right:28px}@media(max-width:768px){.math-material .notes .topic{width:100%;text-align:left;border-right:none;padding-right:0;margin-right:0;margin-bottom:8px}}.math-material .notes .topic{font-weight:unset}.math-material .notes .note{margin-bottom:10px}.math-material a{color:#387397}.react-images__header_button--fullscreen{display:none!important}.react-photo-gallery--gallery,.react-photo-gallery--gallery *{transition:all 0s ease!important}.react-photo-gallery--gallery img{object-fit:cover;border-radius:3px}.blog .category-wrapper,.blog .search-wrapper,.blog .toc-wrapper{padding-left:75px;padding-right:75px}@media(max-width:768px){.blog .category-wrapper,.blog .search-wrapper,.blog .toc-wrapper{padding-left:0;padding-right:0}}.blog .category-row{padding-top:0;padding-bottom:20px;font-size:1.15rem;font-weight:550;align-items:center}.blog .category-row sup{margin-left:4px;font-size:.75rem;opacity:.6;font-weight:500}.blog .category-row ul{padding-left:0;margin-left:0;margin-bottom:0;display:flex;flex-wrap:wrap;grid-gap:10px;gap:10px;list-style:none}.blog .category-row ul li{margin:0}.blog .category-row .top-row{width:100%;display:flex;justify-content:space-between}.blog .category-row .top-row .cat-left{color:#394852;white-space:nowrap;font-size:1.4rem}.blog .category-row .top-row .cat-right button{color:#394852!important;svg-color:#394852}.blog .category-row .cat-button{display:inline-flex;white-space:nowrap;justify-content:center;align-items:center;position:relative;-webkit-user-select:none;-ms-user-select:none;user-select:none;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;padding:8px 20px;cursor:pointer;font-size:.9rem;color:#374151;font-weight:500;transition:all .2s ease;box-shadow:0 1px 2px rgba(0,0,0,.05);overflow:hidden}.blog .category-row .cat-button svg{margin-right:6px}.blog .category-row .cat-button:hover{background:#e5e7eb;border-color:#d1d5db;box-shadow:0 2px 4px rgba(0,0,0,.1)}.blog .category-row .cat-button.active{background:#3b6291;color:#fff;border-color:#3b6291;box-shadow:0 2px 4px rgba(59,98,145,.3)}.blog .category-row .cat-button.active sup{opacity:.8}.blog .category-row .cat-button.active svg{color:#fff!important}.blog .category-row .cat-button.cat-ellipsis{background:transparent;border:1px dashed #d1d5db;color:#9ca3af;font-size:1.2rem;cursor:default;pointer-events:none;letter-spacing:2px}.blog .category-row .cat-button.cat-ellipsis:hover{background:transparent;border-color:#d1d5db;transform:none;box-shadow:none}.blog blockquote{background-color:#f1f1f1;border-left:.5rem solid #d6d6d6;border-radius:6px;padding:.3rem 1rem;margin:0 0 1rem}.blog blockquote p{margin-bottom:0}.blog blockquote ol,.blog blockquote ul{margin-top:.6rem}.blog pre code{padding:0;font-size:.85rem!important}@media(max-width:768px){.blog{width:100%;max-width:100vw;overflow-x:hidden;box-sizing:border-box}.blog .category-row{padding-top:12px;padding-bottom:12px}.blog .category-row ul{grid-gap:8px;gap:8px}.blog .category-row .cat-button{padding:6px 12px;font-size:.85rem}.blog .category-row sup{font-size:.7rem}}.token{background:none!important}.articles .display-math,.articles h1,.articles h2,.articles h3,.articles h4,.articles h5,.articles h6{color:inherit;font-family:unset!important;font-weight:550}.articles .display-math~p,.articles h1~p,.articles h2~p,.articles h3~p,.articles h4~p,.articles h5~p,.articles h6~p{text-indent:0;margin-top:1em;margin-bottom:1em}.articles .display-math+p,.articles h1+p,.articles h2+p,.articles h3+p,.articles h4+p,.articles h5+p,.articles h6+p{text-indent:0!important}.articles h5,.articles h6{margin-top:40px;margin-bottom:15px}.articles h5{font-size:21px!important}.articles h6{font-size:19.5px!important}.articles center+p,.articles ol+p,.articles pre+p,.articles ul+p{text-indent:0!important}.articles h4{margin-top:40px;margin-bottom:20px}.articles ul ul{margin-bottom:0}.articles .TOC-heading>ul{margin-bottom:20px}.articles .TOC-heading ul>li{margin-bottom:10px}.articles .TOC-heading ul>li>ul>li{margin-top:10px;margin-bottom:-5px}.articles .TOC-heading ul>li>ul>li:first-child{margin-top:2px}.articles .prev-next-article-buttons-row{display:flex;justify-content:space-between}.articles .prev-next-article-buttons-row button{text-transform:none;color:#394852}.articles code{background-color:#f5f2f0;padding:.2em .4em;border-radius:6px;color:inherit}.articles pre code{padding:unset}.articles .title p{margin-bottom:0}.articles img{border-radius:4px;box-shadow:0 6px 24px 0 rgba(0,0,0,.05),0 0 0 1px rgba(0,0,0,.08);max-width:100%;height:auto}.articles pre{border-radius:5px;transition:max-width .3s ease-in-out;max-width:860px;overflow-x:auto}.articles pre code{padding:0}.articles.expanded pre{max-width:1040px}.articles .katex-display>.katex{white-space:normal;color:#000}.articles .katex-display>.base{margin:.25em 0}.articles .katex-display{margin:.5em 0}.articles .date{opacity:.7}.articles .date.edited{opacity:.5;font-size:.9rem;font-style:italic}.articles .articles-container{display:flex;justify-content:center}.articles .articles-container .toc-column{text-align:right;border-right:3px solid rgba(0,0,0,.05);padding-right:11px}.articles .articles-container .toc-column .toc-title-row{border-left:3px solid transparent;border-radius:2px;border-top-left-radius:0;border-bottom-left-radius:0;padding-top:5px;padding-bottom:5px;position:relative}.articles .articles-container .toc-column .toc-title-row.active{border-left-color:#7bb9d1;background-color:#deeaee}.articles .articles-container .toc-column .toc-title-row.active .toc-title{font-weight:500;font-size:.88rem}.articles .articles-container .toc-column .toc-title-row .toc-title{font-size:.9rem;line-height:1.2rem;padding:2px 10px}.articles .articles-container .toc-column .toc-title-row .toc-title .toc-title-text{width:100%}.articles .articles-container .toc-column .toc-title-row .toc-date{margin-top:4px;font-size:.95rem;opacity:.7}.articles .articles-container .toc-column .toc-title-row .toc-button{position:absolute;top:0;left:-3px;width:calc(100% + 3px);height:100%;border-radius:0}.articles .articles-container .content{flex:1 1;width:100%;padding:10px 75px 75px}@media(max-width:768px){.articles .articles-container .content{padding:10px 0}}.articles .articles-container .content .article{font-weight:0}.articles .articles-container .content .article>div{position:relative}.articles .articles-container .content .article>div qed:after{display:inline-block;position:absolute;content:"■";width:.6rem;height:1.2rem;color:#394852;right:5px;transform:scale(1.1)}.articles .articles-container .content .first-row{display:flex;align-items:center;justify-content:space-between}.articles .articles-container .content .archive-button-row{display:flex}.articles .articles-container .content .archive-button-row button{text-transform:capitalize;font-feature-settings:"smcp";font-variant:small-caps;min-width:4px;font-size:1rem;color:#394852}.articles h5{margin-top:20px;margin-bottom:15px}@media(max-width:768px){.articles .articles-container{flex-direction:column}.articles .articles-container .toc-column{display:none}.articles .articles-container .content{padding:10px 0}.articles .articles-container .content .article{width:100%;overflow-x:hidden}.articles pre{margin-left:0;margin-right:0}.articles.expanded pre,.articles pre{max-width:calc(100vw - 16px)!important}.articles table{display:block;overflow-x:auto;max-width:100%}}.tech-blog{line-height:28px;font-size:110%}.tech-blog code,.tech-blog pre{font-size:16px}.achive-drawer{padding:20px 40px}.achive-drawer .toc-home-title-text p{margin-bottom:0}.achive-drawer .close-button-row{position:-webkit-sticky;position:sticky;top:0;padding-top:10px;padding-bottom:5px;background-color:#fff;width:100%;z-index:2}.achive-drawer .close-button-row button{margin-left:-8px;text-transform:capitalize;font-feature-settings:"smcp";font-variant:small-caps;color:#394852}.achive-drawer .toc-home-row{border-left:4px solid transparent;padding-left:20px;margin-bottom:20px}.achive-drawer .toc-home-row.active{border-left-color:#7bb9d1}.achive-drawer .toc-home-row .toc-home-title{padding-bottom:2px}.achive-drawer .toc-home-row .toc-home-title-text{transition:color .15s ease-in-out;cursor:pointer;color:#394852;font-weight:550;font-size:1.05rem}.achive-drawer .toc-home-row .toc-home-title-text:hover{color:rgba(59,98,145,.6862745098)}.achive-drawer .toc-home-row .toc-home-date{padding-top:2px;white-space:nowrap;color:#394852;font-size:1rem;opacity:.8}.tags-drawer{padding:20px 40px;height:100%;overflow-y:auto}.tags-drawer .close-button{background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;padding:6px 12px;font-size:.875rem;font-weight:500;color:#374151;transition:all .2s ease;min-width:auto;display:flex;align-items:center;grid-gap:6px;gap:6px}.tags-drawer .close-button:hover{background-color:#e5e7eb;border-color:#9ca3af;color:#1f2937}.tags-drawer .close-button:focus{outline:2px solid #3b6291;outline-offset:2px}.tags-drawer .close-button svg{font-size:1rem;flex-shrink:0}.tags-drawer .tags-drawer-header{display:flex;justify-content:space-between;align-items:center}.tags-drawer .tags-drawer-header h3{padding:0;font-size:1.5rem;font-weight:600;color:#394852;margin:0 0 10px}.tags-drawer .clear-select-section{margin:8px 0 12px}.tags-drawer .clear-select-section .clear-select-button{width:100%;background:#fef3f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.9rem;font-weight:500;padding:10px 16px;cursor:pointer;transition:all .2s ease;text-align:center}.tags-drawer .clear-select-section .clear-select-button:hover{background:#fee2e2;border-color:#fca5a5;color:#b91c1c}.tags-drawer .clear-select-section .clear-select-button:active{background:#fecaca}.tags-drawer .clear-select-section .clear-select-button.disabled{background:#f9fafb;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed;opacity:.6}.tags-drawer .clear-select-section .clear-select-button.disabled:hover{background:#f9fafb;border-color:#e5e7eb;color:#9ca3af}.tags-drawer .tags-drawer-content{margin-top:8px}.tags-drawer .tags-drawer-content .tag-letter-section{margin-bottom:20px}.tags-drawer .tags-drawer-content .tag-letter-section .tag-letter-header{font-size:1.1rem;font-weight:600;color:#3b6291;margin:0 0 12px;padding-bottom:6px;border-bottom:2px solid #e5e7eb}.tags-drawer .tags-drawer-content ul{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;grid-gap:10px;gap:10px}.tags-drawer .tags-drawer-content .tag-button{display:inline-flex;white-space:nowrap;justify-content:center;align-items:center;position:relative;-webkit-user-select:none;-ms-user-select:none;user-select:none;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;padding:8px 20px;cursor:pointer;font-size:.9rem;color:#374151;font-weight:500;transition:all .2s ease;box-shadow:0 1px 2px rgba(0,0,0,.05);overflow:hidden}.tags-drawer .tags-drawer-content .tag-button svg{margin-right:6px;flex-shrink:0}.tags-drawer .tags-drawer-content .tag-button sup{margin-left:4px;font-size:.75rem;opacity:.6;font-weight:500}.tags-drawer .tags-drawer-content .tag-button:hover{background:#e5e7eb;border-color:#d1d5db;box-shadow:0 2px 4px rgba(0,0,0,.1)}.tags-drawer .tags-drawer-content .tag-button.active{background:#3b6291;color:#fff;border-color:#3b6291;box-shadow:0 2px 4px rgba(59,98,145,.3)}.tags-drawer .tags-drawer-content .tag-button.active sup{opacity:.8}@media(max-width:768px){.tags-drawer{padding:16px}.tags-drawer .tags-drawer-header h3{font-size:1.2rem;margin-bottom:8px}.tags-drawer .tags-drawer-header .close-button{padding:4px 10px;font-size:.8rem;grid-gap:4px;gap:4px}.tags-drawer .tags-drawer-header .close-button svg{font-size:.9rem}.tags-drawer .clear-select-section{margin:6px 0 10px}.tags-drawer .clear-select-section .clear-select-button{font-size:.85rem;padding:8px 12px}.tags-drawer .tags-drawer-content{margin-top:6px}.tags-drawer .tags-drawer-content .tag-letter-section{margin-bottom:16px}.tags-drawer .tags-drawer-content .tag-letter-section .tag-letter-header{font-size:1rem;margin-bottom:10px}.tags-drawer .tags-drawer-content ul{grid-gap:8px;gap:8px}.tags-drawer .tags-drawer-content .tag-button{padding:6px 10px;font-size:.8rem;min-width:auto}.tags-drawer .tags-drawer-content .tag-button sup{font-size:.65rem}.tags-drawer .tags-drawer-content .tag-button svg{margin-right:4px;transform:scale(.9);flex-shrink:0}}@media(max-width:480px){.tags-drawer{padding:12px}.tags-drawer .tags-drawer-header h3{font-size:1.1rem;margin-bottom:6px}.tags-drawer .tags-drawer-header .clear-select-section{margin:4px 0 8px}.tags-drawer .tags-drawer-header .clear-select-section .clear-select-button{font-size:.8rem;padding:6px 10px}.tags-drawer .tags-drawer-header .close-button{padding:3px 8px;font-size:.75rem;grid-gap:3px;gap:3px}.tags-drawer .tags-drawer-header .close-button svg{font-size:.8rem}.tags-drawer .tags-drawer-content{margin-top:4px}.tags-drawer .tags-drawer-content .tag-letter-section{margin-bottom:12px}.tags-drawer .tags-drawer-content .tag-letter-section .tag-letter-header{font-size:.9rem;margin-bottom:8px}.tags-drawer .tags-drawer-content ul{grid-gap:6px;gap:6px}.tags-drawer .tags-drawer-content .tag-button{padding:4px 8px;font-size:.75rem;border-radius:16px}.tags-drawer .tags-drawer-content .tag-button sup{font-size:.6rem}.tags-drawer .tags-drawer-content .tag-button svg{margin-right:3px;transform:scale(.8);flex-shrink:0}}@media(max-width:768px){.scroll-top-meter{right:15px!important;bottom:15px!important}}.toc-home{width:100%;overflow:visible}.toc-home>div>div{margin-bottom:0!important;padding-bottom:0!important}.toc-home .toc-read-more-button{cursor:pointer;display:inline-block;transition:opacity .1s ease-in-out;border:1px solid #e83e8c;border-radius:5px;padding:4px 10px}.toc-home .toc-read-more-button:hover{opacity:.5}.toc-home .toc-cards-grid{display:grid;grid-template-columns:1fr;grid-gap:16px;gap:16px;padding:0}.toc-home .toc-card-wrapper{display:block;margin-bottom:16px}.toc-home .toc-home-row{display:flex;margin-bottom:20px}.toc-home .toc-home-row .toc-home-title{border-left:4px solid rgba(59,98,145,.1490196078);flex:1 1;padding:20px 20px 2px}.toc-home .toc-home-row .toc-home-title p{margin-bottom:0}.toc-home .toc-home-row .toc-home-title-text{display:flex}.toc-home .toc-home-row .toc-home-title-text .toc-home-text-container{margin-top:-20px;margin-left:-10px;padding:0 10px;transition:color .15s ease-in-out;opacity:1;cursor:pointer;color:#394852;line-height:1.8rem;font-weight:550;font-size:1.25rem}.toc-home .toc-home-row .toc-home-title-text .toc-home-text-container:hover{color:rgba(59,98,145,.6862745098)}.toc-home .toc-home-row .toc-home-date{white-space:nowrap;text-align:right;padding-right:15px;margin-right:24px;width:120px;max-width:120px;padding-top:2px;color:#394852;font-size:1rem;opacity:.8}.toc-home .toc-home-row .toc-home-date .edited{font-size:.8rem;opacity:.7}.toc-home .toc-home-row .toc-home-intro{opacity:.5}.toc-card{background:#fff;border-radius:6px;box-shadow:0 2px 4px -1px rgba(0,0,0,.06),0 1px 2px -1px rgba(0,0,0,.04);transition:all .3s ease;overflow:hidden;border:1px solid rgba(59,98,145,.08);display:flex;flex-direction:row;height:140px!important;max-height:140px;min-height:140px;position:relative;cursor:pointer}.toc-card:hover{box-shadow:0 12px 24px -8px rgba(0,0,0,.15),0 8px 12px -4px rgba(0,0,0,.06);border-color:rgba(59,98,145,.3)}.toc-card.toc-card-vertical{border-color:#e5eaef!important;cursor:pointer!important;background-color:#fdfefe!important;flex-direction:column!important;height:auto!important;max-height:none!important;min-height:100px!important}.toc-card.toc-card-vertical:hover{background-color:#ecf0f3!important;border-color:#a0aec0!important;box-shadow:none}.toc-card.toc-card-vertical .toc-card-image-container,.toc-card.toc-card-vertical .toc-card-link,.toc-card.toc-card-vertical .toc-card-title{cursor:pointer!important}.toc-card.toc-card-vertical .toc-card-link{grid-template-columns:1fr!important;grid-template-rows:180px auto auto!important}.toc-card.toc-card-vertical .toc-card-image-container{position:relative!important;width:100%!important;height:180px!important;left:0!important;top:0!important;bottom:auto!important}.toc-card.toc-card-vertical .toc-card-title-section{grid-row:2!important;grid-column:1!important;padding:12px 12px 8px!important}.toc-card.toc-card-vertical .toc-card-title-section .toc-card-title{-webkit-line-clamp:2!important;font-size:.95rem!important}.toc-card.toc-card-vertical .toc-card-content-area{grid-row:3!important;grid-column:1!important;padding:0 12px!important}.toc-card.toc-card-vertical .toc-card-content-area .toc-card-intro{-webkit-line-clamp:3!important}@media(max-width:768px){.toc-card:not(.toc-card-vertical),.toc-card:not(.toc-card-vertical):hover{border-color:#cbd5e0!important}}.toc-card .toc-card-link{display:grid;grid-template-columns:200px 1fr;grid-template-rows:auto 1fr;text-decoration:none;color:inherit;width:100%;height:100%;position:relative}.toc-card .toc-card-link:hover{color:inherit}.toc-card .toc-card-title-section{grid-row:1;grid-column:2;margin-bottom:0;padding:10px 14px 0 20px}.toc-card .toc-card-title-section .toc-card-title{font-size:1.25rem;font-weight:600;line-height:1.25;color:#374151;margin:0 0 12px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;text-decoration:none}.toc-card .toc-card-title-section .toc-card-title p{margin:0;color:#374151}.toc-card .toc-card-title-section .toc-card-title *{color:#374151!important}.toc-card .toc-card-title-section .toc-card-date-inline{display:flex;flex-direction:row;align-items:flex-start;grid-gap:16px;gap:16px;margin-bottom:8px}.toc-card .toc-card-title-section .toc-card-date-inline .toc-card-date-section{display:flex;flex-direction:column;grid-gap:2px;gap:2px;min-width:150px;flex-shrink:0}.toc-card .toc-card-title-section .toc-card-date-inline .toc-card-date-main{display:flex;align-items:center;grid-gap:4px;gap:4px;font-size:.9rem;color:#6b7280;font-style:italic;white-space:nowrap}.toc-card .toc-card-title-section .toc-card-date-inline .toc-card-date-main span:first-child{font-weight:500}.toc-card .toc-card-title-section .toc-card-date-inline .toc-card-edited{font-size:.8rem;color:#9ca3af;font-style:italic;white-space:nowrap}.toc-card .toc-card-title-section .toc-card-date-inline .toc-card-edited span:first-child{margin-right:4px}.toc-card .toc-card-title-section .toc-card-date-inline .toc-card-tags{font-size:.85rem;display:flex;align-items:center}.toc-card .toc-card-title-section .toc-card-date-inline .toc-card-tags code{background-color:#6b7280!important;color:#fff!important}@media(max-width:991px){.toc-card .toc-card-title-section .toc-card-date-inline .toc-card-tags{display:none}}.toc-card .toc-card-title-section:not(.no-intro){padding-bottom:0;border-bottom:none}.toc-card .toc-card-image-container{position:absolute;left:0;top:0;bottom:0;width:200px;overflow:hidden;text-decoration:none;display:block}.toc-card .toc-card-content-area{grid-row:2;grid-column:2;display:none;flex-direction:column;padding:6px 14px 10px 20px;overflow:hidden;align-self:start}.toc-card .toc-card-image{position:absolute;top:0;left:0;right:0;bottom:0}.toc-card .toc-card-image img{max-width:100%!important;height:auto!important;object-fit:cover;transition:transform .3s ease,-webkit-filter .3s ease;transition:transform .3s ease,filter .3s ease;transition:transform .3s ease,filter .3s ease,-webkit-filter .3s ease;transform-origin:center center;-webkit-filter:blur(5px) opacity(.4);filter:blur(5px) opacity(.4)}.toc-card .toc-card-image:hover img{transform:scale(1.05)}.toc-card:hover .toc-card-image img{-webkit-filter:blur(0) opacity(1);filter:blur(0) opacity(1)}.toc-card .toc-card-date{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid grayscale(0)}.toc-card .toc-card-date .toc-card-date-main{display:flex;align-items:center;grid-gap:4px;gap:4px;font-size:.9rem;color:#6b7280;font-style:italic}.toc-card .toc-card-date .toc-card-date-main span:first-child{font-weight:500}.toc-card .toc-card-date .toc-card-edited{margin-top:8px;font-size:.8rem;color:#9ca3af;font-style:italic}.toc-card .toc-card-date .toc-card-edited span:first-child{margin-right:4px}.toc-card .toc-card-content{flex:1 1;display:flex;flex-direction:column;overflow:hidden}.toc-card .toc-card-content .toc-card-intro{color:#6b7280;font-size:.95rem;line-height:1.4;opacity:.5;margin-top:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.toc-card .toc-card-content .toc-card-intro p{margin:0;display:inline}.toc-card.toc-card-vertical .toc-card-image-container{display:none!important}.toc-card.toc-card-vertical .toc-card-link{display:flex!important;flex-direction:column!important;grid-template-columns:unset!important;grid-template-rows:unset!important}.toc-card.toc-card-vertical .toc-card-title-section{grid-row:unset!important;grid-column:unset!important;display:flex!important;flex-direction:column!important;border-bottom:none!important;padding:12px 16px!important}.toc-card.toc-card-vertical .toc-card-content-area{padding:0!important;grid-row:unset!important;grid-column:unset!important;display:none!important}.toc-card.toc-card-vertical .toc-card-content-area .toc-card-intro{display:none!important}@media(max-width:991px){.toc-card:not(.toc-card-vertical) .toc-card-link{grid-template-columns:200px 1fr}.toc-card:not(.toc-card-vertical) .toc-card-image-container{width:200px}}@media(max-width:768px){.toc-card.toc-card-horizontal{height:auto!important}.toc-card.toc-card-horizontal .toc-card-image-container{display:none!important}.toc-card.toc-card-horizontal .toc-card-link{display:flex!important;flex-direction:column!important;grid-template-columns:unset!important;grid-template-rows:unset!important}.toc-card.toc-card-horizontal .toc-card-title-section{grid-row:unset!important;grid-column:unset!important;display:flex!important;flex-direction:column!important;border-bottom:none!important;padding:12px 16px!important}.toc-card.toc-card-horizontal .toc-card-title-section .toc-card-date-tags-row{flex-direction:column!important;align-items:flex-start!important;grid-gap:8px!important;gap:8px!important;margin-bottom:8px!important}.toc-card.toc-card-horizontal .toc-card-content-area{padding:0!important;grid-row:unset!important;grid-column:unset!important;display:none!important}.toc-card.toc-card-horizontal .toc-card-content-area .toc-card-intro{display:none!important}}.custom-loading-overlay{position:absolute;width:100vw;height:100vh;background-color:hsla(0,0%,100%,.6);z-index:2}.custom-loading-overlay .loading-svg{position:absolute;top:calc(50% - 20px);left:calc(50% - 20px);transition:unset!important}