@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.8e0177b5.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.b97b3418.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.853070df.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist","Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.c1fdd6c2.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.799d8ef8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.dbea232f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}
*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16pt}@media screen and (max-width:1680px){html{font-size:12pt}}@media screen and (max-width:736px){html{font-size:11pt}}@media screen and (max-width:360px){html{font-size:10pt}}body{color:#fff;background:#1b1f22;min-height:100vh;font-family:Source Sans Pro,sans-serif;font-size:1rem;font-weight:300;line-height:1.65;overflow-x:hidden}.body-wrapper{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative}.body-wrapper.is-preload *,.body-wrapper.is-preload :before,.body-wrapper.is-preload :after{transition:none!important;animation:none!important}a{color:inherit;border-bottom:1px dotted #ffffff80;text-decoration:none;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-bottom-color .2s ease-in-out}a:hover{border-bottom-color:#0000}strong,b{color:#fff;font-weight:600}em,i{font-style:italic}p{margin:0 0 2rem}h1,h2,h3,h4,h5,h6{color:#fff;text-transform:uppercase;letter-spacing:.2rem;margin:0 0 1rem;font-weight:600;line-height:1.5}h2.major{border-bottom:1px solid #fff;width:max-content;margin:0 0 2rem;padding-bottom:.5rem}.text-link{color:inherit;cursor:pointer;font:inherit;background:0 0;border:none;border-bottom:1px dotted #ffffff80;padding:0;transition:border-bottom-color .2s ease-in-out}.text-link:hover{border-bottom-color:#0000}#bg{z-index:-1;background-color:#1b1f22;background-image:linear-gradient(#131519cc,#131519cc),url(/bg.jpg);background-position:50%;background-repeat:no-repeat;background-size:cover;width:100%;height:100vh;position:fixed;top:0;left:0}#bg:before{content:"";background:#1b1f22d9;width:100%;height:100%;position:absolute;top:0;left:0}#wrapper{z-index:1;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem;transition:filter .325s ease-in-out,transform .325s ease-in-out,opacity .325s ease-in-out;display:flex;position:relative}#wrapper.blur{filter:blur(4px);opacity:.5}#header{text-align:center;flex-direction:column;align-items:center;transition:transform .325s ease-in-out,filter .325s ease-in-out,opacity .325s ease-in-out;display:flex}#header.blur{filter:blur(2px);opacity:.5;transform:scale(.95)}#header .logo{border:2px solid #fff;border-radius:100%;justify-content:center;align-items:center;width:10rem;height:10rem;margin-bottom:2rem;display:flex;overflow:hidden}#header .logo .profile-image{object-fit:cover;border-radius:100%;width:100%;height:100%}#header .logo .icon{font-size:2rem}#header .content{margin-bottom:2rem}#header .content .inner{max-width:100%}#header h1{margin:0 0 1rem;font-size:2.25rem;line-height:1.3}#header p{text-transform:uppercase;letter-spacing:.2rem;max-width:40rem;font-size:.8rem;line-height:2}nav ul{flex-wrap:wrap;justify-content:center;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}nav ul li button{color:#fff;cursor:pointer;letter-spacing:.2rem;text-transform:uppercase;background:0 0;border:1px solid #ffffff80;border-radius:4px;padding:.75rem 1.5rem;font-family:inherit;font-size:.8rem;font-weight:300;transition:background-color .2s ease-in-out,border-color .2s ease-in-out,color .2s ease-in-out}nav ul li button:hover{background:#ffffff13;border-color:#fff}#main{z-index:10;pointer-events:none;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}#main article{opacity:0;pointer-events:none;background:#1b1f22d9;border-radius:4px;max-width:40rem;max-height:80vh;padding:4.5rem 2.5rem 1.5rem;transition:opacity .325s ease-in-out,transform .325s ease-in-out;display:none;position:relative;overflow-y:auto;transform:translateY(.25rem)}#main article.active{opacity:1;pointer-events:auto;display:block;transform:translateY(0)}#main article .close{color:#fff;cursor:pointer;background:0 0;border:none;width:4rem;height:4rem;font-size:0;position:absolute;top:0;right:0;overflow:hidden}#main article .close:before{content:"×";text-align:center;font-size:2rem;line-height:4rem;display:block}.image{display:block;position:relative}.image.main{width:100%;margin:0 0 2rem}.image.main img{border-radius:4px;width:100%;height:auto}form{margin:0 0 2rem}.fields{flex-wrap:wrap;gap:1.5rem;margin-bottom:2rem;display:flex}.field{flex:100%}.field.half{flex:calc(50% - .75rem)}@media screen and (max-width:480px){.field.half{flex:100%}}label{letter-spacing:.2rem;text-transform:uppercase;margin-bottom:.5rem;font-size:.8rem;font-weight:300;display:block}input[type=text],input[type=email],textarea{appearance:none;color:inherit;background:#ffffff13;border:none;border-radius:4px;outline:none;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:1rem;font-weight:300;transition:background-color .2s ease-in-out,box-shadow .2s ease-in-out}input[type=text]:focus,input[type=email]:focus,textarea:focus{background:#ffffff20;box-shadow:0 0 0 1px #fff}textarea{resize:vertical;min-height:8rem}.actions{flex-wrap:wrap;gap:1rem;margin:0;padding:0;list-style:none;display:flex}input[type=submit],input[type=button],.button{appearance:none;color:#fff;cursor:pointer;letter-spacing:.2rem;text-transform:uppercase;background:0 0;border:1px solid #fff;border-radius:4px;padding:.75rem 1.5rem;font-family:inherit;font-size:.8rem;font-weight:300;transition:background-color .2s ease-in-out,color .2s ease-in-out}input[type=submit]:hover,input[type=button]:hover,.button:hover,input[type=submit].primary,.button.primary{color:#1b1f22;background:#fff}input[type=submit].primary:hover,.button.primary:hover{color:#fff;background:0 0}.icons{gap:1rem;margin:0;padding:0;list-style:none;display:flex}.icons li a{border:1px solid #ffffff80;border-radius:100%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;transition:background-color .2s ease-in-out,border-color .2s ease-in-out;display:flex}.icons li a:hover{background:#ffffff13;border-color:#fff}.icons li a .label{display:none}.contact-icons{justify-content:center;gap:2rem;margin-top:2rem}.contact-icons li a{width:4rem;height:4rem;font-size:1.5rem}.contact-icons li a:hover{background:#ffffff26;transform:scale(1.1)}#footer{text-align:center;margin-top:2rem}#footer .copyright{letter-spacing:.2rem;text-transform:uppercase;opacity:.5;font-size:.8rem}@media screen and (max-width:736px){#header h1{font-size:1.75rem}#main article{padding:3rem 1.5rem 1rem}}@media screen and (max-width:480px){nav ul{flex-direction:column}nav ul li button{width:100%}}.project-page{z-index:1;max-width:900px;margin:0 auto;padding:2rem 2rem 4rem;position:relative}.project-nav{margin-bottom:2rem}.project-nav .back-link{color:#ffffffb3;text-transform:uppercase;letter-spacing:.1rem;border:1px solid #ffffff4d;border-radius:4px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;transition:all .2s;display:inline-flex}.project-nav .back-link:hover{color:#fff;background:#ffffff13;border-color:#fff}.project-header{text-align:center;border-bottom:1px solid #ffffff26;margin-bottom:3rem;padding:3rem 0}.project-header h1{letter-spacing:.15rem;margin-bottom:1rem;font-size:2rem}.project-header h3{color:#ffffffbf;text-transform:none;letter-spacing:.05rem;margin-bottom:1.5rem;font-size:.95rem;font-weight:300}.project-tagline{text-align:left;background:#ffffff0d;border-left:3px solid #fff6;border-radius:0 4px 4px 0;max-width:700px;margin:0 auto;padding:1rem 1.5rem;font-size:.95rem;line-height:1.7}.project-section{border-bottom:1px solid #ffffff14;margin-bottom:3rem;padding-bottom:2rem}.project-section:last-of-type{border-bottom:none}.project-section h2{border-bottom:2px solid #fff3;margin-bottom:1.5rem;padding-bottom:.5rem;font-size:1.4rem;display:inline-block}.project-section h3{color:#ffffffe6;margin:1.5rem 0 1rem;font-size:1.1rem}.project-section h4{margin-bottom:.75rem;font-size:.95rem}.project-section p{color:#ffffffd9;line-height:1.8}.project-section ul{margin-bottom:1.5rem;padding-left:1.5rem;list-style:outside}.project-section ul li{color:#ffffffd9;margin-bottom:.5rem;line-height:1.7}.architecture-diagram{text-align:center;background:#ffffff08;border:1px solid #ffffff1a;border-radius:8px;padding:2rem}.architecture-diagram .diagram-image{border-radius:4px;width:100%;height:auto}.diagram-placeholder{color:#ffffff80;padding:3rem 1rem}.diagram-placeholder p{color:#ffffff80}.diagram-hint{margin-top:.5rem;font-size:.8rem}.diagram-hint a{color:#ffffffb3}.highlight-box{background:#ffffff0d;border-left:3px solid #fff6;border-radius:0 4px 4px 0;margin:1.5rem 0;padding:1.25rem 1.5rem}.highlight-box p{margin-bottom:.5rem}.highlight-box p:last-child{margin-bottom:0}.tech-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.5rem;margin-top:1rem;display:grid}.tech-item{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;padding:1.25rem}.tech-item h4{color:#fff;text-transform:uppercase;letter-spacing:.1rem;margin-bottom:.75rem;font-size:.85rem}.tech-item ul{padding-left:0;list-style:none}.tech-item ul li{color:#ffffffbf;padding:.2rem 0;font-size:.9rem}.feature-list li{margin-bottom:.75rem}.code-block{background:#0006;border:1px solid #ffffff1a;border-radius:6px;margin:1rem 0;padding:1.25rem 1.5rem;overflow-x:auto}.code-block code{color:#ffffffe6;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85rem;line-height:1.8}.setup-step{border-left:2px solid #ffffff1a;margin-bottom:2rem;padding-left:1rem}.setup-step h3{margin-top:0}.project-links{border-bottom:none;flex-wrap:wrap;justify-content:center;gap:1rem;padding-bottom:0;display:flex}.project-link-btn{color:#fff;letter-spacing:.15rem;text-transform:uppercase;background:0 0;border:1px solid #fff;border-radius:4px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.85rem;font-weight:300;transition:all .2s;display:inline-flex}.project-link-btn:hover{color:#1b1f22;background:#fff}.project-footer{text-align:center;border-top:1px solid #ffffff1a;margin-top:3rem;padding-top:2rem}.project-footer p{letter-spacing:.1rem;text-transform:uppercase;opacity:.5;font-size:.8rem}.project-cards{flex-direction:column;gap:1.5rem;display:flex}.project-card{cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;padding:1.5rem;transition:all .2s;display:block}.project-card:hover{background:#ffffff1a;border-color:#ffffff4d;transform:translateY(-2px)}.project-card h4{margin-bottom:.5rem;font-size:.95rem}.project-card p{color:#ffffffb3;margin-bottom:.75rem;font-size:.9rem}.project-card .card-tags{flex-wrap:wrap;gap:.5rem;display:flex}.project-card .card-tags span{text-transform:uppercase;letter-spacing:.05rem;color:#fff9;background:#ffffff14;border:1px solid #ffffff26;border-radius:3px;padding:.2rem .5rem;font-size:.7rem}.project-card .view-arrow{color:#ffffff80;text-transform:uppercase;letter-spacing:.1rem;align-items:center;gap:.3rem;margin-top:1rem;font-size:.8rem;display:flex}.project-card:hover .view-arrow{color:#fff}@media screen and (max-width:736px){.project-page{padding:1rem 1rem 3rem}.project-header h1{font-size:1.4rem}.tech-grid{grid-template-columns:1fr 1fr}}@media screen and (max-width:480px){.tech-grid{grid-template-columns:1fr}}
