: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}}body{margin:0;font-family:Arial,sans-serif}.footer:before{content:"";position:absolute;top:-40px;left:0;right:0;height:40px}.footer-logo a{display:inline-block}.footer-logo img.footer-logo-img{height:100px;width:auto;display:block;margin-top:-75px}.footer{position:relative;background:#000;color:#aaa;padding:2rem;margin-top:auto;font-family:Arial,sans-serif;width:calc(100vw - 79px)}html,body{overflow-x:hidden}.footer-container{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.footer-logo{font-size:1.4rem;font-weight:700;color:#fff}.footer-links{list-style:none;display:flex;gap:1.2rem;margin:0;padding:0}.footer-link{color:#aaa;text-decoration:none;font-size:.95rem;transition:color .2s ease}.footer-link:hover{color:#fff}.footer-socials{display:flex;gap:1rem}.footer-socials a{color:#aaa;font-size:1.2rem;transition:color .2s ease}.footer-socials a:hover{color:#fff}.footer-bottom{text-align:center;font-size:.85rem;margin-top:1.5rem;color:#666}@media (max-width: 768px){.footer-container{flex-direction:column;text-align:center;gap:2rem}.footer-links{flex-direction:column;gap:.8rem}.footer-socials{justify-content:center}}@media (max-width: 480px){.footer-container{flex-direction:column;align-items:center;text-align:center;gap:2rem}.footer-links{flex-direction:column;gap:.8rem}.footer-socials{justify-content:center}}a:focus,button:focus{outline:none}a:focus-visible,button:focus-visible{box-shadow:0 0 0 2px #d3a859}.navbar{position:fixed;top:0;left:0;right:0;transform:translateY(0);padding:1rem 2rem;background:#000;transition:transform .3s ease,background-color .3s ease,box-shadow .3s ease;z-index:1000}.navbar-hidden{transform:translateY(-105%)}.navbar-scrolled{background:#000000b3;box-shadow:0 2px 6px #0000004d;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.navbar-container{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.navbar-right{display:flex;align-items:center;gap:1rem;margin-left:auto}.navbar-logo{font-size:1.4rem;font-weight:700;cursor:pointer;color:#fff}.navbar-links{list-style:none;display:flex;gap:0rem;margin:0;padding:0}.nav-link{text-decoration:none;display:inline-block;position:relative;font-size:.95rem;background:transparent;border:none;cursor:pointer;font-weight:500;color:#858585;padding:.4rem .8rem;border-radius:8px;transition:all .2s ease}.nav-link:hover{background-color:#696969;color:#fff}.nav-link.active{color:#d3a859}.navbar-connect{text-decoration:none;padding:.4rem .8rem;border-radius:8px;border:2px solid white;background:#fff;color:#000;font-weight:500;cursor:pointer;transition:all .3s ease}.navbar-connect:hover{background:#000;color:#fff;border-color:#fff}.hamburger{display:none;flex-direction:column;justify-content:space-between;width:30px;height:22px;background:transparent;border:none;cursor:pointer;padding:0;z-index:2000}.hamburger span{display:block;height:3px;width:100%;background-color:#fff;border-radius:2px;transition:all .3s ease}.hamburger.open span:nth-child(1){transform:rotate(45deg) translateY(7px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translateY(-7px)}.mobile-menu{position:absolute;top:100%;left:0;right:0;display:flex;flex-direction:column;background:#fff;padding:0 2rem;box-shadow:0 2px 6px #00000014;border-top:1px solid #ddd;max-height:0;opacity:0;overflow:hidden;transition:max-height .3s ease,opacity .3s ease,padding .3s ease;z-index:1500}.mobile-menu.show{max-height:400px;opacity:1;padding:1rem 2rem;transform:translateY(0)}.mobile-menu ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.mobile-connect{width:fit-content;align-self:flex-start}@media (max-width: 1024px){.navbar-links{display:none}.hamburger{display:flex;margin-left:2rem}.navbar-connect{display:inline-block}}@media (max-width: 480px){.navbar-container{padding:.8rem 1rem}.navbar-connect{padding:.3rem .6rem;font-size:.85rem}.hamburger{width:26px;height:18px}.hamburger span{height:2.5px}.mobile-menu{padding:.8rem 1rem}}.gallery-section{padding:4rem 2rem 8rem;text-align:center;background:#f8f8f8;color:#2f3a2e;box-sizing:border-box;width:100%}.gallery-title{font-size:2.4rem;margin-bottom:2rem;color:#264025}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;row-gap:4rem;justify-content:center;width:100%;max-width:1200px;margin:0 auto;transition:all .3s ease}.card{background:transparent;text-align:left;transition:width .3s ease;cursor:pointer}.card:hover{transform:none}.card-image{position:relative;overflow:hidden;border-radius:10px}.card-image img{display:block;width:100%;height:280px;object-fit:cover;border-radius:10px;transition:transform .4s ease}.card-image:hover img{transform:scale(1.05)}.card-image-overlay{position:absolute;left:0;bottom:0;width:100%;height:100%;background-color:#000000b3;transform:translateY(100%);opacity:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:0;border-radius:10px;transition:transform .4s ease,opacity .4s ease}.card-image:hover .card-image-overlay{transform:translateY(0);opacity:1}.card-image-overlay p{color:#fff;font-size:1.2rem;margin:0;width:100%;padding:0 2rem}.card-content{margin-top:1rem;padding:0 .25rem}.card-content h3{font-size:1.1rem;font-weight:600;color:#2f3a2e;margin-bottom:.05rem}.card-description{font-size:.9rem;color:#264025;margin-top:.4rem}.card-date{font-size:.85rem;color:#60715b;margin:0}.card-tags{margin-top:1.2rem;display:flex;flex-wrap:wrap;gap:.5rem}.tag{color:#264025;font-size:.8rem;padding:.2rem .6rem;border-radius:12px;display:inline-block;box-shadow:0 2px 4px #00000026}.modal-overlay{position:fixed;inset:0;background:#000000a6;display:flex;justify-content:center;align-items:center;z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{position:relative;background:#fff;border-radius:18px;width:90%;max-width:750px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 24px #00000040}.modal-header{position:sticky;top:0;background:#fff;padding:1.2rem 2rem .9rem;border-bottom:1px solid #e2e2e2;z-index:10}.modal-title{font-size:1.6rem;font-weight:600;color:#2f3a2e;margin-bottom:.3rem}.modal-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.4rem;margin-top:-.1rem}.modal-date{font-size:.9rem;color:#60715b}.modal-tags{display:flex;flex-wrap:wrap;gap:.4rem}.modal-tags .tag{font-size:.8rem;color:#264025;border-radius:10px;padding:.25rem .6rem;box-shadow:0 2px 4px #0000001f}.modal-body{flex:1;overflow-y:auto;padding:1.5rem 2rem 2rem}.modal-description{color:#2f3a2e;font-size:1rem;line-height:1.7;margin-bottom:1.5rem}.modal-section{margin-top:2rem;text-align:left}.modal-section-heading{font-size:1.2rem;font-weight:600;color:#264025;margin-bottom:.5rem}.modal-section-text{font-size:1rem;color:#3b4a3a;line-height:1.6;margin-bottom:.8rem}.modal-link-inline{color:#4b56f0;text-decoration:underline;transition:color .2s ease}.modal-link-inline:hover{color:#2f3a9b}.modal-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:.8rem}.modal-process-img,.modal-process-video{width:100%;border-radius:8px;box-shadow:0 2px 8px #0000001a;object-fit:cover;display:block}.modal-process-video{max-height:420px;background:#000}.modal-link{display:inline-block;background-color:#c8c9f2;color:#fff;font-weight:500;text-decoration:none;padding:.75rem 1.5rem;border-radius:12px;margin-top:2rem;transition:all .25s ease;box-shadow:0 3px 8px #00000014;position:relative}.modal-link:hover,.modal-link:focus{background-color:#b0b2e8;color:#fff;transform:translateY(-3px);box-shadow:0 6px 14px #00000026}.modal-link:active{transform:translateY(0);box-shadow:0 3px 8px #0000001a}.modal-close{position:absolute;top:1rem;right:1.4rem;background:transparent;border:none;font-size:1.5rem;color:#555;cursor:pointer;z-index:11;transition:color .2s ease}.modal-close:hover{color:#000}@media (max-width: 1150px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:2rem;row-gap:4rem;max-width:950px}.card-image img{height:300px}}@media (min-width: 801px){.card-description{display:none}}@media (max-width: 800px){.gallery-section{padding:4rem 2rem 10rem}.gallery-grid{gap:1.8rem;row-gap:4rem;max-width:700px}.card-image img{height:260px}.card-image-overlay{display:none}.card-image:hover img{transform:none}}@media (max-width: 625px){.gallery-grid{grid-template-columns:1fr;gap:1.5rem;row-gap:4rem;padding:0;max-width:100%;justify-items:center}.card{width:90%;max-width:400px}.gallery-section{padding:4rem 2rem 8rem}.card-image img{height:240px}}.codehero{height:100vh;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;position:relative;color:#fff;text-align:center;margin-top:-80px}.hero{height:100vh;background:url(https://picsum.photos/1600/900) no-repeat center/cover;display:flex;align-items:center;justify-content:center;position:relative;color:#fff;text-align:center;margin-top:-80px}.hero-overlay{background:#0000008c;padding:2rem 3rem;border-radius:12px}.hero-title{font-size:3rem;margin-bottom:.5rem}.hero-subtitle{font-size:1.2rem}.disciplines{padding:4rem 2rem;text-align:center;background:#f8f8f8}.discipline-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:2rem}.discipline-card{display:block;background:#fff;padding:2rem;border-radius:12px;font-size:1.2rem;font-weight:600;color:#000;text-decoration:none;box-shadow:0 4px 12px #00000014;transition:transform .3s ease,background .3s ease}.discipline-card:hover{background:#d3a859;color:#000;transform:translateY(-6px)}.bio{padding:4rem 2rem;text-align:center}.bio p{max-width:700px;margin:0 auto;font-size:1.1rem;line-height:1.6;color:#d3a859}.cta{padding:4rem 2rem;text-align:center;background:#000;color:#fff}.cta-btn{display:inline-block;margin-top:1.5rem;padding:.8rem 1.6rem;background:#d3a859;color:#000;border-radius:8px;text-decoration:none;font-weight:700;transition:all .3s ease}.cta-btn:hover{background:#fff;color:#000;border:2px solid #D3A859}.projects{padding:4rem 2rem}.projects h2{text-align:center;margin-bottom:2rem}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem}.project-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 10px #00000014;text-align:center;transition:transform .3s ease}.project-card:hover{transform:translateY(-6px)}.project-card h3{margin-bottom:.5rem}
