@font-face{font-family:'Noto Sans';font-weight:400;font-style:normal;src:url("../fonts/Noto-Sans-regular/Noto-Sans-regular.eot");src:url("../fonts/Noto-Sans-regular/Noto-Sans-regular.eot?#iefix") format("embedded-opentype"),local("Noto Sans"),local("Noto-Sans-regular"),url("../fonts/Noto-Sans-regular/Noto-Sans-regular.woff2") format("woff2"),url("../fonts/Noto-Sans-regular/Noto-Sans-regular.woff") format("woff"),url("../fonts/Noto-Sans-regular/Noto-Sans-regular.ttf") format("truetype"),url("../fonts/Noto-Sans-regular/Noto-Sans-regular.svg#NotoSans") format("svg")}@font-face{font-family:'Noto Sans';font-weight:700;font-style:normal;src:url("../fonts/Noto-Sans-700/Noto-Sans-700.eot");src:url("../fonts/Noto-Sans-700/Noto-Sans-700.eot?#iefix") format("embedded-opentype"),local("Noto Sans Bold"),local("Noto-Sans-700"),url("../fonts/Noto-Sans-700/Noto-Sans-700.woff2") format("woff2"),url("../fonts/Noto-Sans-700/Noto-Sans-700.woff") format("woff"),url("../fonts/Noto-Sans-700/Noto-Sans-700.ttf") format("truetype"),url("../fonts/Noto-Sans-700/Noto-Sans-700.svg#NotoSans") format("svg")}@font-face{font-family:'Noto Sans';font-weight:400;font-style:italic;src:url("../fonts/Noto-Sans-italic/Noto-Sans-italic.eot");src:url("../fonts/Noto-Sans-italic/Noto-Sans-italic.eot?#iefix") format("embedded-opentype"),local("Noto Sans Italic"),local("Noto-Sans-italic"),url("../fonts/Noto-Sans-italic/Noto-Sans-italic.woff2") format("woff2"),url("../fonts/Noto-Sans-italic/Noto-Sans-italic.woff") format("woff"),url("../fonts/Noto-Sans-italic/Noto-Sans-italic.ttf") format("truetype"),url("../fonts/Noto-Sans-italic/Noto-Sans-italic.svg#NotoSans") format("svg")}@font-face{font-family:'Noto Sans';font-weight:700;font-style:italic;src:url("../fonts/Noto-Sans-700italic/Noto-Sans-700italic.eot");src:url("../fonts/Noto-Sans-700italic/Noto-Sans-700italic.eot?#iefix") format("embedded-opentype"),local("Noto Sans Bold Italic"),local("Noto-Sans-700italic"),url("../fonts/Noto-Sans-700italic/Noto-Sans-700italic.woff2") format("woff2"),url("../fonts/Noto-Sans-700italic/Noto-Sans-700italic.woff") format("woff"),url("../fonts/Noto-Sans-700italic/Noto-Sans-700italic.ttf") format("truetype"),url("../fonts/Noto-Sans-700italic/Noto-Sans-700italic.svg#NotoSans") format("svg")}.highlight table td{padding:5px}.highlight table pre{margin:0}.highlight .cm{color:#999988;font-style:italic}.highlight .cp{color:#999999;font-weight:bold}.highlight .c1{color:#999988;font-style:italic}.highlight .cs{color:#999999;font-weight:bold;font-style:italic}.highlight .c,.highlight .cd{color:#999988;font-style:italic}.highlight .err{color:#a61717;background-color:#e3d2d2}.highlight .gd{color:#000000;background-color:#ffdddd}.highlight .ge{color:#000000;font-style:italic}.highlight .gr{color:#aa0000}.highlight .gh{color:#999999}.highlight .gi{color:#000000;background-color:#ddffdd}.highlight .go{color:#888888}.highlight .gp{color:#555555}.highlight .gs{font-weight:bold}.highlight .gu{color:#aaaaaa}.highlight .gt{color:#aa0000}.highlight .kc{color:#000000;font-weight:bold}.highlight .kd{color:#000000;font-weight:bold}.highlight .kn{color:#000000;font-weight:bold}.highlight .kp{color:#000000;font-weight:bold}.highlight .kr{color:#000000;font-weight:bold}.highlight .kt{color:#445588;font-weight:bold}.highlight .k,.highlight .kv{color:#000000;font-weight:bold}.highlight .mf{color:#009999}.highlight .mh{color:#009999}.highlight .il{color:#009999}.highlight .mi{color:#009999}.highlight .mo{color:#009999}.highlight .m,.highlight .mb,.highlight .mx{color:#009999}.highlight .sb{color:#d14}.highlight .sc{color:#d14}.highlight .sd{color:#d14}.highlight .s2{color:#d14}.highlight .se{color:#d14}.highlight .sh{color:#d14}.highlight .si{color:#d14}.highlight .sx{color:#d14}.highlight .sr{color:#009926}.highlight .s1{color:#d14}.highlight .ss{color:#990073}.highlight .s{color:#d14}.highlight .na{color:#008080}.highlight .bp{color:#999999}.highlight .nb{color:#0086B3}.highlight .nc{color:#445588;font-weight:bold}.highlight .no{color:#008080}.highlight .nd{color:#3c5d5d;font-weight:bold}.highlight .ni{color:#800080}.highlight .ne{color:#990000;font-weight:bold}.highlight .nf{color:#990000;font-weight:bold}.highlight .nl{color:#990000;font-weight:bold}.highlight .nn{color:#555555}.highlight .nt{color:#000080}.highlight .vc{color:#008080}.highlight .vg{color:#008080}.highlight .vi{color:#008080}.highlight .nv{color:#008080}.highlight .ow{color:#000000;font-weight:bold}.highlight .o{color:#000000;font-weight:bold}.highlight .w{color:#bbbbbb}.highlight{background-color:#f8f8f8}body{background-color:#fff;padding:50px;font:14px/1.5 "Noto Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;color:#727272;font-weight:400}h1,h2,h3,h4,h5,h6{color:#222;margin:0 0 20px}p,ul,ol,table,pre,dl{margin:0 0 20px}h1,h2,h3{line-height:1.1}h1{font-size:28px}h2{color:#393939}h3,h4,h5,h6{color:#494949}a{color:#267CB9;text-decoration:none}a:hover,a:focus{color:#069;font-weight:bold}a small{font-size:11px;color:#777;margin-top:-0.3em;display:block}a:hover small{color:#777}.wrapper{width:860px;margin:0 auto}blockquote{border-left:1px solid #e5e5e5;margin:0;padding:0 0 0 20px;font-style:italic}code,pre{font-family:Monaco, Bitstream Vera Sans Mono, Lucida Console, Terminal, Consolas, Liberation Mono, DejaVu Sans Mono, Courier New, monospace;color:#333}pre{padding:8px 15px;background:#f8f8f8;border-radius:5px;border:1px solid #e5e5e5;overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:5px 10px;border-bottom:1px solid #e5e5e5}dt{color:#444;font-weight:700}th{color:#444}img{max-width:100%}kbd{background-color:#fafbfc;border:1px solid #c6cbd1;border-bottom-color:#959da5;border-radius:3px;box-shadow:inset 0 -1px 0 #959da5;color:#444d56;display:inline-block;font-size:11px;line-height:10px;padding:3px 5px;vertical-align:middle}header{width:270px;float:left;position:fixed;-webkit-font-smoothing:subpixel-antialiased}ul.downloads{list-style:none;height:40px;padding:0;background:#f4f4f4;border-radius:5px;border:1px solid #e0e0e0;width:270px}.downloads li{width:89px;float:left;border-right:1px solid #e0e0e0;height:40px}.downloads li:first-child a{border-radius:5px 0 0 5px}.downloads li:last-child a{border-radius:0 5px 5px 0}.downloads a{line-height:1;font-size:11px;color:#676767;display:block;text-align:center;padding-top:6px;height:34px}.downloads a:hover,.downloads a:focus{color:#675C5C;font-weight:bold}.downloads ul a:active{background-color:#f0f0f0}strong{color:#222;font-weight:700}.downloads li+li+li{border-right:none;width:89px}.downloads a strong{font-size:14px;display:block;color:#222}section{width:500px;float:right;padding-bottom:50px}small{font-size:11px}hr{border:0;background:#e5e5e5;height:1px;margin:0 0 20px}footer{width:270px;float:left;position:fixed;bottom:50px;-webkit-font-smoothing:subpixel-antialiased}@media print, screen and (max-width: 960px){div.wrapper{width:auto;margin:0}header,section,footer{float:none;position:static;width:auto}header{padding-right:320px}section{border:1px solid #e5e5e5;border-width:1px 0;padding:20px 0;margin:0 0 20px}header a small{display:inline}header ul{position:absolute;right:50px;top:52px}}@media print, screen and (max-width: 720px){body{word-wrap:break-word}header{padding:0}header ul,header p.view{position:static}pre,code{word-wrap:normal}}@media print, screen and (max-width: 480px){body{padding:15px}.downloads{width:99%}.downloads li,.downloads li+li+li{width:33%}}@media print{body{padding:0.4in;font-size:12pt;color:#444}}.social-links{clear:both;width:100%;margin-top:1rem}.social-links ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:1rem 4rem}@media (max-width: 520px){.social-links ul{grid-template-columns:repeat(2, minmax(0, 1fr))}}@media (max-width: 360px){.social-links ul{grid-template-columns:1fr}}.social-links li{margin:0}.social-links li a{text-decoration:none;color:#333;font-weight:bold;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:0.5rem;transition:color 0.2s}.social-links li a:hover{color:#007acc}.social-links i{font-size:1.2rem}@media (min-width: 1500px){.wrapper{max-width:100%;min-width:90%;padding:1.5rem}header{width:220px;margin-right:1.5rem}section{flex:1;width:70%}}.project-list{display:grid;grid-template-columns:repeat(auto-fit, minmax(380px, 1fr));gap:2rem}@media (max-width: 900px){.project-list{grid-template-columns:1fr}}.project-card{border:1px solid #ccc;padding:1.5rem;border-radius:10px;background-color:#fafafa;box-shadow:0 2px 6px rgba(0,0,0,0.05)}.project-card img{width:100%;height:auto;border-radius:6px;margin-bottom:1rem}.project-card h2{margin-top:0;margin-bottom:0.5rem}.project-card-link *{color:inherit !important;text-decoration:none !important}.project-card{border:1px solid #ccc;padding:1.5rem;border-radius:10px;background-color:#fafafa;box-shadow:0 2px 6px rgba(0,0,0,0.05);transition:transform 0.2s ease, box-shadow 0.2s ease;transform:translateY(0)}.project-card-link:hover .project-card{transform:translateY(-5px);box-shadow:0 4px 12px rgba(0,0,0,0.1)}.project-pill{max-width:700px;margin:2rem auto;background:#fdfdfd;border-radius:2rem;box-shadow:0 8px 20px rgba(0,0,0,0.07);overflow:hidden;padding-bottom:2rem;font-family:sans-serif}.post-image-wrapper{width:100%;max-height:400px;overflow:hidden;border-top-left-radius:2rem;border-top-right-radius:2rem}.post-image{width:100%;height:auto;object-fit:cover;display:block}.project-info{padding:2rem}.project-info h1{margin-top:0;font-size:2rem;margin-bottom:0.25rem}.project-date{color:#666;margin-bottom:1rem}.project-description{font-size:1.1rem;margin-bottom:1rem}.project-info p{margin:0.5rem 0;line-height:1.5}.project-content{margin-top:1.5rem}.project-tags p{margin:0}.project-tags{display:flex;flex-wrap:wrap;gap:0.5rem;margin-bottom:1rem}.project-tag{font-size:0.8rem;padding:0.3rem 0.65rem;border-radius:999px;background-color:#eef3f7;color:#333;border:1px solid #d0d7de;white-space:nowrap}.tag-default{background-color:#e8f1ff;color:#1f3a5f;border-color:#c7dcff}.tag-engine{background-color:#e7f6ec;color:#1e6b3a;border-color:#bfe6cc}.tag-project{background-color:#fff1e6;color:#9a4d00;border-color:#ffd3b3}.tag-uni{background-color:#ffe6e6;color:#b30000;border-color:#ffb3b3}.tag-time{background-color:#ffe6f2;color:#cc0066;border-color:#ffb3d9}.back-button{display:inline-block;margin:1rem;text-decoration:none;font-size:0.9rem;color:#333}.rounded-logo{border-radius:10%;object-fit:cover;display:block;margin-bottom:16px}.read-more-link{color:#007acc;text-decoration:none;font-weight:bold}.read-more-link:hover{text-decoration:underline}.skills-bar{display:flex;justify-content:center;flex-wrap:wrap;gap:1.5rem;margin-top:2rem;margin-bottom:2rem}.skill-icon{position:relative;display:inline-block;cursor:pointer}.skill-icon img{width:48px;height:48px;border-radius:12px;transition:transform 0.2s ease}.skill-icon:hover img{transform:translateY(-4px)}.tooltip{position:absolute;bottom:110%;left:50%;transform:translateX(-50%);background-color:#111;color:#fff;padding:1rem;border-radius:10px;width:260px;text-align:left;box-shadow:0 4px 16px rgba(0,0,0,0.25);opacity:0;visibility:hidden;transition:opacity 0.3s ease, transform 0.3s ease;z-index:1000}.skill-icon:hover .tooltip{visibility:visible;opacity:1;transform:translate(-50%, -8px)}.read-more-link{color:#007acc;text-decoration:none;font-weight:bold}.read-more-link:hover{text-decoration:underline}
