:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}/*! tailwindcss v4.1.7 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-border-style:solid;--tw-font-weight:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-500:oklch(63.7% .237 25.331);--color-red-600:oklch(57.7% .245 27.325);--color-green-500:oklch(72.3% .219 149.579);--color-green-600:oklch(62.7% .194 149.214);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-600:oklch(54.6% .245 262.881);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-white:#fff;--spacing:.25rem;--container-4xl:56rem;--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--font-weight-semibold:600;--font-weight-bold:700;--radius-lg:.5rem;--animate-spin:spin 1s linear infinite;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.fixed{position:fixed}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.mt-2{margin-top:calc(var(--spacing)*2)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.mb-8{margin-bottom:calc(var(--spacing)*8)}.block{display:block}.contents{display:contents}.flex{display:flex}.hidden{display:none}.inline-block{display:inline-block}.h-8{height:calc(var(--spacing)*8)}.h-96{height:calc(var(--spacing)*96)}.min-h-screen{min-height:100vh}.w-8{width:calc(var(--spacing)*8)}.max-w-4xl{max-width:var(--container-4xl)}.flex-grow{flex-grow:1}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.resize{resize:both}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*4)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*8)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*8)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*2)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-x-reverse)))}:where(.space-x-4>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*4)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-x-reverse)))}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-blue-500{border-color:var(--color-blue-500)}.bg-blue-500{background-color:var(--color-blue-500)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-500{background-color:var(--color-gray-500)}.bg-green-500{background-color:var(--color-green-500)}.bg-red-500{background-color:var(--color-red-500)}.p-4{padding:calc(var(--spacing)*4)}.p-5{padding:calc(var(--spacing)*5)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-5{padding-inline:calc(var(--spacing)*5)}.py-1{padding-block:calc(var(--spacing)*1)}.py-2{padding-block:calc(var(--spacing)*2)}.py-3{padding-block:calc(var(--spacing)*3)}.py-5{padding-block:calc(var(--spacing)*5)}.py-8{padding-block:calc(var(--spacing)*8)}.text-center{text-align:center}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-white{color:var(--color-white)}@media (hover:hover){.hover\:bg-blue-600:hover{background-color:var(--color-blue-600)}.hover\:bg-gray-600:hover{background-color:var(--color-gray-600)}.hover\:bg-green-600:hover{background-color:var(--color-green-600)}.hover\:bg-red-600:hover{background-color:var(--color-red-600)}}}:root{--background-clolor:white;--text-color:black;--react-gray:#282c34;--light-text-color:#282c34;--code-background-color:#f7f9fa}@media (prefers-color-scheme:dark){:root{--background-clolor:#2d2f33;--text-color:white;--react-gray:#282c34;--light-text-color:white;--code-background-color:#525457}}.App{text-align:left;box-sizing:border-box;width:100dvw;font-family:Helvetica,sans-serif}.App-logo{pointer-events:none;height:40vmin}@media (prefers-reduced-motion:no-preference){.App-logo{animation:20s linear infinite App-logo-spin}}.App-header{background-color:var(--react-gray);min-height:100vh;color:var(--text-color);flex-direction:column;justify-content:center;align-items:center;font-size:calc(10px + 2vmin);display:flex}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*{box-sizing:border-box;font-family:Helvetica,sans-serif}body{background-color:var(--background-clolor);color:var(--text-color);max-width:99vw;font-family:Helvetica,sans-serif;overflow-x:hidden}h1{font-family:Roboto Mono,monospace;font-size:1.8rem}h2{font-family:Roboto Mono,monospace;font-size:1.4rem}h3,h4{font-family:Roboto Mono,monospace;font-size:1.1rem}a{color:#5f9ea0;font-family:Roboto Mono,monospace;overflow:hidden}li{font-size:1rem}h2.left{text-align:left;position:relative}.page_404{text-align:center;width:100vw;height:100vh}.massive_title{text-align:left;margin-top:3vh;font-family:Roboto Mono,monospace;font-size:min(52pt,max(5vw,1.7rem))}.main_content{grid-column:1/span 7;padding:6px 18px}.author_line{font-family:Roboto Mono,monospace;font-size:.8rem!important;line-height:1.2rem!important}.author_line strong{color:#5f9ea0;font-family:Roboto Mono,monospace;font-weight:500}a:visited{color:#5f9ea0;font-family:Roboto Mono,monospace}h3.myheading>a{color:var(--text-color);font-size:1.2rem;line-height:1rem}.navbar a{color:#5f9ea0;font-family:Roboto Mono,monospace;font-weight:500}.navbar .active_li{text-decoration:underline}.navbar a:visited{color:#5f9ea0}.sidebar{min-height:100vh}.tech_label{color:#5f9ea0;font-weight:700}main{box-sizing:border-box;max-width:99vw;display:flex}.content_wrapper{grid-template-columns:repeat(9,1fr);margin-top:4vh;margin-left:21vw;display:grid}.selected_link{color:pink!important}footer{position:absolute;bottom:10px}.footer_title{font-family:Roboto Mono,monospace;line-height:2rem}.navbar li{font-size:1.5rem}.row.d-flex{width:calc(99vw - 320px);position:relative}.timeline{max-width:1200px;margin:0 auto;position:relative}.timeline:after{content:"";background-color:#888;width:6px;margin-left:-3px;position:absolute;top:0;bottom:0;left:10%}.timeline_container{background-color:inherit;width:80%;padding:10px 40px;position:relative}.timeline_container:after{content:"";z-index:1;background-color:#fff;border:4px solid #555;border-radius:50%;width:25px;height:25px;position:absolute;top:15px;right:-17px}.left{left:0}.right{left:10%}.right:before{content:" ";z-index:1;border:10px solid #0000;border-left-width:0;border-right-color:#fff;width:0;height:0;position:absolute;top:22px;left:30px}.right:after{left:-13px}.timeline_content{background-color:var(--background-clolor);text-align:left;border-radius:6px;padding:20px 30px;position:relative}.hero{margin-top:50px}.contact_main{width:calc(100% - 320px);margin:50px 0 70px}.contact_form_wrapper{width:80vw;max-width:800px}.contact_container{max-width:unset}.contact_gird{flex-wrap:wrap;display:flex}.contact_element{flex:200px;padding:0 10px}.contact_form_wrapper{clear:both;display:block}#thanks{color:#fff;background-color:#add8e6;margin:50px 0;padding:30px}.btn-primary{background-color:#5f9ea0;border-color:#5f9ea0}.articles_wrapper{width:80%;margin:8vh auto}.single_article{border:1px solid #d3d3d3;border-radius:4px;max-width:600px;margin-bottom:40px;padding:0 0 0 20px}.article_summray{line-height:2rem}.single_article span{color:#5f9ea0;font-family:Roboto Mono,monospace}.portrait{text-align:center;flex-direction:column;width:180px;margin-bottom:20px;margin-left:-15px;display:flex}.portrait_img{border-radius:50%;width:180px;height:180px;margin-bottom:10px}.projects_grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin:32px 0;padding:0 18px;display:grid}.project_card{background-color:var(--background-clolor);text-align:center;border:2px solid #e2e8f0;border-radius:12px;flex-direction:column;align-items:center;padding:18px;transition:all .3s;display:flex;box-shadow:0 2px 4px #0000001a}.project_card:hover{border-color:#5f9ea0;transform:translateY(-4px);box-shadow:0 8px 25px #00000026}@media (prefers-color-scheme:dark){.project_card{border-color:#4a5568;box-shadow:0 2px 4px #0000004d}.project_card:hover{box-shadow:0 8px 25px #0006}}.project_icon{color:#fff;text-shadow:0 2px 4px #0000004d;background:linear-gradient(135deg,#5f9ea0,#5f9ea0);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:16px;font-size:3rem;display:flex}.project_title{color:var(--text-color);margin:0 0 12px;font-family:Roboto Mono,monospace;font-size:1.25rem}.project_description{color:var(--light-text-color);flex-grow:1;margin:0 0 20px;font-size:.9rem;line-height:1.5}.project_links{flex-wrap:nowrap;justify-content:center;gap:12px;width:100%;display:flex}.project_link,.github_link{border:2px solid #0000;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-family:Roboto Mono,monospace;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.project_link{color:#fff;background-color:#5f9ea0}.project_link:hover{background-color:#4a7c7e;transform:translateY(-1px)}.project_link.offline{cursor:not-allowed;background-color:#9ca3af}.project_link.offline:hover{background-color:#9ca3af;transform:none}.github_link{color:var(--text-color);background-color:#0000;border-color:#e2e8f0}.github_link:hover{color:#5f9ea0;background-color:#f7fafc;border-color:#5f9ea0;transform:translateY(-1px)}@media (prefers-color-scheme:dark){.github_link{border-color:#4a5568}.github_link:hover{background-color:#2d3748}}.github_link svg{width:16px;height:16px}@media (max-width:768px){.projects_grid{grid-template-columns:1fr;gap:16px}.project_card{padding:20px}.project_links{flex-direction:column;gap:8px}.project_link,.github_link{justify-content:center;width:100%}}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}@media screen and (max-width: 900px){.row.d-flex{padding-left:5px;margin-left:30px;width:99vw;max-width:unset}.contact_gird{display:grid;margin-top:10vh;grid-template-columns:50% 50%}.contact_main{width:unset;margin:unset}.main_aside{width:220px}#nav_hamburger{display:unset}.articles_wrapper{margin:3vh auto;width:100%}.single_article{max-width:unset}.content_wrapper{display:flex;margin-left:4vw;margin-right:4vw;flex-direction:column}}@media screen and (max-width: 680px){body{max-width:99vw;font-size:10px}p,pre{font-size:1rem}.main_aside{height:100%;position:fixed;background-color:#fff;z-index:2}.asside_wrapper{height:100vh;position:fixed}.row.d-flex{max-width:99vw;margin:auto}.timeline:after{left:31px}.timeline_container{width:100%;padding-left:70px;padding-right:25px}.timeline_container:before{left:60px;border:medium solid white;border-width:10px 10px 10px 0;border-color:transparent white transparent transparent}.left:after,.right:after{left:18px}.right{left:0%}.contact_form_wrapper{width:99vw;padding:10px}.contact_gird{display:grid;grid-template-columns:100%}footer{bottom:8vh}.single_article{width:100%;margin:5px auto}}.main_aside{width:0;box-sizing:border-box}.asside_wrapper{width:21vw;padding:70px 30px 30px;height:100vh;position:fixed;box-sizing:border-box;z-index:4;background-color:var(--background-clolor);min-width:190px;top:0}#nav_hamburger{width:30px;height:30px;position:fixed;left:20px;top:20px;z-index:3}.bar1,.bar2,.bar3{width:35px;height:5px;background-color:var(--text-color);margin:6px 0;transition:.4s}.change .bar1{-webkit-transform:rotate(-45deg) translate(-9px,6px);transform:rotate(-45deg) translate(-9px,6px)}.change .bar2{opacity:0}.change .bar3{-webkit-transform:rotate(45deg) translate(-8px,-8px);transform:rotate(45deg) translate(-8px,-8px)}.change{display:none}@media screen and (max-width: 900px){.change{display:block}.asside_wrapper{width:min(100vw,1000px);box-shadow:0 0 10px #0006}}.blog_content{margin:8vh auto 2vh;grid-column:1 / span 7;max-width:820px;font-size:1.1em}.blog_content p{line-height:2rem;margin-bottom:24px;font-family:Inter,sans-serif}.blog_content h2{margin-top:50px;margin-bottom:30px}.blog_content h3{font-size:1.1rem}.blog_content p em{color:var(--light-text-color)}.blog_content pre{background-color:var(--code-background-color);border:1px solid #e6e8eb;border-radius:3px;padding:10px;overflow-x:scroll;max-width:95vw;margin:auto;font-size:.8rem}.blog_content img{max-width:100%;margin:0 auto}@media screen and (max-width: 900px){.blog_content{margin:3vh auto}}.article-list{display:flex;flex-direction:column;gap:1.5rem;max-width:800px;margin:0 auto;padding:2rem 1rem}.article-link{text-decoration:none;color:inherit;transition:transform .2s ease,box-shadow .2s ease}.article-link:hover{transform:translateY(-2px)}.article-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:2rem;transition:all .2s ease;position:relative;overflow:hidden}.article-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);opacity:0;transition:opacity .2s ease}.article-link:hover .article-card{box-shadow:0 8px 25px #0000001a;border-color:#d1d5db}.article-link:hover .article-card:before{opacity:1}.article-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.article-title{font-size:1.5rem;font-weight:600;color:#111827;margin:0;line-height:1.3;flex:1}.article-year{background:#f3f4f6;color:#6b7280;padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500;white-space:nowrap}.article-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.meta-item{color:#6b7280;font-size:.875rem;font-weight:500;position:relative}.meta-item:not(:last-child):after{content:"•";margin-left:1rem;color:#d1d5db}.meta-item.author{color:#4f46e5}.article-summary{color:#4b5563;font-size:.95rem;line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}@media (prefers-color-scheme: dark){.article-card{background:#1f2937;border-color:#374151}.article-title{color:#f9fafb}.article-year{background:#374151;color:#9ca3af}.meta-item{color:#9ca3af}.meta-item.author{color:#818cf8}.article-summary{color:#d1d5db}.article-link:hover .article-card{box-shadow:0 8px 25px #0000004d;border-color:#4b5563}}@media (max-width: 768px){.article-list{padding:1rem;gap:1rem}.article-card{padding:1.5rem}.article-header{flex-direction:column;align-items:flex-start;gap:.5rem}.article-title{font-size:1.25rem}.article-meta{flex-direction:column;gap:.5rem}.meta-item:not(:last-child):after{display:none}}
