.project-top-banner{position:relative;width:100%;background:var(--color-brand-primary)}.project-banner-image-wrapper{position:relative;width:100%;height:500px;overflow:hidden}.project-banner-image{width:100%;height:100%;object-fit:cover;display:block}.project-banner-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,#0000004d,#00000080);display:flex;align-items:center;justify-content:center}.project-banner-title{font-size:4rem;font-weight:700;color:#fff;text-align:center;margin:0 0 1rem;text-shadow:0 2px 10px rgba(0,0,0,.3)}.project-banner-subtitle{font-size:1.25rem;color:#fff;text-align:center;margin:0;opacity:.95;text-shadow:0 2px 10px rgba(0,0,0,.3)}.project-hero{display:grid;grid-template-columns:1fr 1fr;gap:4rem;padding:4rem 2rem;max-width:1400px;margin:0 auto;align-items:center;min-height:600px}.project-hero-image{width:100%;height:100%;border-radius:20px;overflow:hidden;box-shadow:0 10px 40px #0000001a}.project-hero-image img{width:100%;height:100%;object-fit:cover;display:block}.project-hero-content{display:flex;flex-direction:column;gap:1.5rem;padding:2rem}.project-hero-category{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.project-hero-title{font-size:3.5rem;font-weight:700;line-height:1.1;color:var(--color-text-primary);margin:0}.project-hero-description{font-size:1.125rem;line-height:1.7;color:var(--color-text-secondary);margin:0}.project-hero-meta{display:flex;gap:2rem;margin-top:1rem}.project-hero-meta-item{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:var(--color-text-secondary)}.project-hero-meta-item svg{color:var(--color-text-secondary)}.project-hero-button{margin-top:1rem;padding:1rem 2.5rem;background-color:var(--color-btn-primary);color:#fff;border:none;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;align-self:flex-start}.project-hero-button:hover{background-color:var(--color-text-secondary);transform:translateY(-2px);box-shadow:0 4px 12px #1e3a8a40}.project-listing-section{padding:4rem 0}.project-listing-wrapper{display:grid;grid-template-columns:280px 1fr;gap:3rem;align-items:start}.project-filters{position:sticky;top:100px;background:#fff;border-radius:16px;padding:2rem;box-shadow:0 2px 8px #0000000d}.filter-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e5e5}.filter-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0 0 .25rem}.filter-count{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0}.filter-clear{background:none;border:none;color:var(--color-text-secondary);font-size:.875rem;cursor:pointer;text-decoration:underline;padding:0;transition:color .2s ease}.filter-clear:hover{color:var(--color-text-primary)}.filter-group{margin-bottom:2rem}.filter-group:last-child{margin-bottom:0}.filter-group-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0 0 1rem}.filter-options{display:flex;flex-direction:column;gap:.75rem}.filter-option{display:flex;align-items:center;gap:.75rem;cursor:pointer;position:relative;padding:.75rem;border-radius:50px;border:2px solid #e5e5e5;transition:all .2s ease}.filter-option:hover{border-color:#d0d0d0;background-color:#fafafa}.filter-option input[type=checkbox]{position:absolute;opacity:0;cursor:pointer}.filter-radio{width:20px;height:20px;border:2px solid #d0d0d0;border-radius:50%;position:relative;flex-shrink:0;transition:all .2s ease}.filter-option input[type=checkbox]:checked~.filter-radio{border-color:var(--color-btn-primary);background-color:var(--color-btn-primary)}.filter-option input[type=checkbox]:checked~.filter-radio:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background-color:#fff}.filter-label{font-size:1rem;color:var(--color-text-secondary);font-weight:500}.filter-option input[type=checkbox]:checked~.filter-label{color:var(--color-text-primary);font-weight:600}.project-grid-container{min-height:400px}.project-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}@media(max-width:1200px){.project-listing-wrapper{grid-template-columns:250px 1fr;gap:2rem}.project-grid{gap:1.5rem}}@media(max-width:1024px){.project-hero{grid-template-columns:1fr;gap:2rem;padding:3rem 1.5rem;min-height:auto}.project-hero-image{height:400px}.project-hero-title{font-size:2.5rem}.project-listing-wrapper{grid-template-columns:1fr;gap:2rem}.project-filters{position:static;width:100%}.filter-options{flex-direction:row;flex-wrap:wrap}.filter-option{flex:0 0 auto}.project-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}}@media(max-width:768px){.project-banner-image-wrapper{height:350px}.project-banner-title{font-size:2.5rem}.project-banner-subtitle{font-size:1rem}.project-hero{padding:2rem 1rem}.project-hero-content{padding:1rem}.project-hero-title{font-size:2rem}.project-hero-description{font-size:1rem}.project-hero-meta{flex-direction:column;gap:1rem}.project-grid{grid-template-columns:1fr;gap:1.5rem}.filter-header{flex-direction:column;gap:1rem}.filter-clear{align-self:flex-start}}@media(max-width:480px){.project-banner-image-wrapper{height:300px}.project-banner-title{font-size:2rem}.project-banner-subtitle{font-size:.9375rem}.project-hero-image{height:300px}.project-hero-title{font-size:1.75rem}.project-hero-button{width:100%;text-align:center}.filter-options{flex-direction:column}.filter-option{width:100%}}.project-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;min-height:400px;grid-column:1 / -1}.project-empty-state-icon{width:80px;height:80px;margin-bottom:1.5rem;color:#d0d0d0}.project-empty-state-icon svg{width:100%;height:100%}.project-empty-state h3{font-size:1.5rem;font-weight:600;color:var(--color-text-primary);margin:0 0 .75rem}.project-empty-state p{font-size:1rem;color:var(--color-text-secondary);margin:0;max-width:400px}
