@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+Math&family=Noto+Sans+Symbols&family=Noto+Sans+Symbols+2&display=swap);@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+Mono&display=swap);*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.18 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}#root,body,html{color:#fff!important}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:-webkit-sticky;position:sticky}.inset-0{inset:0}.bottom-0{bottom:0}.bottom-\[64px\]{bottom:64px}.bottom-\[88px\]{bottom:88px}.left-0{left:0}.right-0{right:0}.top-0{top:0}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.my-2{margin-bottom:.5rem;margin-top:.5rem}.my-3{margin-bottom:.75rem;margin-top:.75rem}.mb-2{margin-bottom:.5rem}.ml-1{margin-left:.25rem}.ml-4{margin-left:1rem}.mt-2{margin-top:.5rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-\[18px\]{height:18px}.h-full{height:100%}.max-h-\[300px\]{max-height:300px}.max-h-\[400px\]{max-height:400px}.min-h-\[24px\]{min-height:24px}.min-h-\[40px\]{min-height:40px}.w-1\/2{width:50%}.w-\[10px\]{width:10px}.w-full{width:100%}.max-w-\[1200px\]{max-width:1200px}.max-w-\[800px\]{max-width:800px}.max-w-full{max-width:100%}.max-w-none{max-width:none}.flex-1{flex:1 1}.flex-shrink{flex-shrink:1}.border-collapse{border-collapse:collapse}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-\[terminal-blink_1s_step-end_infinite\]{animation:terminal-blink 1s step-end infinite}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-text{cursor:text}.resize-none{resize:none}.resize{resize:both}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-start{justify-content:flex-start}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overscroll-contain{overscroll-behavior:contain}.break-words{overflow-wrap:break-word}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-t-2{border-top-width:2px}.border-\[\#00ff00\]{--tw-border-opacity:1;border-color:#0f0;border-color:rgb(0 255 0/var(--tw-border-opacity,1))}.border-\[\#1a1a1a\]{--tw-border-opacity:1;border-color:#1a1a1a;border-color:rgb(26 26 26/var(--tw-border-opacity,1))}.border-gray-800{--tw-border-opacity:1;border-color:#1f2937;border-color:rgb(31 41 55/var(--tw-border-opacity,1))}.bg-\[\#00ff00\]{--tw-bg-opacity:1;background-color:#0f0;background-color:rgb(0 255 0/var(--tw-bg-opacity,1))}.bg-\[\#0a0a0a\]{--tw-bg-opacity:1;background-color:#0a0a0a;background-color:rgb(10 10 10/var(--tw-bg-opacity,1))}.bg-\[\#1a1a1a\]{--tw-bg-opacity:1;background-color:#1a1a1a;background-color:rgb(26 26 26/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:#f3f4f6;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.px-4{padding-left:1rem;padding-right:1rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.pl-4{padding-left:1rem}.text-left{text-align:left}.align-text-bottom{vertical-align:text-bottom}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-bold{font-weight:700}.italic{font-style:italic}.text-\[\#00dd00\]{--tw-text-opacity:1;color:#0d0;color:rgb(0 221 0/var(--tw-text-opacity,1))}.text-\[\#00ff00\]{--tw-text-opacity:1;color:#0f0;color:rgb(0 255 0/var(--tw-text-opacity,1))}.text-\[\#ff5555\]{--tw-text-opacity:1;color:#f55;color:rgb(255 85 85/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:#1f2937;color:rgb(31 41 55/var(--tw-text-opacity,1))}.underline{-webkit-text-decoration-line:underline;text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.placeholder-\[\#005500\]::placeholder{--tw-placeholder-opacity:1;color:#050;color:rgb(0 85 0/var(--tw-placeholder-opacity,1))}.opacity-0{opacity:0}.opacity-60{opacity:.6}.opacity-80{opacity:.8}.shadow-\[0_-2px_6px_rgba\(0\2c 0\2c 0\2c 0\.3\)\]{--tw-shadow:0 -2px 6px #0000004d;--tw-shadow-colored:0 -2px 6px var(--tw-shadow-color)}.shadow-\[0_-2px_6px_rgba\(0\2c 0\2c 0\2c 0\.3\)\],.shadow-\[0_0_5px_rgba\(0\2c 255\2c 0\2c 0\.5\)\]{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-\[0_0_5px_rgba\(0\2c 255\2c 0\2c 0\.5\)\]{--tw-shadow:0 0 5px #00ff0080;--tw-shadow-colored:0 0 5px var(--tw-shadow-color)}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.blur{--tw-blur:blur(8px)}.blur,.grayscale{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.grayscale{--tw-grayscale:grayscale(100%)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}:root{--bg-color:#2c3137!important;--text-color:#fff!important;--secondary-color:#a8a8b3;--tertiary-color:#e0e0e0;--font-styled:"Noto Sans Math","Noto Sans Symbols","Noto Sans Symbols 2",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}html{background-color:#2c3137!important;margin:0;padding:0}body,html{background-color:var(--bg-color)!important}body{color:var(--text-color);font-family:Arial,sans-serif}body.dark-mode,html.dark-mode{--bg-color:#2c3137;--text-color:#fff;--secondary-color:#a8a8b3;--tertiary-color:#e0e0e0}.theme-toggle{background:none;border:none;cursor:pointer;font-size:1.5rem;padding:.5rem}body.dark-mode,html.dark-mode{background-color:#2c3137;background-color:var(--bg-color);color:#fff;color:var(--text-color)}body.dark-mode header,html.dark-mode header{background-color:#000c}body.dark-mode #about,body.dark-mode #links,body.dark-mode #projects,body.dark-mode #recent-posts,html.dark-mode #about,html.dark-mode #links,html.dark-mode #projects,html.dark-mode #recent-posts{background-color:#ffffff0d}body.dark-mode .blog-post,html.dark-mode .blog-post{background-color:#ffffff08}body.dark-mode .btn,html.dark-mode .btn{background-color:var(--accent-color);color:#2c3137;color:var(--bg-color)}body.dark-mode .btn:hover,html.dark-mode .btn:hover{background-color:#2c3137;background-color:var(--bg-color);color:var(--accent-color)}body.dark-mode .search-form input[type=text],html.dark-mode .search-form input[type=text]{background-color:#2c3137;background-color:var(--bg-color);border-color:var(--accent-color);color:#fff;color:var(--text-color)}body.dark-mode .search-form button,html.dark-mode .search-form button{background-color:var(--accent-color);color:#2c3137;color:var(--bg-color)}body.dark-mode .search-form button:hover,html.dark-mode .search-form button:hover{background-color:#2c3137;background-color:var(--bg-color);color:var(--accent-color)}.container{padding:20px;width:80%}header{background-color:#fffc;padding:20px 0}nav ul{list-style-type:none;padding:0}nav ul li{display:inline;margin-right:20px}nav ul li a{text-decoration:none}h1,h2,h3,nav ul li a{color:#e0e0e0;color:var(--tertiary-color)}a{color:var(--accent-color);text-decoration:none}#hero{padding:40px 0;text-align:center}#about,#links,#projects,#recent-posts{background-color:#0000000d;border-radius:10px;margin-bottom:40px;padding:40px}.blog-post{background-color:#00000008;border-radius:5px;margin-bottom:20px;padding:20px;transition:transform .3s ease}.blog-post:hover{transform:translateY(-5px)}.blog-post h3{margin-top:0}.date{color:#a8a8b3;color:var(--secondary-color);font-size:.9em}.btn{background-color:#2c3137;background-color:var(--bg-color);border:1px solid var(--accent-color);color:var(--accent-color);margin-top:20px}.btn:hover{background-color:var(--accent-color);color:#2c3137;color:var(--bg-color)}@media (max-width:768px){.container{width:95%}}.admin-actions{margin-top:20px}.admin-actions .btn{margin-right:10px}.btn-danger{background-color:#dc3545;border:1px solid #dc3545;color:#2c3137;color:var(--bg-color)}.btn-danger:hover{background-color:#c82333;border-color:#c82333}.pagination{margin-top:20px;text-align:center}.pagination a,.pagination span{border:1px solid var(--accent-color);border-radius:3px;color:var(--accent-color);margin:0 5px;padding:5px 10px;text-decoration:none}.pagination .current-page,.pagination a:hover{background-color:var(--accent-color);color:#2c3137;color:var(--bg-color)}.pagination .ellipsis{border:none}#links ul{list-style-type:none;padding:0}#links ul li{margin-bottom:10px}.about-container{align-items:stretch;display:flex;flex-direction:row;min-height:calc(100vh - 100px)}.about-content,.about-image{flex:1 1;padding:40px}.about-image img{border-radius:10px;height:auto;max-height:400px;object-fit:cover;width:100%}.about-content{background-color:#0000000d;border-radius:10px}@media (max-width:768px){.about-container{flex-direction:column}.about-content,.about-image{width:100%}}.search-form{display:flex;justify-content:flex-end;margin-top:10px}.search-form input[type=text]{background-color:#2c3137;background-color:var(--bg-color);border:1px solid var(--accent-color);border-radius:5px 0 0 5px;color:#fff;color:var(--text-color);padding:5px 10px}.search-form button{background-color:var(--accent-color);border:1px solid var(--accent-color);border-radius:0 5px 5px 0;color:#2c3137;color:var(--bg-color);cursor:pointer;padding:5px 10px}.search-form button:hover{background-color:#2c3137;background-color:var(--bg-color);color:var(--accent-color)}.create-blog-post{margin:0 auto;max-width:800px;padding:20px}.create-blog-post h1,.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:5px}.form-group input[type=text]{font-size:16px;padding:10px;width:100%}.preview{background-color:#f9f9f9;border:1px solid #ccc;min-height:200px;padding:20px}.form-actions{display:flex;justify-content:space-between;margin-top:20px}.form-actions button{cursor:pointer;font-size:16px;padding:10px 20px}body.dark-mode .create-blog-post,html.dark-mode .create-blog-post{color:#fff;color:var(--text-color)}body.dark-mode .form-group input[type=text],body.dark-mode .preview,html.dark-mode .form-group input[type=text],html.dark-mode .preview{background-color:#2c3137;background-color:var(--bg-color);border-color:var(--accent-color);color:#fff;color:var(--text-color)}body.dark-mode .form-actions button,html.dark-mode .form-actions button{background-color:var(--accent-color);border:none;color:#2c3137;color:var(--bg-color)}body.dark-mode .form-actions button:hover,html.dark-mode .form-actions button:hover{background-color:#2c3137;background-color:var(--bg-color);border:1px solid var(--accent-color);color:var(--accent-color)}#root,.App,[data-theme],body,html{background-color:#2c3137!important;background:#2c3137!important;color:#fff!important}.hover\:bg-\[\#1a1a1a\]:hover{--tw-bg-opacity:1;background-color:#1a1a1a;background-color:rgb(26 26 26/var(--tw-bg-opacity,1))}.hover\:underline:hover{-webkit-text-decoration-line:underline;text-decoration-line:underline}.focus\:border-\[\#00ff00\]:focus{--tw-border-opacity:1;border-color:#0f0;border-color:rgb(0 255 0/var(--tw-border-opacity,1))}.focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}@media (min-width:640px){.sm\:h-\[20px\]{height:20px}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:p-4{padding:1rem}.sm\:text-base{font-size:1rem;line-height:1.5rem}}.landing-page{align-items:center;background:#2c3137!important;display:flex;height:100%;justify-content:center;min-height:100vh;padding:2rem 1rem;transition:background-color .3s ease;width:100%}@supports (-webkit-touch-callout:none){body.dark-mode .landing-page,html.dark-mode .landing-page{background-color:#2c3137!important}}.landing-content{max-width:700px;text-align:center;width:100%}.hero-section{margin-bottom:3rem}.hero-title{color:#fff!important;font-size:clamp(2.5rem,8vw,4rem);font-weight:700;letter-spacing:-.02em;line-height:1.2;margin:0 0 .5rem;transition:color .3s ease}@supports (-webkit-touch-callout:none){body.dark-mode .hero-title,html.dark-mode .hero-title{-webkit-text-fill-color:#fff!important;color:#fff!important}}.hero-subtitle{color:#a8a8b3!important;font-size:clamp(1.125rem,3vw,1.5rem);font-weight:400;margin-bottom:1.5rem;transition:color .3s ease}@supports (-webkit-touch-callout:none){body.dark-mode .hero-subtitle,html.dark-mode .hero-subtitle{-webkit-text-fill-color:#a8a8b3!important;color:#a8a8b3!important}}.hero-description{color:#a8a8b3!important;font-size:clamp(1rem,2vw,1.125rem);line-height:1.7;margin:0 auto 2.5rem;max-width:580px;transition:color .3s ease}@supports (-webkit-touch-callout:none){body.dark-mode .hero-description,html.dark-mode .hero-description{-webkit-text-fill-color:#a8a8b3!important;color:#a8a8b3!important}}.cta-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:3rem}.btn-primary,.btn-secondary{-webkit-tap-highlight-color:transparent;border-radius:6px;cursor:pointer;display:inline-block;font-size:1rem;font-weight:500;min-width:150px;padding:.875rem 2rem;text-decoration:none;touch-action:manipulation;transition:all .2s ease;-webkit-user-select:none;user-select:none}.btn-primary{background:#d14043!important;border:2px solid #d14043!important;color:#fff!important;transition:all .2s ease}.btn-primary:hover{background:#333;border-color:#333;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.btn-primary:active{transform:scale(.98)}body.dark-mode .btn-primary:hover,html.dark-mode .btn-primary:hover{background:#e55053!important;border-color:#e55053!important;box-shadow:0 4px 12px #d140434d}.btn-secondary{background:#0000;border:2px solid #fff!important;color:#fff!important;transition:all .2s ease}.btn-secondary:hover{background:#1a1a1a;color:#fff;transform:translateY(-2px)}.btn-secondary:active{transform:scale(.98)}body.dark-mode .btn-secondary:hover,html.dark-mode .btn-secondary:hover{background:#fff!important;color:#2c3137!important}.social-links{align-items:center;display:flex;flex-wrap:wrap;font-size:.9375rem;gap:1.5rem;justify-content:center}.social-links a{color:#a8a8b3!important;text-decoration:none;transition:all .2s ease}@supports (-webkit-touch-callout:none){body.dark-mode .social-links a,html.dark-mode .social-links a{-webkit-text-fill-color:#a8a8b3!important;color:#a8a8b3!important}}.social-links a:hover{color:#1a1a1a}body.dark-mode .social-links a:hover,html.dark-mode .social-links a:hover{color:#fff!important}@supports (-webkit-touch-callout:none){body.dark-mode .social-links a:hover,html.dark-mode .social-links a:hover{-webkit-text-fill-color:#fff!important;color:#fff!important}}.social-links .separator{color:#666!important;opacity:.5;transition:color .3s ease;-webkit-user-select:none;user-select:none}@supports (-webkit-touch-callout:none){body.dark-mode .social-links .separator,html.dark-mode .social-links .separator{-webkit-text-fill-color:#666!important;color:#666!important}}@media (max-width:768px){.landing-page{padding:1.5rem 1rem}.hero-section{margin-bottom:2rem}.cta-buttons{align-items:center;padding:0 1rem;width:100%}.btn-primary,.btn-secondary{max-width:300px;text-align:center}.hero-description{margin-bottom:2rem}.cta-buttons{flex-direction:column;gap:.75rem}.btn-primary,.btn-secondary{max-width:280px;width:100%}.social-links{font-size:.9rem;gap:1rem}}@media (max-width:480px){.landing-page{padding:1rem .75rem}.social-links{flex-direction:column;gap:.5rem}.social-links .separator{display:none}}@media (prefers-reduced-motion:reduce){.btn-primary,.btn-secondary,.social-links a{transition:none}.btn-primary:hover,.btn-secondary:hover,.social-links a:hover{transform:none}}.blog-post{margin-bottom:30px}.blog-post .date,.blog-post h2{margin-bottom:10px}.blog-post .date{color:#666;font-style:italic}.blog-post p{margin-bottom:15px}.blog-post .btn{display:inline-block}.blog-date-container{display:flex;flex-direction:row;gap:10px}.preview-image-container{align-items:center;display:flex;justify-content:center;min-height:150px}.blog-detail{color:#333;font-family:Arial,sans-serif;margin:0 auto;max-width:800px;padding:20px}.blog-detail h1{color:#000;margin-bottom:20px}.blog-meta{color:#666;font-style:italic;margin-bottom:20px}.blog-meta .author{margin-right:15px}.blog-content{line-height:1.6;margin-bottom:20px}.blog-content h1,.blog-content h2,.blog-content h3,.blog-content h4,.blog-content h5,.blog-content h6{color:#000;margin-bottom:10px;margin-top:20px}.blog-content p{margin-bottom:15px}.blog-content a{border-bottom:1px solid red;color:red;text-decoration:none}.blog-content a:hover{border-bottom:2px solid #c00;color:#c00}.blog-content ol,.blog-content ul{margin-bottom:15px;padding-left:30px}.blog-content li{margin-bottom:5px}.blog-content code{font-family:monospace;padding:2px 4px}.blog-content code,.blog-content pre{background-color:#f4f4f4;border-radius:4px}.blog-content pre{margin-bottom:15px;overflow-x:auto;padding:15px}.blog-tags{color:#666;font-style:italic;margin-top:20px}.error,.loading{font-size:18px;padding:20px;text-align:center}.error{color:red}.blog-content img{display:block;height:auto;margin:20px auto;max-width:100%}@media (min-width:768px){.blog-content img{max-width:80%}}@media (min-width:1024px){.blog-content img{max-width:70%}}.contact-container{box-sizing:border-box;margin:0 auto;max-width:800px;min-height:calc(100vh - 4rem);padding:2rem;width:100%}.contact-container h1{color:#fff;font-size:clamp(2rem,5vw,2.5rem);margin-bottom:.5rem;transition:color .3s ease}body.dark-mode .contact-container h1,html.dark-mode .contact-container h1{color:#fff!important}@supports (-webkit-touch-callout:none){.contact-container h1,body.dark-mode .contact-container h1,html.dark-mode .contact-container h1{-webkit-text-fill-color:#fff!important;color:#fff!important}}.contact-container p{color:#d8d8e0;font-size:1.1rem;margin-bottom:2rem;transition:color .3s ease}body.dark-mode .contact-container p,html.dark-mode .contact-container p{color:#d8d8e0!important}@supports (-webkit-touch-callout:none){.contact-container p,body.dark-mode .contact-container p,html.dark-mode .contact-container p{-webkit-text-fill-color:#d8d8e0!important;color:#d8d8e0!important}}.contact-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff08;border-radius:16px;box-shadow:0 8px 32px #0000001a;padding:3rem}.contact-subtitle{color:#666;font-size:1.1rem;margin-bottom:2rem;transition:color .3s ease}body.dark-mode .contact-subtitle,html.dark-mode .contact-subtitle{color:#a8a8b3}.contact-form{gap:1.5rem}.contact-form,.form-group{display:flex;flex-direction:column;width:100%}.form-group{gap:.5rem}.form-group label{color:#fff;font-size:clamp(1rem,3vw,1.1rem);font-weight:600;margin-bottom:.5rem;transition:color .3s ease}body.dark-mode .form-group label,html.dark-mode .form-group label{color:#fff!important}@supports (-webkit-touch-callout:none){.form-group label,body.dark-mode .form-group label,html.dark-mode .form-group label{-webkit-text-fill-color:#fff!important;color:#fff!important}}.form-group input,.form-group textarea{-webkit-tap-highlight-color:transparent;-webkit-appearance:none;appearance:none;background:#1e2228!important;border:2px solid #3a3f48;border-radius:8px;box-sizing:border-box;color:#fff!important;font-family:inherit;font-size:clamp(1rem,2.5vw,1.125rem);padding:1rem;transition:all .3s ease;width:100%}body.dark-mode .form-group input,body.dark-mode .form-group textarea,html.dark-mode .form-group input,html.dark-mode .form-group textarea{-webkit-text-fill-color:#fff!important;background:#1e2228!important;background-color:#1e2228!important;border:2px solid #3a3f48!important;box-shadow:inset 0 1px 3px #0000004d;color:#fff!important}@supports (-webkit-touch-callout:none){.form-group input,.form-group textarea,body.dark-mode .form-group input,body.dark-mode .form-group textarea,html.dark-mode .form-group input,html.dark-mode .form-group textarea{-webkit-text-fill-color:#fff!important;background:#1e2228!important;background-color:#1e2228!important;border-color:#3a3f48!important;color:#fff!important}input[type=email],input[type=text],textarea{-webkit-text-fill-color:#fff!important;background:#1e2228!important;background-color:#1e2228!important;border:2px solid #3a3f48!important;color:#fff!important}}.form-group input::placeholder,.form-group textarea::placeholder{-webkit-text-fill-color:#999;color:#999;opacity:1}body.dark-mode .form-group input::placeholder,body.dark-mode .form-group textarea::placeholder,html.dark-mode .form-group input::placeholder,html.dark-mode .form-group textarea::placeholder{-webkit-text-fill-color:#8a8f9a!important;color:#8a8f9a!important;opacity:1!important}@supports (-webkit-touch-callout:none){input::placeholder,textarea::placeholder{-webkit-text-fill-color:#8a8f9a!important;color:#8a8f9a!important;opacity:1!important}}.form-group input:focus,.form-group textarea:focus{border-color:#1a1a1a;box-shadow:0 0 0 3px #1a1a1a1a;outline:none}body.dark-mode .form-group input:focus,body.dark-mode .form-group textarea:focus,html.dark-mode .form-group input:focus,html.dark-mode .form-group textarea:focus{background:#22272f!important;border-color:#d14043!important;box-shadow:0 0 0 3px #d1404340!important}.form-group textarea{max-width:100%;min-height:150px;resize:vertical}button[type=submit]{-webkit-tap-highlight-color:transparent;align-self:flex-start;-webkit-appearance:none;appearance:none;background:#1a1a1a;border:2px solid #1a1a1a;border-radius:8px;color:#fff;cursor:pointer;font-size:clamp(.9rem,2.5vw,1rem);font-weight:500;padding:.875rem 2rem;touch-action:manipulation;transition:all .2s ease}button[type=submit]:hover{background:#333;border-color:#333;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}button[type=submit]:active{transform:scale(.98)}body.dark-mode button[type=submit],html.dark-mode button[type=submit]{background:#d14043!important;border-color:#d14043!important;color:#fff!important}body.dark-mode button[type=submit]:hover,html.dark-mode button[type=submit]:hover{background:#e55053!important;border-color:#e55053!important;box-shadow:0 4px 12px #d140434d}@media (max-width:768px){.contact-container{margin-top:1rem;padding:1rem}.form-group{gap:.25rem}.form-group input,.form-group textarea{padding:.5rem}button[type=submit]{padding:.75rem 1rem;width:100%}}@media (max-width:480px){.contact-container{padding:1rem .5rem}.form-group textarea{min-height:120px}}@media screen and (max-width:768px){input,select,textarea{font-size:16px!important}}@media screen and (max-height:480px) and (orientation:landscape){.contact-container{padding:1rem}.form-group textarea{min-height:80px}}.alert{border-radius:4px;margin-bottom:20px;padding:10px}.alert-success{background-color:#d4edda;color:#155724}.alert-error{background-color:#f8d7da;color:#721c24}.alert-info{background-color:#cce5ff;color:#004085}.btn{background-color:#007bff;font-size:16px}.btn:hover{background-color:#0056b3}.success-message{background-color:#d4edda;border:2px solid #c3e6cb;border-radius:8px;color:#155724;font-weight:500;margin-top:1.5rem;padding:1rem 1.5rem;text-align:center;transition:all .3s ease}body.dark-mode .success-message,html.dark-mode .success-message{background-color:#48bb7833;border-color:#48bb7866;color:#68d391}.error-message{background-color:#f8d7da;border:2px solid #f5c6cb;border-radius:8px;color:#721c24;font-weight:500;margin-top:1.5rem;padding:1rem 1.5rem;text-align:center;transition:all .3s ease}body.dark-mode .error-message,html.dark-mode .error-message{background-color:#f5656533;border-color:#f5656566;color:#fc8181}button:disabled{cursor:not-allowed;opacity:.6;transform:none!important}button.sending{position:relative}button.sending:after{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;content:"";height:16px;position:absolute;right:1rem;top:50%;transform:translateY(-50%);width:16px}@keyframes spin{to{transform:translateY(-50%) rotate(1turn)}}.projects.container{margin:0 auto;max-width:900px;padding-top:60px}.project.section{background:var(--section-background);border:1px solid var(--secondary-color);border-radius:8px;color:var(--section-text);margin-bottom:2rem;padding:2rem}.project h2{font-size:1.5rem;margin:0 0 1rem}.project-image-container{display:flex;justify-content:center;margin:1rem 0;max-height:200px;overflow:hidden}.project-image{cursor:pointer;height:auto;max-height:200px;max-width:300px;object-fit:contain;width:auto}.project-description{margin:1.5rem 0;text-align:center}.project-links{display:flex;gap:1rem;justify-content:center}.project-links .btn{background:var(--primary-color);border-radius:4px;color:var(--text-on-primary);padding:.5rem 1rem;text-decoration:none;transition:opacity .2s}.project-links .btn:hover{opacity:.9}.project-media{margin-top:20px}.project-media img,.project-media video{border-radius:4px;height:auto;max-width:100%}.btn{background-color:var(--primary-color);border:none;border-radius:5px;color:#fff;display:inline-block;padding:10px 20px;text-decoration:none;transition:background-color .3s ease}.btn:hover{background-color:#2980b9}.btn:disabled{background-color:#ccc;cursor:not-allowed}.section{border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.project-links .btn{margin-bottom:10px;margin-right:10px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;background-color:#2c3137!important;color:#fff;font-family:Inter,sans-serif;font-family:var(--font-sans,"Inter",sans-serif);line-height:1.6;margin:0;padding:0;touch-action:manipulation}@supports (padding:env(safe-area-inset-top)){body{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}}button,input,select,textarea{-webkit-tap-highlight-color:transparent;-webkit-appearance:none;appearance:none}@supports (-webkit-touch-callout:none){body{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}}.container{margin:0 auto;max-width:800px;padding:10px;position:relative}.blog-post-wrapper{margin-bottom:45px;margin-top:45px;position:relative}.section{background-color:var(--section-background);border:1px solid var(--secondary-color);color:var(--section-text);max-height:400px;overflow:hidden;padding:35px;transition:transform .2s ease,box-shadow .2s ease}.section:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.section h2{font-size:1.5rem;font-weight:600;letter-spacing:-.5px;margin-bottom:20px;margin-right:0;margin-top:0}.section h2,.section h2 a{color:var(--primary-color)}.section h2 a{text-decoration:none}.section h2 a:hover{color:var(--accent-color)}@media (max-width:768px){.container{padding:0 15px}.section{padding:20px}}.post-content{color:var(--text-color);font-size:1rem;line-height:1.6}.post-content h1,.post-content h2,.post-content h3,.post-content h4,.post-content h5,.post-content h6{margin-bottom:.5em;margin-top:1.5em}.post-content p{margin:1em 0}.post-content ol,.post-content ul{margin:1em 0;padding-left:2em}.post-content li{margin:.5em 0}.post-content code{border-radius:3px;font-family:Fira Code,monospace;font-size:.9em;padding:.2em .4em}.post-content code,.post-content pre{background-color:var(--secondary-color)}.post-content pre{border-radius:5px;overflow-x:auto;padding:1em}.post-content blockquote{border-left:4px solid var(--accent-color);color:var(--text-color);margin:1em 0;padding-left:1em}.post-preview{color:var(--text-color);font-size:1rem;line-height:1.6;margin:20px 0;overflow:hidden}.post-preview img{margin:10px 0}.read-more{color:var(--text-color);margin-top:.5em;opacity:.7}.date-container{display:flex;gap:20px;justify-content:center;position:absolute;top:-25px;width:100%;z-index:1}.date-stamp.created{color:#000}.date-stamp.updated{color:#c00}.section article{position:relative;z-index:0}.btn{background-color:var(--section-background);border:1px solid var(--secondary-color);border-radius:4px;color:var(--section-text);cursor:pointer;display:block;font-size:.9rem;margin:20px auto;padding:8px 16px;transition:all .2s ease}.btn:hover{background-color:var(--secondary-color);box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.btn:active{box-shadow:none;transform:translateY(0)}[data-theme=dark] .btn{border-color:var(--secondary-color)}[data-theme=dark] .btn:hover{background-color:var(--secondary-color)}.blog-post-wrapper:first-child{margin-top:60px}.date-stamp{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:.9rem;font-weight:400;white-space:nowrap}@media (max-width:768px){.date-stamp{font-size:.8rem}.date-stamp:after{content:none!important}}*{box-sizing:border-box}#root,body,html{margin:0;overflow:hidden;padding:0}#root,.App,body,html{background-color:#2c3137!important;height:100%;width:100%}