@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-primary:#021e7e;--color-primary-light:#1a3a8f;--color-primary-dark:#011a5c;--color-secondary:#f8f9fa;--color-secondary-dark:#e9ecef;--color-text-primary:#021e7e;--color-text-secondary:#1d1d1d;--color-text-muted:#adb5bd;--color-links:#1c43c3;--color-bg-primary:#fff;--color-bg-secondary:#f8f9fa;--color-border-primary:#021e7e;--color-border-light:#021e7e4d;--color-border-medium:#021e7e80;--color-shadow:#0000001a;--lightningcss-light:initial;--lightningcss-dark: ;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--color-text-primary);background-color:var(--color-bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;font-family:Inter,sans-serif;font-weight:400;line-height:1.6}body{background-color:var(--color-bg-primary);min-height:100vh;color:var(--color-text-primary);margin:0;font-family:Inter,sans-serif}#root{min-height:100vh}button{font:inherit;cursor:pointer;outline:inherit;background:0 0;border:none;padding:0}img{max-width:100%;height:auto;display:block}*{box-sizing:border-box;margin:0;padding:0}.layout{min-height:100vh;color:var(--color-text-primary);background-color:#fff;flex-direction:column;font-family:Inter,sans-serif;line-height:1.6;display:flex}.container{max-width:1200px;margin:0 auto;padding:0 20px}.navbar{border-bottom:1px solid var(--color-border-primary);z-index:1000;background:#fff;width:100%;transition:-webkit-backdrop-filter .3s,backdrop-filter .3s;position:fixed;top:0}.navbar--scrolled{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background-color:#ffffff80}.nav-container{justify-content:space-between;align-items:center;max-width:1200px;height:70px;margin:0 auto;padding:0 20px;display:flex}.nav-logo{color:var(--color-text-primary);font-size:1.5rem;font-weight:700;text-decoration:none}.nav-menu{gap:2rem;list-style:none;display:flex}.nav-link{color:var(--color-text-primary);font-weight:400;text-decoration:none;transition:color .3s}.nav-link:hover,.nav-link.active{color:#666}.hamburger{cursor:pointer;flex-direction:column;display:none}.bar{background:var(--color-primary);width:25px;height:2px;margin:3px 0;transition:all .3s}.main{flex:1;margin-top:70px;padding:0 40px}.footer{color:var(--color-text-primary);text-align:center;background:#fff;padding:2rem 0}@media (max-width:768px){.hamburger{display:flex}.nav-menu{text-align:center;background-color:#fff;border-bottom:1px solid #222;flex-direction:column;width:100%;padding:2rem 0;transition:all .3s;position:fixed;top:70px;left:-100%}.nav-menu.active{left:0}.nav-menu li{margin:1rem 0}.main{padding:0 20px}}.project-card{background:#fff;border:none;transition:opacity .3s;position:relative}.project-card:hover{opacity:.8}.project-card.featured{width:100%}.featured .project-image{width:100%;height:40vh;max-height:500px;position:relative;overflow:hidden}.featured .project-image img{object-fit:cover;object-position:center;width:100%;height:100%}.featured .project-content{color:var(--color-text-primary);z-index:2;align-items:center;gap:42px;padding:1.5rem 0;display:flex}.featured .project-title{color:var(--color-text-primary);letter-spacing:-.02em;margin-bottom:.25rem;font-size:1.1rem;font-weight:400}.featured .project-description{color:var(--color-text-secondary);max-width:600px;margin-bottom:1.5rem;font-size:1rem;font-weight:300;line-height:1.6}.featured .project-tags{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.featured .tag{color:var(--color-text-primary);border:1px solid var(--color-border-light);background:#0000001a;padding:.25rem .75rem;font-size:.875rem;font-weight:300}.featured.project-link{color:var(--color-text-primary);border-bottom:1px solid var(--color-border-medium);padding-bottom:2px;font-weight:400;text-decoration:none;transition:border-color .3s}.featured .project-link:hover{border-bottom-color:var(--color-border-primary)}@media (max-width:768px){.featured .project-image{max-height:350px}}@media (max-width:480px){.featured .project-image{max-height:250px}}.home{max-width:100%}.hero{color:var(--color-text-primary);text-align:center;background:#fff;width:100%;padding:80px 0 40px}.hero-content{max-width:1200px;margin:0 auto;padding:0 20px}.cta-button.secondary{color:var(--color-text-primary);border:1px solid var(--color-border-primary);background:0 0}.cta-button.secondary:hover{background:var(--color-primary);color:#fff}section{box-sizing:border-box;padding:0 120px}.featured-projects{background:#fff;width:100%}.projects-grid{flex-direction:column;gap:60px;max-width:1200px;margin:0 auto auto;display:flex}@media (max-width:768px){section.featured-projects{padding:0 40px}.hero-title{font-size:2.5rem}.about-content{grid-template-columns:1fr;gap:2rem}.project-content{padding:2rem 1rem 1rem}.project-title{font-size:2rem}}@media (max-width:480px){section.featured-projects{padding:0 20px}.hero-title{font-size:2rem}}.project{max-width:100%}.project-not-found{text-align:center;color:var(--color-text-primary);background:#fff;padding:4rem 0}.project-not-found h1{margin-bottom:1rem;font-size:2rem;font-weight:300}.project-hero{background:#fff;padding:40px 0 20px}.project-hero-content{align-items:center;margin-bottom:36px;padding-top:20px}.project-hero-text .project-title{color:var(--color-text-primary);letter-spacing:-.02em;font-size:2rem;font-weight:300}.project-subtitle{color:#111;margin-bottom:1.5rem;font-size:1rem;font-weight:300}.project-meta{align-items:center;gap:1rem;display:flex}.project-year{opacity:.7;color:#666;font-size:.875rem}.project-theme{text-transform:uppercase;letter-spacing:.1em;border:1px solid var(--color-border-primary);color:var(--color-text-primary);padding:.25rem .5rem;font-size:.75rem;font-weight:600}.project-hero-image img{width:100%}.project-details{background:#fff;padding:80px 0}.project-description h2{color:var(--color-text-primary);letter-spacing:-.02em;margin-bottom:1rem;font-size:1.5rem;font-weight:300}.project-description p{color:#666;margin-bottom:1.5rem;font-weight:300;line-height:1.7}.rich-content{max-width:800px;margin:0 auto}.content-block{margin-bottom:4rem}.content-block:last-child{margin-bottom:0}.text-block h2{color:var(--color-text-primary);letter-spacing:-.02em;margin-bottom:1.5rem;font-size:1.6rem;font-weight:300}.text-block h3{margin-bottom:1rem;font-size:1.25rem}.text-content p{color:#1d1d1d;margin-bottom:1rem;font-size:1.1rem;font-weight:300;line-height:1.7}.text-content p:last-child{margin-bottom:0}.text-content ul{margin:1.5rem 0;padding-left:0;list-style:none}.text-content li{color:#1d1d1d;margin-bottom:.75rem;padding-left:1.5rem;font-size:1.1rem;font-weight:300;line-height:1.7;position:relative}.text-content li:before{content:"•";color:var(--color-text-primary);font-weight:600;position:absolute;left:0}.text-content li:last-child{margin-bottom:0}.text-content ol{margin:1.5rem 0;padding-left:1.5rem}.text-content ol li{color:#1d1d1d;margin-bottom:.75rem;padding-left:.5rem;font-size:1.1rem;font-weight:300;line-height:1.7;position:relative}.text-content ol li:before{display:none}.image-block h3{color:var(--color-text-primary);margin-bottom:1.5rem;font-size:1.5rem;font-weight:300}.single-image{margin-bottom:1rem}.single-image img{width:100%}.image-caption{color:#666;text-align:center;margin-top:.5rem;font-size:.9rem;font-style:italic}.image-series-block h3{color:var(--color-text-primary);margin-bottom:1.5rem;font-size:1.5rem;font-weight:300}.image-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1rem;display:grid}.series-image img{object-fit:cover;border:1px solid var(--color-border-primary);width:100%;height:200px}.series-caption{color:#666;text-align:center;margin-top:.5rem;font-size:.9rem;font-style:italic}.image-wide-block{width:80vw;max-width:1200px;margin:3rem 0;position:relative;left:50%;right:50%;transform:translate(-50%)}.image-wide-block h3{color:var(--color-text-primary);width:auto;max-width:800px;margin-bottom:1.5rem;margin-left:calc(50vw - 50%);margin-right:calc(50vw - 50%);font-size:1.5rem;font-weight:300;position:relative;left:50%;transform:translate(-50%)}.wide-image{width:100%;margin-bottom:1rem}.wide-image img{width:100%;height:auto;display:block}.wide-image-caption{color:#666;text-align:center;width:auto;max-width:800px;margin-top:.5rem;margin-left:calc(50vw - 50%);margin-right:calc(50vw - 50%);font-size:.9rem;font-style:italic;position:relative;left:50%;transform:translate(-50%)}.project-gallery h3{color:var(--color-text-primary);margin:2rem 0 1.5rem;font-size:1.5rem;font-weight:300}.gallery-images{flex-direction:column;gap:1.5rem;display:flex}.gallery-item img{border:1px solid var(--color-border-primary);width:100%}.project-navigation{border-top:1px solid var(--color-border-primary);background:#fff;padding:80px 0}.project-farewell{max-width:800px;color:var(--color-text-secondary);margin:0 auto;padding:32px 0 0}.project-farewell p{font-weight:300}.nav-buttons{justify-content:space-between;gap:1rem;display:flex}.nav-button{background:var(--color-primary);color:#fff;border:1px solid var(--color-border-primary);padding:1rem 2rem;font-weight:300;text-decoration:none;transition:all .3s}.nav-button:hover{color:var(--color-text-primary);background:#fff}@media (max-width:768px){.project-hero-content{grid-template-columns:1fr;gap:2rem}.project-meta{flex-direction:column;align-items:flex-start;gap:.5rem}.nav-buttons{flex-direction:column}.project-title{font-size:2rem}.text-block h2{font-size:1.5rem}.text-content p{font-size:1rem}.image-grid{grid-template-columns:1fr}.series-image img{height:150px}}.callout-block{background-color:var(--color-bg-secondary);border-left:3px solid;border-radius:8px;align-items:flex-start;gap:.75rem;margin:1.5rem 0;padding:1rem 1.25rem;font-size:.95rem;line-height:1.6;display:flex}.callout-icon{flex-shrink:0;margin-top:.125rem}.callout-icon-default,.callout-icon-custom{font-size:1.1rem;line-height:1}.callout-content{flex:1;min-width:0}.callout-title{color:var(--color-text-primary);margin:0 0 .5rem;font-size:.95rem;font-weight:600}.callout-text{margin:0}.callout-text p{color:var(--color-text-secondary);margin:0 0 .75rem}.callout-text p:last-child{margin-bottom:0}.callout-default{border-left-color:var(--color-primary);background-color:#021e7e0d}.callout-info{background-color:#3b82f60d;border-left-color:#3b82f6}.callout-warning{background-color:#f59e0b0d;border-left-color:#f59e0b}.callout-success{background-color:#22c55e0d;border-left-color:#22c55e}.callout-error{background-color:#ef44440d;border-left-color:#ef4444}@media (max-width:768px){.callout-block{margin:1.25rem 0;padding:.875rem 1rem}.callout-title,.callout-text{font-size:.9rem}}.video-block{margin:2rem 0}.video-block h3{color:var(--color-text-primary);margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.video-block h4{color:var(--color-text-secondary);margin:0 0 1rem;font-size:1.1rem;font-weight:400}.video-container{border-radius:8px;width:100%;height:0;margin:1rem 0;padding-bottom:56.25%;position:relative;overflow:hidden;box-shadow:0 4px 12px #0000001a}.video-iframe{border:none;border-radius:8px;width:100%;height:100%;position:absolute;top:0;left:0}.video-caption{color:var(--color-text-secondary);text-align:center;margin:.75rem 0 0;font-size:.9rem;font-style:italic}@media (max-width:768px){.video-block{margin:1.5rem 0}.video-block h3{font-size:1.3rem}.video-block h4{font-size:1rem}.video-container{border-radius:6px;margin:.75rem 0}.video-iframe{border-radius:6px}.video-caption{font-size:.85rem}}.projects-container .project-card{border:1px solid var(--color-border-light);background:#fff;transition:opacity .3s;overflow:hidden;box-shadow:0 0 1px #0000001a}.projects-container .project-card:hover{opacity:.8}.projects-container .project-image{height:250px;min-height:250px}.projects-container .project-image img{object-fit:cover;width:100%;height:100%}.projects-container .project-content{color:var(--color-text-primary);background:#fff;padding:1.5rem;position:relative}.projects-container .project-title{color:var(--color-text-primary);margin-bottom:.5rem;font-size:1.2rem;font-weight:300}.projects-container .project-description{color:#666;margin-bottom:1rem;font-weight:300;line-height:1.6}.projects-container .tag{color:var(--color-text-primary);border:1px solid var(--color-border-medium);background:0 0;margin-bottom:1rem;padding:.25rem .75rem;font-size:.875rem;font-weight:300;display:inline-block}.projects-container .project-link{color:var(--color-text-primary);border-bottom:1px solid var(--color-border-primary);font-weight:300;text-decoration:none;transition:border-color .3s}.projects-container .project-link:hover{border-bottom-color:#666}.gallery{max-width:100%}.gallery-header{color:var(--color-text-primary);text-align:left;background:#fff;padding:90px 0 40px}.page-title{letter-spacing:-.02em;margin-bottom:0;font-size:2rem;font-weight:300}.page-subtitle{color:#666;font-size:1.25rem;font-weight:300}.gallery-filters{border-bottom:1px solid var(--color-border-light);background:#fff;padding:1.5rem 0}.filter-buttons{flex-wrap:wrap;justify-content:left;gap:1rem;display:flex}.filter-btn{border:1px solid var(--color-border-light);color:var(--color-text-primary);cursor:pointer;background:0 0;padding:.5rem 1.5rem;font-weight:300;transition:all .3s}.filter-btn:hover,.filter-btn.active{background:var(--color-primary);color:#fff}.gallery-grid{background:#fff;padding:3rem 0}.projects-container{grid-template-columns:repeat(auto-fit,minmax(300px,31%));gap:2rem;display:grid}.no-projects{text-align:center;opacity:.7;color:#666;padding:4rem 0}@media (max-width:768px){.page-title{font-size:2rem}.filter-buttons{justify-content:flex-start;padding-bottom:1rem;overflow-x:auto}.filter-btn{white-space:nowrap}.projects-container{grid-template-columns:1fr}}.about{max-width:100%}.about-hero{color:var(--color-text-primary);background:#fff;padding:120px 0 80px}.about-hero-content{grid-template-columns:1fr 1fr;align-items:center;gap:4rem;display:grid}.about-hero-text .page-title{letter-spacing:-.02em;margin-bottom:1rem;font-size:3rem;font-weight:300}.about-hero-text .page-subtitle{color:#666;font-size:1.25rem;font-weight:300}.about-hero-image img{width:100%}.about-content{background:#fff;padding:80px 0}.about-grid{grid-template-columns:2fr 1fr;align-items:start;gap:4rem;display:grid}.about-text h2{color:var(--color-text-primary);letter-spacing:-.02em;margin-bottom:1rem;font-size:2rem;font-weight:300}.about-text h3{color:var(--color-text-primary);margin:2rem 0 1rem;font-size:1.5rem;font-weight:300}.about-text p{color:#666;margin-bottom:1.5rem;font-weight:300;line-height:1.7}.skills-list{padding:0;list-style:none}.skills-list li{border:1px solid var(--color-border-primary);color:var(--color-text-primary);background:#fff;margin-bottom:.5rem;padding:.75rem 1rem;font-weight:300}.about-stats{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.stat-item{text-align:center;border:1px solid var(--color-border-primary);background:#fff;padding:2rem}.stat-number{color:var(--color-text-primary);margin-bottom:.5rem;font-size:2.5rem;font-weight:300}.stat-label{color:#666;font-weight:300}.contact-section{text-align:center;border-top:1px solid var(--color-border-primary);background:#fff;padding:80px 0}.section-title{text-align:center;color:var(--color-text-primary);letter-spacing:-.02em;margin-bottom:1rem;font-size:2.5rem;font-weight:300}.section-subtitle{text-align:center;color:#666;margin-bottom:3rem;font-size:1.1rem;font-weight:300}.contact-info{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin:3rem 0;display:grid}.contact-item h4{color:var(--color-text-primary);margin-bottom:.5rem;font-size:1.25rem;font-weight:300}.contact-item p{color:#666;font-weight:300}.cta-button{background:var(--color-primary);color:#fff;border:1px solid var(--color-border-primary);padding:15px 30px;font-weight:400;text-decoration:none;transition:all .3s;display:inline-block}.cta-button:hover{color:var(--color-text-primary);background:#fff}@media (max-width:768px){.about-hero-content,.about-grid{grid-template-columns:1fr;gap:2rem}.about-stats{grid-template-columns:1fr 1fr}.page-title{font-size:2rem}}@media (max-width:480px){.about-stats,.contact-info{grid-template-columns:1fr}}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg-primary);color:var(--color-text-primary);margin:0;font-family:Inter,sans-serif;line-height:1.5}h1,h2,h3,h4,h5,h6{margin:0;font-weight:300}p{margin:0}a{color:var(--color-links);text-decoration:none}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}
