body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}html{overflow-x:hidden}body{color:#333;line-height:1.5;margin:0;padding:0;width:100%}.top-bar{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:1rem 2rem}.top-bar-left{display:flex;flex-direction:column}.logo-title{color:#d00;font-size:1.5rem;font-weight:700}.logo-subtitle{color:#666;font-size:1rem;font-weight:600}.top-bar-right .nav-link{background:none;border:none;color:#4b4545;cursor:pointer;font-size:1rem;text-decoration:none}.top-bar-right .nav-link:hover{text-decoration:underline;text-decoration-color:#d00}.top-bar{position:relative;z-index:1000}.portfolio-page{padding-bottom:2rem;padding-top:2rem;position:relative;width:100%}@media (min-width:769px){.portfolio-page{min-height:1600px;padding-left:2rem;padding-right:2rem}}.container{display:flex;flex-direction:column;margin:0 auto;max-width:1000px;min-height:calc(100vh - 72px);padding:4rem 2rem 2rem}.content{grid-gap:4rem;align-items:start;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin-bottom:3rem}.text-column h2{font-size:2rem;margin-bottom:1rem}.read-more .content-wrapper{overflow:hidden;transition:max-height .5s ease}.read-more .content-wrapper.collapsed{max-height:0}.read-more .content-wrapper.open{max-height:100vh}.read-more-toggle{background:none;border:none;color:#d00;cursor:pointer;font-weight:700;margin-top:.5rem;padding:0}.read-more-toggle:hover{text-decoration:underline}.signature{margin-top:2rem}.signature img{display:block;height:auto;max-width:200px}.signatory{color:#777;font-size:.9rem;margin:.5rem 0 0}.image-column img{border-radius:8px;display:block;height:auto;width:100%}.site-footer{color:#aaa;font-size:.875rem;margin-top:auto;text-align:center}@media (max-width:768px){.content{gap:2rem;grid-template-columns:1fr}}.top-bar-left .logo{align-items:center;display:flex}.logo-icon{height:2.5rem;margin-right:.75rem;object-fit:contain;width:2.5rem}.logo-text{display:flex;flex-direction:column}.text-column .subheading{color:#555;font-size:1.25rem;font-weight:500;line-height:1.4;margin-bottom:1.5rem;margin-top:.5rem}.splash-screen{align-items:center;animation:fadeOut .5s ease 1.5s forwards;background:#fff;display:flex;flex-direction:column;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:9999}.splash-logo{height:auto;margin-bottom:1rem;width:100px}.progress-bar{background:#eee;border-radius:2px;height:4px;overflow:hidden;width:100px}.progress-fill{animation-fill-mode:forwards;animation-name:loadProgress;animation-timing-function:ease-out;background:#d00;height:100%;width:0}@keyframes loadProgress{to{width:100%}}@keyframes fadeOut{to{opacity:0;visibility:hidden}}@keyframes spin{to{transform:rotate(1turn)}}.stack-diagram{align-items:center;display:flex;flex-wrap:wrap;justify-content:center;margin-top:2rem}.node{border:1px solid #e0e0e0;border-radius:4px;color:#666;font-size:1rem;padding:.5rem 1rem;text-align:center;transition:border-color .25s ease,color .25s ease,box-shadow .25s ease}.node.active{border-color:#d00;box-shadow:0 0 8px #d000004d;color:#d00}.arrow{color:#e0e0e0;font-size:1.25rem;margin:0 .5rem;transform:translateX(-10px);transition:color .25s ease,transform .4s ease}.arrow.active{color:#d00;transform:translateX(0)}.popup-window{background:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 4px 12px #0000001a;display:flex;flex-direction:column;overflow:hidden;transition:transform .2s ease;width:300px}@media (min-width:769px){.popup-window{max-width:300px;position:absolute;z-index:10}.popup-window:hover{box-shadow:0 8px 24px #00000026;transform:scale(1.02);z-index:20}}.popup-header{align-items:center;background:#f5f5f5;display:flex;justify-content:space-between;padding:.5rem}.popup-title{color:#333;flex:1 1;font-size:.9rem}.popup-close{background:none;border:none;color:#666;cursor:pointer;font-size:1.25rem;line-height:1}.popup-close:focus,.popup-close:hover{color:#d00}.popup-media{display:block;max-height:400px;object-fit:cover;width:100%}@media (max-width:768px){.portfolio-page{min-height:auto;overflow:visible;padding:1rem;position:static}.popup-window{box-shadow:0 2px 8px #0000001a;margin:1rem 0;position:static!important;width:100%!important}.popup-media{height:auto;max-height:none}.popup-header{padding:.75rem}}.back-button{background:#f5f5f5;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;left:1rem;padding:.5rem 1rem;position:fixed;top:1rem}.back-button:focus,.back-button:hover{background:#e0e0e0;color:#d00}@media (max-width:768px){.logo-text{display:flex;flex:1 1 auto;flex-direction:column;margin-right:1rem;min-width:0}.top-bar-right{margin-left:auto}}.contact-form{background:#fafafa;border-radius:8px;box-shadow:0 2px 8px #0000000d;margin:2rem auto;max-width:95%;padding:1rem;width:100%}@media (min-width:768px){.contact-form{margin:4rem auto;max-width:900px;padding:2rem}}.contact-form p{margin-bottom:1rem}.contact-form input,.contact-form textarea{border:1px solid #ddd;border-radius:4px;font:inherit;padding:.5rem;width:100%}.contact-form button{background:#d00;border:none;border-radius:4px;color:#fff;cursor:pointer;font:inherit;padding:.75rem 1.5rem}.contact-form button:hover{opacity:.9}.form-status{color:#333;font-style:italic;margin-top:1rem}button,input,select,textarea{font-family:inherit}
/*# sourceMappingURL=main.8c7f09f7.css.map*/